/* ==============================
   RESET & BASE
============================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:'Space Grotesk',system-ui,sans-serif;background:#e8eae8;color:#0F172A;overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.55}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font:inherit;border:none;background:none}
::selection{background:rgba(6,182,212,.25);color:#fff}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:#e8eae8}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#06b6d4,#10b981);border-radius:999px}

/* CSS VARS */
:root{
  --brand:#0891b2;
  --brand-2:#0e7490;
  --brand-dark:#164e63;
  --accent:#059669;
  --accent-2:#047857;
  --bg:#e8eae8;
  --bg2:#f4f5f4;
  --bg3:#edeeed;
  --card:#ffffff;
  --card-hover:#f5f6f5;
  --border:rgba(14,116,144,0.1);
  --border-brand:rgba(8,145,178,0.25);
  --text:#0F172A;
  --muted:#475569;
  --muted2:#94A3B8;
  --glow-brand:rgba(8,145,178,0.12);
  --glow-accent:rgba(5,150,105,0.1);
  --ease:cubic-bezier(0.16,1,0.3,1);
  --ease-std:cubic-bezier(0.4,0,0.2,1);
  --shadow:0 8px 40px rgba(8,145,178,0.1);
  --shadow-sm:0 2px 16px rgba(8,145,178,0.08);
}

