@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --tc:#0A6DB8;--tc2:#074F8A;--tcl:#D6EEFF;--tca:#00B4FF;
  --ink:#071E3D;--bdy:#4A5568;--smk:#F0F7FF;--smk2:#F8FBFF;
  --wh:#FFFFFF;--brd:#D4E6F5;--brd2:#E8F4FF;
  --tf:'Outfit',sans-serif;--bf:'DM Sans',sans-serif;
  --sh-sm:0 2px 8px rgba(7,30,61,.06);
  --sh-md:0 8px 32px rgba(7,30,61,.10);
  --sh-lg:0 20px 64px rgba(7,30,61,.14);
  --sh-bl:0 12px 40px rgba(10,109,184,.25);
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--bf);font-size:16px;color:var(--bdy);line-height:1.65;overflow-x:hidden;background:#fff}
a{text-decoration:none;color:inherit}
ul{list-style:none;padding:0;margin:0}
img{max-width:100%;display:block;height:auto}
h1,h2,h3,h4,h5{font-family:var(--tf);color:var(--ink);font-weight:700;line-height:1.2;margin:0}
p{margin:0}
button{cursor:pointer;border:none;background:none;font-family:inherit}
.wrap{max-width:1320px;margin:0 auto;padding:0 28px}
.wrap-sm{max-width:860px;margin:0 auto;padding:0 28px}
.sec{padding:108px 0}.sec-sm{padding:72px 0}.sec-xs{padding:48px 0}
.bg-smoke{background:var(--smk)}.bg-dark{background:var(--ink)}
/* BOUTONS */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--tf);font-size:15px;font-weight:700;padding:15px 30px;border-radius:50px;transition:all .35s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;z-index:1;letter-spacing:.01em;cursor:pointer;border:none}
.btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--tca),var(--tc2));opacity:0;transition:opacity .35s;z-index:-1}
.btn-primary{background:var(--tc);color:#fff}
.btn-primary:hover::before{opacity:1}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--sh-bl)}
.btn-outline{background:transparent;color:var(--ink);border:2px solid var(--brd)}
.btn-outline::before{background:var(--tc)}
.btn-outline:hover{color:#fff;border-color:var(--tc)}
.btn-white{background:#fff;color:var(--ink)}
.btn-white::before{background:var(--tc)}
.btn-white:hover{color:#fff}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.25)}
.btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn svg{width:16px;height:16px;flex-shrink:0;transition:transform .3s}
.btn:hover svg{transform:translateX(4px)}
.btn-sm{padding:11px 22px;font-size:13.5px}
.btn-lg{padding:18px 38px;font-size:17px}
/* EYEBROW */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--bf);font-weight:600;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--tc);margin-bottom:14px}
.ew-dots{display:flex;gap:4px}
.ew-dots span{width:6px;height:6px;border-radius:50%}
.ew-dots span:first-child{background:var(--tca)}
.ew-dots span:last-child{background:rgba(10,109,184,.3)}
.eyebrow-wh{color:rgba(255,255,255,.6)}
.eyebrow-wh .ew-dots span:first-child{background:rgba(255,255,255,.8)}
.eyebrow-wh .ew-dots span:last-child{background:rgba(255,255,255,.25)}
/* TITLES */
.sec-title{margin-bottom:56px}
.sec-title h2{font-size:46px;letter-spacing:-.035em;line-height:1.12}
.sec-title p{font-size:17px;color:var(--bdy);line-height:28px;max-width:580px;margin-top:16px}
.sec-title.center{text-align:center}.sec-title.center p{margin:16px auto 0}
.sec-title-wh h2{color:#fff}.sec-title-wh p{color:rgba(255,255,255,.5)}
.tc{color:var(--tc)!important}
.grad{background:linear-gradient(135deg,var(--tca),var(--tc));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
/* ICON */
.icon-w{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--tc),var(--tca));display:flex;align-items:center;justify-content:center;flex-shrink:0}
.icon-w svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.icon-w-sm{width:40px;height:40px;border-radius:10px}
.icon-w-sm svg{width:18px;height:18px}
.icon-w-lg{width:64px;height:64px;border-radius:16px}
.icon-w-lg svg{width:30px;height:30px}
/* PULSE */
.pulse-badge{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--tca);background:rgba(0,180,255,.08);border:1px solid rgba(0,180,255,.18);padding:5px 14px;border-radius:50px}
.pulse-dot{width:7px;height:7px;border-radius:50%;background:var(--tca);animation:pdot 2s ease-in-out infinite}
@keyframes pdot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
/* TOPBAR */
.topbar{background:var(--ink);padding:10px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.topbar-in{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;color:rgba(255,255,255,.4)}
.tb-badge{background:rgba(10,109,184,.3);border:1px solid rgba(10,180,255,.2);color:var(--tca);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 10px;border-radius:50px}
.tb-phone{color:var(--tcl)!important;font-weight:600;transition:.2s}
.tb-phone:hover{color:var(--tca)!important}
.tb-r{display:flex;align-items:center;gap:16px}
.tb-sep{color:rgba(255,255,255,.15)}
.tb-social{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:50px;transition:all .2s;border:1px solid transparent}
.tb-social span{letter-spacing:.03em}
.tb-wa{color:#25D366;border-color:rgba(37,211,102,.2);background:rgba(37,211,102,.08)}
.tb-wa:hover{background:rgba(37,211,102,.18);border-color:rgba(37,211,102,.35);color:#25D366}
.tb-ig{color:#E1306C;border-color:rgba(225,48,108,.2);background:rgba(225,48,108,.08)}
.tb-ig:hover{background:rgba(225,48,108,.18);border-color:rgba(225,48,108,.35);color:#E1306C}
/* HEADER */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);border-bottom:1px solid var(--brd);transition:box-shadow .3s}
.site-header.scrolled{box-shadow:var(--sh-md);border-color:rgba(10,109,184,.15)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;height:80px;gap:20px}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--tf);font-weight:800;font-size:21px;color:var(--ink);flex-shrink:0}
.logo-mark{width:38px;height:38px;background:linear-gradient(135deg,var(--tc),var(--tca));border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(10,109,184,.35)}
.logo-mark svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round}
.logo em{font-style:normal;color:var(--tc)}
.main-nav>ul{display:flex;align-items:center}
.main-nav>ul>li>a{display:block;padding:28px 14px;font-family:var(--bf);font-size:14px;font-weight:500;color:var(--bdy);transition:color .2s}
.main-nav>ul>li>a:hover,.main-nav>ul>li.active>a{color:var(--tc)}
.main-nav>ul>li{position:relative}
.has-sub>a::after{content:'▾';margin-left:3px;font-size:10px;opacity:.5}
.sub-nav{display:none;position:absolute;top:calc(100% + 1px);left:-16px;background:#fff;border:1px solid var(--brd);border-radius:14px;padding:8px 0;min-width:240px;box-shadow:var(--sh-lg);z-index:999;animation:snin .2s ease}
@keyframes snin{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.main-nav>ul>li:hover .sub-nav{display:block}
.sub-nav a{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:13.5px;font-weight:500;color:var(--bdy);transition:.2s}
.sub-nav a:hover{color:var(--tc);background:var(--smk);padding-left:24px}
.sn-dot{width:5px;height:5px;border-radius:50%;background:var(--tc);flex-shrink:0}
.hdr-btns{display:flex;align-items:center;gap:12px;flex-shrink:0}
.burger{display:none;flex-direction:column;gap:5px;padding:6px;background:none;border:none;cursor:pointer}
.burger span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.3s;display:block}
/* MOBILE */
.mob-overlay{display:none;position:fixed;inset:0;z-index:2000;background:var(--ink);flex-direction:column;padding:24px 28px 40px;overflow-y:auto}
.mob-overlay.open{display:flex}
.mob-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}
.mob-close{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;cursor:pointer}
.mob-close svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2}
.mob-links{display:flex;flex-direction:column;gap:6px;flex:1}
.mob-link{display:block;padding:14px 20px;border-radius:14px;font-family:var(--tf);font-size:16px;font-weight:600;color:#fff;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);transition:.2s}
.mob-link:hover{background:rgba(10,109,184,.2);border-color:rgba(10,109,184,.3)}
.mob-cta{background:var(--tc)!important;border-color:var(--tc)!important;margin-top:12px;text-align:center}
.mob-contact{margin-top:28px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08)}
.mob-contact p{font-size:11px;color:rgba(255,255,255,.3);margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em}
.mob-contact a{display:block;font-size:15px;font-weight:600;color:var(--tcl);margin-bottom:4px}
/* BREADCRUMB */
.breadcrumb{padding:14px 0;border-bottom:1px solid var(--brd)}
.bc-in{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--bdy)}
.bc-in a{color:var(--bdy);transition:.2s}.bc-in a:hover{color:var(--tc)}
.bc-sep{color:rgba(7,30,61,.2);font-size:11px}
.bc-in span{color:var(--tc);font-weight:500}
/* PAGE HERO */
.pg-hero{background:var(--ink);padding:72px 0 80px;position:relative;overflow:hidden}
.pg-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 100% at 80% 50%,rgba(10,109,184,.2),transparent 70%)}
.pg-dots{position:absolute;inset:0;background-image:radial-gradient(rgba(10,180,255,.08) 1px,transparent 1px);background-size:36px 36px}
.pg-hero-in{position:relative;z-index:2}
.pg-hero h1{font-size:46px;font-weight:900;color:#fff;letter-spacing:-.04em;margin-bottom:16px;line-height:1.1}
.pg-hero p{font-size:18px;color:rgba(255,255,255,.55);max-width:560px;line-height:28px}
.pg-stats{display:flex;gap:16px;flex-wrap:wrap;margin-top:24px}
.pg-stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:12px 20px}
.pg-stat-val{font-family:var(--tf);font-size:26px;font-weight:800;color:var(--tca);line-height:1}
.pg-stat-lbl{font-size:11px;font-weight:500;color:rgba(255,255,255,.4);letter-spacing:.06em;text-transform:uppercase;margin-top:3px}
/* FAQ */
.faq-item{background:#fff;border:1px solid var(--brd);border-radius:14px;overflow:hidden;transition:border-color .25s}
.faq-item:hover,.faq-item.open{border-color:rgba(10,109,184,.3)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;cursor:pointer}
.faq-q span{font-family:var(--tf);font-size:15px;font-weight:600;color:var(--ink);line-height:1.4}
.faq-ico{width:30px;height:30px;border-radius:50%;flex-shrink:0;background:var(--smk);border:1px solid var(--brd);display:flex;align-items:center;justify-content:center;transition:.3s}
.faq-ico svg{width:14px;height:14px;stroke:var(--tc);fill:none;stroke-width:2.5;transition:transform .3s}
.faq-item.open .faq-ico{background:var(--tc);border-color:var(--tc)}
.faq-item.open .faq-ico svg{stroke:#fff;transform:rotate(45deg)}
.faq-a{display:none;padding:0 24px 20px;font-size:14.5px;color:var(--bdy);line-height:24px;border-top:1px solid var(--brd)}
.faq-a p{padding-top:16px}
.faq-item.open .faq-a{display:block}
/* CHECK LIST */
.chk-list{display:flex;flex-direction:column;gap:11px}
.chk-item{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:var(--ink)}
.chk-item svg{width:20px;height:20px;stroke:var(--tc);fill:none;stroke-width:2.5;flex-shrink:0;margin-top:2px}
/* CARD BASE */
.card{background:#fff;border-radius:20px;border:1px solid var(--brd);transition:all .35s cubic-bezier(.4,0,.2,1)}
.card:hover{border-color:rgba(10,109,184,.3);box-shadow:var(--sh-md);transform:translateY(-4px)}
/* SPECS */
.specs-tbl{width:100%;border-collapse:collapse;border-radius:16px;overflow:hidden;border:1px solid var(--brd)}
.specs-tbl tr:nth-child(even) td{background:var(--smk)}
.specs-tbl td{padding:14px 20px;font-size:14px;border-bottom:1px solid var(--brd)}
.specs-tbl tr:last-child td{border-bottom:none}
.specs-tbl td:first-child{font-weight:600;color:var(--ink);width:45%}
/* FOOTER */
.site-footer{background:#040F1E;padding:80px 0 0}
.ftr-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:48px}
.ftr-brand p{font-size:13.5px;color:rgba(255,255,255,.35);line-height:22px;max-width:250px;margin-top:16px}
.ftr-contact{margin-top:20px}
.ftr-contact a{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.4);margin-bottom:8px;transition:.2s}
.ftr-contact a:hover{color:var(--tca)}
.ftr-contact svg{width:14px;height:14px;stroke:var(--tc);fill:none;stroke-width:2;flex-shrink:0}
.ftr-col h5{font-family:var(--tf);font-size:13px;font-weight:700;color:#fff;margin-bottom:18px;letter-spacing:.03em}
.ftr-col ul li{margin-bottom:9px}
.ftr-col ul li a{font-size:13px;color:rgba(255,255,255,.35);transition:.2s}
.ftr-col ul li a:hover{color:var(--tca)}
.ftr-bottom{border-top:1px solid rgba(255,255,255,.06);padding:24px 0;margin-top:56px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.ftr-bottom p{font-size:12px;color:rgba(255,255,255,.25)}
.ftr-legal{display:flex;gap:20px}
.ftr-legal a{font-size:12px;color:rgba(255,255,255,.25);transition:.2s}
.ftr-legal a:hover{color:var(--tca)}
/* ANIM */
.fu{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.fu.v{opacity:1;transform:translateY(0)}
.fi{opacity:0;transition:opacity .7s ease}
.fi.v{opacity:1}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}
/* RESPONSIVE */
@media(max-width:1080px){.sec{padding:80px 0}.sec-title h2{font-size:38px}.pg-hero h1{font-size:36px}.ftr-grid{grid-template-columns:1fr 1fr;gap:32px}.main-nav{display:none}.burger{display:flex}}
@media(max-width:640px){.wrap{padding:0 18px}.sec{padding:56px 0}.sec-title h2{font-size:30px}.sec-title{margin-bottom:36px}.pg-hero{padding:48px 0 56px}.pg-hero h1{font-size:28px}.ftr-grid{grid-template-columns:1fr}.ftr-bottom{flex-direction:column;text-align:center}.tb-l{display:none}}

/* ── LOGO IMAGE RÉEL ── */
.logo-img-wrap{display:flex;align-items:center;flex-shrink:0;text-decoration:none}
.logo-img-wrap img{height:42px;width:auto;border-radius:8px;transition:opacity .2s}
.logo-img-wrap:hover img{opacity:.85}
/* Fond sombre autour du logo (car logo PNG sur fond noir) */
.site-header .logo-img-wrap img{
  background:#071E3D;
  padding:5px 10px;
  border-radius:8px;
  box-shadow:0 2px 8px rgba(7,30,61,.15);
}