/*
Theme Name: Adomos PRO
Theme URI: https://www.adomos.com
Author: Adomos Group
Author URI: https://www.adomos.com
Description: Thème sur-mesure Adomos PRO. Header et footer modifiables dans Apparence > Menus et Apparence > Widgets. Couleurs et coordonnées dans Apparence > Personnaliser.
Version: 1.0.12
Text Domain: adomos-pro
*/

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --rouge:#FF3131;--vert:#35474B;--noir:#0D0D0D;--blanc:#FFFFFF;
  --creme:#F8F5F0;--encre:#1A1A1A;
  --t2:rgba(255,255,255,.65);--t3:rgba(255,255,255,.52);--t4:rgba(255,255,255,.3);
  --rule:rgba(255,255,255,.07);--rule-l:rgba(26,26,26,.1);--rule-ll:rgba(26,26,26,.06);
  --t2l:rgba(26,26,26,.65);--t3l:rgba(26,26,26,.58);--t4l:rgba(26,26,26,.38);
}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--noir);color:var(--blanc);overflow-x:hidden}

/* ── BG ── */
.lines-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.line{position:absolute;bottom:0;width:1px;background:linear-gradient(to top,rgba(255,49,49,.18),transparent);transform-origin:bottom center;animation:rise 6s ease-out infinite}
.line:nth-child(1){left:18%;height:55vh;animation-delay:0s}
.line:nth-child(2){left:35%;height:40vh;animation-delay:1.2s}
.line:nth-child(3){left:52%;height:65vh;animation-delay:.6s}
.line:nth-child(4){left:68%;height:45vh;animation-delay:2s}
.line:nth-child(5){left:82%;height:35vh;animation-delay:1.6s}
@keyframes rise{0%{opacity:0;transform:scaleY(0)}20%{opacity:1}80%{opacity:.4}100%{opacity:0;transform:scaleY(1)}}
#hero,#idee,#comment,#investisseur,#contact{position:relative;overflow:hidden}
#hero>*:not(.lines-bg),#idee>*:not(.lines-bg),#comment>*:not(.lines-bg),#investisseur>*:not(.lines-bg),#contact>*:not(.lines-bg){position:relative;z-index:1}

/* ── HEADER ── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:200;transition:background .3s,border-color .3s,backdrop-filter .3s}
.site-header.scrolled{background:rgba(13,13,13,.97);backdrop-filter:blur(20px)}
.hdr-top{padding:.6rem 3.5rem;border-bottom:1px solid transparent;display:flex;align-items:center;justify-content:space-between;transition:border-color .3s}
.site-header.scrolled .hdr-top{border-color:var(--rule)}
.hdr-top-left{display:flex;align-items:center;gap:1.5rem}
.hdr-status{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.25)}
.hdr-status-dot{width:5px;height:5px;border-radius:50%;background:var(--rouge);animation:blink 2.4s ease-in-out infinite}
.hdr-top-right{display:flex;align-items:center;gap:1.5rem}
.hdr-contact{font-size:10px;color:rgba(255,255,255,.2);letter-spacing:.04em;text-decoration:none;transition:color .2s}
.hdr-contact:hover{color:var(--blanc)}

.hdr-main{padding:.9rem 3.5rem;border-bottom:1px solid transparent;display:flex;align-items:center;justify-content:space-between;gap:2rem;transition:border-color .3s;position:relative;z-index:201}
.site-header.scrolled .hdr-main{border-color:var(--rule)}

.wordmark{font-size:13px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--blanc);text-decoration:none;flex-shrink:0}
.wordmark sup{font-size:9px;font-weight:500;letter-spacing:.1em;color:var(--rouge);vertical-align:super;margin-left:3px}

/* ── NAV (WP menu) ── */
.primary-menu{display:flex;align-items:center;gap:0;flex:1;justify-content:center;list-style:none;margin:0;padding:0}
.primary-menu li{position:relative;list-style:none}
.primary-menu > li::after{content:'';position:absolute;top:100%;left:0;right:0;height:14px;display:block}
.primary-menu > li > a{display:flex;flex-direction:column;align-items:center;gap:4px;padding:.6rem 1.1rem;text-decoration:none;cursor:pointer;font-size:12px;color:rgba(255,255,255,.45);letter-spacing:.06em;text-transform:uppercase;font-weight:600;line-height:1;transition:color .2s;position:relative}
.primary-menu > li:hover > a{color:var(--blanc)}
.primary-menu > li > a::after{content:'';display:block;width:0;height:1px;background:var(--rouge);transition:width .25s ease;margin-top:6px}
.primary-menu > li:hover > a::after{width:70%}
.primary-menu .sub-menu{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-6px);width:280px;background:rgba(12,12,12,.99);border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:1.25rem;opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;backdrop-filter:blur(20px);z-index:300;list-style:none;margin:0}
.primary-menu > li:hover .sub-menu{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
.primary-menu .sub-menu::before{content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:10px;height:6px;background:rgba(12,12,12,.99);clip-path:polygon(50% 0%,0% 100%,100% 100%)}
.primary-menu .sub-menu li{display:block;width:100%}
.primary-menu .sub-menu a{display:block;font-size:12px;color:rgba(255,255,255,.45);text-decoration:none;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.04);transition:color .15s;line-height:1.4;text-transform:none;letter-spacing:normal;font-weight:500}
.primary-menu .sub-menu li:last-child a{border-bottom:none}
.primary-menu .sub-menu a:hover{color:var(--blanc)}

.nav-right{display:flex;align-items:center;gap:1.5rem;flex-shrink:0}
.hdr-cta{display:inline-flex;align-items:center;gap:6px;padding:.6rem 1.25rem;background:var(--rouge);color:#fff;text-decoration:none;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border-radius:3px;transition:opacity .2s}
.hdr-cta:hover{opacity:.85;color:#fff}
.hdr-cta svg{width:12px;height:12px;transition:transform .2s}
.hdr-cta:hover svg{transform:translateX(2px)}
.hdr-tel{font-size:11px;color:rgba(255,255,255,.3);text-decoration:none;letter-spacing:.04em;transition:color .2s}
.hdr-tel:hover{color:var(--blanc)}

.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.burger span{display:block;width:22px;height:1px;background:var(--blanc);transition:all .3s}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}
.mnav{display:none;position:fixed;inset:0;z-index:190;background:rgba(13,13,13,.98);backdrop-filter:blur(20px);flex-direction:column;align-items:flex-start;justify-content:center;padding:3rem 3.5rem;overflow-y:auto}
.mnav.open{display:flex}
.mnav ul{list-style:none;padding:0;margin:0;width:100%}
.mnav ul li{border-bottom:1px solid var(--rule);padding:1rem 0;list-style:none}
.mnav ul li a{font-size:1.4rem;font-weight:800;letter-spacing:-.02em;color:var(--blanc);text-decoration:none;display:block;transition:color .15s}
.mnav ul li a:hover{color:var(--rouge)}
.mnav ul .sub-menu{padding-left:1rem;margin-top:.5rem}
.mnav ul .sub-menu li{border:none;padding:.25rem 0}
.mnav ul .sub-menu li a{font-size:.9rem;font-weight:500;color:var(--t3)}
.mn-close{position:absolute;top:1.75rem;right:1.75rem;font-size:11px;color:var(--t3);text-transform:uppercase;letter-spacing:.1em;cursor:pointer;background:none;border:none;font-family:inherit;font-weight:600}
.mn-bottom{margin-top:2rem;display:flex;flex-direction:column;gap:.5rem}
.mn-bottom a{font-size:12px;color:var(--t3);text-decoration:none}

.page{position:relative;z-index:0}
.w{max-width:1200px;margin:0 auto}

.s-dark{background:var(--noir);color:var(--blanc);padding:8rem 3.5rem}
.s-light{background:var(--creme);color:var(--encre);padding:8rem 3.5rem}
.s-white{background:var(--blanc);color:var(--encre);padding:8rem 3.5rem}
.s-mid{background:#F0EDE8;color:var(--encre);padding:8rem 3.5rem}

.lbl-d,.lbl-l{font-size:11px;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--rouge);margin-bottom:2rem;display:flex;align-items:center;gap:12px}
.lbl-d::after,.lbl-l::after{content:'';display:block;width:32px;height:1px;background:var(--rouge);opacity:.5}

.h1d{font-size:clamp(3rem,6vw,5.5rem);font-weight:800;line-height:1.05;letter-spacing:-.04em;color:var(--blanc)}
.h1d .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.6)}
.tag-d{font-size:clamp(3rem,6vw,5.5rem);font-weight:800;line-height:1.05;letter-spacing:-.04em}
.tag-d em{font-style:normal;-webkit-text-stroke:1.5px rgba(255,255,255,.5);color:transparent}
.hero-title{overflow:hidden;margin-bottom:2.5rem}
.hero-line{font-size:clamp(2.6rem,5.5vw,5rem);font-weight:800;line-height:1.05;letter-spacing:-.04em;color:var(--blanc);overflow:hidden;opacity:0;transform:translateY(60px);animation:heroLineUp .9s cubic-bezier(.16,1,.3,1) forwards}
.hero-line .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.55)}
.hero-line em{font-style:normal;-webkit-text-stroke:1.5px rgba(255,255,255,.45);color:transparent}
.hero-line-2{animation-delay:.18s}
.hero-line-3{animation-delay:.34s;margin-top:.1rem}
@keyframes heroLineUp{to{opacity:1;transform:translateY(0)}}
@media(max-width:640px){.hero-line{font-size:clamp(2rem,9vw,2.8rem)}}
.h2d{font-size:clamp(2rem,4vw,3.5rem);font-weight:800;line-height:1.05;letter-spacing:-.04em;color:var(--blanc)}
.h2d .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.58)}
.h2d em{font-style:normal;-webkit-text-stroke:1.5px rgba(255,255,255,.45);color:transparent}

.h2l{font-size:clamp(2rem,4vw,3.5rem);font-weight:800;line-height:1.05;letter-spacing:-.04em;color:var(--encre)}
.h2l .thin{font-weight:300;font-style:italic;color:rgba(26,26,26,.55)}
.h2l em{font-style:normal;color:rgba(26,26,26,.2)}
.h3l{font-size:1.5rem;font-weight:800;line-height:1.1;letter-spacing:-.03em;color:var(--encre)}
.h3l .thin{font-weight:300;font-style:italic;color:rgba(26,26,26,.55)}

.sub-d{font-size:16px;color:var(--t3);line-height:1.8;max-width:520px;margin-bottom:2.5rem}
.sub-l{font-size:16px;color:var(--t3l);line-height:1.8;max-width:520px;margin-bottom:3.5rem}
.body-d{font-size:14px;color:var(--t3);line-height:1.85}
.body-l{font-size:14px;color:var(--t3l);line-height:1.85}

.form-block{max-width:440px}
.form-hint{font-size:13px;font-weight:500;color:var(--t3);letter-spacing:.02em;margin-bottom:1rem}
.form-hint-l{font-size:13px;font-weight:500;color:var(--t3l);letter-spacing:.02em;margin-bottom:1rem}
.input-row{display:flex;align-items:stretch;border-bottom:1.5px solid rgba(255,255,255,.2);padding-bottom:1px;transition:border-color .25s}
.input-row:focus-within{border-color:var(--rouge)}
.input-row input{flex:1;background:transparent;border:none;outline:none;font-family:inherit;font-size:15px;color:var(--blanc);padding:.6rem 0;min-width:0}
.input-row input::placeholder{color:rgba(255,255,255,.2)}
.input-row-l{display:flex;align-items:stretch;border-bottom:1.5px solid rgba(26,26,26,.2);padding-bottom:1px;transition:border-color .25s}
.input-row-l:focus-within{border-color:var(--rouge)}
.input-row-l input{flex:1;background:transparent;border:none;outline:none;font-family:inherit;font-size:15px;color:var(--encre);padding:.6rem 0;min-width:0}
.input-row-l input::placeholder{color:rgba(26,26,26,.25)}
.input-row button,.input-row-l button{background:none;border:none;color:var(--rouge);font-family:inherit;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;padding:.6rem 0 .6rem 1.25rem;white-space:nowrap;transition:opacity .2s;display:flex;align-items:center;gap:6px}
.input-row button:hover,.input-row-l button:hover{opacity:.75}
.input-row button svg,.input-row-l button svg{width:14px;height:14px;transition:transform .2s}
.input-row button:hover svg,.input-row-l button:hover svg{transform:translateX(3px)}
.cr{display:flex;align-items:flex-start;gap:10px;margin-top:1.1rem}
.cr input[type=checkbox]{appearance:none;-webkit-appearance:none;width:14px;height:14px;min-width:14px;border:1px solid rgba(255,255,255,.25);border-radius:3px;background:transparent;cursor:pointer;margin-top:1px;transition:all .2s;position:relative}
.cr-l input[type=checkbox]{border-color:rgba(26,26,26,.25)!important}
.cr input[type=checkbox]:checked{background:var(--rouge);border-color:var(--rouge)}
.cr input[type=checkbox]:checked::after{content:'';position:absolute;left:3px;top:1px;width:5px;height:8px;border:1.5px solid #fff;border-top:none;border-left:none;transform:rotate(45deg)}
.cl{font-size:10.5px;color:rgba(255,255,255,.28);line-height:1.6;letter-spacing:.02em}
.cl-l{font-size:10.5px;color:rgba(26,26,26,.3);line-height:1.6;letter-spacing:.02em}
.cl a,.cl-l a{text-decoration:underline;text-underline-offset:2px;color:inherit}
.errmsg{font-size:11px;color:var(--rouge);margin-top:.6rem;display:none}
.okmsg{display:none;font-size:12px;margin-top:1rem;letter-spacing:.04em}
.okmsg-d{color:var(--t3)}.okmsg-l{color:var(--t3l)}
.okmsg span{color:#5DCAA5}

#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:9rem 3.5rem 5rem;position:relative;overflow:hidden}
.hero-img{position:absolute;right:0;top:0;bottom:0;width:48%;object-fit:cover;opacity:.18;mask-image:linear-gradient(to left,rgba(0,0,0,.6),transparent)}

#statsbar{position:relative;z-index:2}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);background:var(--creme);border-top:1px solid var(--rule-l)}
.st{padding:2rem 2.75rem;border-right:1px solid var(--rule-l)}
.st:last-child{border-right:none}
.st-v{font-size:2rem;font-weight:800;letter-spacing:-.04em;color:var(--encre);line-height:1;margin-bottom:.35rem}
.st-v .thin{font-weight:300;font-style:italic;color:rgba(26,26,26,.5);font-size:.75em}
.st-l{font-size:13px;color:var(--t3l);line-height:1.55;font-weight:500}

#realite{background:var(--creme)}
.rl-split{display:grid;grid-template-columns:1fr 1fr;gap:7rem;align-items:center}
.rl-img{border-radius:4px;overflow:hidden;aspect-ratio:4/3;position:relative}
.rl-img img{width:100%;height:100%;object-fit:cover;display:block}
.rl-img-caption{position:absolute;bottom:0;left:0;right:0;padding:1.25rem;background:linear-gradient(to top,rgba(13,13,13,.7),transparent);font-size:11px;color:rgba(255,255,255,.6);letter-spacing:.04em}

#idee{background:var(--noir)}
.idee-inner{max-width:900px}
.idee-claim{font-size:clamp(2.2rem,5vw,4.5rem);font-weight:800;line-height:1.05;letter-spacing:-.04em;margin-bottom:3rem;color:var(--blanc)}
.idee-claim .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.58)}
.idee-claim .red{color:var(--rouge)}
.idee-proof{font-size:14px;color:var(--t3);letter-spacing:.02em;border-left:2px solid rgba(255,49,49,.35);padding-left:1.25rem;line-height:1.8;font-style:italic;margin-top:2rem;max-width:540px}

#pourqui{background:var(--blanc)}
.pq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule-ll);border:1px solid var(--rule-l);margin-top:4rem}
.pq-item{padding:3rem 2.5rem;background:var(--blanc);transition:background .2s}
.pq-item:hover{background:var(--creme)}
.pq-num{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,49,49,.45);margin-bottom:1.5rem}
.pq-title{font-size:1.2rem;font-weight:800;color:var(--encre);margin-bottom:.75rem;letter-spacing:-.02em;line-height:1.2}
.pq-pain{font-size:13px;color:rgba(26,26,26,.5);line-height:1.7;margin-bottom:1.25rem;font-style:italic;border-left:2px solid rgba(255,49,49,.2);padding-left:.85rem}
.pq-sol{font-size:14px;color:var(--t3l);line-height:1.75}
.pq-sol strong{color:var(--encre);font-weight:600}

#comment{background:var(--noir)}
.cm-split{display:grid;grid-template-columns:1fr 1fr;gap:7rem;align-items:start;margin-top:4rem}
.cm-img{border-radius:4px;overflow:hidden;aspect-ratio:3/4;position:relative}
.cm-img img{width:100%;height:100%;object-fit:cover;display:block;opacity:.85}
.cm-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,13,13,.6) 0%,transparent 50%);pointer-events:none}
.cm-steps{display:flex;flex-direction:column;gap:0}
.cm-step{display:grid;grid-template-columns:52px 1fr;gap:1.75rem;padding:2rem 0;border-bottom:1px solid var(--rule)}
.cm-step:first-child{border-top:1px solid var(--rule)}
.cs-n{font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,49,49,.5);padding-top:.1rem}
.cs-t{font-size:1.15rem;font-weight:800;color:var(--blanc);margin-bottom:.6rem;letter-spacing:-.02em;line-height:1.2}
.cs-t .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.55)}
.cs-b{font-size:14px;color:var(--t3);line-height:1.75}

#investisseur{background:#111;text-align:center;padding:5rem 3.5rem}
.inv-claim{font-size:clamp(2rem,4.5vw,4rem);font-weight:800;line-height:1.05;letter-spacing:-.04em;max-width:800px;margin:0 auto 2rem}
.inv-claim .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.58)}
.inv-claim em{font-style:normal;-webkit-text-stroke:1.5px rgba(255,255,255,.45);color:transparent}
.inv-sub{font-size:15px;color:var(--t3);line-height:1.8;max-width:580px;margin:0 auto 3.5rem}
.inv-profiles{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.07);max-width:980px;margin:0 auto}
.ip{padding:2.25rem 2rem;background:#111;transition:background .2s;text-align:left}
.ip:hover{background:rgba(255,49,49,.04)}
.ip-age{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:800;letter-spacing:-.03em;color:var(--blanc);line-height:1;margin-bottom:.5rem}
.ip-age .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.5);font-size:.7em}
.ip-div{height:1px;background:rgba(255,255,255,.06);margin:.75rem 0}
.ip-prof{font-size:13px;color:var(--t3);line-height:1.65;margin-bottom:.75rem}
.ip-tag{font-size:10px;color:rgba(255,49,49,.5);font-weight:700;letter-spacing:.06em;text-transform:uppercase}

