/* JM SERRURES — feuille de style de production (complete) */
:root{--g:#9BC01C;--gd:#6f8f14;--ink:#111;--bg:#f7f7f5;--gray:#6b6b6b;--border:#e4e4e0}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Barlow',system-ui,Arial,sans-serif;color:var(--ink);background:#fff;line-height:1.6}
img{display:block;max-width:100%}a{text-decoration:none;color:inherit}
h1,h2,h3{font-family:'Barlow Condensed',sans-serif;text-transform:uppercase;line-height:.98;letter-spacing:-.01em}
.wrap,.container{max-width:1200px;margin:0 auto;padding:0 24px}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:.9rem 1.5rem;border-radius:5px;cursor:pointer;transition:.2s;border:0}
.btn svg{fill:currentColor}
.btn--g{background:var(--gd);color:#fff}.btn--g:hover{background:#5c7710}
.btn--ink{background:var(--ink);color:#fff}.btn--ink:hover{background:var(--gd)}
.btn--out{background:transparent;border:2px solid var(--ink);color:var(--ink)}.btn--out:hover{background:var(--ink);color:#fff}
.btn--wout{background:transparent;border:2px solid #fff;color:#fff}.btn--wout:hover{background:#fff;color:var(--ink)}
.btn--sm{padding:.55rem 1rem;font-size:.82rem}
.btn--txt{background:none;color:var(--gd);padding:.4rem 0;border-bottom:1px solid var(--gd);border-radius:0}
.top{position:sticky;top:0;z-index:80;background:#fff;border-bottom:1px solid var(--border)}
.top__bar{display:flex;align-items:center;gap:1.5rem;padding:.7rem 24px;max-width:1200px;margin:0 auto}
.brand{display:flex;align-items:baseline;gap:.35rem;font-family:'Barlow Condensed';font-weight:900;font-size:1.7rem;color:var(--ink)}
.brand img{max-height:46px;width:auto}
.brand span{font-size:.6rem;letter-spacing:.3em;font-weight:800;align-self:center}
.topnav{margin:0 auto;display:flex;gap:1.9rem}
.topnav a{font-family:'Barlow Condensed';font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:1.05rem;color:#333;padding:.35rem 0;border-bottom:2px solid transparent}
.topnav a:hover{border-color:var(--g)}
.topphone{display:inline-flex;align-items:center;gap:.4rem;background:var(--gd);color:#fff;font-family:'Barlow Condensed';font-weight:800;padding:.6rem 1.1rem;border-radius:5px;white-space:nowrap}
.subnav{background:var(--ink)}
.subnav__in{display:flex;flex-wrap:nowrap;justify-content:center;max-width:1320px;margin:0 auto;padding:0 10px}
.subnav__item{position:relative;border-left:1px solid #2a2a2a}
.subnav__item:first-child{border-left:0}
.subnav__top{display:flex;align-items:center;gap:5px;white-space:nowrap;font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;font-size:clamp(.74rem,1.04vw,.96rem);letter-spacing:.04em;color:#e7e7e7;padding:.85rem clamp(.5rem,1vw,1.2rem)}
.subnav__item:hover .subnav__top{color:var(--g)}
.subnav__car{font-size:.62em;opacity:.85}
.subnav__drop{position:absolute;top:100%;left:0;min-width:240px;background:#fff;border:1px solid var(--border);box-shadow:0 16px 36px rgba(0,0,0,.16);border-radius:0 0 12px 12px;padding:8px 0;opacity:0;visibility:hidden;transform:translateY(7px);transition:.2s;z-index:90}
.subnav__item:hover .subnav__drop{opacity:1;visibility:visible;transform:none}
.subnav__drop a{display:block;color:#1d1d1d;padding:.6rem 1.3rem;font-family:'Barlow';font-weight:600;font-size:.94rem;border-left:0}
.subnav__drop a:hover{background:var(--g);color:#fff}
/* État catégorie vide */
.cat-empty{text-align:center;padding:3rem 1rem}
.cat-empty h3{font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;font-size:1.7rem;color:var(--gd);margin-bottom:.5rem}
.cat-empty p{color:#555;max-width:540px;margin:0 auto 1.4rem}
.cat-empty__cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.burger{display:none;margin-left:auto;background:none;border:0;font-size:1.7rem;cursor:pointer}
.hero{position:relative;min-height:640px;display:flex;align-items:center;overflow:hidden;background:linear-gradient(120deg,#fbfcf9,#eef1ea)}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.5}
.hero__ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(247,248,245,.94) 0%,rgba(247,248,245,.78) 48%,rgba(247,248,245,.4) 100%)}
.hero__glow{position:absolute;right:16%;top:50%;width:620px;height:620px;transform:translateY(-50%);background:radial-gradient(circle,rgba(155,192,28,.28),transparent 62%)}
.hero__door{position:absolute;right:5%;bottom:0;height:108%;width:auto;z-index:2;filter:drop-shadow(0 26px 44px rgba(0,0,0,.28))}
.hero__in{position:relative;z-index:3;max-width:1200px;margin:0 auto;padding:5rem 24px;width:100%}
.hero__col{max-width:60%}
.hero__eye{display:inline-flex;align-items:center;gap:.5rem;border:1px solid rgba(155,192,28,.55);color:var(--gd);font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;padding:.4rem .9rem;border-radius:50px;background:rgba(155,192,28,.1)}
.hero__eye:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--g)}
.hero__kick{font-family:'Barlow Condensed';font-weight:800;color:var(--gd);letter-spacing:.22em;font-size:.95rem;margin:1.4rem 0 .2rem}
.hero h1{font-size:clamp(3rem,7vw,5.6rem);font-weight:900;color:var(--ink)}.hero h1 .gr{color:var(--g)}
.hero__sub2{font-family:'Barlow Condensed';font-weight:800;font-size:clamp(1.4rem,3vw,2.1rem);color:var(--ink)}
.hero__mini{font-family:'Barlow Condensed';font-weight:700;letter-spacing:.18em;color:var(--gray);text-transform:uppercase;font-size:.85rem;margin-top:.2rem}
.hero p.lead{max-width:38ch;color:#444;margin:1.3rem 0 1.7rem;font-size:1.12rem}
.hero__cta{display:flex;gap:.7rem;flex-wrap:wrap}
.hero__rate{margin-top:1.6rem;font-family:'Barlow Condensed';font-weight:700;color:var(--gray)}.hero__rate b{color:var(--ink)}.hero__rate .s{color:var(--g)}
.marq{background:var(--gd);overflow:hidden;white-space:nowrap}
.marq span{display:inline-block;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#fff;padding:.7rem 0;animation:mq 30s linear infinite}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.sec{padding:5rem 0}.sec--bg{background:var(--bg)}
.shead{margin-bottom:2.4rem}.shead.center{text-align:center}
.shead .k{font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;letter-spacing:.2em;color:var(--gd);font-size:.82rem}
.shead h2{font-size:clamp(1.9rem,4.5vw,3.1rem);font-weight:900;margin-top:.3rem}
.lead{color:#444}
.trust{display:grid;grid-template-columns:200px 1fr;gap:2rem;align-items:start}
.trust__score{text-align:center}.trust__score .ex{font-family:'Barlow Condensed';font-weight:900;font-size:1.4rem}
.trust__score .stars{color:#f5a623;font-size:1.4rem}.trust__score .based{font-family:'Barlow Condensed';font-weight:700;color:var(--gray);font-size:.85rem;text-transform:uppercase}
.trust__score .gg{font-weight:700;color:#4285F4;margin-top:.3rem}
.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.rev{border:1px solid var(--border);border-radius:10px;padding:1.2rem;background:#fff}
.rev__top{display:flex;align-items:center;gap:.6rem;margin-bottom:.5rem}
.rev__av{width:36px;height:36px;border-radius:50%;background:var(--gd);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Barlow Condensed'}
.rev__n{font-weight:700;font-size:.92rem}.rev__t{font-size:.75rem;color:var(--gray)}
.rev__g{margin-left:auto;font-weight:800;color:#4285F4}.rev__st{color:#f5a623}.rev__txt{font-size:.88rem;color:#444;margin:.5rem 0}
.rev__more{font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;font-size:.78rem;color:var(--gray)}
.trust__note{text-align:center;color:var(--gray);font-size:.85rem;margin-top:1.4rem}
.phwrap{position:relative}
.phrow{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(240px,1fr);gap:1.2rem;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:1rem}
.ph{scroll-snap-align:start;background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:.3s}
.ph:hover{transform:translateY(-5px);box-shadow:0 20px 36px -22px rgba(0,0,0,.35);border-color:var(--g)}
.ph__img{aspect-ratio:1/1;background:#fff;display:flex;align-items:center;justify-content:center;padding:14px}
.ph__img img{width:100%;height:100%;object-fit:contain}
.ph__b{padding:1rem 1.1rem;border-top:1px solid var(--border)}
.ph__c{font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;color:var(--gd)}
.ph__b h3{font-size:1.15rem;font-weight:800;margin:.2rem 0 .5rem}
.ph__cta{display:inline-flex;align-items:center;gap:.3rem;font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;font-size:.78rem}
.pharr{display:flex;gap:.5rem;justify-content:flex-end;margin-bottom:1rem}
.pharr button{width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:1.1rem;transition:.2s}
.pharr button:hover{background:var(--gd);border-color:var(--gd);color:#fff}
.hot{position:relative;max-width:1040px;margin:0 auto}
.hot>img{width:100%;display:block}
.hotpt{position:absolute;transform:translate(-50%,-50%);z-index:2}
.hotpt{cursor:pointer;text-decoration:none}
.hotdot{display:block;width:30px;height:30px;border-radius:50%;background:var(--g);position:relative;box-shadow:0 4px 14px rgba(0,0,0,.3)}
.hotdot:before{content:"";position:absolute;inset:0;margin:auto;width:10px;height:10px;background:#fff;border-radius:50%}
.hotdot>span{position:absolute;inset:-6px;border:2px solid var(--g);border-radius:50%;opacity:.6;animation:hp 2.2s ease-out infinite}
@keyframes hp{0%{transform:scale(.7);opacity:.6}100%{transform:scale(1.7);opacity:0}}
.hottip{position:absolute;bottom:150%;left:50%;transform:translateX(-50%) translateY(6px);background:var(--ink);color:#fff;padding:.6rem .9rem;border-radius:8px;white-space:nowrap;text-align:center;opacity:0;visibility:hidden;transition:.25s;box-shadow:0 10px 24px rgba(0,0,0,.3);z-index:5}
.hottip:after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:7px solid transparent;border-top-color:var(--ink)}
.hottip strong{display:block;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;font-size:.95rem}
.hottip span{font-size:.78rem;color:var(--g);font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.hotpt:hover .hottip,.hotpt:focus .hottip,.hotpt.on .hottip{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.hotpt:hover .hotdot,.hotpt:focus .hotdot,.hotpt.on .hotdot{background:var(--gd);transform:scale(1.12)}
.promo{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;display:grid;grid-template-columns:1.3fr .7fr}
.promo__l{padding:2.2rem 2.4rem}
.promo__tag{display:inline-block;border:1px solid rgba(155,192,28,.5);color:var(--gd);font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:.75rem;padding:.35rem .8rem;border-radius:50px}
.promo h2{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:900;margin:1rem 0}.promo h2 .gr{color:var(--gd)}
.promo__stats{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin:1.4rem 0}
.promo__stat{background:var(--bg);border-radius:8px;padding:.9rem 1.1rem}
.promo__stat .l{font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;font-size:.7rem;color:var(--gray)}
.promo__stat .v{font-family:'Barlow Condensed';font-weight:900;font-size:1.3rem}.promo__stat .v.gr{color:var(--gd)}
.promo__r{background:var(--gd);display:flex;align-items:center;justify-content:center}.promo__r .pct{font-family:'Barlow Condensed';font-weight:900;font-size:5rem;color:#fff}
.prods{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.prodcard{position:relative;border-radius:12px;overflow:hidden;display:block;box-shadow:0 14px 30px -20px rgba(0,0,0,.35)}
.prodcard img{width:100%;height:100%;object-fit:cover;transition:.5s;aspect-ratio:4/5}
.prodcard:hover img{transform:scale(1.05)}
.prodcard__cta{position:absolute;left:14px;bottom:14px;display:inline-flex;align-items:center;gap:.3rem;background:var(--gd);color:#fff;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;font-size:.78rem;padding:.4rem .9rem;border-radius:5px}
.actus{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.actu{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:.3s}
.actu:hover{transform:translateY(-5px);box-shadow:0 20px 36px -22px rgba(0,0,0,.3)}.actu--on{border-color:var(--g)}
.actu__img{height:170px;background-size:cover;background-position:center}
.actu__img--ph{display:flex;align-items:center;justify-content:center;background:#f0f0ee;font-family:'Barlow Condensed';font-weight:900;font-size:2.2rem;color:#cfcfcf}
.actu__b{padding:1.2rem;display:flex;flex-direction:column;flex:1}
.actu__d{display:inline-block;align-self:flex-start;background:var(--gd);color:#fff;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;padding:.25rem .7rem;border-radius:4px;margin-bottom:.6rem}
.actu__b h3{font-size:1.2rem;font-weight:800}.actu__b p{color:var(--gray);font-size:.9rem;margin:.4rem 0 .9rem;flex:1}
.actu__l{display:inline-flex;align-items:center;gap:.3rem;font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;font-size:.8rem}.actu__l:hover{color:var(--gd)}
.marques{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:2.5rem}
.marques img{height:46px;width:auto;filter:grayscale(1);opacity:.55;transition:.3s}
.marques a:hover img{filter:none;opacity:1}
.team{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center}
.team__boxes{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.6rem}
.tbox{background:#fff;border:1px solid var(--border);border-radius:10px;padding:1.2rem}
.tbox .ic{width:44px;height:44px;border-radius:8px;background:var(--gd);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:.6rem}
.tbox h3{font-size:1.05rem;font-weight:800}.tbox p{font-size:.86rem;color:var(--gray);margin-top:.2rem}
.team__img{position:relative;border-radius:14px;min-height:340px;background:#222 center/cover no-repeat;display:flex;align-items:flex-end;padding:1.4rem;overflow:hidden}
.team__img:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 45%,rgba(0,0,0,.5) 100%)}
.team__img span{position:relative;z-index:1}
.team__img span{background:var(--gd);color:#fff;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;font-size:.8rem;padding:.4rem .9rem;border-radius:5px}
.ctab{background:linear-gradient(140deg,var(--g),var(--gd));text-align:center;padding:3.4rem 0;color:#fff}
.ctab h2{font-size:clamp(1.7rem,4vw,2.7rem);font-weight:900;color:#fff}
.ctab p{font-family:'Barlow Condensed';font-weight:700;color:rgba(255,255,255,.92);margin:.4rem 0 1.2rem}
.ctab__cta{display:flex;gap:.7rem;justify-content:center;align-items:center;flex-wrap:wrap}
.ctab .btn--g{background:var(--g);color:#fff}.ctab .btn--g:hover{background:#fff;color:var(--ink)}
.ctab .btn--ink{background:#fff;color:var(--ink)}.ctab .btn--ink:hover{background:var(--ink);color:#fff}
.ctab .btn--wout{background:transparent;border:2px solid #fff;color:#fff}.ctab .btn--wout:hover{background:#fff;color:var(--ink)}
.breadcrumb{font-size:.82rem;color:var(--gray);padding:1.1rem 0}.breadcrumb a{color:var(--gd)}
.chead{background:var(--bg);padding:1rem 0 3rem;position:relative;overflow:hidden}
.chead__glow{position:absolute;right:-5%;top:-30%;width:520px;height:520px;background:radial-gradient(circle,rgba(155,192,28,.18),transparent 62%)}
.chead .k{font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;letter-spacing:.2em;color:var(--gd);font-size:.82rem;position:relative}
.chead h1{font-size:clamp(2.4rem,5vw,3.6rem);font-weight:900;margin:.3rem 0 .8rem;position:relative}
.chead p{max-width:62ch;color:#444;position:relative}
.chead__cta{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.4rem;position:relative}
.chips{display:flex;gap:.6rem;flex-wrap:wrap;margin:2.2rem 0 0;position:relative}
.chip{font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;font-size:.82rem;letter-spacing:.04em;padding:.5rem 1.1rem;border:1px solid var(--border);border-radius:50px;background:#fff;cursor:pointer}
.chip.on,.chip:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.cat{padding:3rem 0 4rem}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.pc{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:.3s;display:flex;flex-direction:column}
.pc:hover{transform:translateY(-5px);box-shadow:0 22px 40px -24px rgba(0,0,0,.35);border-color:var(--g)}
.pc__img{aspect-ratio:3/4;background:#f4f4f1;display:flex;align-items:center;justify-content:center;padding:18px;position:relative}
.pc__img img{width:100%;height:100%;object-fit:contain}
.pc__cert{position:absolute;top:12px;left:12px;background:var(--ink);color:#fff;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;font-size:.7rem;letter-spacing:.05em;padding:.25rem .6rem;border-radius:4px}
.pc__b{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;flex:1}
.pc__c{font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;color:var(--gd)}
.pc__b h3{font-size:1.2rem;font-weight:800;margin:.2rem 0 .9rem}
.pc__act{display:flex;gap:.5rem;margin-top:auto;align-items:center;flex-wrap:wrap}
.rea{background:var(--ink);color:#fff;padding:2.4rem 0}
.rea__g{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.rea__i{display:flex;gap:.7rem;align-items:flex-start}
.rea__i .ic{flex-shrink:0;width:40px;height:40px;border-radius:8px;background:var(--gd);display:flex;align-items:center;justify-content:center;color:#fff}
.rea__i h4{font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;font-size:.95rem}
.rea__i p{font-size:.82rem;color:#bdbdbd}
.prod{display:grid;grid-template-columns:1fr 1fr;gap:3rem;padding:1rem 0 3rem;align-items:start}
.prod__media{background:#f4f4f1;border:1px solid var(--border);border-radius:16px;padding:20px;position:relative}
.prod__media img{width:100%;height:auto;object-fit:contain}
.prod-bandeau{max-width:1200px;margin:1.2rem auto 0;padding:0 24px}
.prod-bandeau img{width:100%;max-height:420px;object-fit:cover;border-radius:14px}
.eye{display:inline-block;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--gd);font-size:.85rem}
.prod h1{font-size:clamp(2rem,4vw,3rem);font-weight:900;margin:.3rem 0}
.prod__st{font-family:'Barlow Condensed';font-weight:700;font-size:1.2rem;color:var(--gray);text-transform:uppercase}
.badges{display:flex;gap:.6rem;flex-wrap:wrap;margin:1.2rem 0}
.badge{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:10px;padding:.5rem .9rem;background:#fff}
.badge .k{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gray);font-family:'Barlow Condensed';font-weight:700}
.badge .v{font-weight:800;font-family:'Barlow Condensed'}
.prod__lead{color:#444;margin:1rem 0}
.prix{font-family:'Barlow Condensed';font-weight:900;font-size:1.5rem;margin:.4rem 0 1rem}
.prod__cta{display:flex;gap:.7rem;flex-wrap:wrap;align-items:center}
.prod__rea{list-style:none;margin:1.4rem 0 0;display:grid;gap:.5rem}
.prod__rea li{display:flex;gap:.5rem;align-items:center;font-size:.92rem;color:#333}
.prod__rea .ic{color:var(--gd);display:inline-flex}
.decl{display:flex;gap:.6rem;flex-wrap:wrap;margin:.6rem 0 0}
.decl span{width:34px;height:34px;border-radius:50%;border:2px solid var(--border)}
.content ul{list-style:none;margin:.4rem 0}.content ul li{padding-left:1.4rem;position:relative;margin:.4rem 0;color:#444}
.content ul li:before{content:"";position:absolute;left:0;top:.55em;width:7px;height:7px;background:var(--g);border-radius:2px;transform:rotate(45deg)}
.acc{border-top:2px solid var(--ink);margin:2.5rem 0}
.acc__i{border-bottom:1px solid var(--border)}
.acc__h{width:100%;display:flex;justify-content:space-between;align-items:center;background:none;border:0;cursor:pointer;padding:1.2rem .2rem;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;font-size:1.15rem;color:var(--ink)}
.acc__h .pl{color:var(--g);font-size:1.4rem;transition:.3s}
.acc__i.open .acc__h .pl{transform:rotate(45deg)}
.acc__b{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s ease}
.acc__i.open .acc__b{grid-template-rows:1fr}
.acc__bi{overflow:hidden}
.acc__c{padding:0 .2rem 1.4rem}
.form{display:flex;flex-direction:column;gap:1rem;background:#fff;border:1px solid var(--border);border-radius:14px;padding:2rem;box-shadow:0 14px 30px -22px rgba(0,0,0,.2)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form label{font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;font-size:.82rem;letter-spacing:.04em;display:flex;flex-direction:column;gap:.35rem}
.form input,.form select,.form textarea{font:inherit;padding:.8rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);font-family:'Barlow',sans-serif;text-transform:none;font-weight:400}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--g)}
.form__check{flex-direction:row;align-items:flex-start;gap:.6rem;font-weight:400;font-size:.85rem;text-transform:none;letter-spacing:0;color:#555}
.alert{padding:1rem 1.2rem;border-radius:10px;margin-bottom:1.2rem}
.alert--ok{background:#e8f3da;color:#3b6d11}.alert--err{background:#fbe9e9;color:#9a2727}
.foot{background:var(--ink);color:#bdbdbd;padding:3.5rem 0 0}
.foot__g{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem}
.foot h4{color:#fff;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;margin-bottom:.8rem}
.foot a{color:#bdbdbd}.foot a:hover{color:var(--g)}.foot ul{list-style:none}.foot li{margin:.35rem 0;font-size:.9rem}
.foot__b{border-top:1px solid #2a2a2a;margin-top:2.5rem;padding:1.2rem 0;text-align:center;font-size:.82rem;color:#777}
.mbar{position:fixed;bottom:0;left:0;right:0;display:none;z-index:95;box-shadow:0 -6px 20px rgba(0,0,0,.15)}
.mbar a{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.95rem;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.mbar .d{background:var(--gd);color:#fff}.mbar .c{background:var(--ink);color:#fff}
.reveal{opacity:0;transform:translateY(26px);transition:.8s cubic-bezier(.32,.72,0,1)}.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
/* PRESTATIONS (accordeon .jmp) */
.jmp{background:var(--bg);padding:4.5rem 5vw 5rem;font-family:'Barlow Condensed',sans-serif}
.jmp-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:2.5rem;gap:20px;flex-wrap:wrap}
.jmp-eyebrow{display:block;font-size:10px;font-weight:800;letter-spacing:.28em;text-transform:uppercase;color:var(--gd);margin-bottom:10px}
.jmp-title{font-size:clamp(36px,5vw,58px);font-weight:900;line-height:.9;text-transform:uppercase;color:var(--ink)}
.jmp-title span{color:var(--g)}
.jmp-head-cta{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:14px 26px;border-radius:5px;transition:.2s}
.jmp-head-cta:hover{background:var(--g);color:#10210a}
.jmp-list{display:flex;flex-direction:column;border-top:2px solid var(--ink)}
.jmp-item{border-bottom:1px solid var(--border);overflow:hidden}
.jmp-trigger{display:flex;align-items:center;gap:16px;width:100%;background:none;border:none;cursor:pointer;padding:18px 14px;text-align:left;transition:background .25s}
.jmp-num{flex-shrink:0;width:32px;height:32px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900;color:var(--gray);transition:.25s}
.jmp-icon{flex-shrink:0;width:34px;height:34px;display:flex;align-items:center;justify-content:center;opacity:.5}
.jmp-icon svg{width:22px;height:22px;fill:var(--ink)}
.jmp-tname{flex:1;font-size:clamp(17px,2.4vw,25px);font-weight:800;text-transform:uppercase;color:var(--ink);transition:.2s}
.jmp-arrow{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:transform .35s}
.jmp-arrow svg{fill:var(--ink)}
.jmp-item.open .jmp-arrow{transform:rotate(45deg)}
.jmp-item.open .jmp-trigger{background:var(--g)}
.jmp-item.open .jmp-num{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.5);color:#fff}
.jmp-item.open .jmp-tname{color:#fff}
.jmp-item.open .jmp-arrow svg,.jmp-item.open .jmp-icon svg{fill:#fff}
.jmp-item.open .jmp-icon{opacity:1}
.jmp-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s ease}
.jmp-item.open .jmp-body{grid-template-rows:1fr}
.jmp-body-inner{overflow:hidden}
.jmp-content{padding:0 0 28px 84px;font-family:'Barlow',sans-serif}
.jmp-desc{font-size:14px;line-height:1.7;color:var(--gray);max-width:620px;margin-bottom:18px}
.jmp-points{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.jmp-point{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--border);color:var(--ink);font-family:'Barlow Condensed';font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px}
.jmp-point-dot{width:5px;height:5px;background:var(--g);border-radius:50%}
.jmp-brands{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px;align-items:center}
.jmp-brands-label{font-size:11px;color:var(--gray);text-transform:uppercase;letter-spacing:.08em;margin-right:4px}
.jmp-brand-pill{background:var(--ink);color:#fff;font-family:'Barlow Condensed';font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:4px 12px;border-radius:2px}
.jmp-item-cta{display:inline-flex;align-items:center;gap:8px;color:var(--gd);font-family:'Barlow Condensed';font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;border-bottom:1px solid var(--gd);padding-bottom:2px}
.jmp-item-cta svg{fill:currentColor}
.jmp-item.open .jmp-item-cta{color:var(--gd);border-color:var(--gd)}
@media(max-width:640px){.jmp{padding:3rem 5vw 3.5rem}.jmp-content{padding:0 0 22px 0}.jmp-tname{font-size:15px}.jmp-head-cta{width:100%;justify-content:center}}
@media(max-width:980px){.trust{grid-template-columns:1fr}.revs{grid-template-columns:1fr}.promo,.team,.actus{grid-template-columns:1fr}.prods{grid-template-columns:1fr 1fr}.grid{grid-template-columns:1fr 1fr}.rea__g{grid-template-columns:1fr 1fr}.prod{grid-template-columns:1fr}.foot__g{grid-template-columns:1fr 1fr}.promo__r{min-height:160px}}
@media(max-width:760px){.topnav,.subnav{display:none}.burger{display:block}body.nav-open .top{max-height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch}.top__bar{position:relative;flex-wrap:wrap}.topphone{display:none}body.nav-open .topnav{display:flex;flex-direction:column;order:3;width:100%;background:#fff;padding:.3rem 0 .4rem;gap:0}body.nav-open .topnav a{padding:.9rem .3rem;border-bottom:1px solid var(--border);font-size:1.05rem;color:var(--ink);border-bottom-color:var(--border)}body.nav-open .subnav{display:block;order:4;width:100%}.subnav__in{flex-direction:column;flex-wrap:nowrap;padding:0;max-width:none}.subnav__item{border-left:0;border-top:1px solid #2a2a2a;width:100%}.subnav__top{padding:.9rem 1rem;font-size:1rem;color:#fff;justify-content:space-between}.subnav__item:hover .subnav__top,.subnav__item:focus-within .subnav__top{color:#fff}.subnav__drop{position:static!important;opacity:1!important;visibility:visible!important;transform:none!important;box-shadow:none;border:0;border-radius:0;padding:.1rem 0 .5rem;min-width:0;background:#191919}.subnav__drop a{padding:.6rem 1rem .6rem 2rem;color:#d2d2d2;background:transparent;font-size:.95rem}.subnav__drop a:hover{background:rgba(255,255,255,.06);color:#fff}.prods,.grid,.foot__g,.promo__stats,.rea__g{grid-template-columns:1fr}.hero{min-height:auto;padding:1rem 0}.hero__door,.hero__glow{display:none}.hero__col{max-width:100%}.hero__ov{background:rgba(247,248,245,.6)}body{padding-bottom:58px}.mbar{display:flex}}
@media(max-width:480px){.grid{grid-template-columns:1fr}}

/* Carousel marques */
.brandcar{position:relative;display:flex;align-items:center;gap:12px}
.brandcar__row{display:flex;gap:24px;overflow-x:auto;scroll-behavior:smooth;scroll-snap-type:x mandatory;padding:6px 2px;flex:1;scrollbar-width:none}
.brandcar__row::-webkit-scrollbar{display:none}
.brandcar__item{flex:0 0 calc((100% - 48px)/3);scroll-snap-align:start;display:flex;align-items:center;justify-content:center;height:130px;background:#fff;border:1px solid var(--border);border-radius:14px}
.brandcar__item img{max-height:66px;max-width:80%;width:auto;object-fit:contain;filter:grayscale(1);opacity:.7;transition:.3s}
.brandcar__item:hover img{filter:none;opacity:1}
.brandcar__nav{flex:0 0 auto;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:24px;line-height:1;color:var(--ink);display:flex;align-items:center;justify-content:center;transition:.25s}
.brandcar__nav:hover{background:var(--g);color:#fff;border-color:var(--g)}
@media(max-width:760px){.brandcar__item{flex:0 0 calc((100% - 24px)/2);height:104px}.brandcar__nav{width:38px;height:38px}}

/* Hero slider */
.heroslider{position:relative;width:100%;max-width:none;margin:0;border-radius:0;overflow:hidden}
.hs__track{position:relative;height:clamp(500px,46vw,600px)}
.hs__slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease;pointer-events:none}
.hs__slide.on{opacity:1;pointer-events:auto}
.hs__bg{position:absolute;inset:0;background:linear-gradient(105deg,#f7f8f5 0%,#eef1ea 60%,#e6eae1 100%)}
.hs__bg:after{content:none}
.hs__in{position:relative;height:100%;max-width:1280px;margin:0 auto;padding:0 5vw;display:flex;align-items:center}
.hs__txt{max-width:540px;z-index:2}
.hs__eye{font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--gd);font-size:.86rem}
.hs__txt h1{font-family:'Barlow Condensed';font-weight:900;text-transform:uppercase;font-size:clamp(2.4rem,4.6vw,4rem);line-height:.95;margin:.45rem 0}
.hs__txt h1 .gr{color:var(--g)}
.hs__txt p{color:#2c2c2c;font-size:1.06rem;line-height:1.45;margin-bottom:1.4rem;max-width:450px}
.hs__cta{display:flex;gap:12px;flex-wrap:wrap}
.hs__door{position:absolute;right:3%;bottom:0;height:98%;width:auto;max-width:50%;object-fit:contain;object-position:bottom;filter:drop-shadow(-24px 22px 38px rgba(0,0,0,.28));z-index:1;pointer-events:none}
.hs__nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;border:0;background:rgba(255,255,255,.92);color:var(--ink);font-size:26px;line-height:1;cursor:pointer;z-index:4;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(0,0,0,.18);transition:.25s}
.hs__nav:hover{background:var(--g);color:#fff}.hs__prev{left:14px}.hs__next{right:14px}
.hs__dots{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:4}
.hs__dots button{width:10px;height:10px;border-radius:50%;border:0;background:rgba(0,0,0,.28);cursor:pointer;padding:0;transition:.25s}
.hs__dots button.on{background:var(--g);width:26px;border-radius:6px}
@media(max-width:760px){.hs__track{height:392px}.hs__door{display:none}.hs__in{padding:0 22px}.heroslider{margin:10px;border-radius:14px}}

/* Hero slider - animations d'entree */
.hs__slide .hs__eye,.hs__slide .hs__txt h1,.hs__slide .hs__txt p,.hs__slide .hs__cta{opacity:0;transform:translateY(24px)}
.hs__slide .hs__door,.hs__slide .hs__photo{opacity:0;transform:translateX(48px)}
.hs__slide.on .hs__eye{animation:hsUp .7s .12s forwards cubic-bezier(.22,.61,.36,1)}
.hs__slide.on .hs__txt h1{animation:hsUp .75s .26s forwards cubic-bezier(.22,.61,.36,1)}
.hs__slide.on .hs__txt p{animation:hsUp .75s .42s forwards cubic-bezier(.22,.61,.36,1)}
.hs__slide.on .hs__cta{animation:hsUp .75s .58s forwards cubic-bezier(.22,.61,.36,1)}
.hs__slide.on .hs__door,.hs__slide.on .hs__photo{animation:hsDoor .9s .18s forwards cubic-bezier(.22,.61,.36,1)}
@keyframes hsUp{to{opacity:1;transform:none}}
@keyframes hsDoor{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.hs__slide .hs__eye,.hs__slide .hs__txt h1,.hs__slide .hs__txt p,.hs__slide .hs__cta,.hs__slide .hs__door,.hs__slide .hs__photo{opacity:1;transform:none;animation:none}}

/* Avis Google */
.grev{max-width:1040px;margin:0 auto}
.grev__card{display:flex;align-items:center;gap:20px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:20px 26px;box-shadow:0 10px 30px rgba(0,0,0,.06);flex-wrap:wrap;justify-content:center}
.grev__info{text-align:left}
.grev__top{display:flex;align-items:center;gap:10px}
.grev__top b{font-family:'Barlow Condensed';font-size:2.3rem;font-weight:900;line-height:1;color:var(--ink)}
.grev__stars{color:#fbbc05;font-size:1.25rem;letter-spacing:2px}
.grev__sub{color:#666;font-size:.95rem;margin-top:2px}
.grev__card .btn{margin-left:auto}
.grev__list{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:22px}
.grev__rev{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px;text-align:left}
.grev__rh{display:flex;align-items:center;gap:10px}
.grev__av{width:40px;height:40px;border-radius:50%;background:var(--g);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-family:"Barlow Condensed";font-size:1.1rem;flex:0 0 auto}
.grev__n{font-weight:700;font-size:.95rem}
.grev__d{color:#888;font-size:.8rem}
.grev__rh .grev__gg{margin-left:auto}
.grev__st{color:#fbbc05;letter-spacing:2px;margin:8px 0}
.grev__txt{color:#444;font-size:.92rem;line-height:1.5}
@media(max-width:860px){.grev__list{grid-template-columns:1fr}.grev__card{justify-content:flex-start}.grev__card .btn{margin-left:0;width:100%;justify-content:center}}

/* Pages locales (zones) */
.zhero{background:linear-gradient(135deg,#f3f5ef,#fff);border-bottom:1px solid var(--border);padding:2.6rem 0}
.zhero__in{max-width:920px}
.zhero__eye{font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--gd);font-size:.86rem}
.zhero h1{font-family:'Barlow Condensed';font-weight:900;text-transform:uppercase;font-size:clamp(2rem,4vw,3.1rem);line-height:1;margin:.5rem 0 .7rem}
.zhero__lead{color:#333;font-size:1.08rem;line-height:1.5;max-width:680px}
.zhero__cta{display:flex;gap:12px;flex-wrap:wrap;margin:1.3rem 0 1rem}
.zhero__badges{display:flex;gap:8px;flex-wrap:wrap}
.zhero__badges span{background:#fff;border:1px solid var(--border);border-radius:30px;padding:.35rem .9rem;font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;font-size:.74rem;letter-spacing:.05em;color:#444}
.zsvc{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.zsvc__c{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:1.1rem 1.2rem;transition:.25s}
.zsvc__c:hover{border-color:var(--g);box-shadow:0 10px 26px rgba(0,0,0,.07);transform:translateY(-2px)}
.zsvc__c h3{font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;font-size:1.02rem;color:var(--ink)}
.zsvc__a{color:var(--gd)}
.zwhy{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;text-align:center}
.zwhy div{background:#fff;border:1px solid var(--border);border-radius:14px;padding:1.3rem .8rem}
.zwhy b{display:block;font-family:'Barlow Condensed';font-weight:900;font-size:1.9rem;color:var(--g);line-height:1}
.zwhy span{display:block;color:#555;font-size:.9rem;margin-top:.3rem}
.zzone{margin-top:1.4rem;color:#444;background:#f7f8f5;border-left:3px solid var(--g);padding:1rem 1.2rem;border-radius:0 10px 10px 0}
.zfaq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.zfaq__i{background:#fff;border:1px solid var(--border);border-radius:12px;padding:0 1.2rem}
.zfaq__i summary{cursor:pointer;list-style:none;padding:1rem 0;font-family:'Barlow Condensed';font-weight:700;font-size:1.08rem;color:var(--ink);display:flex;justify-content:space-between;align-items:center}
.zfaq__i summary::-webkit-details-marker{display:none}
.zfaq__i summary::after{content:"+";color:var(--gd);font-size:1.4rem;font-weight:700}
.zfaq__i[open] summary::after{content:"–"}
.zfaq__a{padding:0 0 1rem;color:#444;line-height:1.55}
@media(max-width:860px){.zsvc{grid-template-columns:1fr 1fr}.zwhy{grid-template-columns:1fr 1fr}}

.foot__zones{max-width:1200px;margin:0 auto;padding:14px;border-top:1px solid rgba(255,255,255,.12);font-size:.85rem;color:#9aa0a6;line-height:1.9}
.foot__zones span{color:#cfd2d6;font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;margin-right:6px}
.foot__zones a{color:#9aa0a6;margin-right:12px}.foot__zones a:hover{color:var(--g)}

.hs__photo{position:absolute;right:3.5%;top:7%;bottom:7%;width:min(40%,460px);border-radius:20px;overflow:hidden;box-shadow:0 22px 50px rgba(0,0,0,.3);z-index:1}
.hs__photo img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:760px){.hs__photo{display:none}}

.hs__rate{display:flex;align-items:center;gap:8px;margin:.1rem 0 .9rem;flex-wrap:wrap}
.hs__rate b{font-family:'Barlow Condensed';font-weight:900;font-size:1.25rem;color:var(--ink)}
.hs__rate .hs__stars{color:#fbbc05;letter-spacing:1px}
.hs__rate .hs__rev{color:#555;font-size:.85rem}
.hs__list{list-style:none;margin:0 0 1.2rem;padding:0;display:flex;flex-direction:column;gap:6px}
.hs__list li{position:relative;padding-left:26px;color:#1d1d1d;font-weight:600;font-size:.98rem}
.hs__list li:before{content:"✓";position:absolute;left:0;top:-1px;color:#fff;background:var(--g);width:18px;height:18px;border-radius:50%;font-size:.7rem;display:flex;align-items:center;justify-content:center;font-weight:800}
@media(max-width:760px){.hs__list{display:none}.hs__rate{margin-bottom:.6rem}}

/* Panneau marque (section équipe) */
.team__panel{border-radius:16px;min-height:340px;background:linear-gradient(150deg,var(--g),var(--gd));color:#fff;padding:2rem 1.9rem;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.team__panel:before{content:"";position:absolute;right:-50px;top:-50px;width:220px;height:220px;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 70%);pointer-events:none}
.team__panel-h{font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.85);font-size:.85rem;margin-bottom:1.4rem;position:relative}
.team__stats{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem 1.2rem;position:relative}
.team__stats b{display:block;font-family:'Barlow Condensed';font-weight:900;font-size:2.3rem;line-height:1;color:#fff}
.team__stats span{display:block;color:#d2d2d2;font-size:.9rem;margin-top:.25rem;line-height:1.25}
.team__panel-cta{display:inline-flex;align-items:center;gap:8px;margin-top:1.7rem;color:#fff;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.95rem;border-bottom:2px solid #fff;padding-bottom:3px;width:fit-content;position:relative}
.team__panel-cta svg{fill:#fff}
@media(max-width:760px){.team__stats b{font-size:2rem}}

.chead__cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:1.1rem}
.svc{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.svc__c{background:#fff;border:1px solid var(--border);border-radius:16px;padding:1.6rem;box-shadow:0 10px 26px rgba(0,0,0,.05)}
.svc__c h3{font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;font-size:1.3rem;color:var(--ink);margin-bottom:.5rem}
.svc__c p{color:#555;margin-bottom:.8rem}
.svc__c ul{list-style:none;margin:0 0 1rem;padding:0;display:flex;flex-direction:column;gap:6px}
.svc__c li{position:relative;padding-left:24px;color:#222;font-size:.95rem}
.svc__c li:before{content:"✓";position:absolute;left:0;color:#fff;background:var(--g);width:17px;height:17px;border-radius:50%;font-size:.66rem;display:flex;align-items:center;justify-content:center;font-weight:800;top:2px}
.svc__cta{display:inline-flex;align-items:center;gap:7px;color:var(--gd);font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.92rem;border-bottom:1px solid var(--gd);padding-bottom:2px}
.svc__cta svg{fill:currentColor}
@media(max-width:760px){.svc{grid-template-columns:1fr}}

.art-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;color:#777;font-size:.85rem}
.art-rt{font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gd)}
.wapp{position:fixed;right:18px;bottom:18px;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(0,0,0,.28);z-index:95;transition:.25s}
.wapp:hover{transform:scale(1.08)}
@media(max-width:760px){.wapp{bottom:70px;right:14px;width:52px;height:52px}}

/* Diagnostic sécurité */
.topnav__hl{color:var(--gd) !important;font-weight:800 !important}
.btn--lg{font-size:1.05rem;padding:1rem 1.7rem}
.diagband{background:linear-gradient(120deg,#f3f5ef,#fff);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.diagband__in{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:2rem 0;flex-wrap:wrap}
.diagband__k{display:inline-block;font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--gd);font-size:.82rem;margin-bottom:.3rem}
.diagband__t h2{font-family:'Barlow Condensed';font-weight:900;text-transform:uppercase;font-size:clamp(1.5rem,3vw,2.2rem);line-height:1;color:var(--ink)}
.diagband__t p{color:#555;margin-top:.4rem}
.diag{background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:0 14px 40px rgba(0,0,0,.06);padding:1.8rem 1.8rem 2rem}
.diag__top{margin-bottom:1.6rem}
.diag__step{font-family:'Barlow Condensed';font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gd);font-size:.82rem}
.diag__bar{height:7px;background:#eceee8;border-radius:5px;margin-top:.5rem;overflow:hidden}
.diag__bar span{display:block;height:100%;background:var(--g);border-radius:5px;transition:width .35s ease}
.diag__q{font-family:'Barlow Condensed';font-weight:800;font-size:1.55rem;line-height:1.1;color:var(--ink);margin-bottom:1.2rem}
.diag__opts{display:flex;flex-direction:column;gap:10px}
.diag__opt{text-align:left;background:#f7f8f5;border:1.5px solid var(--border);border-radius:12px;padding:1rem 1.1rem;font-size:1rem;cursor:pointer;transition:.18s;font-weight:600;color:var(--ink)}
.diag__opt:hover{border-color:var(--g);background:#fff;transform:translateY(-1px);box-shadow:0 8px 20px rgba(0,0,0,.07)}
.diag__back{margin-top:1.2rem;background:none;border:0;color:var(--gray);cursor:pointer;font-size:.92rem}
.diag__res{display:flex;gap:2rem;align-items:center;flex-wrap:wrap}
.diag__gauge{position:relative;width:150px;height:150px;flex:0 0 auto;margin:0 auto}
.diag__gauge svg{width:150px;height:150px}
.diag__num{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.diag__num b{font-family:'Barlow Condensed';font-weight:900;font-size:2.6rem;line-height:1;color:var(--ink)}
.diag__num span{color:var(--gray);font-size:.85rem}
.diag__resb{flex:1;min-width:260px}
.diag__lvl{display:block;font-family:'Barlow Condensed';font-weight:900;text-transform:uppercase;font-size:1.4rem;margin-bottom:.4rem}
.diag__intro{color:#444;margin-bottom:.6rem}
.diag__rec{list-style:none;margin:0 0 1.2rem;padding:0;display:flex;flex-direction:column;gap:8px}
.diag__rec li{position:relative;padding-left:26px;color:#222;line-height:1.4}
.diag__rec li:before{content:"✓";position:absolute;left:0;top:1px;color:#fff;background:var(--g);width:18px;height:18px;border-radius:50%;font-size:.7rem;display:flex;align-items:center;justify-content:center;font-weight:800}
.diag__cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:.8rem}
@media(max-width:760px){.diagband__in{flex-direction:column;align-items:flex-start;gap:1rem}.diag__res{flex-direction:column;text-align:center}.diag__rec{text-align:left}}

.promo__cd{display:flex;gap:10px;margin:1.2rem 0 .2rem;flex-wrap:wrap}
.promo__cd>div{min-width:64px;text-align:center;background:#f4f6ef;border:1px solid var(--border);border-radius:10px;padding:.5rem .4rem}
.promo__cd b{display:block;font-family:'Barlow Condensed';font-weight:900;font-size:1.8rem;line-height:1;color:var(--gd)}
.promo__cd span{font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;color:var(--gray)}
.promo__cdend{font-family:'Barlow Condensed';font-weight:800;text-transform:uppercase;color:var(--gd)}

.promo__img{width:100%;height:100%;object-fit:cover;display:block;border-radius:0 16px 16px 0}
@media(max-width:760px){.promo__img{border-radius:0 0 16px 16px;max-height:240px}}

.promo__txt{color:#444;margin:.3rem 0 0;font-size:1.02rem}
.promo__cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:1.4rem}
.promo__r{min-height:230px}