/* AMBIENT BG */
.bg-scene{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.bg-gradient{position:absolute;inset:0;background:linear-gradient(160deg,#dfe3df 0%,#e8eae8 50%,#e4e6e4 100%)}
.bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(6,182,212,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(6,182,212,.025) 1px,transparent 1px);background-size:48px 48px}
.bg-noise{position:absolute;inset:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.bg-orb{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none}
.orb1{top:-10%;left:-5%;width:60vw;height:60vw;max-width:900px;max-height:900px;background:radial-gradient(circle,rgba(6,182,212,.06) 0%,transparent 65%);animation:orb1 25s ease-in-out infinite alternate}
.orb2{bottom:-15%;right:-8%;width:50vw;height:50vw;max-width:800px;max-height:800px;background:radial-gradient(circle,rgba(16,185,129,.05) 0%,transparent 65%);animation:orb2 30s ease-in-out infinite alternate}
.orb3{top:40%;right:20%;width:30vw;height:30vw;max-width:500px;max-height:500px;background:radial-gradient(circle,rgba(6,182,212,.03) 0%,transparent 65%);animation:orb3 20s ease-in-out infinite alternate}
@keyframes orb1{to{transform:translate(40px,25px) scale(1.06)}}
@keyframes orb2{to{transform:translate(-30px,-20px) scale(1.08)}}
@keyframes orb3{to{transform:translate(15px,-20px) scale(.94)}}

/* PROGRESS */
.progress{position:fixed;top:0;left:0;height:2px;width:0%;background:linear-gradient(90deg,var(--brand),var(--accent));z-index:9999;transition:width .08s linear}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:72px;display:flex;align-items:center;padding:0 clamp(20px,4vw,56px);gap:24px;border-bottom:1px solid transparent;transition:all .4s var(--ease-std);background:rgba(232,234,232,.85);backdrop-filter:blur(20px) saturate(1.5);-webkit-backdrop-filter:blur(20px) saturate(1.5)}
.nav.scrolled{background:rgba(232,234,232,.94);border-bottom-color:rgba(8,145,178,.1)}
.nav-brand{display:flex;align-items:center;gap:12px;font-family:'Outfit',sans-serif;font-weight:800;font-size:1.1rem;letter-spacing:-.02em;flex-shrink:0}
.nav-brand img{height:38px;object-fit:contain}
.nav-brand-text{color:var(--brand)}
.nav-center{flex:1;display:flex;align-items:center;justify-content:center;gap:2px}
.nav-link{padding:8px 15px;border-radius:8px;font-size:.83rem;font-weight:500;color:#0F172A;transition:.25s;white-space:nowrap;display:inline-flex;align-items:center;gap:8px}
.nav-link:hover{color:var(--brand);background:rgba(8,145,178,.06)}
.nav-link.active{color:var(--brand);background:rgba(8,145,178,.08);font-weight:600}
.nav-link-new{position:relative}
.nav-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;background:linear-gradient(135deg,#0891b2,#059669);color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;line-height:1.4;box-shadow:0 0 12px rgba(8,145,178,.35);animation:pillPulse 2.6s ease-in-out infinite}
@keyframes pillPulse{0%,100%{box-shadow:0 0 0 0 rgba(8,145,178,.5)}70%{box-shadow:0 0 0 8px rgba(8,145,178,0)}}
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-tel{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;font-size:.78rem;font-weight:600;color:var(--brand);border:1px solid var(--border-brand);background:rgba(6,182,212,.05);transition:.25s;white-space:nowrap}
.nav-tel:hover{background:rgba(6,182,212,.1)}
.nav-tel svg{width:14px;height:14px;fill:currentColor;flex-shrink:0}
.nav-cta{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:8px;font-size:.78rem;font-weight:700;transition:.3s;white-space:nowrap;line-height:1}
.nav-cta svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2;flex-shrink:0}
.nav-cta-pl{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#001018;box-shadow:0 0 18px var(--glow-brand)}
.nav-cta-pl:hover{transform:translateY(-2px);box-shadow:0 6px 26px rgba(6,182,212,.42)}
.nav-cta-locaux{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 0 18px var(--glow-accent);position:relative;overflow:hidden}
.nav-cta-locaux::after{content:'';position:absolute;top:-2px;right:-2px;width:8px;height:8px;border-radius:50%;background:#fff;box-shadow:0 0 0 0 rgba(255,255,255,.7);animation:locauxPulse 2.4s ease-in-out infinite}
@keyframes locauxPulse{0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,.7)}70%{box-shadow:0 0 0 7px rgba(255,255,255,0)}}
.nav-cta-locaux:hover{transform:translateY(-2px);box-shadow:0 6px 26px rgba(5,150,105,.42)}
.burger{display:none;flex-direction:column;gap:5px;width:36px;height:36px;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:8px;cursor:pointer}
.burger span{width:18px;height:1.5px;background:var(--muted);border-radius:999px;transition:.3s}
@media(max-width:1180px){.nav-center{display:none}.burger{display:flex}}
@media(max-width:860px){.nav-tel{display:none}}
@media(max-width:760px){.nav-cta .nav-cta-label{display:none}.nav-cta{padding:9px 12px}}
@media(max-width:540px){.nav-cta-pl{display:none}}
@media(max-width:380px){.nav-cta-locaux{display:none}}

/* OVERLAY */
.overlay{position:fixed;inset:0;z-index:998;background:rgba(232,234,232,.97);backdrop-filter:blur(24px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transform:translateY(-100%);transition:transform .5s var(--ease)}
.overlay.open{transform:none}
.overlay-link{font-family:'Outfit',sans-serif;font-size:clamp(1.4rem,4vw,2rem);font-weight:800;color:#0F172A;padding:8px 24px;border-radius:12px;transition:.3s;text-align:center}
.overlay-link:hover{color:var(--brand)}
.overlay-close{position:absolute;top:24px;right:24px;width:44px;height:44px;border:1px solid var(--border);border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);font-size:1.1rem;transition:.3s}
.overlay-close:hover{color:var(--text);border-color:rgba(148,163,184,.3)}
.overlay-cta{margin-top:14px;padding:14px 30px;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#001018;font-weight:800;font-size:.92rem;box-shadow:0 0 30px var(--glow-brand);display:inline-flex;align-items:center;gap:10px}
.overlay-cta svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2}
.overlay-cta-locaux{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 0 30px var(--glow-accent)}
.overlay-cta-tel{background:rgba(8,145,178,.1);border:1px solid var(--border-brand);color:var(--brand);box-shadow:none;margin-top:8px}
.overlay-ctas{display:flex;flex-direction:column;gap:10px;align-items:center;margin-top:18px}

/* DOTNAV */
.dotnav{position:fixed;right:20px;top:50%;transform:translateY(-50%);z-index:100;display:flex;flex-direction:column;gap:10px}
.dotnav a{width:7px;height:7px;border-radius:50%;background:rgba(8,145,178,.18);border:1px solid rgba(8,145,178,.28);transition:.3s;display:block}
.dotnav a:hover,.dotnav a.active{background:var(--brand);border-color:var(--brand);box-shadow:0 0 10px var(--glow-brand);transform:scale(1.5)}
@media(max-width:768px){.dotnav{display:none}}

/* LAYOUT */
.wrap{max-width:1160px;margin:0 auto;padding:0 clamp(20px,4vw,56px);position:relative;z-index:1}
section{padding:clamp(48px,6vw,80px) 0;position:relative}
.section-label{display:inline-flex;align-items:center;gap:8px;padding:5px 14px 5px 8px;border-radius:6px;background:rgba(8,145,178,.07);border:1px solid var(--border-brand);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brand);margin-bottom:20px}
.label-line{width:20px;height:1.5px;background:var(--brand);border-radius:999px}
h2.title{font-family:'Outfit',sans-serif;font-size:clamp(2rem,5vw,3.6rem);font-weight:800;line-height:1.04;letter-spacing:-.04em;margin-bottom:16px;color:#0F172A}
h2.title .cyan,h2.title em,.title .cyan{background:linear-gradient(135deg,#0891b2,#059669);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
h2.title .green{color:var(--accent)}
.subtitle{font-size:clamp(.92rem,2vw,1.1rem);color:var(--muted);line-height:1.75;max-width:620px}
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--border) 25%,var(--border) 75%,transparent)}

/* Reveal */
.r{opacity:0;transform:translateY(28px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.r.in{opacity:1;transform:none}
.rl{opacity:0;transform:translateX(-28px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.rl.in{opacity:1;transform:none}
.rr{opacity:0;transform:translateX(28px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.rr.in{opacity:1;transform:none}

/* HERO */
.hero{min-height:78svh;display:grid;place-items:center;padding:120px clamp(20px,4vw,56px) 64px;position:relative;overflow:hidden;text-align:center}
.hero.hero-full{min-height:100svh;padding:72px clamp(20px,4vw,56px) 56px}
.hero-media{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-img{width:100%;height:100%;object-fit:cover;object-position:center center}
.hero-mask{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,14,28,.55) 0%,rgba(8,14,28,.75) 55%,rgba(8,14,28,.9) 82%,#e8eae8 100%)}
.hero-content{position:relative;z-index:1;max-width:820px;display:flex;flex-direction:column;align-items:center}
.hero-chip{display:inline-flex;align-items:center;gap:10px;padding:7px 18px 7px 10px;border-radius:6px;background:rgba(56,189,248,.1);border:1px solid rgba(56,189,248,.25);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#38bdf8;margin-bottom:32px;animation:fadeUp .9s var(--ease) both}
.hero-chip-dot{width:7px;height:7px;border-radius:50%;background:#38bdf8;animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.7)}}
h1.hero-h1{font-family:'Outfit',sans-serif;font-size:clamp(2.6rem,6.5vw,5.5rem);font-weight:900;line-height:1.0;letter-spacing:-.05em;margin-bottom:24px;color:#fff;text-shadow:0 3px 24px rgba(0,0,0,.55);animation:fadeUp .9s .1s var(--ease) both}
.hero-h1 em{font-style:normal;background:linear-gradient(135deg,#38bdf8 0%,#34d399 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-lead{font-size:clamp(.95rem,2.2vw,1.15rem);color:rgba(255,255,255,.85);text-shadow:0 1px 6px rgba(0,0,0,.3);line-height:1.75;max-width:600px;margin-bottom:36px;animation:fadeUp .9s .2s var(--ease) both}
.hero-features{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:40px;animation:fadeUp .9s .25s var(--ease) both}
.hero-feature{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:6px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-size:.8rem;font-weight:500;color:rgba(255,255,255,.9);backdrop-filter:blur(8px)}
.hero-feature svg{width:14px;height:14px;flex-shrink:0}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;animation:fadeUp .9s .32s var(--ease) both}
.btn-primary{display:inline-flex;align-items:center;gap:10px;padding:15px 32px;border-radius:8px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#001018;font-size:.9rem;font-weight:700;transition:.3s;box-shadow:0 0 28px var(--glow-brand);white-space:nowrap;position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.22) 50%,transparent 60%);transform:translateX(-100%);transition:none}
.btn-primary:hover::after{transform:translateX(100%);transition:transform .5s ease}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 40px rgba(6,182,212,.45)}
.btn-primary svg{width:16px;height:16px}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border-radius:8px;background:rgba(255,255,255,.05);border:1px solid rgba(249,250,251,.25);color:#fff;font-size:.9rem;font-weight:600;transition:.3s;backdrop-filter:blur(8px);white-space:nowrap}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(148,163,184,.4);transform:translateY(-2px)}
.btn-ghost svg{width:16px;height:16px;stroke:#fff;fill:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

/* SERVICES GRID */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border-radius:16px;overflow:hidden;margin-top:32px}
@media(max-width:860px){.services-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.services-grid{grid-template-columns:1fr}}
.service-card{background:#fff;position:relative;overflow:hidden;transition:.4s var(--ease);box-shadow:0 2px 20px rgba(0,0,0,.07)}
.service-card:hover{z-index:2;transform:translateY(-5px);box-shadow:0 20px 50px rgba(0,0,0,.12)}
.service-img-wrap{height:240px;overflow:hidden;position:relative}
.service-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.service-card:hover .service-img-wrap img{transform:scale(1.07)}
.service-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,15,26,.9) 0%,rgba(10,15,26,.1) 60%)}
.service-num{position:absolute;top:16px;left:16px;font-family:'Outfit',sans-serif;font-size:1.6rem;font-weight:900;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.6);letter-spacing:-.04em;z-index:2}
.service-body{padding:24px}
.service-category{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brand);margin-bottom:10px}
.service-title{font-family:'Outfit',sans-serif;font-size:1.15rem;font-weight:700;line-height:1.3;margin-bottom:10px;color:#0F172A}
.service-desc{font-size:.84rem;color:var(--muted);line-height:1.65}
.service-tag{display:inline-flex;align-items:center;gap:6px;margin-top:16px;padding:4px 12px;border-radius:4px;background:rgba(8,145,178,.07);border:1px solid rgba(8,145,178,.15);font-size:.7rem;font-weight:700;color:var(--brand);letter-spacing:.04em}

.carousel-hint{display:none}
@media(max-width:640px){
  .carousel-hint{display:flex;align-items:center;gap:6px;font-size:.72rem;color:var(--muted);margin-top:10px;justify-content:center}
  .carousel-hint svg{width:14px;height:14px;opacity:.6}
  .services-grid{display:flex!important;grid-template-columns:unset!important;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:12px;padding:0 20px 20px;margin-left:-20px;margin-right:-20px;margin-top:32px;background:transparent!important;border-radius:0!important;scrollbar-width:none}
  .services-grid::-webkit-scrollbar{display:none}
  .service-card{flex:0 0 78vw!important;border-radius:14px!important;scroll-snap-align:start;border:1px solid var(--border);box-shadow:0 6px 24px rgba(0,0,0,.08)}
  .services-grid::after{content:'';flex:0 0 8px}
}

/* STATS BAR */
.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:linear-gradient(135deg,#0891b2,#0e7490 45%,#059669);border-radius:16px;overflow:hidden;margin-top:64px;box-shadow:0 8px 40px rgba(8,145,178,.22)}
@media(max-width:640px){.stats-bar{grid-template-columns:1fr 1fr}.stats-bar .stat:nth-child(2){border-right:none!important}.stats-bar .stat:nth-child(-n+2){border-bottom:1px solid rgba(255,255,255,.12)}}
.stat{background:transparent;padding:clamp(24px,3vw,36px) 24px;text-align:center;transition:.3s;border-right:1px solid rgba(255,255,255,.12)}
.stat:last-child{border-right:none}
.stat:hover{background:rgba(255,255,255,.06)}
.stat-num{font-family:'Outfit',sans-serif;font-size:clamp(2rem,4vw,2.8rem);font-weight:900;line-height:1;letter-spacing:-.04em;color:#fff;margin-bottom:8px;text-shadow:0 2px 12px rgba(0,0,0,.15)}
.stat-label{font-size:.78rem;color:rgba(255,255,255,.82);font-weight:500;line-height:1.4}

/* SECTEURS */
.secteurs-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;margin-top:56px}
@media(max-width:860px){.secteurs-layout{grid-template-columns:1fr}}
.secteurs-map-wrap{border-radius:16px;overflow:hidden;height:380px;position:relative}
.secteurs-map-wrap img{width:100%;height:100%;object-fit:contain;border-radius:16px}
.secteurs-list{display:flex;flex-direction:column;gap:12px}
.secteur-item{display:flex;align-items:flex-start;gap:16px;padding:20px;border-radius:10px;background:#fff;border:1px solid var(--border);transition:.3s;cursor:default;box-shadow:0 2px 16px rgba(0,0,0,.06)}
.secteur-item:hover{background:var(--card-hover);border-color:var(--border-brand);transform:translateY(-2px)}
.secteur-icon{width:40px;height:40px;border-radius:8px;background:rgba(8,145,178,.08);border:1px solid var(--border-brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.secteur-icon svg{width:18px;height:18px;stroke:var(--brand);fill:none;stroke-width:2}
.secteur-name{font-family:'Outfit',sans-serif;font-size:.95rem;font-weight:700;margin-bottom:4px;color:#0F172A}
.secteur-desc{font-size:.82rem;color:var(--muted);line-height:1.5}
.secteurs-cities{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.city-chip{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#fff;border:1px solid var(--border);border-radius:10px;font-size:.86rem;font-weight:600;color:#0F172A;transition:.3s}
.city-chip:hover{background:rgba(8,145,178,.05);border-color:var(--border-brand);transform:translateX(4px)}
.city-chip svg{width:14px;height:14px;stroke:var(--brand);fill:none;stroke-width:2.5;flex-shrink:0}

/* PROCESS */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-radius:16px;overflow:hidden;margin-top:56px}
@media(max-width:860px){.process-grid{grid-template-columns:1fr 1fr}}
@media(max-width:440px){.process-grid{grid-template-columns:1fr}}
.step{background:#fff;padding:clamp(24px,3vw,36px) 24px;position:relative;overflow:hidden;transition:.3s;box-shadow:0 2px 16px rgba(0,0,0,.06)}
.step:hover{background:rgba(8,145,178,.03);transform:translateY(-4px)}
.step::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand),var(--accent));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.step:hover::before,.step.in::before{transform:scaleX(1)}
.step-num{font-family:'Outfit',sans-serif;font-size:3.5rem;font-weight:900;line-height:1;color:rgba(8,145,178,.12);position:absolute;top:16px;right:20px;letter-spacing:-.06em}
.step-badge{width:36px;height:36px;border-radius:8px;background:rgba(8,145,178,.1);border:1px solid var(--border-brand);display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-family:'Outfit',sans-serif;font-size:.85rem;font-weight:800;color:var(--brand)}
.step-title{font-family:'Outfit',sans-serif;font-size:1rem;font-weight:700;margin-bottom:8px;color:#0F172A}
.step-desc{font-size:.83rem;color:var(--muted);line-height:1.6}

/* FLOTTE */
.flotte-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px}
@media(max-width:560px){.flotte-grid{grid-template-columns:1fr}}
.flotte-card{border-radius:12px;overflow:hidden;position:relative;height:280px;border:1px solid var(--border);transition:.4s var(--ease);box-shadow:0 4px 24px rgba(0,0,0,.12)}
.flotte-card:hover{border-color:var(--border-brand);transform:translateY(-5px);box-shadow:0 20px 50px rgba(8,145,178,.18)}
.flotte-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.flotte-card:hover img{transform:scale(1.05)}
.flotte-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,15,26,.95) 0%,rgba(10,15,26,.3) 55%,transparent 100%)}
.flotte-content{position:absolute;bottom:0;left:0;right:0;padding:24px;color:#fff}
.flotte-tag{display:inline-block;padding:3px 10px;border-radius:4px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28);font-size:.68rem;font-weight:700;color:#fff;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.flotte-title{font-family:'Outfit',sans-serif;font-size:1.05rem;font-weight:700;margin-bottom:4px;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.flotte-desc{font-size:.8rem;color:rgba(255,255,255,.78);line-height:1.5}

/* TEMOIGNAGES */
.temo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:56px}
@media(max-width:860px){.temo-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.temo-grid{grid-template-columns:1fr}}
.temo{background:#fff;border:1px solid var(--border);border-radius:12px;padding:28px;display:flex;flex-direction:column;transition:.3s;box-shadow:0 2px 16px rgba(0,0,0,.06)}
.temo:hover{background:var(--card-hover);border-color:var(--border-brand);transform:translateY(-5px);box-shadow:0 12px 36px rgba(0,0,0,.1)}
.temo-stars{display:flex;gap:2px;margin-bottom:16px}
.temo-star{width:14px;height:14px;fill:var(--brand)}
.temo-text{font-size:.88rem;color:#374151;line-height:1.75;flex:1;margin-bottom:20px;font-style:italic}
.temo-sep{height:1px;background:var(--border);margin-bottom:16px}
.temo-author{display:flex;align-items:center;gap:12px}
.temo-initials{width:38px;height:38px;border-radius:8px;background:linear-gradient(135deg,var(--brand-dark),var(--brand-2));display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-size:.85rem;font-weight:800;color:#fff;flex-shrink:0}
.temo-name{font-size:.84rem;font-weight:600;color:#0F172A}
.temo-role{font-size:.72rem;color:#9CA3AF;margin-top:2px}

/* AVANT/APRES */
.aa-header{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:56px}
@media(max-width:640px){.aa-header{grid-template-columns:1fr}}
.aa-pair{border-radius:12px;overflow:hidden;border:1px solid var(--border);background:#fff}
.aa-pair-label{padding:14px 20px;background:#f0f2f0;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border)}
.aa-imgs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border)}
.aa-img{position:relative;overflow:hidden}
.aa-img img{width:100%;height:200px;object-fit:cover;transition:transform .5s var(--ease)}
.aa-img:hover img{transform:scale(1.05)}

/* AVANT/APRÈS — Slider interactif (paire portrait) */
.aa-pair--slider{padding:0}
.aa-pair--slider .aa-pair-label{margin:0}
.aa-slider{position:relative;width:100%;height:clamp(360px,52vw,620px);overflow:hidden;background:#0c1a2e;touch-action:none;user-select:none;cursor:ew-resize}
.aa-slider-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 40%;pointer-events:none;transition:transform .6s var(--ease)}
.aa-slider-after{clip-path:inset(0 var(--pos) 0 0);-webkit-clip-path:inset(0 var(--pos) 0 0)}
.aa-slider:hover .aa-slider-img{transform:scale(1.02)}
.aa-slider-badge-avant{position:absolute;top:16px;left:16px;z-index:3}
.aa-slider-badge-apres{position:absolute;top:16px;right:16px;left:auto;z-index:3}
.aa-slider-handle{position:absolute;top:0;bottom:0;left:calc(100% - var(--pos));transform:translateX(-50%);width:48px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;padding:0;cursor:ew-resize;z-index:5;outline:none}
.aa-slider-handle:focus-visible .aa-slider-knob{box-shadow:0 0 0 4px rgba(56,189,248,.55),0 8px 24px rgba(0,0,0,.4)}
.aa-slider-line{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:3px;background:#fff;box-shadow:0 0 10px rgba(0,0,0,.45)}
.aa-slider-knob{position:relative;display:flex;align-items:center;justify-content:center;gap:2px;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;box-shadow:0 6px 22px rgba(0,0,0,.4),0 0 0 4px rgba(255,255,255,.92);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.aa-slider-handle:hover .aa-slider-knob,.aa-slider.is-dragging .aa-slider-knob{transform:scale(1.08);box-shadow:0 8px 28px rgba(0,0,0,.5),0 0 0 4px rgba(255,255,255,1)}
.aa-slider-knob svg{width:14px;height:14px}
.aa-slider-hint{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);padding:6px 14px;border-radius:999px;background:rgba(10,15,26,.7);color:#fff;font-size:.72rem;font-weight:600;letter-spacing:.04em;backdrop-filter:blur(6px);z-index:4;pointer-events:none;opacity:.95;transition:opacity .3s ease}
.aa-slider.is-dragging .aa-slider-hint,.aa-slider.has-interacted .aa-slider-hint{opacity:0}
@media(max-width:760px){
  .aa-slider{height:clamp(300px,68vw,440px)}
  .aa-slider-knob{width:44px;height:44px}
  .aa-slider-badge-avant,.aa-slider-badge-apres{top:10px;left:10px;font-size:.62rem;padding:2px 8px}
  .aa-slider-badge-apres{right:10px;left:auto}
}
@media(prefers-reduced-motion:reduce){
  .aa-slider:hover .aa-slider-img{transform:none}
  .aa-slider-knob{transition:none}
}
.aa-badge{position:absolute;top:10px;left:10px;padding:3px 10px;border-radius:4px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.aa-badge.avant{background:rgba(239,68,68,.85);color:#fff}
.aa-badge.apres{background:rgba(16,185,129,.85);color:#fff}

/* CTA SECTION */
.cta-box{position:relative;border-radius:20px;overflow:hidden;padding:clamp(48px,6vw,96px) clamp(28px,5vw,80px);text-align:center}
.cta-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.cta-bg img{width:100%;height:100%;object-fit:cover;object-position:center center}
.cta-bg-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(6,10,26,.93),rgba(6,20,36,.88))}
.cta-content{position:relative;z-index:1}
.cta-title{font-family:'Outfit',sans-serif;font-size:clamp(1.9rem,4.5vw,3.2rem);font-weight:900;letter-spacing:-.04em;margin-bottom:12px;color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.35)}
.cta-sub{font-size:clamp(.9rem,2vw,1.05rem);color:rgba(255,255,255,.8);margin-bottom:40px;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.7}
.cta-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.cta-actions .btn-ghost{color:#fff;border-color:rgba(255,255,255,.25)}
.cta-actions .btn-ghost svg{stroke:#fff;fill:none}
.cta-line{display:flex;align-items:center;justify-content:center;gap:28px;margin-top:32px;flex-wrap:wrap}
.cta-line-item{display:flex;align-items:center;gap:8px;font-size:.82rem;color:rgba(255,255,255,.75)}
.cta-line-item svg{width:16px;height:16px;stroke:#34d399;fill:none;stroke-width:2;flex-shrink:0}
@keyframes ctaPulse{0%,100%{box-shadow:0 0 0 0 rgba(8,145,178,.4)}70%{box-shadow:0 0 0 14px rgba(8,145,178,0)}}
.cta-box .btn-primary{animation:ctaPulse 2.8s ease-in-out infinite}

/* SVC LIST */
.svc-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:32px}
@media(max-width:480px){.svc-list{grid-template-columns:1fr}}
.svc-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fff;border:1px solid var(--border);border-radius:8px;font-size:.84rem;font-weight:500;color:#0F172A;transition:.25s}
.svc-item:hover{background:var(--card-hover);border-color:var(--border-brand);transform:translateX(4px)}
.svc-check{width:20px;height:20px;border-radius:5px;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.svc-check svg{width:11px;height:11px;stroke:var(--accent);fill:none;stroke-width:2.5}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:8px;margin-top:48px}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:.3s;box-shadow:0 2px 12px rgba(0,0,0,.05)}
.faq-item:hover{border-color:var(--border-brand)}
.faq-item.open{border-color:rgba(8,145,178,.3);background:rgba(8,145,178,.03)}
.faq-q{padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;cursor:pointer;font-size:.92rem;font-weight:600;color:#0F172A;transition:.25s;user-select:none}
.faq-q:hover,.faq-item.open .faq-q{color:var(--brand)}
.faq-toggle{width:28px;height:28px;border-radius:6px;background:rgba(8,145,178,.08);border:1px solid var(--border-brand);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.3s var(--ease)}
.faq-toggle svg{width:14px;height:14px;stroke:var(--brand);fill:none;stroke-width:2.5;transition:transform .3s var(--ease)}
.faq-item.open .faq-toggle svg{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a-inner{padding:0 24px 20px;font-size:.86rem;color:var(--muted);line-height:1.8}
.faq-item.open .faq-a{max-height:420px}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 400px;gap:40px;margin-top:56px}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}}
.form-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:clamp(28px,4vw,44px);box-shadow:0 4px 28px rgba(0,0,0,.07)}
.form-heading{font-family:'Outfit',sans-serif;font-size:1.4rem;font-weight:800;margin-bottom:6px;color:#0F172A}
.form-sub{font-size:.84rem;color:var(--muted);margin-bottom:28px}
.field{margin-bottom:14px}
.field label{display:block;font-size:.75rem;font-weight:600;color:#374151;margin-bottom:7px;letter-spacing:.03em}
.field input,.field select,.field textarea{width:100%;padding:12px 16px;background:#f0f2f0;border:1px solid rgba(8,145,178,.18);border-radius:8px;color:#0F172A;font-family:'Space Grotesk',sans-serif;font-size:.87rem;transition:.25s;outline:none}
.field input::placeholder{color:var(--muted2)}
.field input:focus,.field select:focus,.field textarea:focus{background:#fff;border-color:var(--brand);box-shadow:0 0 0 3px rgba(8,145,178,.1)}
.field select option{background:#fff;color:#0F172A}
.field textarea{resize:vertical;min-height:80px;font-family:inherit}
.form-btn{width:100%;padding:14px;border-radius:8px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#001018;font-family:'Outfit',sans-serif;font-size:.92rem;font-weight:800;transition:.3s;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 0 24px var(--glow-brand)}
.form-btn:hover{transform:translateY(-2px);box-shadow:0 8px 36px rgba(6,182,212,.4)}
.form-btn svg{width:16px;height:16px}
.contact-side{display:flex;flex-direction:column;gap:16px}
.info-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:24px;transition:.3s;box-shadow:0 4px 28px rgba(0,0,0,.07)}
.info-card:hover{border-color:var(--border-brand)}
.info-card-title{font-family:'Outfit',sans-serif;font-size:.95rem;font-weight:700;margin-bottom:16px;color:var(--brand)}
.info-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}
.info-row:last-child{margin-bottom:0}
.info-icon{width:36px;height:36px;border-radius:7px;background:rgba(8,145,178,.08);border:1px solid var(--border-brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.info-icon svg{width:16px;height:16px;stroke:var(--brand);fill:none;stroke-width:2}
.info-label{font-size:.72rem;color:#9CA3AF;margin-bottom:2px;font-weight:600;letter-spacing:.03em;text-transform:uppercase}
.info-val{font-size:.86rem;font-weight:500;transition:.2s;color:#0F172A}
.info-val a:hover{color:var(--brand)}
.hours-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.hour-block{padding:12px 14px;background:#f0f2f0;border:1px solid var(--border);border-radius:7px}
.hour-day{font-size:.68rem;color:#9CA3AF;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.hour-time{font-size:.86rem;font-weight:600;color:#0F172A}
.call-cta{width:100%;padding:14px;border-radius:8px;background:#eef2f0;border:1px solid rgba(8,145,178,.15);color:var(--brand);font-family:'Outfit',sans-serif;font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:10px;transition:.3s}
.call-cta:hover{background:linear-gradient(135deg,rgba(8,145,178,.2),rgba(16,185,129,.12));transform:translateY(-2px);box-shadow:0 8px 30px rgba(8,145,178,.15)}
.call-cta svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}

/* FOOTER */
footer{background:#0C1A2E;color:#fff;border-top:1px solid rgba(255,255,255,.04);padding:clamp(28px,3vw,48px) 0 32px;position:relative;z-index:1}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.foot-grid{grid-template-columns:1fr}}
.foot-brand img{height:110px;object-fit:contain;margin-bottom:16px;display:block}
.foot-brand-desc{font-size:.84rem;color:rgba(255,255,255,.48);line-height:1.7;max-width:300px;margin-bottom:20px;text-align:center}
.foot-col-title{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.32);margin-bottom:16px}
.foot-links{display:flex;flex-direction:column;gap:9px}
.foot-link{font-size:.84rem;color:rgba(255,255,255,.55);transition:.25s}
.foot-link:hover{color:#38bdf8}
.foot-contact-item{display:flex;align-items:center;gap:9px;font-size:.84rem;color:rgba(255,255,255,.55);margin-bottom:10px;transition:.25s}
.foot-contact-item:hover{color:#38bdf8}
.foot-contact-item svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0}
.foot-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.foot-copy{font-size:.78rem;color:rgba(255,255,255,.28)}
.foot-legal{font-size:.78rem;color:rgba(255,255,255,.28);transition:.25s}
.foot-legal:hover{color:rgba(255,255,255,.6)}

/* MARQUEE */
.marquee-wrap{padding:clamp(28px,4vw,48px) 0;border-top:1px solid rgba(8,145,178,.1);border-bottom:1px solid rgba(8,145,178,.1);background:#fff;position:relative;z-index:1;overflow:hidden}
.marquee-label{text-align:center;font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--muted2);margin-bottom:24px}
.track{display:flex;animation:scroll 22s linear infinite;width:max-content}
.track:hover{animation-play-state:paused}
.track-item{padding:0 44px;display:flex;align-items:center}
.track-item img{height:32px;object-fit:contain;opacity:1;transition:.3s}
.track-item:hover img{opacity:.85}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* TEASER MORE */
.teaser-more{text-align:center;margin-top:48px}
.more-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border-radius:8px;background:#fff;border:1px solid var(--border-brand);color:var(--brand);font-family:'Outfit',sans-serif;font-size:.9rem;font-weight:700;transition:.3s;box-shadow:0 4px 24px rgba(8,145,178,.1)}
.more-btn:hover{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#001018;transform:translateY(-2px);box-shadow:0 12px 40px rgba(8,145,178,.3);border-color:transparent}
.more-btn svg{width:14px;height:14px}

/* RESPONSIVE FINE-TUNE */
@media(max-width:480px){h2.title{font-size:1.9rem}h1.hero-h1{font-size:2.4rem}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