#espace{background:var(--blanc)}
.es-split{display:grid;grid-template-columns:1fr 1fr;gap:7rem;align-items:center}
.es-feats{display:flex;flex-direction:column;gap:0;margin-top:2.5rem}
.ef{display:flex;align-items:flex-start;gap:1rem;padding:1.1rem 0;border-bottom:1px solid var(--rule-ll)}
.ef:first-child{border-top:1px solid var(--rule-ll)}
.ef-n{font-size:10px;font-weight:700;letter-spacing:.14em;color:rgba(255,49,49,.5);flex-shrink:0;width:28px;padding-top:.1rem}
.ef-t{font-size:13px;font-weight:700;color:var(--encre);margin-bottom:.2rem}
.ef-d{font-size:13px;color:var(--t3l);line-height:1.65}
.wire{background:rgba(26,26,26,.03);border:1px solid var(--rule-l);border-radius:5px;padding:1.5rem;position:relative;overflow:hidden}
.wire::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--rouge),rgba(53,71,75,.4),transparent)}
.w-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--rule-l)}
.w-dot{width:6px;height:6px;border-radius:50%;background:var(--rouge);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.w-bar-txt{font-size:10px;color:var(--t4l);letter-spacing:.08em;text-transform:uppercase}
.w-hero-num{font-size:2.5rem;font-weight:800;letter-spacing:-.04em;color:var(--encre);margin-bottom:.25rem}
.w-hero-lbl{font-size:10px;color:var(--t4l);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1.25rem}
.w-prog{height:3px;background:rgba(26,26,26,.06);border-radius:2px;margin-bottom:1.5rem}
.w-prog-fill{height:100%;width:93.7%;background:linear-gradient(90deg,var(--vert),rgba(53,71,75,.5));border-radius:2px}
.w-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.25rem}
.w-card{background:rgba(26,26,26,.04);border:1px solid var(--rule-l);border-radius:3px;padding:.75rem}
.w-card-v{font-size:1.1rem;font-weight:800;color:var(--encre);letter-spacing:-.02em}
.w-card-l{font-size:9px;color:var(--t4l);text-transform:uppercase;letter-spacing:.06em;margin-top:.2rem}
.w-row{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;border-bottom:1px solid rgba(26,26,26,.04)}
.w-row:last-child{border:none}
.w-dsm{width:4px;height:4px;border-radius:50%;background:rgba(255,49,49,.4);flex-shrink:0}
.w-ln{height:7px;background:rgba(26,26,26,.07);border-radius:2px;flex:1}
.w-tg{height:16px;width:48px;background:rgba(255,49,49,.08);border-radius:2px;flex-shrink:0}
.w-tg.g{background:rgba(74,180,100,.1)}

#faq{background:var(--creme)}
.faq-wrap{max-width:820px;margin-top:4rem}
.faq-item{border-bottom:1px solid var(--rule-l);cursor:pointer}
.faq-item:first-child{border-top:1px solid var(--rule-l)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:1.75rem 0;gap:2rem}
.faq-qt{font-size:15px;font-weight:700;color:var(--encre);letter-spacing:-.01em;line-height:1.3;transition:color .2s}
.faq-icon{font-size:22px;color:var(--rouge);font-weight:300;flex-shrink:0;transition:transform .25s}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-item.open .faq-qt{color:var(--rouge)}
.faq-a{display:none;padding:0 0 1.75rem;font-size:14px;color:var(--t3l);line-height:1.85;max-width:700px}
.faq-item.open .faq-a{display:block}

#contact{background:var(--noir)}
.ct-split{display:grid;grid-template-columns:1fr 1fr;gap:8rem;align-items:start}
.ctif-l{font-size:9px;text-transform:uppercase;letter-spacing:.18em;color:var(--t4);font-weight:700;margin-bottom:.4rem}
.ctif-v{font-size:14px;color:var(--t2);text-decoration:none;transition:color .2s;display:block}
.ctif-v:hover{color:var(--blanc)}
.ctif-s{font-size:11px;color:var(--t4);margin-top:.2rem}
.sonia{background:rgba(255,255,255,.03);border:1px solid var(--rule);border-radius:4px;padding:1.5rem;margin-top:2rem}
.sonia-nm{font-size:13px;font-weight:700;color:var(--blanc);margin-bottom:.2rem}
.sonia-rl{font-size:11px;color:var(--t4);margin-bottom:.75rem}
.sonia-av{display:flex;align-items:center;gap:6px;font-size:11px;color:rgba(93,202,165,.65);letter-spacing:.04em}
.sonia-dot{width:5px;height:5px;border-radius:50%;background:#5DCAA5;animation:blink 2s infinite}

/* ── FOOTER ── */
.site-footer{border-top:1px solid var(--rule);background:var(--noir);color:var(--blanc)}
.ft-main{padding:4rem 3.5rem;display:grid;grid-template-columns:240px 1fr 1fr 1fr;gap:4rem}
.ft-col h4,.ft-col .widget-title,.ft-ht{font-size:9px;text-transform:uppercase;letter-spacing:.2em;color:var(--t4);font-weight:700;margin-bottom:1.25rem;display:flex;align-items:center;gap:8px}
.ft-col h4::after,.ft-col .widget-title::after,.ft-ht::after{content:'';display:block;width:12px;height:1px;background:rgba(255,255,255,.1)}
.ft-brand{font-size:13px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;margin-bottom:1rem;display:block;color:var(--blanc);text-decoration:none}
.ft-brand sup{font-size:9px;color:var(--rouge);vertical-align:super;margin-left:3px}
.ft-desc{font-size:13px;color:var(--t3);line-height:1.7;margin-bottom:1.5rem}
.ft-ct{display:flex;flex-direction:column;gap:.35rem}
.ft-ct a{font-size:11px;color:var(--t4);text-decoration:none;transition:color .2s}
.ft-ct a:hover{color:var(--blanc)}
.ft-ct span{font-size:11px;color:var(--t4)}
.ft-col ul,.ft-lks{display:flex;flex-direction:column;gap:.75rem;list-style:none;padding:0;margin:0}
.ft-col ul li{list-style:none}
.ft-col ul a,.ft-lks a{font-size:13px;color:var(--t3);text-decoration:none;transition:color .2s}
.ft-col ul a:hover,.ft-lks a:hover{color:var(--blanc)}
.ft-social{display:flex;gap:.75rem;margin-top:1.25rem}
.ft-social a{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--rule);border-radius:4px;color:var(--t3);transition:all .2s}
.ft-social a:hover{border-color:var(--rouge);color:var(--rouge)}
.ft-social svg{width:16px;height:16px}
.ft-bot{padding:1.25rem 3.5rem;border-top:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.ft-copy{font-size:10px;color:var(--t4);letter-spacing:.04em}
.ft-leg{display:flex;gap:1.5rem;list-style:none;padding:0;margin:0}
.ft-leg li{list-style:none}
.ft-leg a{font-size:10px;color:var(--t4);text-decoration:none;letter-spacing:.04em;transition:color .2s}
.ft-leg a:hover{color:rgba(255,255,255,.4)}

#club{padding:5.5rem 3.5rem;background:var(--blanc)}
.club-split{display:grid;grid-template-columns:1fr 1fr;gap:7rem;align-items:start}
.club-stat-big{font-size:clamp(3rem,5vw,5rem);font-weight:800;letter-spacing:-.05em;color:var(--encre);line-height:1;margin-bottom:.5rem}
.club-stat-big .thin{font-weight:300;font-style:italic;color:rgba(26,26,26,.45);font-size:.75em}
.club-stat-lbl{font-size:14px;color:var(--t3l);font-weight:500;margin-bottom:2.5rem}
.club-formats{display:flex;flex-direction:column;gap:0}
.cf-item{padding:1.5rem 0;border-bottom:1px solid var(--rule-l);display:grid;grid-template-columns:56px 1fr;gap:1.5rem;align-items:start;opacity:0;transform:translateX(-16px);transition:opacity .6s ease,transform .6s ease}
.cf-item.v{opacity:1;transform:none}
.cf-item:first-child{border-top:1px solid var(--rule-l)}
.cf-item:nth-child(1){transition-delay:.0s}
.cf-item:nth-child(2){transition-delay:.1s}
.cf-item:nth-child(3){transition-delay:.2s}
.cf-item:nth-child(4){transition-delay:.3s}
.cf-num{font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,49,49,.45);padding-top:.1rem}
.cf-title{font-size:14px;font-weight:700;color:var(--encre);margin-bottom:.35rem;letter-spacing:-.01em}
.cf-body{font-size:13px;color:var(--t3l);line-height:1.7}
.club-nums{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule-l);border:1px solid var(--rule-l);margin-top:2.5rem}
.cn-item{padding:1.75rem 2rem;background:var(--blanc)}
.cn-v{font-size:1.8rem;font-weight:800;letter-spacing:-.04em;color:var(--encre);line-height:1;margin-bottom:.3rem}
.cn-v .thin{font-weight:300;font-style:italic;color:rgba(26,26,26,.4);font-size:.75em}
.cn-l{font-size:11px;color:var(--t4l);text-transform:uppercase;letter-spacing:.06em}
.club-proof{background:var(--creme);border:1px solid var(--rule-l);border-radius:4px;padding:1.5rem 1.75rem;margin-top:2rem}
.cp-label{font-size:9px;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,49,49,.5);font-weight:700;margin-bottom:.6rem}
.cp-text{font-size:13px;color:var(--t3l);line-height:1.7}

.cta-band{text-align:center;padding:4rem 3.5rem;border-top:1px solid var(--rule-l)}
.cta-band.dk{background:var(--noir);border-top:1px solid var(--rule)}
.cta-band.lt{background:var(--blanc)}
.cta-band.cr{background:var(--creme)}
.cta-band-t{font-size:1.4rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.5rem}
.cta-band-t.d{color:var(--blanc)}
.cta-band-t.l{color:var(--encre)}
.cta-band-s{font-size:14px;line-height:1.65;margin-bottom:2rem}
.cta-band-s.d{color:var(--t3)}
.cta-band-s.l{color:var(--t3l)}
.cta-btn{display:inline-flex;align-items:center;gap:8px;padding:.85rem 2rem;font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;border-radius:3px;transition:all .2s;font-family:inherit;cursor:pointer;border:none}
.cta-btn.rouge{background:var(--rouge);color:#fff;position:relative;overflow:hidden}
.cta-btn.rouge:hover{opacity:.88;transform:translateY(-1px);color:#fff}
.cta-btn.rouge::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transform:skewX(-20deg);animation:shimmer 3.5s ease infinite}
@keyframes shimmer{0%,60%{left:-100%}100%{left:180%}}
.cta-btn.outline-d{background:transparent;color:var(--blanc);border:1.5px solid rgba(255,255,255,.2)}
.cta-btn.outline-d:hover{border-color:var(--rouge);color:var(--rouge)}
.cta-btn.outline-l{background:transparent;color:var(--encre);border:1.5px solid rgba(26,26,26,.2)}
.cta-btn.outline-l:hover{border-color:var(--rouge);color:var(--rouge)}
.cta-btn svg{width:14px;height:14px;transition:transform .2s}
.cta-btn:hover svg{transform:translateX(3px)}
.cta-duo{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}

@keyframes wordUp{to{transform:translateY(0);opacity:1}}
.w1{animation-delay:.1s}.w2{animation-delay:.22s}.w3{animation-delay:.34s}
.w4{animation-delay:.46s}.w5{animation-delay:.58s}.w6{animation-delay:.7s}

.label-anim{font-size:11px;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--rouge);margin-bottom:2rem;display:flex;align-items:center;gap:12px;opacity:0;transform:translateX(-12px);transition:opacity .6s ease,transform .6s ease}
.label-anim.v{opacity:1;transform:none}
.label-anim::after{content:'';display:block;width:0;height:1px;background:var(--rouge);opacity:.5;transition:width .6s ease .4s}
.label-anim.v::after{width:32px}

.counter{display:inline-block}

