:root{--navy:#0f2744;--blue:#0066cc;--blue-dk:#004499;--off:#f4f6f9;--white:#fff;--border:#e2ddd6;--text:#1a1612;--muted:#6b6560;--green:#0a7c4e;--green-lt:#e6f7f0;--amber:#b45000;--hd:'Barlow Condensed',sans-serif;--bd:'Inter',sans-serif;--r:10px;--r-lg:14px;--max:1400px;--px:clamp(16px,4vw,52px);--py:clamp(32px,5vw,56px);--nav-h:68px;--header-h:97px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--bd);color:var(--text);background:#fff;-webkit-font-smoothing:antialiased;padding-top:var(--header-h);padding-top:calc(var(--header-h) + constant(safe-area-inset-top));padding-top:calc(var(--header-h) + env(safe-area-inset-top))}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;top:-100%;left:0;background:var(--blue);color:#fff;padding:8px 16px;border-radius:0 0 8px 0;font-size:14px;z-index:9999;transition:top .2s}
.skip-link:focus{top:0}
.topbar{background:var(--navy);color:rgba(255,255,255,.65);font-size:12px;padding:6px var(--px);display:flex;justify-content:space-between;align-items:center;gap:12px;position:fixed;top:0;left:0;right:0;z-index:200;padding-top:6px;padding-top:constant(safe-area-inset-top);padding-top:env(safe-area-inset-top);height:28px;height:calc(28px + constant(safe-area-inset-top));height:calc(28px + env(safe-area-inset-top))}
.topbar a{color:rgba(255,255,255,.65);text-decoration:none;display:inline-flex;align-items:center;gap:4px}
.topbar a:hover{color:#fff;text-decoration:underline}
.tb-left,.tb-right{display:flex;align-items:center;gap:14px}
nav[role="navigation"]{position:fixed;top:28px;top:calc(28px + constant(safe-area-inset-top));top:calc(28px + env(safe-area-inset-top));left:0;right:0;z-index:199;background:#fff;border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h);padding:0 var(--px)}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-mark{width:44px;height:44px;background:var(--navy);border-radius:9px;position:relative;overflow:hidden;flex-shrink:0}
.logo-mark::before{content:'';position:absolute;width:28px;height:2.5px;background:#fff;top:13px;left:8px;border-radius:2px}
.logo-mark::after{content:'';position:absolute;width:18px;height:2.5px;background:var(--blue);bottom:13px;left:8px;border-radius:2px}
.logo-text{font-family:var(--hd);font-size:20px;font-weight:700;color:var(--navy);letter-spacing:.04em}
.nav-links{display:flex;align-items:center;gap:6px}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:8px;font-size:13px;font-family:var(--bd);cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:6px;min-height:44px;transition:border-color .15s,color .15s}
.btn-ghost:hover,.btn-ghost:focus{border-color:var(--navy);color:var(--navy)}
.btn-cta{background:var(--blue);color:#fff;border:none;padding:9px 18px;border-radius:8px;font-size:13px;font-weight:500;font-family:var(--bd);cursor:pointer;display:inline-flex;align-items:center;gap:6px;min-height:44px;text-decoration:none;transition:background .15s}
.btn-cta:hover,.btn-cta:focus{background:var(--blue-dk)}
.hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;gap:5px;background:none;border:1px solid var(--border);border-radius:8px;cursor:pointer;padding:0}
.hamburger span{display:block;width:20px;height:2px;background:var(--navy);border-radius:2px;transition:all .3s}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:#fff;z-index:99;box-shadow:0 8px 32px rgba(0,0,0,.12);flex-direction:column}
.mobile-menu[aria-hidden="false"]{display:flex}
.mm-contact{background:var(--navy);padding:14px var(--px)}
.mm-contact-title{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:9px}
.mm-btn-phone{background:var(--blue);color:#fff;border:none;border-radius:9px;padding:13px 16px;font-size:14px;font-weight:600;font-family:var(--bd);display:flex;align-items:center;gap:9px;width:100%;text-decoration:none;min-height:52px;margin-bottom:7px}
.mm-btns-row{display:flex;gap:7px}
.mm-btn-devis{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:9px;padding:11px 14px;font-size:13px;font-weight:500;font-family:var(--bd);cursor:pointer;display:flex;align-items:center;gap:7px;flex:1;min-height:44px;text-decoration:none}
.mm-btn-mail{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:9px;padding:11px 14px;display:flex;align-items:center;justify-content:center;text-decoration:none;min-height:44px;min-width:44px}
.mm-nav{padding:8px var(--px);display:flex;flex-direction:column}
.mm-nav a{display:flex;align-items:center;gap:9px;padding:13px 0;color:var(--text);text-decoration:none;font-size:14px;font-weight:500;border-bottom:1px solid var(--border)}
.mm-nav a:last-child{border-bottom:none}
.mm-nav a:hover{color:var(--blue)}
.hero{position:relative;overflow:hidden;padding:var(--py) var(--px);min-height:480px}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(155deg,rgba(8,18,45,.9) 0%,rgba(12,32,72,.82) 45%,rgba(18,48,100,.75) 100%);z-index:1}
.hero-inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,52px);align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(0,102,204,.22);border:1px solid rgba(0,102,204,.4);border-radius:20px;padding:5px 12px;font-size:11px;color:#a8cfff;margin-bottom:14px;font-weight:500}
.hero h1{font-family:var(--hd);font-size:clamp(28px,4.2vw,46px);font-weight:700;color:#fff;line-height:1.12;margin-bottom:12px;letter-spacing:.01em}
.hero h1 em{font-style:normal;color:#7ec8ff}
.hero-desc{font-size:clamp(13px,1.4vw,15px);color:rgba(255,255,255,.75);line-height:1.7;margin-bottom:22px}
.hero-btns{display:flex;gap:10px;flex-wrap:wrap}
.btn-hero{background:var(--blue);color:#fff;border:none;padding:13px 24px;border-radius:9px;font-size:14px;font-weight:500;font-family:var(--bd);cursor:pointer;display:inline-flex;align-items:center;gap:7px;min-height:50px;text-decoration:none;transition:background .15s}
.btn-hero:hover{background:var(--blue-dk)}
.btn-hero-sec{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.28);padding:12px 20px;border-radius:9px;font-size:14px;font-family:var(--bd);cursor:pointer;display:inline-flex;align-items:center;gap:7px;text-decoration:none;min-height:50px}
.btn-hero-sec:hover{background:rgba(255,255,255,.2)}
.hero-cards{display:flex;flex-direction:column;gap:10px}
.hcard{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:11px;padding:14px 16px;display:flex;align-items:center;gap:12px;transition:all .2s;text-decoration:none}
.hcard:hover{background:rgba(255,255,255,.18);transform:translateX(4px)}
.hcard-icon{width:40px;height:40px;border-radius:9px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hcard-icon svg{stroke:#fff;fill:none;width:20px;height:20px;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
.hcard-text h3{font-family:var(--hd);font-size:13.5px;font-weight:600;color:#fff;margin-bottom:2px}
.hcard-text p{font-size:11.5px;color:rgba(255,255,255,.6)}
.hcard-arr{margin-left:auto;color:rgba(255,255,255,.4)}
.stats{background:var(--off);border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap}
.stat{flex:1;min-width:80px;padding:clamp(14px,2vw,22px) 12px;text-align:center;border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat-icon{display:flex;justify-content:center;margin-bottom:5px;color:var(--blue)}
.stat-icon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
.stat-n{font-family:var(--hd);font-size:clamp(20px,3vw,26px);font-weight:700;color:var(--navy)}
.stat-l{font-size:11px;color:var(--muted);margin-top:2px}
.section{padding:var(--py) var(--px)}
.section-inner{max-width:var(--max);margin:0 auto}
.section-label{font-size:11px;font-weight:600;letter-spacing:.1em;color:var(--blue);text-transform:uppercase;margin-bottom:6px}
.section-title{font-family:var(--hd);font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--navy);letter-spacing:.01em;margin-bottom:6px}
.section-sub{font-size:14px;color:var(--muted);line-height:1.65;max-width:540px;margin-bottom:clamp(16px,3vw,26px)}
.section-title-row{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:6px}
.see-all{font-size:13px;color:var(--blue);text-decoration:none;font-weight:500;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.see-all:hover{text-decoration:underline}
.sep{height:1px;background:var(--border)}
.gammes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,260px),1fr));gap:12px}
.gamme-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:20px;cursor:pointer;transition:all .2s;text-decoration:none;display:block;position:relative;overflow:hidden}
.gamme-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue);transform:scaleY(0);transition:transform .25s;transform-origin:bottom}
.gamme-card:hover,.gamme-card:focus{border-color:var(--blue);box-shadow:0 4px 14px rgba(0,102,204,.1);transform:translateY(-2px);outline:none}
.gamme-card:hover::before,.gamme-card:focus::before{transform:scaleY(1)}
.gamme-icon{width:40px;height:40px;border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.gamme-card h3{font-family:var(--hd);font-size:14px;font-weight:700;color:var(--navy);margin-bottom:4px}
.gamme-card p{font-size:12.5px;color:var(--muted);line-height:1.5}
.produits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,195px),1fr));gap:11px}
.prod-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:all .2s;display:flex;flex-direction:column;text-decoration:none}
.prod-card:hover,.prod-card:focus{border-color:var(--blue);box-shadow:0 5px 18px rgba(0,102,204,.12);transform:translateY(-3px);outline:none}
.prod-thumb{height:110px;display:flex;align-items:center;justify-content:center;position:relative;background:#fff;border-bottom:1px solid #e2ddd6;overflow:hidden}
.prod-thumb img{width:100%;height:100%;object-fit:contain;padding:10px}
.prod-badge{position:absolute;top:7px;right:7px;font-size:9px;font-weight:600;padding:2px 7px;border-radius:20px;background:rgba(0,102,204,.1);color:var(--blue)}
.prod-body{padding:11px 13px;flex:1}
.prod-ref{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px}
.prod-body h3{font-family:var(--hd);font-size:12.5px;font-weight:700;color:var(--navy);margin-bottom:3px;line-height:1.3}
.prod-body p{font-size:11.5px;color:var(--muted);line-height:1.5}
.prod-footer{padding:7px 13px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--off)}
.dispo{font-size:11px;display:flex;align-items:center;gap:4px;font-weight:500}
.dispo.ok{color:var(--green)}
.dispo.cmd{color:var(--amber)}
.dispo-dot{width:5px;height:5px;border-radius:50%}
.dispo-dot.ok{background:var(--green)}
.dispo-dot.cmd{background:var(--amber)}
.loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--muted);font-size:13px}
.spinner{width:24px;height:24px;border:2.5px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.cta-band{background:linear-gradient(110deg,var(--blue),var(--blue-dk));padding:var(--py) var(--px);text-align:center}
.cta-band h2{font-family:var(--hd);font-size:clamp(20px,3vw,28px);font-weight:700;color:#fff;margin-bottom:8px;letter-spacing:.01em}
.cta-band p{font-size:14px;color:rgba(255,255,255,.82);margin-bottom:clamp(16px,3vw,26px);line-height:1.6}
.cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-white{background:#fff;color:var(--blue);border:none;padding:13px 24px;border-radius:9px;font-size:14px;font-weight:600;font-family:var(--bd);cursor:pointer;display:inline-flex;align-items:center;gap:7px;min-height:50px;text-decoration:none;transition:opacity .15s}
.btn-white:hover{opacity:.9}
.btn-ghost-w{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.45);padding:12px 20px;border-radius:9px;font-size:14px;font-family:var(--bd);display:inline-flex;align-items:center;gap:7px;text-decoration:none;min-height:50px}
.btn-ghost-w:hover{background:rgba(255,255,255,.1)}
.breadcrumb{padding:12px var(--px);background:var(--off);border-bottom:1px solid var(--border);font-size:12px}
.breadcrumb-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.breadcrumb a{color:var(--muted);text-decoration:none}
.breadcrumb a:hover{color:var(--navy);text-decoration:underline}
.breadcrumb strong{color:var(--text)}
footer{background:var(--navy);color:rgba(255,255,255,.55);padding:clamp(24px,3vw,36px) var(--px) clamp(16px,2vw,24px)}
.footer-inner{max-width:var(--max);margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(20px,4vw,48px);margin-bottom:clamp(16px,3vw,32px)}
.footer-brand p{font-size:12.5px;color:rgba(255,255,255,.5);line-height:1.7;margin-top:10px;max-width:260px}
.footer-col h4{font-family:var(--hd);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:12px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:7px}
.footer-col a{font-size:12.5px;color:rgba(255,255,255,.55);text-decoration:none;display:flex;align-items:center;gap:6px}
.footer-col a:hover{color:#fff;text-decoration:underline}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:clamp(12px,2vw,18px);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:11.5px}
.footer-legal{display:flex;gap:16px;flex-wrap:wrap}
.footer-legal a{color:rgba(255,255,255,.4);text-decoration:none}
.footer-legal a:hover{color:#fff}
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:300;align-items:center;justify-content:center;padding:16px}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:var(--r-lg);width:100%;max-width:520px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal-head{background:linear-gradient(110deg,var(--navy),#1e4d7b);padding:20px 24px;display:flex;justify-content:space-between;align-items:flex-start}
.modal-head h2{font-family:var(--hd);font-size:18px;font-weight:700;color:#fff;margin-bottom:3px}
.modal-head p{font-size:12px;color:rgba(255,255,255,.65)}
.modal-close{background:rgba(255,255,255,.15);border:none;color:#fff;width:32px;height:32px;border-radius:7px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.modal-close:hover{background:rgba(255,255,255,.25)}
.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:10px}
.f-group{display:flex;flex-direction:column;gap:3px}
.f-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.f-req{color:var(--blue);margin-left:2px}
.f-inp,.f-sel,.f-ta{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:7px;font-size:13px;font-family:var(--bd);outline:none;background:#fff;min-height:44px;transition:border-color .15s}
.f-inp:focus,.f-sel:focus,.f-ta:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,102,204,.12)}
.f-ta{resize:vertical;min-height:80px}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.btn-submit{width:100%;background:var(--blue);color:#fff;border:none;padding:13px;border-radius:8px;font-size:14px;font-weight:600;font-family:var(--hd);cursor:pointer;min-height:50px;display:flex;align-items:center;justify-content:center;gap:7px;transition:background .15s}
.btn-submit:hover{background:var(--blue-dk)}
.success-banner{background:var(--green-lt);border:1px solid #a8e6cc;border-radius:8px;padding:14px;font-size:13px;color:var(--green);text-align:center;display:none;align-items:center;justify-content:center;gap:7px}
.contact-strip{padding:var(--py) var(--px);background:#fff;border-top:1px solid var(--border)}
.contact-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));gap:14px}
.contact-card{border:1px solid var(--border);border-radius:var(--r);padding:20px;text-align:center;transition:border-color .2s}
.contact-card:hover{border-color:var(--blue)}
.cc-icon{width:48px;height:48px;border-radius:12px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center}
.cc-icon svg{width:22px;height:22px;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
.contact-card h3{font-family:var(--hd);font-size:14px;font-weight:700;color:var(--navy);margin-bottom:4px}
.contact-card p{font-size:12.5px;color:var(--muted);line-height:1.55;margin-bottom:12px}
.cc-btn{width:100%;padding:10px;border-radius:8px;font-size:13px;font-weight:500;font-family:var(--bd);cursor:pointer;border:1px solid var(--border);background:#fff;color:var(--navy);transition:all .15s;min-height:44px;display:flex;align-items:center;justify-content:center;gap:6px;text-decoration:none}
.cc-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.contact-grid{display:grid;grid-template-columns:1fr 380px;gap:clamp(24px,4vw,52px);align-items:start;max-width:var(--max);margin:0 auto;padding:clamp(20px,4vw,48px) var(--px)}
.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.form-head{background:linear-gradient(110deg,var(--navy),#1e4d7b);padding:22px 24px}
.form-head h2{font-family:var(--hd);font-size:20px;font-weight:700;color:#fff;margin-bottom:4px}
.form-head p{font-size:13px;color:rgba(255,255,255,.7)}
.form-body{padding:22px 24px;display:flex;flex-direction:column;gap:13px}
.fg{display:flex;flex-direction:column;gap:4px}
.fl{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.fi,.fs,.ft{width:100%;padding:11px 13px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:var(--bd);outline:none;background:#fff;min-height:48px;transition:border-color .15s}
.fi:focus,.fs:focus,.ft:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,102,204,.1)}
.ft{resize:vertical;min-height:100px}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.btn-sub{width:100%;background:var(--blue);color:#fff;border:none;padding:15px;border-radius:9px;font-size:15px;font-weight:700;font-family:var(--hd);cursor:pointer;min-height:54px;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.02em;transition:background .15s}
.btn-sub:hover{background:var(--blue-dk)}
.ok-box{background:var(--green-lt);border:1px solid #a8e6cc;border-radius:9px;padding:18px;text-align:center;display:none;flex-direction:column;gap:6px;align-items:center}
.ok-box h3{font-family:var(--hd);font-size:16px;color:var(--green);font-weight:700}
.info-aside{display:flex;flex-direction:column;gap:16px}
.ic{border:1px solid var(--border);border-radius:var(--r);padding:20px;background:#fff;transition:border-color .2s}
.ic:hover{border-color:var(--blue)}
.ic-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.ic h3{font-family:var(--hd);font-size:15px;font-weight:700;color:var(--navy);margin-bottom:5px}
.ic p{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:10px}
.ic a{color:var(--blue);text-decoration:none;font-size:13.5px;font-weight:500}
.ic a:hover{text-decoration:underline}
.horaires{background:var(--off);border-radius:8px;padding:12px 14px;font-size:12.5px;color:var(--muted);margin-top:8px;line-height:1.7}
.adrs{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.adr{background:var(--off);border-radius:8px;padding:12px;font-size:12px;color:var(--muted);line-height:1.6}
.adr strong{display:block;color:var(--navy);font-weight:600;margin-bottom:3px}
.fiche-layout{display:grid;grid-template-columns:1fr 380px;gap:clamp(20px,3vw,40px);max-width:var(--max);margin:0 auto;padding:clamp(16px,3vw,32px) var(--px)}
.img-main{background:#fff;border-bottom:1px solid #e2ddd6;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;margin-bottom:10px;border:1px solid var(--border)}
.img-main img{width:100%;height:100%;object-fit:contain;padding:24px}
.fiche-header{margin-bottom:clamp(16px,3vw,28px)}
.fiche-gamme{font-size:11px;font-weight:600;letter-spacing:.08em;color:var(--blue);text-transform:uppercase;margin-bottom:6px}
.fiche-header h1{font-family:var(--hd);font-size:clamp(20px,3.5vw,30px);font-weight:700;color:var(--navy);margin-bottom:6px;line-height:1.15}
.fiche-ref{display:inline-flex;align-items:center;gap:6px;background:var(--off);border:1px solid var(--border);border-radius:6px;padding:4px 11px;font-size:12px;font-weight:600;color:var(--muted);font-family:monospace;letter-spacing:.05em;margin-bottom:12px}
.dispo-banner{display:flex;align-items:center;gap:8px;padding:9px 14px;border-radius:9px;font-size:13px;font-weight:500;margin-bottom:14px}
.dispo-banner.ok{background:var(--green-lt);border:1px solid #b8dfc9;color:var(--green)}
.dispo-banner.cmd{background:#fff6f0;border:1px solid #f5c9a8;color:var(--amber)}
.dispo-dot-lg{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dispo-dot-lg.ok{background:var(--green)}
.dispo-dot-lg.cmd{background:var(--amber)}
.tabs{border-bottom:1px solid var(--border);margin-bottom:20px;display:flex;gap:0;overflow-x:auto}
.tab{padding:10px 16px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;transition:all .15s;white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none;font-family:var(--bd);min-height:44px}
.tab:hover{color:var(--navy)}
.tab.active{color:var(--navy);border-bottom-color:var(--blue);font-weight:600}
.tab-content{display:none}
.tab-content.active{display:block}
.specs-table{width:100%;border-collapse:collapse;font-size:13px}
.specs-table tr{border-bottom:1px solid var(--border)}
.specs-table td{padding:10px 8px;vertical-align:top}
.specs-table td:first-child{font-weight:500;color:var(--muted);width:45%;padding-left:0}
.aside-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;margin-bottom:14px}
.aside-card-head{background:linear-gradient(110deg,var(--navy),#1e4d7b);padding:16px;text-align:center}
.aside-card-head h3{font-family:var(--hd);font-size:16px;font-weight:700;color:#fff;margin-bottom:3px}
.aside-card-head p{font-size:12px;color:rgba(255,255,255,.65)}
.aside-card-body{padding:16px;display:flex;flex-direction:column;gap:9px}
.aside-field label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:4px}
.aside-field input,.aside-field select{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:7px;font-size:13px;font-family:var(--bd);outline:none;min-height:44px}
.aside-field input:focus,.aside-field select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,102,204,.1)}
.btn-devis-lg{width:100%;background:var(--blue);color:#fff;border:none;padding:13px;border-radius:8px;font-size:14px;font-weight:600;font-family:var(--hd);cursor:pointer;min-height:50px;display:flex;align-items:center;justify-content:center;gap:7px;transition:background .15s}
.btn-devis-lg:hover{background:var(--blue-dk)}
.btn-phone-lg{width:100%;background:var(--off);color:var(--navy);border:1px solid var(--border);padding:11px;border-radius:8px;font-size:13px;font-weight:500;font-family:var(--bd);cursor:pointer;min-height:44px;display:flex;align-items:center;justify-content:center;gap:7px;text-decoration:none;transition:all .15s}
.btn-phone-lg:hover{background:#fff;border-color:var(--navy)}
.pdf-links{display:flex;flex-direction:column;gap:7px;padding:14px;border-top:1px solid var(--border)}
.pdf-link{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--off);border:1px solid var(--border);border-radius:8px;font-size:12.5px;color:var(--navy);text-decoration:none;font-weight:500;transition:all .15s;min-height:44px}
.pdf-link:hover{background:#fff;border-color:var(--blue);color:var(--blue)}
.fiche-aside{position:sticky;top:calc(var(--header-h) + 16px);align-self:start}
.legal-page{max-width:780px;margin:0 auto;padding:clamp(24px,4vw,48px) var(--px)}
.legal-page h1{font-family:var(--hd);font-size:clamp(22px,4vw,32px);font-weight:700;color:var(--navy);margin-bottom:8px}
.legal-date{font-size:12px;color:var(--muted);margin-bottom:32px}
.legal-page h2{font-family:var(--hd);font-size:18px;font-weight:700;color:var(--navy);margin:28px 0 10px;padding-bottom:6px;border-bottom:2px solid var(--off)}
.legal-page h3{font-family:var(--hd);font-size:15px;font-weight:600;color:var(--navy);margin:18px 0 7px}
.legal-page p{font-size:14px;color:var(--text);line-height:1.75;margin-bottom:10px}
.legal-page ul{font-size:14px;color:var(--text);line-height:1.75;margin:8px 0 14px 20px}
.legal-page li{margin-bottom:5px}
.legal-page a{color:var(--blue);text-decoration:underline}
.info-box{background:var(--off);border:1px solid var(--border);border-radius:9px;padding:16px 18px;margin:12px 0;font-size:13.5px;line-height:1.7}
@media(max-width:768px){
  nav[role="navigation"]{top:0!important}
  body{padding-top:69px!important}
  .topbar{display:none}
  .nav-links{display:none}
  .hamburger{display:flex}
  .mobile-menu[aria-hidden="false"]{display:flex}
  .hero-inner{grid-template-columns:1fr}
  .hero-btns{flex-direction:column}
  .btn-hero,.btn-hero-sec{width:100%;justify-content:center}
  .produits-grid{grid-template-columns:repeat(2,1fr)}
  .gammes-grid{grid-template-columns:repeat(2,1fr)}
  .cta-row{flex-direction:column;align-items:center}
  .modal-bg{align-items:flex-end;padding:0}
  .modal{border-radius:var(--r-lg) var(--r-lg) 0 0;max-width:100%}
  .f-row,.fr2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .fiche-layout{grid-template-columns:1fr}
  .fiche-aside{position:static}
  .contact-grid{grid-template-columns:1fr}
  .adrs{grid-template-columns:1fr}
}
@media(max-width:480px){
  .produits-grid{grid-template-columns:repeat(2,1fr)}
  .stat{flex:0 0 50%}
  .footer-grid{grid-template-columns:1fr}
}
@media(min-width:1440px){
  .produits-grid{grid-template-columns:repeat(5,1fr)}
  .gammes-grid{grid-template-columns:repeat(4,1fr)}
}
/* prod-footer homepage */
.prod-footer{padding:7px 13px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--off)}
.prod-link{font-size:11px;color:var(--blue);font-weight:500;white-space:nowrap}