.st{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.st.v{opacity:1;transform:none}
.st:nth-child(1){transition-delay:.05s}.st:nth-child(2){transition-delay:.15s}.st:nth-child(3){transition-delay:.25s}.st:nth-child(4){transition-delay:.35s}

.pq-item{opacity:0;transform:translateY(20px);transition:opacity .65s ease,transform .65s ease,background .2s}
.pq-item.v{opacity:1;transform:none}
.pq-item:nth-child(1){transition-delay:0s}.pq-item:nth-child(2){transition-delay:.1s}.pq-item:nth-child(3){transition-delay:.2s}
.pq-item:nth-child(4){transition-delay:.08s}.pq-item:nth-child(5){transition-delay:.18s}.pq-item:nth-child(6){transition-delay:.28s}

.cm-step{opacity:0;transform:translateX(-18px);transition:opacity .6s ease,transform .6s ease,border-bottom-color .2s}
.cm-step.v{opacity:1;transform:none}
.cm-step:nth-child(1){transition-delay:0s}.cm-step:nth-child(2){transition-delay:.12s}.cm-step:nth-child(3){transition-delay:.24s}
.cm-step:nth-child(4){transition-delay:.36s}.cm-step:nth-child(5){transition-delay:.48s}

.ql-item{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease,border-color .2s}
.ql-item.v{opacity:1;transform:none}
.ql-item:nth-child(1){transition-delay:0s}.ql-item:nth-child(2){transition-delay:.12s}.ql-item:nth-child(3){transition-delay:.24s}.ql-item:nth-child(4){transition-delay:.36s}

.ip{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease,background .2s}
.ip.v{opacity:1;transform:none}
.ip:nth-child(1){transition-delay:0s}.ip:nth-child(2){transition-delay:.12s}.ip:nth-child(3){transition-delay:.24s}.ip:nth-child(4){transition-delay:.36s}

.rl-img img,.cm-img img{transform:scale(1.04);transition:transform 1.4s cubic-bezier(.16,1,.3,1),opacity .6s ease}
.rl-img.v img,.cm-img.v img{transform:scale(1)}
.rl-img{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.rl-img.v{opacity:1;transform:none}
.cm-img{opacity:0;transition:opacity .7s ease .1s}
.cm-img.v{opacity:1}

.section-line{height:1px;background:linear-gradient(90deg,var(--rouge),transparent);width:0;transition:width 1s cubic-bezier(.16,1,.3,1)}
.section-line.v{width:100%}

.hero-sub-tag{opacity:0;transform:translateY(10px);transition:opacity .6s ease .8s,transform .6s ease .8s}
.hero-sub-tag.v{opacity:1;transform:none}

.faq-item{transition:background .15s}

.wire{opacity:0;transform:scale(.97) translateY(12px);transition:opacity .7s ease,transform .7s ease}
.wire.v{opacity:1;transform:none}

.r{opacity:0;transform:translateY(22px);transition:opacity .75s ease,transform .75s ease}
.r.v{opacity:1;transform:none}
.r.d1{transition-delay:.1s}.r.d2{transition-delay:.2s}.r.d3{transition-delay:.3s}.r.d4{transition-delay:.4s}

@media(max-width:960px){
  .rl-split,.cm-split,.ql-split,.es-split,.ct-split{grid-template-columns:1fr;gap:3.5rem}
  .pq-grid{grid-template-columns:repeat(2,1fr)}
  .inv-profiles{grid-template-columns:repeat(2,1fr)}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .st:nth-child(3),.st:nth-child(4){border-top:1px solid var(--rule-l)}
  .ft-main{grid-template-columns:1fr 1fr;gap:2.5rem}
  .hdr-top{display:none}
  .primary-menu{display:none}
  .hdr-tel{display:none}
  .burger{display:flex}
  .hdr-cta{display:none}
}
@media(max-width:640px){
  .site-header,.s-dark,.s-light,.s-white,.s-mid,#hero,#statsbar,#realite,#idee,#pourqui,#comment,#investisseur,#espace,#faq,#contact,.site-footer,.ft-main,.ft-bot{padding-left:1.75rem;padding-right:1.75rem}
  #hero{padding:8rem 1.75rem 4rem}
  .h1d,.tag-d{font-size:2.6rem}
  .h2d,.h2l{font-size:2rem}
  .pq-grid,.inv-profiles{grid-template-columns:1fr}
  .ft-main{grid-template-columns:1fr}
  .ft-bot{flex-direction:column;align-items:flex-start}
  .cm-step{grid-template-columns:44px 1fr;gap:1.25rem}
}




/* ============================================================
   ADOMOS PRO — overrides post-cleanup
   Modif facile : tout est ici.
   ============================================================ */

/* 1. KILL Tour Eiffel (wp-custom-css du Customizer + thème) ----- */
html body section.hero::after,
html body .hero::after,
html body #hero::after,
html body .hero::before,
html body .hero-img,
html body #hero .hero-img,
html body .hero .hero-img {
  content: none !important;
  background: none !important;
  background-image: none !important;
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
}

/* 2. Cacher les anciens placeholders cassés (img src vide) ----- */
.img-placeholder, .section-figure { display: none !important; }
.hero-visual-wrap:not(.has-image)::before { display: none !important; }
.hero-visual-wrap:not(.has-image) { background: transparent !important; border: none !important; }





/* 5. Image header articles & blog (page archive) -------------- */
.post-hero-image, .blog-hero-image, .article-hero-image {
  position: relative; width: 100%;
  aspect-ratio: 21/9; max-height: 360px;
  border-radius: 18px; overflow: hidden;
  margin: 24px 0 32px;
  box-shadow: 0 20px 60px rgba(0,0,0,.4);
}
.post-hero-image img, .blog-hero-image img, .article-hero-image img {
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(.85) saturate(1.05);
}
.post-hero-image::after, .article-hero-image::after, .blog-hero-image::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(135deg, rgba(255,49,49,.32) 0%, rgba(255,49,49,.08) 40%, rgba(10,10,11,.65) 100%),
    radial-gradient(circle at 25% 25%, rgba(255,255,255,.06), transparent 60%);
  mix-blend-mode: multiply;
}

/* 6. Widget chat 'Parler à un conseiller' (réactivé + restyle) - */
.adomi-bubble {
  display: flex !important;
  position: fixed; right: 24px; bottom: 24px; z-index: 9999;
  align-items: center; gap: 10px;
  padding: 14px 22px 14px 18px;
  background: linear-gradient(135deg, var(--rouge,#FF3131), #d32626);
  color: #fff; border-radius: 999px;
  box-shadow: 0 12px 40px rgba(255,49,49,.35), 0 4px 14px rgba(0,0,0,.4);
  cursor: pointer; user-select: none;
  font-size: 13px; font-weight: 600; letter-spacing: .02em;
  transition: transform .2s, box-shadow .2s;
  border: none;
}
.adomi-bubble:hover { transform: translateY(-2px); box-shadow: 0 18px 50px rgba(255,49,49,.45); }
.adomi-bubble::before {
  content: ""; width: 18px; height: 18px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z'/></svg>") center/contain no-repeat;
  flex-shrink: 0;
}
.adomi-badge { display: none !important; }
.adomi-panel, .adomi-status, .adomi-dot, .adomi-head, .adomi-status-row, .adomi-body { display: none !important; }
@media (max-width: 600px) { .adomi-bubble { padding: 12px 18px 12px 14px; right: 16px; bottom: 16px; } }







/* === HERO image plein fond v2 (sans casser le layout hero original) === */
section.hero { position: relative; overflow: hidden; isolation: isolate; }

.hero-visual-wrap {
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
  width: 100% !important; height: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  transform: none !important;
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  z-index: 0 !important;
  pointer-events: none;
  aspect-ratio: auto !important;
  animation: none !important;
  box-shadow: none !important;
}
.hero-visual-wrap::before { content: none !important; display: none !important; }
.hero-visual-wrap img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  filter: brightness(.5) saturate(1.15) contrast(1.05) !important;
  animation: heroKenBurnsV2 24s ease-in-out infinite alternate;
  border-radius: 0 !important;
  display: block !important;
  opacity: 1 !important;
}
.hero-visual-wrap::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    linear-gradient(105deg, rgba(10,10,11,.92) 0%, rgba(10,10,11,.78) 35%, rgba(10,10,11,.50) 70%, rgba(10,10,11,.30) 100%),
    linear-gradient(180deg, transparent 0%, rgba(10,10,11,.40) 100%),
    radial-gradient(ellipse at 80% 30%, rgba(255,49,49,.10), transparent 60%);
  z-index: 1;
  pointer-events: none;
  display: block !important;
}
@keyframes heroKenBurnsV2 {
  0% { transform: scale(1) translate(0,0); }
  100% { transform: scale(1.10) translate(-1.5%,-1.5%); }
}

/* Contenu hero au-dessus de l'image, aligne avec les autres sections (max-width centre) */
section.hero > *:not(.hero-visual-wrap) { position: relative; z-index: 2; }
section.hero .lines-bg { z-index: 1; opacity: .25; }
section.hero .label-anim,
section.hero .hero-title,
section.hero .hero-sub,
section.hero .hero-ctas {
  max-width: 1240px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  width: 100%;
}


/* === FINAL: hide adomi-bubble (garder uniquement HubSpot Chat natif) === */
.adomi-panel,.adomi-badge,.adomi-status,.adomi-dot,.adomi-head{display:none!important}



/* === Stats colors + pulse dots === */


.sb-it.sb-pos .sb-plus{color:var(--encre);font-weight:800;margin-right:2px;display:inline-block}
.sb-it .sb-l { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.sb-it.sb-pos .sb-l strong { color: rgba(255,255,255,.85); font-weight: 600; }
.pulse-dot {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: #4ADE80; flex-shrink: 0; position: relative;
  box-shadow: 0 0 0 0 rgba(74,222,128,.7);
  animation: pulseDot 1.6s ease-in-out infinite;
}
@keyframes pulseDot {
  0% { box-shadow: 0 0 0 0 rgba(74,222,128,.7); transform: scale(1); }
  50% { box-shadow: 0 0 0 6px rgba(74,222,128,0); transform: scale(1.15); }
  100% { box-shadow: 0 0 0 0 rgba(74,222,128,0); transform: scale(1); }
}


/* === Stepper animé + dashboard ec === */

/* STEPPER au-dessus des 5 etapes */
.cm-stepper-bar {
  position: relative;
  margin: 48px auto 56px;
  max-width: 1100px;
  padding: 0 8px;
}
.cm-stepper-track,
.cm-stepper-progress {
  position: absolute;
  left: 8%;
  right: 8%;
  top: 36px;
  height: 2px;
  border-radius: 2px;
}
.cm-stepper-track { background: rgba(255,255,255,.08); }
.cm-stepper-progress {
  background: linear-gradient(90deg, var(--rouge,#FF3131) 0%, rgba(255,49,49,.4) 100%);
  width: 0;
  animation: stepperFill 5s ease-out forwards;
  box-shadow: 0 0 12px rgba(255,49,49,.4);
}
.cm-stepper-dots {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  z-index: 2;
}
.cm-stepper-dot {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  text-align: center;
  opacity: 0;
  transform: translateY(8px);
  animation: stepperDotIn .6s ease-out forwards;
}
.cm-stepper-dot:nth-child(1) { animation-delay: .2s; }
.cm-stepper-dot:nth-child(2) { animation-delay: 1.0s; }
.cm-stepper-dot:nth-child(3) { animation-delay: 1.8s; }
.cm-stepper-dot:nth-child(4) { animation-delay: 2.6s; }
.cm-stepper-dot:nth-child(5) { animation-delay: 3.4s; }

.cm-stepper-dot .cs-bignum {
  display: flex; align-items: center; justify-content: center;
  width: 72px; height: 72px;
  border-radius: 50%;
  background: #0E0E10;
  border: 2px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.85);
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -.02em;
  font-feature-settings: "tnum";
  position: relative;
  transition: all .3s ease;
  box-shadow: 0 6px 20px rgba(0,0,0,.4);
}
.cm-stepper-dot .cs-bignum::before {
  content: ""; position: absolute; inset: -6px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,49,49,.25), transparent 70%);
  opacity: 0;
  animation: stepperPulse 2s ease-in-out infinite;
}
.cm-stepper-dot:nth-child(1) .cs-bignum::before { animation-delay: .2s; }
.cm-stepper-dot:nth-child(2) .cs-bignum::before { animation-delay: 1.0s; }
.cm-stepper-dot:nth-child(3) .cs-bignum::before { animation-delay: 1.8s; }
.cm-stepper-dot:nth-child(4) .cs-bignum::before { animation-delay: 2.6s; }
.cm-stepper-dot:nth-child(5) .cs-bignum::before { animation-delay: 3.4s; }

.cm-stepper-dot:hover .cs-bignum {
  border-color: var(--rouge,#FF3131);
  color: #fff;
  background: linear-gradient(135deg, var(--rouge,#FF3131), #d32626);
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 10px 30px rgba(255,49,49,.4);
}
.cm-stepper-dot .cs-bigl {
  margin-top: 12px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  max-width: 110px;
  line-height: 1.3;
}

@keyframes stepperFill {
  0% { width: 0; }
  100% { width: 84%; }
}
@keyframes stepperDotIn {
  to { opacity: 1; transform: translateY(0); }
}
@keyframes stepperPulse {
  0%, 100% { opacity: 0; transform: scale(.9); }
  50% { opacity: 1; transform: scale(1.1); }
}
@media(max-width:780px){
  .cm-stepper-dot .cs-bignum { width: 52px; height: 52px; font-size: 16px; }
  .cm-stepper-dot .cs-bigl { font-size: 9px; max-width: 70px; }
  .cm-stepper-track, .cm-stepper-progress { top: 26px; }
}

/* DASHBOARD MOCKUP dans #espace-client */
.ec-dashboard {
  margin-top: 32px;
  background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  padding: 22px 24px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.4);
}
.ec-dashboard::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 80% 0%, rgba(255,49,49,.08), transparent 50%);
  pointer-events: none;
}
.ec-d-head {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  font-size: 11px;
  letter-spacing: .12em;
  color: rgba(255,255,255,.4);
  text-transform: uppercase;
  font-weight: 600;
}
.ec-d-user { display: flex; align-items: center; gap: 6px; color: rgba(255,255,255,.7); text-transform: none; letter-spacing: 0; font-weight: 500;}
.ec-d-dot { width: 6px; height: 6px; border-radius: 50%; background: #4ADE80; box-shadow: 0 0 8px rgba(74,222,128,.7); animation: ecDotPulse 1.6s ease-in-out infinite; }
@keyframes ecDotPulse { 0%,100%{opacity:1;}50%{opacity:.5;} }

.ec-d-kpis {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  padding: 22px 0;
}
.ec-d-kpi {
  padding: 14px 16px;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.05);
  border-radius: 10px;
}
.ec-d-kpi-v {
  font-size: 30px;
  font-weight: 800;
  color: #fff;
  letter-spacing: -.02em;
  font-feature-settings: "tnum";
  margin-bottom: 4px;
}
.ec-d-kpi-l { font-size: 12px; color: rgba(255,255,255,.6); font-weight: 500; }
.ec-d-kpi-d { font-size: 10px; color: rgba(255,255,255,.35); margin-top: 6px; letter-spacing: .04em; }

.ec-d-leads { padding-top: 14px; border-top: 1px solid rgba(255,255,255,.06); }
.ec-d-leads-head { font-size: 10px; letter-spacing: .14em; color: rgba(255,255,255,.4); text-transform: uppercase; font-weight: 700; margin-bottom: 8px; }
.ec-d-row {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  padding: 10px 0;
  border-top: 1px solid rgba(255,255,255,.04);
  font-size: 12px; align-items: center;
}
.ec-d-row:first-of-type { border-top: none; }
.ec-d-id { color: rgba(255,255,255,.7); font-family: 'JetBrains Mono', 'Courier New', monospace; font-size: 11px; }
.ec-d-status { font-size: 11px; font-weight: 600; }
.ec-d-status.ok { color: #4ADE80; }
.ec-d-status.pending { color: #FBBF24; }
.ec-d-time { color: rgba(255,255,255,.4); font-size: 11px; text-align: right; }
@media(max-width:640px){
  .ec-d-kpis { grid-template-columns: 1fr; }
  .ec-d-row { grid-template-columns: 1fr 1fr; }
  .ec-d-time { display: none; }
}


/* === Stepper aere + espace-client right === */
/* Stepper : aerer les ronds */
.cm-stepper-bar { padding: 0 24px; max-width: 1180px; }
.cm-stepper-track, .cm-stepper-progress { left: 12%; right: 12%; }
.cm-stepper-dots { gap: 24px; }
.cm-stepper-dot { padding: 0 8px; }
.cm-stepper-dot .cs-bignum { width: 80px; height: 80px; font-size: 24px; }
.cm-stepper-dot .cs-bigl { max-width: 130px; margin-top: 16px; }

/* Espace client : dashboard a droite, contenu a gauche */
#espace-client .cm-wrap { position: relative; }
#espace-client .cm-split {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 56px;
  align-items: start;
  margin-top: 36px;
}
#espace-client .cm-steps { padding-top: 0; }
#espace-client .ec-dashboard {
  margin-top: 0;
  position: sticky;
  top: 32px;
}
@media (max-width: 980px) {
  #espace-client .cm-split { grid-template-columns: 1fr; gap: 36px; }
  #espace-client .ec-dashboard { position: static; }
}

/* === Adomi-bubble = Prendre RDV pill === */
.adomi-bubble{display:flex!important;position:fixed!important;right:24px!important;bottom:24px!important;z-index:9999!important;align-items:center;gap:10px;padding:14px 22px 14px 18px!important;background:linear-gradient(135deg,#FF3131,#d32626)!important;color:#fff!important;border-radius:999px!important;box-shadow:0 12px 40px rgba(255,49,49,.35)!important;cursor:pointer;font-size:13px;font-weight:600;letter-spacing:.02em;transition:transform .2s,box-shadow .2s;border:none!important;width:auto!important;height:auto!important}
.adomi-bubble:hover{transform:translateY(-2px)!important;box-shadow:0 18px 50px rgba(255,49,49,.45)!important}
.adomi-bubble::before{content:"";width:18px;height:18px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='18' rx='2'/><line x1='16' y1='2' x2='16' y2='6'/><line x1='8' y1='2' x2='8' y2='6'/><line x1='3' y1='10' x2='21' y2='10'/></svg>") center/contain no-repeat;flex-shrink:0}
@media(max-width:600px){.adomi-bubble{padding:12px 18px 12px 14px!important;right:16px!important;bottom:16px!important}}


/* === Front-page header CSS imported (so /promoteurs/ etc. inherit it) === */

/* ─── DESIGN SYSTEM GLOBAL (10-components) ─── */
:root{--rouge:#FF3131;--noir:#0D0D0D;--blanc:#FFFFFF;--creme:#F8F5F0;--encre:#1A1A1A;--vert:#35474B;--t2:rgba(255,255,255,.65);--t3:rgba(255,255,255,.52);--t4:rgba(255,255,255,.3);--t3l:rgba(26,26,26,.58);--t4l:rgba(26,26,26,.38);--rule:rgba(255,255,255,.07);--rule-l:rgba(26,26,26,.1)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;background:var(--noir);color:var(--blanc);overflow-x:hidden;line-height:1.5}
.lines-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.line{position:absolute;bottom:0;width:1px;background:linear-gradient(to top,rgba(255,49,49,.18),transparent);transform-origin:bottom center;animation:rise 6s ease-out infinite}
.line:nth-child(1){left:18%;height:55vh;animation-delay:0s}.line:nth-child(2){left:35%;height:40vh;animation-delay:1.2s}.line:nth-child(3){left:52%;height:65vh;animation-delay:.6s}.line:nth-child(4){left:68%;height:45vh;animation-delay:2s}.line:nth-child(5){left:82%;height:35vh;animation-delay:1.6s}
@keyframes rise{0%{opacity:0;transform:scaleY(0)}20%{opacity:1}80%{opacity:.4}100%{opacity:0;transform:scaleY(1)}}
section{position:relative;overflow:hidden}
section>*:not(.lines-bg){position:relative;z-index:1}
.label-anim{font-size:11px;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--rouge);margin-bottom:2rem;display:flex;align-items:center;gap:12px;opacity:0;transform:translateX(-12px);transition:opacity .6s,transform .6s}
.label-anim.v{opacity:1;transform:none}
.label-anim::after{content:'';display:block;width:0;height:1px;background:var(--rouge);opacity:.5;transition:width .6s ease .3s}
.label-anim.v::after{width:32px}
/* HEADER */
header.hdr{position:fixed;top:0;left:0;right:0;z-index:200;transition:background .3s,backdrop-filter .3s}
header.hdr.scrolled{background:rgba(13,13,13,.97);backdrop-filter:blur(20px)}
.hdr-top{padding:.6rem 3.5rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid transparent;transition:border-color .3s}
header.hdr.scrolled .hdr-top{border-color:var(--rule)}
.hdr-status{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.25)}
.hdr-status-dot{width:5px;height:5px;border-radius:50%;background:var(--rouge);animation:blink 2.4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hdr-top-right{display:flex;align-items:center;gap:1.5rem}
.hdr-contact{font-size:10px;color:rgba(255,255,255,.2);letter-spacing:.04em;text-decoration:none;transition:color .2s}
.hdr-contact:hover{color:var(--blanc)}
.hdr-main{padding:.9rem 3.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;border-bottom:1px solid transparent;transition:border-color .3s;z-index:201;position:relative}
header.hdr.scrolled .hdr-main{border-color:var(--rule)}
.wordmark{font-size:13px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--blanc);text-decoration:none;flex-shrink:0}
.wordmark sup{font-size:9px;font-weight:500;letter-spacing:.1em;color:var(--rouge);vertical-align:super;margin-left:3px}
.nav{display:flex;align-items:center;gap:0;flex:1;justify-content:center}
.nav-item{position:relative}
.nav-item::after{content:'';position:absolute;top:100%;left:0;right:0;height:14px}
.nav-link{display:flex;flex-direction:column;align-items:center;padding:.6rem 1.1rem;text-decoration:none;cursor:pointer;transition:all .2s}
.nav-link-main{font-size:12px;color:rgba(255,255,255,.45);letter-spacing:.06em;text-transform:uppercase;font-weight:600;pointer-events:none;transition:color .2s}
.nav-item:hover .nav-link-main{color:var(--blanc)}
.nav-link-bar{display:block;width:0;height:1px;background:var(--rouge);margin-top:3px;transition:width .25s ease;pointer-events:none}
.nav-item:hover .nav-link-bar{width:100%}
.nav-drop{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-6px);width:280px;background:rgba(12,12,12,.99);border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:1rem 1.25rem 1.25rem;opacity:0;pointer-events:none;transition:opacity .18s,transform .18s;backdrop-filter:blur(20px);z-index:300}
.nav-item:hover .nav-drop{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
.nav-drop::before{content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:10px;height:6px;background:rgba(12,12,12,.99);clip-path:polygon(50% 0%,0% 100%,100% 100%)}
.nd-title{font-size:9px;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,49,49,.5);font-weight:700;margin-bottom:.75rem}
.nd-link{display:block;font-size:12px;color:rgba(255,255,255,.45);text-decoration:none;padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.04);transition:color .15s;line-height:1.4}
.nd-link:last-child{border-bottom:none}
.nd-link:hover{color:var(--blanc)}
.nd-link span{display:block;font-size:10px;color:rgba(255,255,255,.2);margin-top:1px;font-weight:400}
.nav-right{display:flex;align-items:center;gap:1.5rem;flex-shrink:0}
.hdr-cta{display:inline-flex;align-items:center;gap:6px;padding:.6rem 1.25rem;background:var(--rouge);color:#fff;text-decoration:none;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border-radius:3px;transition:opacity .2s}
.hdr-cta:hover{opacity:.85}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.burger span{display:block;width:22px;height:1px;background:var(--blanc);transition:all .3s}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}
.mnav{display:none;position:fixed;inset:0;z-index:190;background:rgba(13,13,13,.98);backdrop-filter:blur(20px);flex-direction:column;align-items:flex-start;justify-content:center;padding:3rem 3.5rem}
.mnav.open{display:flex}
.mn-item{border-bottom:1px solid var(--rule);width:100%;padding:1.25rem 0}
.mn-link{font-size:1.4rem;font-weight:800;letter-spacing:-.02em;color:var(--blanc);text-decoration:none;display:block}
.mn-link:hover{color:var(--rouge)}
@media(max-width:960px){.hdr-top{display:none}.nav,.hdr-cta{display:none}.burger{display:flex}}
@media(max-width:640px){.hdr-main{padding:.75rem 1.25rem}}
/* FOOTER */
footer.ftr{border-top:1px solid var(--rule);background:var(--noir);position:relative;z-index:5}
.ft-main{padding:4rem 3.5rem;display:grid;grid-template-columns:240px 1fr 1fr 1fr;gap:4rem}
.ft-brand{font-size:13px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;margin-bottom:1rem;display:block;color:#fff;text-decoration:none}
.ft-brand sup{font-size:9px;color:var(--rouge);vertical-align:super;margin-left:3px}
.ft-desc{font-size:13px;color:var(--t3);line-height:1.7;margin-bottom:1.5rem}
.ft-ct{display:flex;flex-direction:column;gap:.35rem}
.ft-ct a{font-size:11px;color:var(--t4);text-decoration:none;transition:color .2s}
.ft-ct a:hover{color:var(--blanc)}
.ft-ht{font-size:9px;text-transform:uppercase;letter-spacing:.2em;color:var(--t4);font-weight:700;margin-bottom:1.25rem;display:flex;align-items:center;gap:8px}
.ft-ht::after{content:'';display:block;width:12px;height:1px;background:rgba(255,255,255,.1)}
.ft-lks{display:flex;flex-direction:column;gap:.75rem}
.ft-lks a{font-size:13px;color:var(--t3);text-decoration:none;transition:color .2s}
.ft-lks a:hover{color:var(--blanc)}
.ft-bot{padding:1.25rem 3.5rem;border-top:1px solid var(--rule);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.ft-copy{font-size:10px;color:var(--t4);letter-spacing:.04em}
.ft-leg{display:flex;gap:1.5rem}
.ft-leg a{font-size:10px;color:var(--t4);text-decoration:none;letter-spacing:.04em}
.ft-leg a:hover{color:rgba(255,255,255,.4)}
@media(max-width:960px){.ft-main{grid-template-columns:1fr 1fr;gap:2.5rem}}
@media(max-width:640px){.ft-main,.ft-bot{padding-left:1.75rem;padding-right:1.75rem}.ft-main{grid-template-columns:1fr}.ft-bot{flex-direction:column;align-items:flex-start}}
/* FORMS */
.step-label{font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,49,49,.6);margin-bottom:1rem}
.step-title{font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:1.75rem;line-height:1.3}
.sector-grid{display:flex;flex-direction:column;gap:.75rem}
.sector-btn{padding:1.1rem 1.5rem;background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.1);border-radius:6px;color:rgba(255,255,255,.65);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;text-align:left;transition:all .15s;display:flex;justify-content:space-between;align-items:center}
.sector-btn span{font-size:12px;color:rgba(255,255,255,.25);font-weight:400}
.sector-btn:hover,.sector-btn.selected{background:rgba(255,49,49,.08);border-color:rgba(255,49,49,.4);color:#fff}
.zone-btn{padding:.85rem 1rem;background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.1);border-radius:6px;color:rgba(255,255,255,.6);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}
.zone-btn:hover,.zone-btn.selected{background:rgba(255,49,49,.08);border-color:rgba(255,49,49,.4);color:#fff}
.field-block{margin-bottom:.75rem}
.field-block label,.form-step label.fl{font-size:10px;font-weight:700;color:rgba(255,255,255,.45);display:block;margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.06em}
.form-step input[type="text"],.form-step input[type="email"],.form-step input[type="tel"]{width:100%;background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.12);border-radius:6px;padding:.75rem 1rem;font-size:14px;color:#fff;font-family:inherit;outline:none;transition:border-color .2s}
.form-step input:focus{border-color:rgba(255,49,49,.5)}
.rgpd-row{display:flex;align-items:flex-start;gap:.75rem;margin:1rem 0 1.5rem;cursor:pointer}
.rgpd-row input{width:14px;height:14px;margin-top:2px;accent-color:#FF3131}
.rgpd-row span{font-size:10.5px;color:rgba(255,255,255,.28);line-height:1.6}
.rgpd-row a{color:rgba(255,255,255,.4);text-decoration:underline}
.step-nav{display:flex;gap:1rem;margin-top:1.75rem}
.btn-back{padding:.75rem 1.25rem;background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:rgba(255,255,255,.4);font-family:inherit;font-size:12px;cursor:pointer;text-transform:uppercase;letter-spacing:.06em}
.btn-next{flex:1;padding:.9rem;background:#FF3131;border:none;border-radius:4px;color:#fff;font-family:inherit;font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer}
.form-step{animation:fadeUp .35s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
/* SOCIAL PROOF TICKER */
.sp-ticker{position:fixed;bottom:24px;left:24px;z-index:150;background:rgba(13,13,13,.97);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:.85rem 1.1rem;max-width:320px;opacity:0;transform:translateY(20px);transition:opacity .4s,transform .4s;backdrop-filter:blur(12px);display:flex;align-items:center;gap:.75rem}
.sp-ticker.v{opacity:1;transform:none}
.sp-pulse{width:8px;height:8px;border-radius:50%;background:#4ade80;flex-shrink:0;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(74,222,128,.5)}50%{box-shadow:0 0 0 6px rgba(74,222,128,0)}}
.sp-txt{font-size:12px;color:rgba(255,255,255,.75);line-height:1.4}
.sp-txt strong{color:#fff;font-weight:600}
.sp-close{background:none;border:none;color:rgba(255,255,255,.3);cursor:pointer;font-size:14px;padding:0;margin-left:.25rem}
@media(max-width:640px){.sp-ticker{left:12px;right:12px;max-width:none;bottom:12px}}
/* ADOMIA BUBBLE */
.adomi-bubble{position:fixed;bottom:24px;right:24px;z-index:150;background:var(--rouge);border-radius:50%;width:56px;height:56px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 24px rgba(255,49,49,.3);transition:transform .2s}
.adomi-bubble:hover{transform:scale(1.08)}
.adomi-bubble svg{width:24px;height:24px}
.adomi-badge{position:absolute;top:-4px;right:-4px;width:16px;height:16px;background:#fff;color:var(--rouge);border-radius:50%;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center}
.adomi-panel{position:fixed;bottom:96px;right:24px;z-index:150;width:360px;max-width:calc(100vw - 48px);background:rgba(13,13,13,.98);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.25rem;display:none;backdrop-filter:blur(20px);box-shadow:0 20px 40px rgba(0,0,0,.5)}
.adomi-panel.open{display:block;animation:fadeUp .25s ease}
.adomi-head{display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:1px solid var(--rule);margin-bottom:1rem}
.adomi-dot{width:10px;height:10px;border-radius:50%;background:#4ade80;animation:pulse 2s infinite}
.adomi-name{font-size:13px;font-weight:700;color:#fff}
.adomi-status{font-size:10px;color:rgba(255,255,255,.4);margin-top:1px}
.adomi-close{margin-left:auto;background:none;border:none;color:rgba(255,255,255,.4);cursor:pointer;font-size:18px;line-height:1}
.adomi-msg{background:rgba(255,255,255,.05);border:1px solid var(--rule);border-radius:8px;padding:.85rem;font-size:12px;color:rgba(255,255,255,.75);line-height:1.6;margin-bottom:.75rem}
.adomi-input{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--rule);border-radius:6px;padding:.6rem .85rem;font-size:12px;color:#fff;font-family:inherit;outline:none}
.adomi-input::placeholder{color:rgba(255,255,255,.25)}
@media(max-width:640px){.adomi-panel{right:12px;left:12px;width:auto}.adomi-bubble{right:12px;bottom:12px}}
/* EXIT INTENT */
.xi-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.7);display:none;align-items:center;justify-content:center;padding:1.5rem;backdrop-filter:blur(8px)}
.xi-overlay.open{display:flex;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.xi-modal{background:var(--noir);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:2.5rem;max-width:440px;width:100%;text-align:center;position:relative}
.xi-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:rgba(255,255,255,.4);cursor:pointer;font-size:22px}
.xi-title{font-size:1.5rem;font-weight:800;letter-spacing:-.03em;color:#fff;margin-bottom:.5rem;line-height:1.2}
.xi-sub{font-size:14px;color:rgba(255,255,255,.5);line-height:1.65;margin-bottom:2rem}
.xi-form{display:flex;gap:.5rem;margin-bottom:1rem}
.xi-form input{flex:1;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:.75rem 1rem;font-size:13px;color:#fff;font-family:inherit;outline:none}
.xi-form button{padding:.75rem 1.25rem;background:var(--rouge);border:none;border-radius:4px;color:#fff;font-family:inherit;font-size:12px;font-weight:700;cursor:pointer;text-transform:uppercase;letter-spacing:.06em}
.xi-note{font-size:10.5px;color:rgba(255,255,255,.25);line-height:1.55}
/* REVEAL */
.r{opacity:0;transform:translateY(22px);transition:opacity .75s ease,transform .75s ease}
.r.v{opacity:1;transform:none}
.r.d1{transition-delay:.1s}.r.d2{transition-delay:.2s}.r.d3{transition-delay:.3s}.r.d4{transition-delay:.4s}
/* ─── HOME-SPECIFIC CSS ─── */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:9rem 3.5rem 5rem;background:var(--noir)}
.hero-title{margin-bottom:2.5rem}
.hero-line{font-size:clamp(2.4rem,5vw,4.8rem);font-weight:800;line-height:1.05;letter-spacing:-.04em;color:var(--blanc);white-space:nowrap;opacity:0;transform:translateY(60px);animation:heroLineUp .9s cubic-bezier(.16,1,.3,1) forwards}
.hero-line .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.6)}
.hero-line em{font-style:normal;-webkit-text-stroke:1.5px rgba(255,255,255,.5);color:transparent}
.hero-line-2{animation-delay:.16s}.hero-line-3{animation-delay:.3s;font-size:clamp(2.8rem,6vw,5.6rem)}.hero-line-4{animation-delay:.46s;margin-top:.2rem}
@keyframes heroLineUp{to{opacity:1;transform:translateY(0)}}
@media(max-width:960px){.hero-line{font-size:clamp(2rem,6vw,3.8rem)}.hero-line-3{font-size:clamp(2.4rem,7vw,4.4rem)}}
@media(max-width:640px){.hero-line{font-size:clamp(1.8rem,8.5vw,2.8rem);white-space:normal}.hero-line-3{font-size:clamp(2.2rem,10vw,3.4rem)}.hero{padding:6rem 1.5rem 3rem}}
.bc-ticker{display:inline-flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:rgba(74,222,128,.05);border:1px solid rgba(74,222,128,.2);border-radius:100px;font-size:11px;color:rgba(255,255,255,.7);font-weight:500;letter-spacing:.04em;margin-top:1rem}
.bc-pulse{width:6px;height:6px;border-radius:50%;background:#4ade80;box-shadow:0 0 0 0 rgba(74,222,128,.5);animation:pulse 2s infinite}
.bc-ticker strong{color:#4ade80;font-weight:700}
.hero-sub{font-size:16px;color:var(--t3);line-height:1.85;max-width:560px;margin:0 0 2.5rem 0;opacity:0;transform:translateY(22px);transition:opacity .8s ease .55s,transform .8s ease .55s}
.hero-sub.v{opacity:1;transform:none}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;transform:translateY(22px);transition:opacity .8s ease .7s,transform .8s ease .7s}
.hero-ctas.v{opacity:1;transform:none}
.btn-p{display:inline-flex;align-items:center;gap:8px;padding:.9rem 1.75rem;background:var(--rouge);color:#fff;font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;border-radius:4px;transition:transform .2s,opacity .2s;position:relative;overflow:hidden}
.btn-p:hover{transform:translateY(-1px);opacity:.92}
.btn-p::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transform:skewX(-20deg);animation:shimmer 3.5s infinite}
@keyframes shimmer{0%,60%{left:-100%}100%{left:180%}}
.btn-p svg{width:14px;height:14px;transition:transform .2s}
.btn-p:hover svg{transform:translateX(3px)}
.btn-s{display:inline-flex;align-items:center;gap:8px;padding:.9rem 1.75rem;background:transparent;border:1.5px solid rgba(255,255,255,.2);color:var(--blanc);font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;border-radius:4px;transition:all .2s}
.btn-s:hover{border-color:var(--rouge);color:var(--rouge)}
.sb{background:var(--creme);border-top:1px solid var(--rule-l);border-bottom:1px solid var(--rule-l)}
.sb-row{display:grid;grid-template-columns:repeat(4,1fr);max-width:1400px;margin:0 auto}
.sb-it{padding:1.75rem 2.5rem;border-right:1px solid var(--rule-l)}
.sb-it:last-child{border-right:none}
.sb-v{font-size:1.85rem;font-weight:800;letter-spacing:-.04em;color:var(--encre);line-height:1;margin-bottom:.35rem}
.sb-v .thin{font-weight:300;font-style:italic;color:rgba(26,26,26,.5);font-size:.75em}
.sb-l{font-size:13px;color:var(--t3l);line-height:1.55;font-weight:500}
@media(max-width:960px){.sb-row{grid-template-columns:repeat(2,1fr)}.sb-it:nth-child(1),.sb-it:nth-child(2){border-bottom:1px solid var(--rule-l)}.sb-it:nth-child(2){border-right:none}}
@media(max-width:640px){.sb-row{grid-template-columns:1fr}.sb-it{border-right:none;border-bottom:1px solid var(--rule-l)}.sb-it:last-child{border-bottom:none}}
.tl{background:var(--creme);padding:7rem 3.5rem}
.tl-wrap{max-width:1200px;margin:0 auto}
.tl-lbl{font-size:11px;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--rouge);margin-bottom:2rem;display:flex;align-items:center;gap:12px}
.tl-lbl::after{content:'';display:block;width:32px;height:1px;background:var(--rouge);opacity:.5}
.tl-title{font-size:clamp(2rem,4vw,3.2rem);font-weight:800;letter-spacing:-.04em;color:var(--encre);line-height:1.05;margin-bottom:1rem}
.tl-title .thin{font-weight:300;font-style:italic;color:rgba(26,26,26,.45)}
.tl-sub{font-size:16px;color:var(--t3l);line-height:1.75;max-width:640px;margin-bottom:4rem}
.tl-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;position:relative}
.tl-steps::before{content:'';position:absolute;top:32px;left:6%;right:6%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,49,49,.3),rgba(255,49,49,.3),transparent);z-index:0}
.tl-st{background:var(--blanc);border:1px solid var(--rule-l);border-radius:6px;padding:1.5rem;position:relative;z-index:1}
.tl-ic{width:64px;height:64px;background:var(--noir);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;border:3px solid var(--creme);position:relative}
.tl-ic svg{width:24px;height:24px;stroke:var(--rouge)}
.tl-ic .tl-dot{position:absolute;top:-4px;right:-4px;width:14px;height:14px;border-radius:50%;background:#4ade80;border:2px solid var(--creme);animation:pulse 2.5s infinite}
.tl-num{font-size:10px;font-weight:700;color:var(--rouge);letter-spacing:.18em;text-transform:uppercase;text-align:center;margin-bottom:.5rem}
.tl-tit{font-size:14px;font-weight:700;color:var(--encre);text-align:center;margin-bottom:.4rem;letter-spacing:-.01em}
.tl-tx{font-size:12px;color:var(--t3l);line-height:1.65;text-align:center}
@media(max-width:960px){.tl-steps{grid-template-columns:repeat(2,1fr)}.tl-steps::before{display:none}}
@media(max-width:640px){.tl-steps{grid-template-columns:1fr}.tl{padding:4rem 1.5rem}}
.idee{background:var(--noir);padding:7rem 3.5rem}
.idee-in{max-width:900px}
.idee-claim{font-size:clamp(2.2rem,5vw,4.5rem);font-weight:800;line-height:1.05;letter-spacing:-.04em;margin-bottom:3rem;color:var(--blanc)}
.idee-claim .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.58)}
.idee-claim .red{color:var(--rouge)}
.idee-claim em{font-style:normal;-webkit-text-stroke:1.5px rgba(255,255,255,.45);color:transparent}
.idee-body{font-size:16px;color:var(--t3);line-height:1.85;max-width:640px;margin-bottom:2rem}
.idee-proof{font-size:14px;color:var(--t3);border-left:2px solid rgba(255,49,49,.4);padding-left:1.25rem;line-height:1.8;font-style:italic;max-width:560px;margin-top:2rem}
.pq{background:var(--blanc);padding:6rem 3.5rem}
.pq-wrap{max-width:1200px;margin:0 auto}
.pq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(26,26,26,.08);border:1px solid var(--rule-l);margin-top:4rem}
.pq-it{padding:2.75rem 2.5rem;background:var(--blanc);transition:background .2s;text-decoration:none;color:inherit;display:block}
.pq-it:hover{background:var(--creme)}
.pq-num{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,49,49,.45);margin-bottom:1.25rem}
.pq-tit{font-size:1.15rem;font-weight:800;color:var(--encre);margin-bottom:.75rem;letter-spacing:-.02em}
.pq-pain{font-size:13px;color:rgba(26,26,26,.5);line-height:1.7;margin-bottom:1.25rem;font-style:italic;border-left:2px solid rgba(255,49,49,.2);padding-left:.85rem}
.pq-sol{font-size:14px;color:var(--t3l);line-height:1.75}
.pq-sol strong{color:var(--encre);font-weight:600}
.pq-arrow{display:inline-flex;align-items:center;gap:4px;margin-top:1rem;font-size:11px;font-weight:700;color:var(--rouge);letter-spacing:.06em;text-transform:uppercase}
@media(max-width:960px){.pq-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.pq{padding:4rem 1.5rem}.pq-grid{grid-template-columns:1fr}}
/* ── NOS SERVICES ── */
.sv{background:var(--creme);padding:7rem 3.5rem}
.sv-wrap{max-width:1200px;margin:0 auto}
.sv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:4rem}
.sv-card{background:var(--blanc);border:1px solid rgba(26,26,26,.08);border-radius:6px;padding:2.25rem;position:relative;transition:box-shadow .2s}
.sv-card:hover{box-shadow:0 6px 30px rgba(26,26,26,.08)}
.sv-card.new::before{content:'NOUVEAU';position:absolute;top:1.25rem;right:1.25rem;font-size:9px;font-weight:700;letter-spacing:.18em;color:var(--blanc);background:var(--rouge);padding:.2rem .5rem;border-radius:2px}
.sv-icon{width:40px;height:40px;border-radius:6px;background:rgba(255,49,49,.07);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.sv-icon svg{width:20px;height:20px;stroke:var(--rouge);fill:none;stroke-width:2}
.sv-tit{font-size:1.05rem;font-weight:800;color:var(--encre);margin-bottom:.5rem;letter-spacing:-.02em}
.sv-desc{font-size:13px;color:var(--t3l);line-height:1.75;margin-bottom:1.25rem}
.sv-price{font-size:12px;font-weight:700;color:var(--rouge);letter-spacing:.04em;border-top:1px solid rgba(26,26,26,.07);padding-top:.85rem;margin-top:auto}
.sv-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(26,26,26,.35);background:rgba(26,26,26,.05);border-radius:2px;padding:.2rem .5rem;margin-bottom:.75rem}
@media(max-width:960px){.sv-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.sv{padding:4rem 1.5rem}.sv-grid{grid-template-columns:1fr}}
.cm{background:var(--noir);padding:7rem 3.5rem}
.cm-wrap{max-width:1200px;margin:0 auto}
.cm-split{display:grid;grid-template-columns:1fr 1fr;gap:6rem;margin-top:4rem;align-items:start}
.cm-steps{display:flex;flex-direction:column;gap:0}
.cm-step{display:grid;grid-template-columns:52px 1fr;gap:1.75rem;padding:2rem 0;border-bottom:1px solid var(--rule)}
.cm-step:first-child{border-top:1px solid var(--rule)}
.cs-n{font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,49,49,.5);padding-top:.1rem}
.cs-t{font-size:1.15rem;font-weight:800;color:var(--blanc);margin-bottom:.6rem;letter-spacing:-.02em;line-height:1.2}
.cs-t .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.55)}
.cs-b{font-size:14px;color:var(--t3);line-height:1.8}
.ec-preview{background:rgba(255,255,255,.02);border:1px solid var(--rule);border-radius:8px;padding:1.5rem;position:relative;overflow:hidden}
.ec-preview::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--rouge),rgba(53,71,75,.4),transparent)}
.ec-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--rule)}
.ec-logo{font-size:10px;font-weight:700;letter-spacing:.2em;color:#fff;text-transform:uppercase}
.ec-logo sup{color:var(--rouge);font-size:8px;margin-left:2px}
.ec-block{font-family:'Courier New',monospace;font-size:9px;color:rgba(255,49,49,.45)}
.ec-hero{font-size:2.5rem;font-weight:800;letter-spacing:-.04em;color:#fff;line-height:1;margin-bottom:.25rem}
.ec-hero .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.35);font-size:.7em}
.ec-hlbl{font-size:10px;color:var(--t4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1.25rem}
.ec-prog{height:3px;background:rgba(255,255,255,.06);border-radius:2px;margin-bottom:1.5rem;overflow:hidden}
.ec-prog-fill{height:100%;width:0;background:linear-gradient(90deg,var(--vert),rgba(74,180,100,.5));border-radius:2px;animation:progFill 2.5s ease 1s forwards}
@keyframes progFill{to{width:93.7%}}
.ec-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin-bottom:1.25rem}
.ec-card{background:rgba(255,255,255,.03);border:1px solid var(--rule);border-radius:4px;padding:.75rem}
.ec-card-v{font-size:1.1rem;font-weight:800;letter-spacing:-.02em}
.ec-card-l{font-size:9px;color:var(--t4);text-transform:uppercase;letter-spacing:.06em;margin-top:.15rem}
.ec-row{display:flex;align-items:center;gap:.75rem;padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.03)}
.ec-row:last-child{border:none}
.ec-dot{width:4px;height:4px;border-radius:50%;background:rgba(255,49,49,.5);flex-shrink:0}
.ec-ln{height:6px;background:rgba(255,255,255,.06);border-radius:2px;flex:1}
.ec-tag{height:14px;width:44px;background:rgba(255,49,49,.1);border-radius:2px;flex-shrink:0}
.ec-tag.g{background:rgba(74,180,100,.15)}
.ec-cap{font-size:10px;color:var(--t4);text-align:center;margin-top:1rem;letter-spacing:.06em;text-transform:uppercase}
@media(max-width:960px){.cm-split{grid-template-columns:1fr;gap:3rem}}
.ql{background:var(--creme);padding:7rem 3.5rem}
.ql-wrap{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}
.ql-items{display:flex;flex-direction:column;gap:0}
.ql-it{padding:1.75rem 0;border-bottom:1px solid var(--rule-l);opacity:0;transform:translateY(14px);transition:opacity .65s,transform .65s}
.ql-it.v{opacity:1;transform:none}
.ql-it:first-child{border-top:1px solid var(--rule-l)}
.qi-t{font-size:15px;font-weight:700;color:var(--encre);margin-bottom:.5rem;letter-spacing:-.02em}
.qi-b{font-size:14px;color:var(--t3l);line-height:1.75}
.qi-tag{display:inline-block;margin-top:.6rem;border:1px solid rgba(26,26,26,.12);border-radius:2px;padding:2px 8px;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--t4l)}
.qi-tag.g{border-color:rgba(53,71,75,.3);color:rgba(53,71,75,.6)}
.ql-seal{background:var(--blanc);border:1px solid var(--rule-l);border-radius:8px;padding:2rem;margin-top:2rem;position:relative;overflow:hidden}
.seal-hdr{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}
.seal-dot{width:10px;height:10px;border-radius:50%;background:#4ade80;animation:pulse 2s infinite}
.seal-lbl{font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:rgba(26,26,26,.5);font-weight:700}
.seal-hash{font-family:'Courier New',monospace;font-size:11px;color:rgba(26,26,26,.6);line-height:2;display:block}
.seal-hash strong{color:var(--rouge);font-weight:normal}
.seal-pct{font-size:3rem;font-weight:800;letter-spacing:-.05em;color:var(--encre);line-height:1;margin-top:1rem;margin-bottom:.25rem}
.seal-pct .thin{font-weight:300;font-style:italic;color:rgba(26,26,26,.4);font-size:.7em}
.seal-cap{font-size:12px;color:var(--t4l)}
@media(max-width:960px){.ql-wrap{grid-template-columns:1fr;gap:3rem}}
@media(max-width:640px){.ql{padding:4rem 1.5rem}}
.cc{background:var(--blanc);padding:6rem 3.5rem}
.cc-wrap{max-width:1200px;margin:0 auto}
.cc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(26,26,26,.08);border:1px solid var(--rule-l);margin-top:3rem}
.cc-card{padding:2rem;background:var(--blanc)}
.cc-tag{display:inline-block;background:rgba(255,49,49,.08);color:var(--rouge);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:2px 8px;border-radius:3px;margin-bottom:1rem}
.cc-v{font-size:1.6rem;font-weight:800;letter-spacing:-.04em;color:var(--encre);line-height:1;margin-bottom:.4rem}
.cc-ct{font-size:14px;font-weight:700;color:var(--encre);margin-bottom:.5rem;letter-spacing:-.01em}
.cc-desc{font-size:13px;color:var(--t3l);line-height:1.7}
.cc-cta-row{text-align:center;margin-top:2.5rem}
@media(max-width:640px){.cc{padding:4rem 1.5rem}.cc-grid{grid-template-columns:1fr}}
.cta-f{background:var(--noir);padding:6rem 3.5rem;text-align:center}
.cta-f-t{font-size:clamp(2rem,4vw,3.4rem);font-weight:800;letter-spacing:-.04em;color:var(--blanc);line-height:1.05;margin-bottom:.5rem}
.cta-f-t .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.55)}
.cta-f-s{font-size:16px;color:var(--t3);line-height:1.7;max-width:520px;margin:0 auto 2.5rem}
.form-sec{background:var(--noir);padding:5rem 3.5rem}
.form-wrap{max-width:640px;margin:0 auto}
.form-h{text-align:center;margin-bottom:3rem}
.form-h h2{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;letter-spacing:-.04em;color:#fff;line-height:1.05}
.form-h h2 .thin{font-weight:300;font-style:italic;color:rgba(255,255,255,.55)}
.form-prog{background:rgba(255,255,255,.07);height:2px;border-radius:2px;margin-bottom:2.5rem;overflow:hidden}
.form-prog-fill{height:100%;background:var(--rouge);width:33%;transition:width .4s}
@media(max-width:640px){.form-sec,.cta-f,.cm,.idee{padding:4rem 1.5rem}}

/* Services grid */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin:14px 0}
.svc-opt{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border:1px solid var(--rule);border-radius:10px;cursor:pointer;background:transparent;transition:all .2s}
.svc-opt:hover{border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.03)}
.svc-opt input[type=checkbox]{accent-color:var(--rouge);margin-top:3px;flex-shrink:0;width:16px;height:16px}
.svc-opt:has(input:checked){border-color:var(--rouge);background:rgba(255,49,49,.06)}
.svc-opt strong{display:block;color:#fff;font-weight:600;font-size:13.5px;letter-spacing:-.01em}
.svc-opt small{display:block;color:var(--t2);font-size:11.5px;margin-top:2px}

/* Eclaircir le rendu visuel global (demande user) */
section.hero .lines-bg{opacity:.4}
section.hero{background:linear-gradient(180deg,#0f0f12 0%,#0A0A0B 100%)}
.hero-title{color:#fff}
.hero-sub{color:rgba(255,255,255,.85)}
.hero-line.hero-line-2,.hero-line.hero-line-3{opacity:.55!important}
img,.hero-visual,.hero-img{filter:brightness(1.25) contrast(1.05)}
img.hero-visual,picture.hero-visual img{box-shadow:0 18px 60px rgba(255,49,49,.08);border-radius:16px}
/* Helpers pour ajouter facilement des images partout */
.section-img{display:block;width:100%;height:auto;border-radius:14px;filter:brightness(1.18) saturate(1.05);box-shadow:0 12px 40px rgba(0,0,0,.45)}
.img-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:24px 0}
.img-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:24px 0}
@media(max-width:780px){.img-grid-3{grid-template-columns:1fr 1fr}.img-grid-2{grid-template-columns:1fr}}

/* Hide custom Adomi widget (replaced by native HubSpot Chat) */

/* === END front-page header CSS === */

/* === Article breadcrumb separators (fix for single-post.php) === */
.a-crumb{display:flex;flex-wrap:wrap;align-items:center;gap:.5em;font-size:.85rem}
.a-crumb>*:not(:last-child)::after{content:"\203A";margin-left:.5em;color:rgba(255,255,255,.3);display:inline-block}
.a-crumb a{transition:color .15s ease}
.a-crumb a:hover{color:#fff}
@media(max-width:640px){.a-crumb{font-size:.75rem;gap:.35em}.a-crumb>*:not(:last-child)::after{margin-left:.35em}}

/* === ADOMOS REVAMP MOBILE === */

/* 1. Kill old Adomia chat widgets globally */
.adomi-bubble, .adomi-panel, #adomiaBubble, #adomiPanel { display: none !important; }

/* 2. New global RDV CTA (bottom-right, mobile + desktop) */
.rdv-cta { position: fixed; bottom: 20px; right: 20px; z-index: 9999; display: inline-flex; align-items: center; gap: .5em; padding: 14px 22px; background: linear-gradient(135deg, #FF3131, #d32626); color: #fff !important; border: none; border-radius: 999px; font-family: inherit; font-weight: 700; font-size: .92rem; letter-spacing: .02em; cursor: pointer; box-shadow: 0 8px 28px rgba(255,49,49,.35); text-decoration: none; transition: transform .15s ease, box-shadow .15s ease; }
.rdv-cta:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(255,49,49,.45); }
.rdv-cta svg { width: 16px; height: 16px; flex-shrink: 0; }
@media (max-width: 640px) { .rdv-cta { bottom: 16px; right: 16px; padding: 12px 18px; font-size: .85rem; } }

/* 3. Mobile menu sub-items (Pour qui > Secteurs) */
.mnav .mn-sub { display: flex; flex-direction: column; gap: .25rem; padding: .5rem 0 1.25rem 1rem; margin: -.4rem 0 .5rem; border-left: 2px solid rgba(255,49,49,.4); }
.mnav .mn-sub-title { font-size: 10px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,49,49,.7); padding-left: .75rem; padding-bottom: .5rem; }
.mnav .mn-sublink { font-size: 1rem; font-weight: 500; color: rgba(255,255,255,.78); text-decoration: none; padding: .55rem .75rem; border-radius: 8px; transition: background .15s ease, color .15s ease; }
.mnav .mn-sublink:hover, .mnav .mn-sublink:focus { color: #fff; background: rgba(255,255,255,.05); }

/* 4. Cas-Clients mobile fixes */
@media (max-width: 640px) {
  .cc-hero { padding: 5rem 1.25rem 2.5rem !important; }
  .cc-hero h1 { font-size: 2rem !important; }
  .cc-hero p { font-size: .92rem !important; }
  .cc-filters-bar { padding: 0 1rem; margin: 1.5rem 0 1.5rem; }
  .cc-filters { display: flex; flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; gap: .5rem; padding-bottom: .5rem; }
  .cc-filters::-webkit-scrollbar { display: none; }
  .cc-filters .fpill { flex-shrink: 0; white-space: nowrap; padding: .5rem 1rem; font-size: .8rem; }
  .cc-cta { margin-top: 2.5rem; }
}

/* 5. Section 5 etapes mobile */
@media (max-width: 640px) {
  .cm-split { gap: 2rem !important; margin-top: 2rem !important; }
  .cm-step { padding: 1.5rem 0 !important; grid-template-columns: 32px 1fr !important; gap: 1rem !important; }
  .cm-step > * { min-width: 0; }
  .cm-step .cs-t, .cm-step .cs-b { word-break: break-word; overflow-wrap: anywhere; }
  .cs-t { font-size: 1rem !important; line-height: 1.3 !important; }
  .cs-b { font-size: .88rem !important; line-height: 1.45 !important; margin-top: .35rem; }
}

/* 6. Mobile menu polish */
.mnav { padding-top: 4.5rem !important; padding-left: 1.75rem !important; padding-right: 1.75rem !important; overflow-y: auto !important; }
.mnav .mn-link { font-size: 1.25rem !important; padding: .5rem 0; display: block; }
.mnav .mn-item { width: 100%; }

/* === ADOMOS BASE MNAV (global, for landing-sector and any template missing inline mnav CSS) === */
.burger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 4px; background: none; border: none; }
.burger span { display: block; width: 22px; height: 1px; background: #fff; transition: all .3s; }
.burger.open span:nth-child(1) { transform: rotate(45deg) translate(4px, 4px); }
.burger.open span:nth-child(2) { opacity: 0; }
.burger.open span:nth-child(3) { transform: rotate(-45deg) translate(4px, -4px); }
@media (max-width: 960px) {
  .nav { display: none !important; }
  .burger { display: flex !important; }
}
.mnav { display: none; position: fixed; inset: 0; z-index: 190; background: rgba(13,13,13,.98); backdrop-filter: blur(20px); flex-direction: column; align-items: flex-start; justify-content: flex-start; }
.mnav.open { display: flex; }
.mnav .mn-item { width: 100%; border-bottom: 1px solid rgba(255,255,255,.08); }
.mnav .mn-link { color: #fff; text-decoration: none; font-weight: 600; }

/* === ADOMOS UX V2 === */

/* Mobile menu - clean UX (mobile only) */
@media (max-width: 960px) {
  .nav, .hdr-top, .hdr-cta { display: none !important; }
  .burger { display: flex !important; }
  .mnav { background: #0a0a0b !important; padding: 5rem 1.5rem 7rem !important; align-items: stretch !important; justify-content: flex-start !important; z-index: 9990 !important; overflow-y: auto !important; }
  .mnav button[onclick*="closeMNav"] { position: absolute !important; top: 1.1rem !important; right: 1.1rem !important; width: 44px !important; height: 44px !important; padding: 0 !important; display: grid !important; place-items: center !important; background: rgba(255,255,255,.06) !important; border: 1px solid rgba(255,255,255,.1) !important; border-radius: 50% !important; font-size: 0 !important; color: transparent !important; }
  .mnav button[onclick*="closeMNav"]::before { content: '\d7' !important; font-size: 26px !important; line-height: 1 !important; color: #fff !important; }
  .mnav .mn-item { width: 100% !important; border: none !important; border-bottom: 1px solid rgba(255,255,255,.06) !important; padding: 0 !important; }
  .mnav .mn-link { display: block !important; padding: 1.05rem .5rem !important; font-size: 1.1rem !important; font-weight: 600 !important; color: #fff !important; text-decoration: none !important; letter-spacing: -.01em !important; }
  .mnav .mn-link:active { color: #FF3131 !important; }
  .mnav .mn-sub { display: flex !important; flex-direction: column !important; padding: .25rem 0 1rem 1rem !important; margin: -.25rem 0 0 .25rem !important; border: none !important; border-left: 2px solid #FF3131 !important; border-bottom: 1px solid rgba(255,255,255,.06) !important; gap: 0 !important; }
  .mnav .mn-sub-title { font-size: 9px !important; font-weight: 700 !important; letter-spacing: .16em !important; text-transform: uppercase !important; color: #FF3131 !important; padding: .6rem .75rem .25rem !important; }
  .mnav .mn-sublink { display: block !important; padding: .65rem .75rem !important; font-size: .95rem !important; font-weight: 500 !important; color: rgba(255,255,255,.78) !important; text-decoration: none !important; border-radius: 6px !important; }
}

/* Section comment ca marche - force stack on mobile */
@media (max-width: 760px) {
  .cm-split { grid-template-columns: 1fr !important; gap: 1.5rem !important; margin-top: 1.5rem !important; }
  .cm-stepper { width: 100% !important; max-width: 100% !important; }
  .cm-stepper-dots { padding: 0 !important; gap: .5rem !important; }
  .cm-steps { width: 100% !important; max-width: 100% !important; }
  .cm-step { grid-template-columns: 28px 1fr !important; gap: .85rem !important; padding: 1.1rem 0 !important; }
  .cm-step > * { min-width: 0 !important; }
  .cs-n { font-size: 9px !important; padding-top: .15rem !important; }
  .cs-t { font-size: .98rem !important; line-height: 1.3 !important; word-break: break-word !important; overflow-wrap: anywhere !important; }
  .cs-t .thin { display: inline !important; }
  .cs-b { font-size: .85rem !important; line-height: 1.45 !important; margin-top: .35rem !important; word-break: break-word !important; overflow-wrap: anywhere !important; }
  .cm { padding: 3.5rem 1.25rem !important; }
}

/* Hide rdv-cta when mnav open */
body:has(.mnav.open) .rdv-cta { display: none !important; }

/* === HEADER MOBILE COMPACT === */
@media (max-width: 760px) {
  .hdr-main { padding: .65rem 1rem !important; min-height: 56px !important; }
  .hdr .wordmark { font-size: 1.05rem !important; }
  .hdr .wordmark sup { font-size: .55em !important; }
  .hdr.scrolled .hdr-main { padding: .5rem 1rem !important; }
  .burger { padding: 8px !important; }
}

/* === CM TYPO MATCH (align comment-ca-marche typography with .sv section) === */
.cm .cs-t, .qa .cs-t { font-size: 16px !important; font-weight: 700 !important; line-height: 1.4 !important; letter-spacing: -.005em !important; margin-bottom: .5rem !important; }
.cm .cs-b, .qa .cs-b { font-size: 16px !important; font-weight: 400 !important; line-height: 1.7 !important; }
.cm .cs-t .thin, .qa .cs-t .thin { font-weight: 400 !important; opacity: .85 !important; }
@media (max-width: 760px) {
  .cm .cs-t, .qa .cs-t { font-size: 15px !important; line-height: 1.35 !important; }
  .cm .cs-b, .qa .cs-b { font-size: 14.5px !important; line-height: 1.55 !important; margin-top: .35rem !important; }
  .cm-split { grid-template-columns: 1fr !important; gap: 1rem !important; }
  .cm-stepper, .cm-stepper-dots { display: none !important; }
  .cm-steps { width: 100% !important; }
  .cm-step { grid-template-columns: 32px 1fr !important; gap: .9rem !important; padding: 1.25rem 0 !important; }
  .cm-step > * { min-width: 0 !important; max-width: 100% !important; }
  .cm { padding: 3rem 1.25rem !important; overflow-x: hidden !important; }
  .cm-wrap { overflow-x: hidden !important; max-width: 100% !important; }
}

/* === HERO MOBILE COMPACT === */
@media (max-width: 760px) {
  .hero { min-height: auto !important; padding: 5.5rem 1.25rem 2.5rem !important; }
  .hero-title { margin-bottom: 1.25rem !important; }
  .hero-line { font-size: clamp(1.75rem, 8vw, 2.5rem) !important; line-height: 1.08 !important; }
  .hero-sub { font-size: 14.5px !important; line-height: 1.55 !important; margin: 0 0 1.5rem !important; max-width: 100% !important; }
  .hero-ctas { gap: .6rem !important; flex-wrap: wrap !important; }
  .a-hero, .cc-hero, [class*="hero"] { min-height: auto !important; }
}

/* === ADOMOS UX V3 === */

/* 1. KPI bars (.sb-it) - add breathing room on mobile so text not touching colored border */
@media (max-width: 760px) {
  .sb-row { display: flex !important; flex-direction: column !important; gap: 1.25rem !important; }
  .sb-it { padding-left: 1.1rem !important; padding-right: .25rem !important; }
  .sb-it .sb-trend, .sb-it .sb-v, .sb-it .sb-l { padding-left: 0 !important; }
  .sb { padding: 3rem 1.25rem !important; }
}

/* 2. Restore stepper dots on mobile (small, horizontal, above the steps) */
@media (max-width: 760px) {
  .cm-stepper, .cm-stepper-dots { display: flex !important; justify-content: flex-start !important; align-items: center !important; gap: .75rem !important; padding: 0 0 1.5rem !important; flex-wrap: wrap !important; }
  .cm-stepper-dot { display: inline-flex !important; flex-direction: column !important; align-items: center !important; gap: .35rem !important; min-width: auto !important; }
  .cm-stepper-dot .cs-bignum { width: 32px !important; height: 32px !important; font-size: 12px !important; line-height: 32px !important; border-radius: 50% !important; display: inline-grid !important; place-items: center !important; padding: 0 !important; }
  .cm-stepper-dot .cs-lbl { font-size: 8.5px !important; letter-spacing: .12em !important; }
}

/* 3. Article mobile - match modern desktop design */
@media (max-width: 760px) {
  .a-hero { padding: 5rem 1.25rem 2rem !important; min-height: auto !important; }
  .a-hero .a-title, .a-hero h1 { font-size: 1.85rem !important; line-height: 1.15 !important; }
  .a-hero p, .a-hero .a-sub { font-size: .95rem !important; line-height: 1.5 !important; }
  .a-cat { font-size: .8rem !important; }
  .a-meta { font-size: .75rem !important; flex-wrap: wrap !important; gap: .5rem !important; }
  .a-layout { padding: 2rem 1.25rem !important; gap: 2rem !important; grid-template-columns: 1fr !important; }
  .article-body { font-size: 16px !important; line-height: 1.65 !important; }
  .article-body h2 { font-size: 1.4rem !important; line-height: 1.25 !important; margin-top: 2rem !important; }
  .article-body h3 { font-size: 1.15rem !important; }
  .article-body p { font-size: 16px !important; line-height: 1.65 !important; }
  .article-hero-image img { width: 100% !important; height: auto !important; border-radius: 8px !important; }
  .a-side, .article-side { width: 100% !important; }
  .vb { padding: 2rem 1.25rem !important; }
  .vb img { max-height: 250px !important; width: 100% !important; object-fit: cover !important; }
}

/* === STEPS NUMBERS V4 (mobile only - desktop untouched) === */
@media (max-width: 760px) {
  /* Hide round stepper dots in cm + qa sections */
  .cm-stepper, .cm-stepper-dots, .cm-stepper-dot { display: none !important; }
  /* Tight section padding */
  .cm, .qa { padding: 2.5rem 1.25rem !important; }
  .cm-wrap, .qa-wrap { padding: 0 !important; }
  .cm-split { margin-top: 1.25rem !important; gap: 0 !important; }
  /* Bigger emphasized numbers next to text */
  .cm-step, .qa .cm-step { grid-template-columns: 44px 1fr !important; gap: .9rem !important; padding: 1.1rem 0 !important; align-items: baseline !important; }
  .cm .cs-n, .qa .cs-n { font-size: 22px !important; font-weight: 800 !important; line-height: 1 !important; letter-spacing: -.02em !important; color: #FF3131 !important; padding-top: .15rem !important; }
  .qa .cs-n { color: #FF3131 !important; }
  /* Step title and body */
  .cm .cs-t, .qa .cs-t { font-size: 17px !important; font-weight: 700 !important; line-height: 1.3 !important; margin-bottom: .35rem !important; }
  .cm .cs-b, .qa .cs-b { font-size: 15px !important; line-height: 1.55 !important; margin-top: 0 !important; }
}

/* === SB FIRST BAR (mobile - restore left bar on first KPI item) === */
@media (max-width: 760px) {
  .sb-it:first-child::before { display: block !important; }
  .sb-it { border-right: none !important; padding-left: 1.1rem !important; padding-right: 0 !important; }
  .sb-it:first-child { padding-left: 1.1rem !important; }
  .sb-it::before { content: "" !important; position: absolute !important; left: 0 !important; top: 0 !important; bottom: 0 !important; width: 3px !important; }
}

/* === EC DASHBOARD MOBILE === */
@media (max-width: 760px) {
  .ec-dashboard { width: 100% !important; max-width: 100% !important; min-width: 0 !important; margin: 1.5rem 0 0 !important; padding: 1rem !important; border-radius: 10px !important; overflow: hidden !important; box-sizing: border-box !important; }
  .ec-dashboard * { max-width: 100% !important; box-sizing: border-box !important; }
  .ec-d-head { flex-direction: column !important; align-items: flex-start !important; gap: .5rem !important; padding: 0 0 .75rem !important; }
  .ec-d-brand { font-size: 9px !important; letter-spacing: .14em !important; }
  .ec-d-user { font-size: 11px !important; }
  .ec-d-grid, .ec-d-cards, [class*="ec-d-grid"] { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: .5rem !important; }
  .ec-d-card, .ec-d-kpi, [class*="ec-d-card"] { padding: .65rem !important; font-size: 11px !important; }
  .ec-d-card .v, .ec-d-kpi .v, .ec-d-num { font-size: 1.1rem !important; }
  .ec-d-row, .ec-d-table { font-size: 11px !important; }
  .ec-d-table th, .ec-d-table td { padding: .35rem .25rem !important; }
  #espace-client { padding: 2.5rem 1.25rem !important; }
  #espace-client .cm-split { gap: 1rem !important; }
}

/* === MNAV ENRICHED V5 === */
@media (max-width: 960px) {
  .mnav { padding: 1.25rem 1.5rem 1.5rem !important; gap: 0 !important; }
  .mnav button[onclick*="closeMNav"] { top: 1rem !important; right: 1rem !important; }
  .mn-brand { padding: 1.5rem .25rem 1.5rem !important; border-bottom: 1px solid rgba(255,255,255,.08) !important; margin-bottom: .5rem !important; }
  .mn-brand-name { font-size: 1.4rem !important; font-weight: 800 !important; letter-spacing: -.02em !important; color: #fff !important; line-height: 1 !important; }
  .mn-brand-name sup { color: #FF3131 !important; font-size: .55em !important; font-weight: 700 !important; vertical-align: super !important; margin-left: 2px !important; letter-spacing: .04em !important; }
  .mn-brand-desc { margin-top: .65rem !important; font-size: .82rem !important; line-height: 1.45 !important; color: rgba(255,255,255,.55) !important; max-width: 90% !important; }
  .mn-foot { margin-top: 1.5rem !important; padding-top: 1.25rem !important; border-top: 1px solid rgba(255,255,255,.08) !important; display: flex !important; flex-direction: column !important; gap: .55rem !important; }
  .mn-cta { display: block !important; padding: .9rem 1rem !important; border-radius: 999px !important; text-align: center !important; font-weight: 700 !important; font-size: .92rem !important; text-decoration: none !important; transition: transform .15s ease !important; }
  .mn-cta.primary { background: linear-gradient(135deg, #FF3131, #d32626) !important; color: #fff !important; box-shadow: 0 4px 16px rgba(255,49,49,.3) !important; }
  .mn-cta.secondary { background: rgba(255,255,255,.06) !important; color: #fff !important; border: 1px solid rgba(255,255,255,.12) !important; }
  .mn-cta:active { transform: scale(.97) !important; }
  .mn-linkedin { align-self: center !important; margin-top: .75rem !important; width: 42px !important; height: 42px !important; display: grid !important; place-items: center !important; border-radius: 50% !important; background: rgba(255,255,255,.06) !important; color: rgba(255,255,255,.7) !important; transition: background .15s ease, color .15s ease !important; }
  .mn-linkedin:hover, .mn-linkedin:active { background: #0A66C2 !important; color: #fff !important; }
}

/* === HERO TIGHT V2 === */
@media (max-width: 760px) {
  .hero { min-height: auto !important; padding: 4rem 1.25rem 1.5rem !important; }
  .hero-title { margin-bottom: .9rem !important; }
  .hero-line { font-size: clamp(1.65rem, 7.5vw, 2.3rem) !important; line-height: 1.05 !important; white-space: normal !important; }
  .hero-sub { font-size: 14px !important; line-height: 1.5 !important; margin: 0 0 1.1rem !important; max-width: 100% !important; }
  .hero-ctas { gap: .55rem !important; flex-wrap: wrap !important; margin: 0 !important; }
  .hero-ctas a, .hero-ctas button { padding: .75rem 1.1rem !important; font-size: .85rem !important; }
  .hero .lines-bg { display: none !important; }
  .hero::after, .hero::before { display: none !important; }
}

/* === MOBILE COMPACT V6 (reduce home scroll) === */
@media (max-width: 760px) {
  /* Decorative lines hidden everywhere */
  .lines-bg { display: none !important; }
  /* Compact all major sections */
  section.sv, section.sb, section.cm, section.qa, section[class*="cc-"] { padding: 2.5rem 1.25rem !important; }
  /* Section titles smaller */
  section .label-anim { font-size: 10px !important; margin-bottom: .5rem !important; }
  section [style*="clamp(2rem"], section [style*="clamp(2.4rem"] { font-size: clamp(1.55rem, 7vw, 2.1rem) !important; line-height: 1.05 !important; margin-bottom: .15rem !important; }
  /* sb subtitle */
  .sb-sub { font-size: 14px !important; line-height: 1.45 !important; margin: .75rem 0 1.25rem !important; }
  /* CM/QA wrap & split tighter */
  .cm-wrap, .qa-wrap { padding: 0 !important; }
  .cm-split { margin-top: 1rem !important; }
  .cm-step { padding: .9rem 0 !important; }
  /* Espace dashboard mockup - hide on very narrow if too heavy */
  .ec-dashboard { margin-top: 1rem !important; padding: .75rem !important; font-size: 10px !important; }
  /* Hide secondary decorative bits */
  .sv-badge, .cm-badge, .qa-badge, [class*="-decoration"], .sv-illustration { display: none !important; }
  /* Form / acces section tighter */
  #form-acces, .acces-section, [id*="form"] { padding: 2rem 1.25rem !important; }
  /* Margin between sections collapsed */
  section + section { margin-top: 0 !important; }
  /* Footer compact */
  .ftr, footer { padding: 2rem 1.25rem !important; }
  .ftr-cols, [class*="ftr-grid"] { grid-template-columns: 1fr !important; gap: 1.25rem !important; }
}

/* === HOME MOBILE HIDE (home only) === */
@media (max-width: 760px) {
  body.home section.cc,
  body.home #espace-client { display: none !important; }
}

/* === HERO CENTER V3 (better vertical position on mobile) === */
@media (max-width: 760px) {
  .hero { min-height: calc(100vh - 56px) !important; justify-content: center !important; padding: 1.5rem 1.25rem !important; }
  .hero .label-anim { margin-bottom: .75rem !important; }
  .hero-title { margin-bottom: 1rem !important; }
}

/* === HERO SHORT V4 (no min-height, content-driven) === */
@media (max-width: 760px) {
  .hero { min-height: 0 !important; height: auto !important; padding: 1.5rem 1.25rem 2rem !important; justify-content: flex-start !important; }
  .hero::before, .hero::after { display: none !important; }
}

/* === MOBILE V7 === */
@media (max-width: 760px) {
  /* Footer compact */
  footer, .ftr, .site-footer { padding: 1.5rem 1rem 1rem !important; }
  footer .ftr-cols, footer [class*="grid"], footer [class*="cols"] { grid-template-columns: 1fr !important; gap: 1rem !important; }
  footer h3, footer h4, footer .ftr-title { font-size: .85rem !important; margin-bottom: .35rem !important; }
  footer ul, footer ol { padding-left: 0 !important; margin: 0 !important; }
  footer li, footer p, footer a { font-size: .82rem !important; line-height: 1.45 !important; }
  footer .ftr-bottom, footer .ftr-legal { font-size: .7rem !important; padding-top: .75rem !important; margin-top: .75rem !important; }
  /* Hide redundant secondary footers on /acces or pages with multiple footers */
  body.page-id-acces footer:nth-of-type(n+2),
  body[class*="page-template-acces"] footer:nth-of-type(n+2),
  footer + footer { display: none !important; }
  /* Hide back-to-home link "Accueil" on /acces page */
  body[class*="page-template-acces"] a[href="/"]:not(.wordmark):not(.mn-link),
  .acces-back-link, a.back-home { display: none !important; }
  /* Slider sector page KPI cards */
  .lp-mockup-kpis, .lp-svc-grid, .lp-adv-grid { display: flex !important; overflow-x: auto !important; scroll-snap-type: x mandatory !important; gap: .75rem !important; padding: 0 .25rem !important; -webkit-overflow-scrolling: touch !important; scrollbar-width: none !important; grid-template-columns: none !important; }
  .lp-mockup-kpis::-webkit-scrollbar, .lp-svc-grid::-webkit-scrollbar, .lp-adv-grid::-webkit-scrollbar { display: none !important; }
  .lp-mockup-kpi, .lp-svc-card, .lp-adv-card { flex: 0 0 78% !important; scroll-snap-align: start !important; min-width: 0 !important; }
}

/* === HEADER FIX FINAL (mobile only - definitive) === */
@media (max-width: 760px) {
  .hdr { background: #0a0a0b !important; border-bottom: 1px solid rgba(255,255,255,.06) !important; position: fixed !important; top: 0 !important; left: 0 !important; right: 0 !important; z-index: 100 !important; }
  .hdr-main { padding: .65rem 1rem !important; min-height: 56px !important; }
  .hero, .a-hero, .cc-hero, .lp-hero, .acces-hero, main > section:first-of-type { padding-top: 5.5rem !important; }
  .hero { min-height: 0 !important; height: auto !important; padding: 5.5rem 1.25rem 2rem !important; justify-content: flex-start !important; }
}

/* === MNAV TIGHT V8 (compact menu, less scroll) === */
@media (max-width: 760px) {
  .mnav { padding: 4.25rem 1.25rem 1.25rem !important; gap: 0 !important; }
  /* Brand block - tighter */
  .mn-brand { padding: 0 .25rem .9rem !important; margin-bottom: .5rem !important; border-bottom: 1px solid rgba(255,255,255,.06) !important; }
  .mn-brand-name { font-size: 1.15rem !important; }
  .mn-brand-desc { font-size: .75rem !important; line-height: 1.35 !important; margin-top: .35rem !important; max-width: 100% !important; }
  /* Items - tighter rows */
  .mnav .mn-item { border-bottom: 1px solid rgba(255,255,255,.05) !important; }
  .mnav .mn-link { padding: .65rem .25rem !important; font-size: 1rem !important; line-height: 1.2 !important; }
  /* Secteurs sub-list - more compact */
  .mnav .mn-sub { padding: .25rem 0 .65rem .85rem !important; margin: -.15rem 0 0 .15rem !important; }
  .mnav .mn-sub-title { font-size: 8.5px !important; padding: .35rem .65rem .15rem !important; }
  .mnav .mn-sublink { padding: .42rem .65rem !important; font-size: .88rem !important; line-height: 1.2 !important; }
  /* Footer CTAs - tighter */
  .mn-foot { margin-top: .9rem !important; padding-top: .85rem !important; gap: .5rem !important; }
  .mn-cta { padding: .75rem .9rem !important; font-size: .88rem !important; }
  .mn-linkedin { width: 38px !important; height: 38px !important; margin-top: .5rem !important; }
  /* Close btn smaller */
  .mnav button[onclick*="closeMNav"] { width: 38px !important; height: 38px !important; top: .85rem !important; right: .85rem !important; }
  .mnav button[onclick*="closeMNav"]::before { font-size: 22px !important; }
}

/* === HERO LOGO V9 === */
@media (max-width: 760px) {
  /* Hero - title centered vertically over image */
  .hero { min-height: 65vh !important; height: auto !important; padding: 5.5rem 1.25rem 2rem !important; justify-content: center !important; }
  /* Logo in mnav matches .wordmark exactly (uppercase, letter-spacing, sup red) */
  .mn-brand-name { font-size: 13px !important; font-weight: 700 !important; letter-spacing: .22em !important; text-transform: uppercase !important; color: #fff !important; line-height: 1 !important; }
  .mn-brand-name sup { font-size: 9px !important; font-weight: 500 !important; letter-spacing: .1em !important; color: #FF3131 !important; vertical-align: super !important; margin-left: 3px !important; }
}

/* === FOOTER CLEAN V10 (global) === */
.ft-bot .ft-leg, footer .ft-leg { display: none !important; }
.ft-bot { justify-content: center !important; padding: 1rem 0 !important; }
.ft-bot .ft-copy { text-align: center !important; opacity: .5 !important; }
@media (max-width: 760px) {
  footer, .ftr { padding: 1.5rem 1rem .75rem !important; }
  .ft-cols, footer [class*="grid"] { grid-template-columns: 1fr !important; gap: 1rem !important; }
  .ft-ht { font-size: .8rem !important; margin-bottom: .35rem !important; }
  .ft-lks a { font-size: .82rem !important; padding: .15rem 0 !important; display: block !important; }
  .ft-bot { padding: .75rem 0 0 !important; margin-top: 1rem !important; }
  .ft-copy { font-size: .65rem !important; line-height: 1.4 !important; }
}

/* === HERO CENTER FINAL (mobile only) === */
@media (max-width: 760px) {
  .hero { display: flex !important; flex-direction: column !important; justify-content: center !important; align-items: flex-start !important; min-height: 100vh !important; height: 100vh !important; padding: 56px 1.25rem 0 !important; box-sizing: border-box !important; }
  .hero > * { width: 100% !important; }
  /* All other first sections - keep simple top padding */
  main > section:first-of-type:not(.hero), .a-hero:first-of-type, .cc-hero:first-of-type, .lp-hero:first-of-type { padding-top: 5.5rem !important; }
}

/* === SLIDERS V11 (mobile horizontal scroll-snap, desktop untouched) === */
@media (max-width: 760px) {
  /* Generic slider strip behavior */
  .sb-row, .sv-grid, .cc-grid, .lp-mockup-kpis, .lp-svc-grid, .lp-adv-grid, .ftr-grid-clients, [class*="-cards-strip"] {
    display: flex !important;
    flex-direction: row !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    gap: .75rem !important;
    padding: .25rem .5rem 1.5rem !important;
    margin: 0 -1.25rem !important;
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
    grid-template-columns: none !important;
    scroll-padding-left: 1.25rem !important;
  }
  .sb-row::-webkit-scrollbar, .sv-grid::-webkit-scrollbar, .cc-grid::-webkit-scrollbar,
  .lp-mockup-kpis::-webkit-scrollbar, .lp-svc-grid::-webkit-scrollbar, .lp-adv-grid::-webkit-scrollbar { display: none !important; height: 0 !important; }
  /* Cards inside sliders */
  .sb-it, .sv-card, .cc-card, .lp-mockup-kpi, .lp-svc-card, .lp-adv-card {
    flex: 0 0 78% !important;
    scroll-snap-align: start !important;
    min-width: 0 !important;
    max-width: 78% !important;
    box-sizing: border-box !important;
  }
  /* KPI bars : keep colored left bar, padding tight */
  .sb-it { padding: 1rem 1rem 1rem 1.1rem !important; border-right: none !important; background: rgba(255,255,255,.02) !important; border-radius: 8px !important; }
  .sb-it::before { width: 3px !important; border-radius: 0 4px 4px 0 !important; }
  .sb-it .sb-v { font-size: 2rem !important; line-height: 1.05 !important; }
  .sb-it .sb-trend { font-size: 9.5px !important; }
  .sb-it .sb-l { font-size: 12.5px !important; line-height: 1.4 !important; }
  /* Hint subtle "swipe" indicator using scrollbar visual */
  .sb-row, .sv-grid, .cc-grid, .lp-mockup-kpis, .lp-svc-grid, .lp-adv-grid { scroll-behavior: smooth !important; }
  /* Section padding tweak so slider edges align */
  .sb, .sv, .cm, .qa { padding-left: 1.25rem !important; padding-right: 1.25rem !important; }
}

/* === DEDUP MNAV V12 === */
#mnav ~ #mnav, .mnav + .mnav { display: none !important; }

/* === SECTOR PAGE COMPACT V13 (mobile) === */
@media (max-width: 760px) {
  .lp-hero, .lp-args, .lp-services, .lp-audience, .lp-how, .lp-adv, .lp-space, .lp-mockup { padding: 2.25rem 1.25rem !important; }
  .lp-h-title, .lp-args-title { font-size: 1.55rem !important; line-height: 1.1 !important; margin-bottom: .35rem !important; }
  .lp-h-label, .lp-args-eyebrow { font-size: 10px !important; margin-bottom: .35rem !important; }
  .lp-h-thin { font-size: .95rem !important; }
  .lp-sub, .lp-svc-intro, .lp-aud-intro { font-size: 14px !important; line-height: 1.5 !important; margin: .5rem 0 1rem !important; }
  .lp-args-in, .lp-segs-grid, .lp-how-grid, .lp-adv-in, .lp-space-list {
    display: flex !important; flex-direction: row !important; overflow-x: auto !important; overflow-y: visible !important;
    scroll-snap-type: x mandatory !important; -webkit-overflow-scrolling: touch !important; scrollbar-width: none !important;
    gap: .65rem !important; padding: .25rem 1.25rem 1rem !important; margin: 0 -1.25rem !important;
    grid-template-columns: none !important; scroll-padding-left: 1.25rem !important; scroll-behavior: smooth !important;
  }
  .lp-args-in::-webkit-scrollbar, .lp-segs-grid::-webkit-scrollbar, .lp-how-grid::-webkit-scrollbar, .lp-adv-in::-webkit-scrollbar, .lp-space-list::-webkit-scrollbar { display: none !important; height: 0 !important; }
  .lp-arg-k, .lp-seg, .lp-how-step, .lp-space-it { flex: 0 0 78% !important; scroll-snap-align: start !important; min-width: 0 !important; max-width: 78% !important; box-sizing: border-box !important; }
  .lp-seg, .lp-how-step, .lp-space-it { background: rgba(255,255,255,.03) !important; border: 1px solid rgba(255,255,255,.06) !important; border-radius: 10px !important; padding: 1rem !important; }
  .lp-arg-k { background: rgba(255,255,255,.02) !important; padding: .9rem 1rem !important; border-radius: 8px !important; }
  .lp-arg-v { font-size: 1.6rem !important; line-height: 1.05 !important; }
  .lp-arg-t { font-size: 12px !important; line-height: 1.4 !important; margin-top: .35rem !important; }
  .lp-hero .lines-bg, .lp-services .lines-bg, .lp-args .lines-bg, .lp-mockup .lines-bg { display: none !important; }
  .lp-aud-needs { gap: .75rem !important; margin-top: 1rem !important; }
  .lp-aud-need { padding: 1rem !important; border-radius: 10px !important; }
  .lp-aud-need-l { font-size: 11px !important; }
  .lp-aud-need-p { font-size: 13.5px !important; line-height: 1.5 !important; }
  .lp-mockup-rows { display: none !important; }
  .lp-svc-card { padding: 1rem !important; border-radius: 10px !important; }
  .lp-svc-h { font-size: 14.5px !important; line-height: 1.25 !important; }
  .lp-svc-d { font-size: 12.5px !important; line-height: 1.45 !important; }
  .lp-adv-num { font-size: 18px !important; }
  .lp-adv-t { font-size: 14px !important; }
  .lp-adv-d { font-size: 12.5px !important; line-height: 1.45 !important; }
}

/* === FULL MOBILE PASS V14 === */
@media (max-width: 760px) {
  .sv-grid { display: flex !important; flex-direction: row !important; overflow-x: auto !important; scroll-snap-type: x mandatory !important; -webkit-overflow-scrolling: touch !important; scrollbar-width: none !important; gap: .65rem !important; padding: .25rem 1.25rem 1rem !important; margin: 0 -1.25rem !important; grid-template-columns: none !important; scroll-padding-left: 1.25rem !important; }
  .sv-grid::-webkit-scrollbar { display: none !important; }
  .sv-card { flex: 0 0 78% !important; scroll-snap-align: start !important; min-width: 0 !important; max-width: 78% !important; padding: 1.25rem !important; box-sizing: border-box !important; }
  .sv-tit { font-size: 1rem !important; }
  .sv-card p { font-size: 13px !important; line-height: 1.5 !important; }
  .cro-row, .cro-form-card { padding: 1rem !important; }
  .cc-stats-grid { display: flex !important; flex-direction: row !important; overflow-x: auto !important; scroll-snap-type: x mandatory !important; -webkit-overflow-scrolling: touch !important; scrollbar-width: none !important; gap: .65rem !important; padding: .25rem 1.25rem 1rem !important; margin: 0 -1.25rem !important; grid-template-columns: none !important; }
  .cc-stats-grid::-webkit-scrollbar { display: none !important; }
  .cc-stats-grid > * { flex: 0 0 65% !important; scroll-snap-align: start !important; min-width: 0 !important; max-width: 65% !important; box-sizing: border-box !important; padding: 1rem !important; }
  .cc-stats-eyebrow { font-size: 9px !important; }
  .cc-stats-grid h3, .cc-stats-grid .cc-stats-v { font-size: 1.6rem !important; line-height: 1.05 !important; }
  .cc-stats-grid p { font-size: 11.5px !important; line-height: 1.4 !important; }
  .a-similar-in { display: flex !important; flex-direction: row !important; overflow-x: auto !important; scroll-snap-type: x mandatory !important; -webkit-overflow-scrolling: touch !important; scrollbar-width: none !important; gap: .65rem !important; padding: .25rem 1.25rem 1rem !important; margin: 0 -1.25rem !important; grid-template-columns: none !important; }
  .a-similar-in::-webkit-scrollbar { display: none !important; }
  .a-similar-in > * { flex: 0 0 78% !important; scroll-snap-align: start !important; min-width: 0 !important; max-width: 78% !important; box-sizing: border-box !important; }
  .a-nl-in { padding: 1.5rem 1rem !important; }
  .a-nl-in h3, .a-nl-in h2 { font-size: 1.2rem !important; line-height: 1.2 !important; }
  .a-nl-in p { font-size: 13px !important; }
  .a-nl-in form, .a-nl form { display: flex !important; flex-direction: column !important; gap: .5rem !important; }
  .a-nl-in input, .a-nl-in button { width: 100% !important; }
  .a-side { margin-top: 2rem !important; padding: 1rem !important; }
  .cro-form-card, .ame-card { padding: 1rem !important; border-radius: 10px !important; }
  .bl-grid { display: flex !important; flex-direction: column !important; gap: 1rem !important; padding: 0 !important; grid-template-columns: 1fr !important; }
  .bl-card { padding: 1rem !important; border-radius: 10px !important; }
  .bl-card img { width: 100% !important; height: auto !important; max-height: 180px !important; object-fit: cover !important; border-radius: 8px !important; margin-bottom: .75rem !important; }
  .bl-card h3, .bl-card .bl-title { font-size: 1.05rem !important; line-height: 1.25 !important; }
  .bl-card .bl-excerpt, .bl-card p { font-size: 13.5px !important; line-height: 1.5 !important; }
  .bl-filters, .blog-filters { display: flex !important; overflow-x: auto !important; scrollbar-width: none !important; gap: .5rem !important; padding: 0 1rem .5rem !important; margin: 0 -1.25rem !important; }
  .bl-filters::-webkit-scrollbar, .blog-filters::-webkit-scrollbar { display: none !important; }
  .bl-filters > *, .blog-filters > * { flex: 0 0 auto !important; white-space: nowrap !important; padding: .5rem 1rem !important; font-size: .8rem !important; }
  .mrc-wrap { padding: 1.5rem 1.25rem !important; }
  .mrc-grid { grid-template-columns: 1fr !important; gap: 1rem !important; }
  .mrc-ec-cards { grid-template-columns: 1fr !important; gap: .75rem !important; }
  .mrc-ec-cards > * { padding: 1rem !important; }
}

/* === FULL FIX V15 (mobile only) === */
@media (max-width: 760px) {
  /* Anti-overflow horizontal global */
  html, body { overflow-x: hidden !important; max-width: 100vw !important; }
  
  /* === BLOG === */
  .bl-filters, .blog-filters, .bf-bar, [class*="blog-filter"] {
    display: flex !important; flex-wrap: wrap !important; overflow: visible !important;
    gap: .5rem !important; padding: 0 !important; margin: 0 0 1.25rem !important;
    justify-content: flex-start !important; align-items: center !important;
  }
  .bl-filters > *, .blog-filters > *, .bf-bar > *, [class*="blog-filter"] > * {
    flex: 0 0 auto !important; white-space: nowrap !important;
    padding: .45rem .85rem !important; font-size: .78rem !important; font-weight: 600 !important;
    border-radius: 999px !important; background: rgba(255,255,255,.05) !important;
    color: rgba(255,255,255,.75) !important; border: 1px solid rgba(255,255,255,.08) !important;
    text-decoration: none !important; transition: all .15s ease !important;
  }
  .bl-filters > *.active, .blog-filters > *.active, [class*="blog-filter"] > *.active { background: #FF3131 !important; color: #fff !important; border-color: #FF3131 !important; }
  
  /* === SECTOR PAGES : aérer les sections === */
  .lp-hero, .lp-args, .lp-services, .lp-audience, .lp-how, .lp-adv, .lp-space, .lp-mockup {
    padding: 3.25rem 1.5rem !important;
  }
  .lp-h-title, .lp-args-title { font-size: 1.75rem !important; line-height: 1.15 !important; margin-bottom: .5rem !important; }
  .lp-h-label, .lp-args-eyebrow { font-size: 11px !important; margin-bottom: .65rem !important; letter-spacing: .14em !important; }
  .lp-sub, .lp-svc-intro, .lp-aud-intro { font-size: 15px !important; line-height: 1.6 !important; margin: .75rem 0 1.5rem !important; }
  
  /* === AVANTAGES : slider sur le BON container === */
  .lp-adv-in { display: block !important; padding: 0 !important; }
  .lp-adv-grid {
    display: flex !important; flex-direction: row !important; overflow-x: auto !important; overflow-y: visible !important;
    scroll-snap-type: x mandatory !important; -webkit-overflow-scrolling: touch !important; scrollbar-width: none !important;
    gap: 1rem !important; padding: .25rem 1.5rem 1rem !important; margin: 1.5rem -1.5rem 0 !important;
    grid-template-columns: none !important;
  }
  .lp-adv-grid::-webkit-scrollbar { display: none !important; }
  .lp-adv-card {
    flex: 0 0 78% !important; scroll-snap-align: start !important;
    min-width: 0 !important; max-width: 78% !important; box-sizing: border-box !important;
    padding: 1.5rem !important; border-radius: 14px !important;
    background: rgba(255,255,255,.04) !important; border: 1px solid rgba(255,255,255,.08) !important;
  }
  .lp-adv-card-light { background: rgba(255,255,255,.92) !important; border-color: rgba(0,0,0,.08) !important; }
  .lp-adv-num { font-size: 14px !important; color: #FF3131 !important; font-weight: 800 !important; letter-spacing: .04em !important; margin-bottom: .65rem !important; }
  .lp-adv-t { font-size: 15px !important; font-weight: 700 !important; margin-bottom: .5rem !important; line-height: 1.3 !important; }
  .lp-adv-d { font-size: 13.5px !important; line-height: 1.6 !important; }
  
  /* === ESPACE PARTENAIRE : annule slider, stack vertical propre === */
  .lp-space-in { display: grid !important; grid-template-columns: 1fr !important; gap: 1.5rem !important; }
  .lp-space-l { width: 100% !important; }
  .lp-space-list {
    display: flex !important; flex-direction: column !important;
    gap: 1.25rem !important; overflow: visible !important;
    padding: 0 !important; margin: 1.25rem 0 0 !important;
    grid-template-columns: none !important; scroll-snap-type: none !important;
  }
  .lp-space-it {
    display: grid !important; grid-template-columns: 40px 1fr !important;
    gap: .9rem !important; padding: 0 !important;
    background: transparent !important; border: none !important;
    align-items: start !important; flex: none !important; max-width: 100% !important;
  }
  .lp-space-bullet {
    font-size: 18px !important; font-weight: 800 !important; color: #FF3131 !important;
    line-height: 1.2 !important; padding-top: .1rem !important;
    background: transparent !important; border: none !important; width: auto !important;
  }
  .lp-space-it > div strong, .lp-space-it strong {
    display: block !important; font-size: 15px !important; font-weight: 700 !important;
    margin-bottom: .35rem !important; color: inherit !important;
  }
  .lp-space-it > div span, .lp-space-it span:not(.lp-space-bullet) {
    font-size: 13.5px !important; line-height: 1.55 !important;
    opacity: .7 !important; display: block !important;
  }
  .lp-space-r { display: none !important; }
  
  /* === SLIDERS LP : aérer cards === */
  .lp-args-in, .lp-segs-grid, .lp-how-grid, .lp-svc-grid {
    gap: 1rem !important; padding: .25rem 1.5rem 1rem !important; margin: 1rem -1.5rem 0 !important;
  }
  .lp-arg-k, .lp-seg, .lp-how-step, .lp-svc-card {
    padding: 1.5rem !important; border-radius: 14px !important;
  }
  .lp-arg-v { font-size: 1.85rem !important; line-height: 1.05 !important; }
  .lp-arg-t { font-size: 13px !important; line-height: 1.45 !important; margin-top: .5rem !important; }
  .lp-svc-h { font-size: 15.5px !important; line-height: 1.3 !important; }
  .lp-svc-d { font-size: 13.5px !important; line-height: 1.55 !important; margin-top: .5rem !important; }
  .lp-svc-price { margin-top: .85rem !important; padding-top: .85rem !important; }
  .lp-svc-price-l { font-size: 10px !important; }
  .lp-svc-price-v { font-size: 13px !important; }
  .lp-seg .lp-seg-h, .lp-seg-h { font-size: 15px !important; font-weight: 700 !important; }
  .lp-seg .lp-seg-d, .lp-seg-d { font-size: 13.5px !important; line-height: 1.55 !important; margin-top: .35rem !important; }
  .lp-seg-n { font-size: 12px !important; color: #FF3131 !important; font-weight: 800 !important; margin-bottom: .5rem !important; }
  .lp-how-step .lp-how-n, .lp-how-n { font-size: 13px !important; color: #FF3131 !important; font-weight: 800 !important; margin-bottom: .5rem !important; }
  
  /* === HERO LP : padding et image === */
  .lp-hero { padding-top: 4.5rem !important; padding-bottom: 2.5rem !important; }
  .lp-h1 { font-size: 1.85rem !important; line-height: 1.1 !important; }
  .lp-h1 .thin { font-weight: 300 !important; }
  .lp-hero-image img { width: 100% !important; height: auto !important; max-height: 280px !important; object-fit: cover !important; border-radius: 0 !important; }
  
  /* === FORM SECTION === */
  .form-sec, .cro-form { padding: 3rem 1.5rem !important; }
  .cro-row { display: grid !important; grid-template-columns: 1fr !important; gap: 1.25rem !important; }
  .cro-form-card, .cro-meet-card, .ame-card { padding: 1.5rem !important; border-radius: 14px !important; }
  
  /* === FAQ === */
  .adomos-faq { padding: 2.5rem 1.25rem !important; }
  
  /* === Anti débordement général === */
  .lp-hero-image, .lp-hero, section { max-width: 100vw !important; box-sizing: border-box !important; }
}

/* === V16 GAPS COVERED (mobile only) === */
@media (max-width: 760px) {
  /* HOME : tl + idee sections */
  .tl, .idee { padding: 2.75rem 1.5rem !important; }
  .tl-wrap, .idee-in { max-width: 100% !important; padding: 0 !important; }
  .tl [style*="grid-template-columns"], .idee-in [style*="grid-template-columns"] { grid-template-columns: 1fr !important; gap: 1rem !important; }
  .tl h2, .idee h2 { font-size: 1.6rem !important; line-height: 1.15 !important; }
  .tl p, .idee p { font-size: 14.5px !important; line-height: 1.6 !important; }
  
  /* BLOG : hero compact */
  .bl-hero { padding: 4.5rem 1.5rem 2rem !important; }
  .bl-hero-in { max-width: 100% !important; }
  .bl-hero h1 { font-size: 1.85rem !important; line-height: 1.1 !important; margin-bottom: .5rem !important; }
  .bl-hero p { font-size: 14.5px !important; line-height: 1.55 !important; }
  .bl-grid-in { max-width: 100% !important; padding: 0 1.25rem !important; }
  
  /* CAS CLIENTS : pull quote + cta */
  .cc-pull { padding: 3rem 1.5rem !important; }
  .cc-pull-in { max-width: 100% !important; }
  .cc-pull-eyebrow { font-size: 10px !important; margin-bottom: .65rem !important; letter-spacing: .14em !important; }
  .cc-pull blockquote, .cc-pull q, .cc-pull-in p, .cc-pull-text { font-size: 1.1rem !important; line-height: 1.45 !important; font-style: italic !important; font-weight: 500 !important; }
  .cc-cta { padding: 2.5rem 1.5rem !important; text-align: center !important; }
  .cc-cta-row, .cc-cta > div { display: flex !important; flex-direction: column !important; gap: .65rem !important; align-items: stretch !important; }
  .cc-cta a, .cc-cta button { display: block !important; width: 100% !important; text-align: center !important; padding: .9rem 1rem !important; }
  .cc-cta h2, .cc-cta h3 { font-size: 1.55rem !important; line-height: 1.15 !important; margin-bottom: .65rem !important; }
  .cc-cta p { font-size: 14px !important; line-height: 1.55 !important; margin-bottom: 1.25rem !important; }
  
  /* SECTOR : FAQ adomos-faq accordion mobile */
  .adomos-faq { padding: 2.75rem 1.25rem !important; }
  .afaq-in { max-width: 100% !important; padding: 0 !important; }
  .afaq-in h2, .adomos-faq h2 { font-size: 1.65rem !important; line-height: 1.15 !important; margin-bottom: 1.5rem !important; }
  .afaq-list { display: flex !important; flex-direction: column !important; gap: .55rem !important; }
  .afaq-list details, .afaq-list .afaq-item, .afaq-item {
    background: rgba(255,255,255,.04) !important; border: 1px solid rgba(255,255,255,.08) !important;
    border-radius: 10px !important; padding: 1rem 1.15rem !important; transition: border-color .2s !important;
  }
  .afaq-list details[open], .afaq-item[open] { border-color: #FF3131 !important; }
  .afaq-list summary, .afaq-q {
    cursor: pointer !important; list-style: none !important;
    font-size: .95rem !important; font-weight: 700 !important;
    display: flex !important; justify-content: space-between !important; align-items: center !important;
    gap: 1rem !important; padding: .15rem 0 !important;
  }
  .afaq-list summary::-webkit-details-marker, .afaq-q::-webkit-details-marker { display: none !important; }
  .afaq-list summary::after, .afaq-q::after {
    content: "+" !important; font-size: 1.4rem !important; font-weight: 300 !important;
    color: #FF3131 !important; transition: transform .2s !important; flex-shrink: 0 !important;
  }
  .afaq-list details[open] summary::after, .afaq-item[open] .afaq-q::after { transform: rotate(45deg) !important; }
  .afaq-list .afaq-a, .afaq-a, .afaq-list details > div, .afaq-list details > p {
    margin-top: .75rem !important; font-size: .88rem !important; line-height: 1.55 !important; opacity: .75 !important;
  }
  
  /* Hide leftover row mockup if any */
  .lpm-row { display: none !important; }
  
  /* Bonus : éviter horizontal scroll sur tous les wrappers */
  .sb-wrap, .tl-wrap, .idee-in, .sv-wrap, .cm-wrap, .cc-wrap, .cro-in, .ft-main, .bl-hero-in, .bl-grid-in,
  .cc-hero-in, .cc-stats-in, .cc-pull-in, .lp-args-head, .lp-services-in, .lp-audience-in, .lp-how-in, .lp-adv-in, .lp-space-in, .afaq-in {
    max-width: 100% !important; box-sizing: border-box !important; overflow-x: visible !important;
  }
}

/* === V17 NAV FORM AERATE === */
/* Hide Se connecter partout (mobile + desktop) */
#mn-login-btn, .mn-espace, .hdr-login, a[href="/connexion/"]:not(.mn-link):not(.mn-sublink) { display: none !important; }
.mn-bottom { padding-top: .5rem !important; }

@media (max-width: 760px) {
  /* === FORM AERATION (cro-form sur home + sector) === */
  .form-sec, .cro-form { padding: 3rem 1.25rem !important; }
  .cro-in { display: grid !important; grid-template-columns: 1fr !important; gap: 1.5rem !important; max-width: 100% !important; padding: 0 !important; }
  .cro-left, .cro-right { width: 100% !important; max-width: 100% !important; }
  .cro-label { font-size: 11px !important; letter-spacing: .14em !important; margin-bottom: .65rem !important; color: #FF3131 !important; }
  .cro-title { font-size: 1.6rem !important; line-height: 1.15 !important; margin-bottom: .5rem !important; }
  .cro-title-thin { font-weight: 300 !important; opacity: .7 !important; display: inline !important; }
  .cro-sub { font-size: 14.5px !important; line-height: 1.55 !important; margin-bottom: 1.5rem !important; }
  .cro-proofs { display: flex !important; flex-direction: column !important; gap: 1rem !important; margin-top: 1.25rem !important; }
  .cro-proof { display: flex !important; align-items: baseline !important; gap: .65rem !important; padding: 0 !important; border: none !important; }
  .cro-proof-v { font-size: 1.6rem !important; line-height: 1 !important; font-weight: 800 !important; color: #FF3131 !important; }
  .cro-proof-l { font-size: 13px !important; line-height: 1.4 !important; opacity: .75 !important; }
  .cro-form-card { padding: 1.5rem !important; border-radius: 14px !important; background: rgba(255,255,255,.04) !important; border: 1px solid rgba(255,255,255,.08) !important; }
  .cro-form-h { font-size: 1.1rem !important; font-weight: 700 !important; margin-bottom: 1.25rem !important; line-height: 1.2 !important; }
  .cro-form-card form { display: flex !important; flex-direction: column !important; gap: .85rem !important; }
  .cro-form-card input, .cro-form-card select, .cro-form-card textarea, .cro-form-card .cro-select {
    width: 100% !important; padding: .85rem 1rem !important; font-size: 16px !important; line-height: 1.4 !important;
    background: rgba(255,255,255,.06) !important; border: 1px solid rgba(255,255,255,.12) !important;
    border-radius: 10px !important; color: #fff !important; box-sizing: border-box !important;
    -webkit-appearance: none !important; appearance: none !important;
  }
  .cro-form-card input::placeholder, .cro-form-card textarea::placeholder { color: rgba(255,255,255,.4) !important; }
  .cro-form-card input:focus, .cro-form-card select:focus, .cro-form-card textarea:focus { outline: none !important; border-color: #FF3131 !important; background: rgba(255,255,255,.08) !important; }
  .cro-rgpd { display: flex !important; align-items: flex-start !important; gap: .65rem !important; margin: .25rem 0 !important; font-size: 12.5px !important; line-height: 1.45 !important; opacity: .8 !important; }
  .cro-rgpd input { width: 18px !important; height: 18px !important; flex-shrink: 0 !important; margin-top: 2px !important; padding: 0 !important; }
  .cro-legal { font-size: 11.5px !important; line-height: 1.45 !important; opacity: .55 !important; margin-top: .25rem !important; }
  .cro-btn { width: 100% !important; padding: 1rem !important; font-size: 15px !important; font-weight: 700 !important; border-radius: 999px !important; background: linear-gradient(135deg,#FF3131,#d32626) !important; color: #fff !important; border: none !important; cursor: pointer !important; margin-top: .5rem !important; }
  .cro-or { text-align: center !important; font-size: 11px !important; letter-spacing: .14em !important; opacity: .5 !important; margin: 1.5rem 0 1rem !important; }
  .cro-meet { display: flex !important; flex-direction: row !important; align-items: center !important; gap: 1rem !important; padding: 1.25rem !important; background: rgba(255,255,255,.03) !important; border: 1px solid rgba(255,255,255,.08) !important; border-radius: 12px !important; text-decoration: none !important; }
  .cro-meet-i { width: 38px !important; height: 38px !important; flex-shrink: 0 !important; }
  .cro-meet-content { flex: 1 !important; min-width: 0 !important; }
  .cro-meet-t { font-size: 14px !important; font-weight: 700 !important; color: #fff !important; line-height: 1.2 !important; margin-bottom: .2rem !important; }
  .cro-meet-d { font-size: 12px !important; opacity: .65 !important; line-height: 1.4 !important; }
  .cro-meet-arrow { width: 18px !important; height: 18px !important; flex-shrink: 0 !important; opacity: .5 !important; }
  
  /* === NAV AERATION === */
  .mnav { padding-top: 4.5rem !important; padding-bottom: 1.5rem !important; }
  .mn-foot { margin-top: 1.5rem !important; padding-top: 1.5rem !important; gap: .65rem !important; }
  .mn-foot .mn-cta { padding: .9rem 1rem !important; font-size: .95rem !important; }
  .mnav .mn-link { padding: .75rem .25rem !important; font-size: 1.05rem !important; }
  .mnav .mn-sub { padding: .35rem 0 .85rem 1.1rem !important; }
  .mnav .mn-sublink { padding: .55rem .85rem !important; font-size: .92rem !important; }
  
  /* hide Se connecter & .mn-bottom anywhere */
  .mn-bottom { display: none !important; }
}

/* === V18 HERO FORM KPI === */
@media (max-width: 760px) {
  /* === HERO HOME : padding stable, anti-overlap === */
  body.home section.hero, .hero {
    min-height: 100vh !important; height: auto !important;
    padding: 5.5rem 1.25rem 2rem !important;
    display: flex !important; flex-direction: column !important;
    justify-content: center !important; align-items: flex-start !important;
    box-sizing: border-box !important;
  }
  .hero .label-anim {
    margin-bottom: 1rem !important; font-size: 11px !important;
    letter-spacing: .14em !important;
  }
  .hero .hero-title { margin-bottom: 1.25rem !important; }
  .hero .hero-line { font-size: clamp(1.65rem, 7vw, 2.2rem) !important; line-height: 1.1 !important; white-space: normal !important; }
  
  /* === SECTOR FORMS : inputs uniformes === */
  .form-sec input, .form-sec select, .form-sec textarea,
  .cro-form input, .cro-form select, .cro-form textarea,
  #f-prenom, #f-nom, #f-email, #f-tel, #f-secteur, #f-message {
    width: 100% !important;
    padding: .85rem 1rem !important;
    font-size: 16px !important;
    line-height: 1.4 !important;
    background: rgba(255,255,255,.06) !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    border-radius: 10px !important;
    color: #fff !important;
    box-sizing: border-box !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    font-family: inherit !important;
    margin: 0 !important;
    height: auto !important;
    min-height: 48px !important;
  }
  .form-sec input::placeholder, .cro-form input::placeholder,
  #f-prenom::placeholder, #f-nom::placeholder, #f-email::placeholder, #f-tel::placeholder {
    color: rgba(255,255,255,.4) !important;
  }
  .form-sec input:focus, .form-sec select:focus, .form-sec textarea:focus,
  .cro-form input:focus, .cro-form select:focus, .cro-form textarea:focus,
  #f-prenom:focus, #f-nom:focus, #f-email:focus, #f-tel:focus {
    outline: none !important;
    border-color: #FF3131 !important;
    background: rgba(255,255,255,.08) !important;
  }
  /* Force grid prenom/nom row to stack vertical on mobile */
  .form-sec form > div, .cro-form form > div, .cro-form-card form > div,
  .form-sec form .row, .cro-form .row {
    display: flex !important; flex-direction: column !important; gap: .85rem !important;
  }
  /* Checkboxes RGPD/newsletter exception */
  #f-rgpd, #f-newsletter, .cro-rgpd input[type="checkbox"] {
    width: 18px !important; height: 18px !important; min-height: 18px !important;
    flex-shrink: 0 !important; padding: 0 !important; margin: 0 !important;
    border-radius: 4px !important;
  }
  
  /* === CHIFFRES CLÉS sector : taille adaptative === */
  .lp-arg-k { padding: 1.25rem !important; }
  .lp-arg-v {
    font-size: clamp(1.4rem, 6vw, 1.7rem) !important;
    line-height: 1.05 !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    white-space: normal !important;
  }
  .lp-arg-t { font-size: 12.5px !important; line-height: 1.4 !important; margin-top: .5rem !important; word-break: break-word !important; }
  /* KPI sb-row sur home : pareil */
  .sb-it .sb-v { font-size: clamp(1.6rem, 7vw, 2rem) !important; line-height: 1.05 !important; word-break: keep-all !important; white-space: normal !important; }
  .sb-it .sb-l { font-size: 12px !important; line-height: 1.4 !important; word-break: break-word !important; }
}

/* === V19 LP HERO AERATE === */
@media (max-width: 760px) {
  /* Hero LP : aérer top + spacing rythmé */
  .lp-hero {
    padding: 6.5rem 1.5rem 3rem !important;
    min-height: 0 !important; height: auto !important;
    display: flex !important; flex-direction: column !important;
    justify-content: center !important; align-items: flex-start !important;
  }
  .lp-hero .lp-hero-image { position: absolute !important; inset: 0 !important; z-index: 0 !important; }
  .lp-hero .lp-hero-image img { width: 100% !important; height: 100% !important; object-fit: cover !important; opacity: .35 !important; }
  .lp-hero > div:not(.lp-hero-image):not(.lines-bg) { position: relative !important; z-index: 2 !important; width: 100% !important; }
  .lp-hero .label-anim { font-size: 11px !important; letter-spacing: .14em !important; margin-bottom: 1.25rem !important; color: #FF3131 !important; }
  .lp-hero .lp-h1 { font-size: 1.95rem !important; line-height: 1.1 !important; font-weight: 800 !important; margin-bottom: 1.25rem !important; }
  .lp-hero .lp-h1 .thin { font-weight: 300 !important; opacity: .85 !important; display: inline !important; }
  .lp-hero .lp-sub { font-size: 14.5px !important; line-height: 1.6 !important; margin: 0 0 1.75rem !important; opacity: .85 !important; }
  .lp-hero .lp-cta, .lp-hero a.lp-cta-link, .lp-hero .lp-hero-cta {
    display: inline-flex !important; align-items: center !important; justify-content: center !important;
    width: 100% !important; padding: 1rem 1.25rem !important; font-size: 14px !important;
    font-weight: 700 !important; letter-spacing: .04em !important; text-transform: uppercase !important;
    background: #FF3131 !important; color: #fff !important; border-radius: 999px !important;
    text-decoration: none !important; box-shadow: 0 8px 24px rgba(255,49,49,.35) !important;
    margin-top: .25rem !important;
  }
  
  /* === Sections internes : spacing rythmé === */
  .lp-args, .lp-services, .lp-audience, .lp-how, .lp-adv, .lp-space, .lp-mockup, .form-sec, .adomos-faq {
    padding-top: 3.5rem !important; padding-bottom: 3.5rem !important;
  }
  .lp-args-head, .lp-services-in > .lp-h-label, .lp-audience-in > .lp-h-label, .lp-how-in > .lp-h-label, .lp-adv-in > .lp-h-label, .lp-space-in .lp-h-label {
    margin-bottom: 1.25rem !important;
  }
  .lp-h-title { margin-bottom: 1rem !important; }
  .lp-svc-intro, .lp-aud-intro { margin-bottom: 1.75rem !important; }
  
  /* CTA section "Voir tous les services" link */
  .lp-svc-cta-wrap { margin-top: 1.5rem !important; }
  .lp-svc-cta-link { display: inline-block !important; padding: .85rem 1.25rem !important; font-size: 13px !important; font-weight: 700 !important; }
}

/* === V20 LP ARGS REAL FIX === */
@media (max-width: 760px) {
  /* Annule les fausses règles précédentes sur .lp-arg-k */
  .lp-arg-k {
    background: transparent !important;
    padding: 0 !important;
    border-radius: 0 !important;
    border: none !important;
    box-sizing: content-box !important;
    flex: none !important;
    max-width: none !important;
    min-width: 0 !important;
  }
  /* La VRAIE card = direct div enfant de .lp-args-in */
  .lp-args-in > div {
    flex: 0 0 78% !important;
    scroll-snap-align: start !important;
    min-width: 0 !important;
    max-width: 78% !important;
    box-sizing: border-box !important;
    padding: 1.5rem !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,.04) !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    display: flex !important;
    flex-direction: column !important;
    gap: .65rem !important;
  }
  /* Les 3 spans en BLOCK avec hierarchie typo */
  .lp-arg-k {
    display: block !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: .14em !important;
    text-transform: uppercase !important;
    color: #FF3131 !important;
  }
  .lp-arg-v {
    display: block !important;
    font-size: clamp(1.6rem, 7vw, 2.1rem) !important;
    font-weight: 800 !important;
    line-height: 1.05 !important;
    color: inherit !important;
    word-break: keep-all !important;
    white-space: normal !important;
  }
  .lp-arg-v strong {
    font-weight: 800 !important;
    font-size: .65em !important;
    opacity: .7 !important;
    margin-left: .15em !important;
  }
  .lp-arg-t {
    display: block !important;
    font-size: 13px !important;
    line-height: 1.5 !important;
    opacity: .75 !important;
    margin-top: .25rem !important;
  }
}

/* === V21 ANTI TRUNCATION (defensive global mobile) === */
@media (max-width: 760px) {
  /* GLOBAL : tout container ne dépasse jamais 100vw */
  html, body { overflow-x: hidden !important; max-width: 100vw !important; width: 100% !important; }
  body * { max-width: 100% !important; }
  /* Allow images and svg to scale */
  img, svg, video, iframe { max-width: 100% !important; height: auto !important; }
  /* Ensure flex/grid items can shrink */
  body * { min-width: 0; }
  /* Texte : casser proprement les longs mots */
  h1, h2, h3, h4, p, span, div, li, a, button, label {
    overflow-wrap: anywhere !important;
    word-wrap: break-word !important;
  }
  /* Exceptions : nombres compacts (chiffres clés) — keep-all pour préserver "48h", "+67%" etc */
  .lp-arg-v, .sb-v, .cc-stats-v, .cc-stats-grid > * h3, .lp-mockup-kpi .lp-mockup-kpi-v {
    overflow-wrap: normal !important;
    word-wrap: normal !important;
    word-break: keep-all !important;
    white-space: nowrap !important;
    overflow: visible !important;
  }
  /* Si le chiffre est trop large, autoriser le wrap mais sur espaces uniquement */
  .lp-arg-v, .sb-v {
    text-overflow: clip !important;
    overflow: visible !important;
  }
  /* Cards sliders : forcer flex 0 0 auto et width contrôlée */
  .lp-args-in > div, .lp-svc-grid > .lp-svc-card, .lp-segs-grid > .lp-seg, .lp-how-grid > .lp-how-step,
  .lp-adv-grid > .lp-adv-card, .lp-space-list > .lp-space-it,
  .sb-row > .sb-it, .sv-grid > .sv-card, .cc-grid > *, .cc-stats-grid > * {
    flex-shrink: 0 !important;
    box-sizing: border-box !important;
  }
  /* Sliders : container avec scroll horizontal propre */
  .lp-args-in, .lp-svc-grid, .lp-segs-grid, .lp-how-grid, .lp-adv-grid,
  .sb-row, .sv-grid, .cc-grid, .cc-stats-grid {
    overflow-x: auto !important;
    overflow-y: visible !important;
    -webkit-overflow-scrolling: touch !important;
    scroll-snap-type: x mandatory !important;
    scrollbar-width: none !important;
  }
  .lp-args-in::-webkit-scrollbar, .lp-svc-grid::-webkit-scrollbar, .lp-segs-grid::-webkit-scrollbar,
  .lp-how-grid::-webkit-scrollbar, .lp-adv-grid::-webkit-scrollbar,
  .sb-row::-webkit-scrollbar, .sv-grid::-webkit-scrollbar, .cc-grid::-webkit-scrollbar,
  .cc-stats-grid::-webkit-scrollbar { display: none !important; height: 0 !important; }
  /* Sections : padding horizontal cohérent */
  section, .form-sec, .lp-hero, .lp-args, .lp-services, .lp-audience, .lp-how, .lp-adv, .lp-space, .lp-mockup, .adomos-faq, .acces-faq, .ac-hero, .cc-hero, .cc-stats, .cc-pull, .cc-cta, .bl-hero, .a-hero {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
    box-sizing: border-box !important;
  }
  /* Wrappers internes : pas de max-width fixe qui dépasse */
  .lp-args-head, .lp-services-in, .lp-audience-in, .lp-how-in, .lp-adv-in, .lp-space-in,
  .cc-hero-in, .cc-stats-in, .cc-pull-in, .cro-in, .ft-main, .bl-hero-in, .bl-grid-in,
  .ac-hero-in, .acces-faq .af-wrap, .adomos-faq .afaq-in {
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  /* Sliders : margin negatif compensé par padding inside */
  .lp-args-in, .lp-svc-grid, .lp-segs-grid, .lp-how-grid, .lp-adv-grid,
  .sb-row, .sv-grid, .cc-grid, .cc-stats-grid {
    margin-left: -1.5rem !important;
    margin-right: -1.5rem !important;
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
    width: auto !important;
    max-width: none !important;
  }
  /* Buttons : full width safe */
  .cro-btn, .lp-cta, .cc-cta a, .cc-cta button { word-break: keep-all !important; }
  /* Tables : scroll horizontal */
  table { display: block !important; overflow-x: auto !important; -webkit-overflow-scrolling: touch !important; max-width: 100% !important; }
}

/* === V23 BLOG STEPPER === */
@media (max-width: 760px) {
  /* Blog filtres : cibler la VRAIE classe .bl-cat (chip de catégorie) */
  .bl-filters { display: flex !important; flex-wrap: wrap !important; gap: .5rem !important; padding: 0 1.25rem 1rem !important; margin: 0 !important; overflow: visible !important; }
  .bl-cat { display: inline-flex !important; align-items: center !important; padding: .5rem .9rem !important; font-size: 12px !important; font-weight: 600 !important; border-radius: 999px !important; background: rgba(255,255,255,.06) !important; color: rgba(255,255,255,.8) !important; border: 1px solid rgba(255,255,255,.12) !important; text-decoration: none !important; white-space: nowrap !important; }
  .bl-cat.active, .bl-cat[aria-current], .bl-cat.is-active { background: #FF3131 !important; color: #fff !important; border-color: #FF3131 !important; }
  /* Home : stepper cs-bignum stable, no jumping */
  .cm-stepper, .cm-stepper-dots { display: none !important; }
  /* Re-show stepper on home but compact + stable */
  body.home .cm-stepper, body.home .cm-stepper-dots { display: flex !important; flex-direction: row !important; justify-content: flex-start !important; gap: .75rem !important; padding: 0 0 1rem !important; margin: 0 !important; flex-wrap: wrap !important; }
  body.home .cm-stepper-dot { display: inline-flex !important; flex-direction: column !important; align-items: center !important; gap: .35rem !important; flex: 0 0 auto !important; }
  body.home .cs-bignum { width: 36px !important; height: 36px !important; border-radius: 50% !important; display: inline-grid !important; place-items: center !important; font-size: 13px !important; font-weight: 700 !important; padding: 0 !important; line-height: 1 !important; }
  body.home .cm-stepper-dot .cs-lbl { font-size: 9px !important; letter-spacing: .12em !important; text-align: center !important; }
}


/* === V24 : stepper scroll + form cro-row + prices + bigl fix === */
/* Hide service prices globally */
.sv-price { display: none !important; }

@media (max-width: 760px) {
  /* Stepper dots : scroll instead of wrap (was flex-wrap:wrap) */
  body.home .cm-stepper-dots { flex-wrap: nowrap !important; overflow-x: auto !important; scrollbar-width: none !important; -webkit-overflow-scrolling: touch !important; padding-bottom: .5rem !important; }
  body.home .cm-stepper-dots::-webkit-scrollbar { display: none !important; }
  /* Fix label class (cs-bigl, not cs-lbl) */
  body.home .cm-stepper-dot .cs-bigl { font-size: 9px !important; letter-spacing: .12em !important; text-align: center !important; max-width: 60px !important; white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important; }
  /* cs-bignum explicit bg+color on mobile */
  body.home .cs-bignum { background: #0E0E10 !important; color: rgba(255,255,255,.85) !important; }
  /* Fix form row : prenom/nom same width as other fields */
  .cro-row { grid-template-columns: 1fr !important; }
  .cro-row input { width: 100% !important; }
}