*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Palette : blanc dominant, bleu marine, rouge Paris */
  --white:#FFFFFF;
  --off:#F7F8FC;
  --off2:#EEF1F8;
  --navy:#0B1F4B;
  --navy2:#122460;
  --navy-light:#1A3280;
  --blue-mid:#2458C8;
  --red:#D42B2B;
  --red2:#B71C1C;
  --red-light:#F5E5E5;
  --text:#0B1F4B;
  --muted:#5A6A8A;
  --border:rgba(11,31,75,0.1);
  --border2:rgba(11,31,75,0.18);
  --ff-head:'Sora',sans-serif;
  --ff-body:'Manrope',sans-serif;
  --fs-xs:11px;
  --fs-sm:13px;
  --fs-md:14px;
  --fs-lg:15px;
  --fs-xl:18px;
  --space-1:4px;
  --space-2:8px;
  --space-3:12px;
  --space-4:16px;
  --space-5:20px;
  --space-6:24px;
  --ease:cubic-bezier(.4,0,.2,1);
  --t:.3s;
  --r:14px;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--white);color:var(--text);font-family:var(--ff-body);overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}

/* Ergonomie globale : focus clavier visible et cibles tactiles confortables */
:where(a,button,input,select,textarea,.do,.form-dot,.lang-btn){touch-action:manipulation}
:where(a,button,input,select,textarea,.do,.form-dot,.lang-btn):focus-visible{
  outline:2px solid var(--red);
  outline-offset:2px;
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
}
/* ─── SPLASH ─── */
#splash{
  position:fixed;inset:0;z-index:9999;
  background:var(--navy);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;
  transition:opacity .9s var(--ease),visibility .9s;
}
#splash.hide{opacity:0;visibility:hidden;pointer-events:none}

.sp-wrap{display:flex;flex-direction:column;align-items:center;gap:36px;animation:spIn .8s var(--ease) both}
@keyframes spIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

.sp-logo{
  width:110px;height:110px;position:relative;
  animation:spinSlow 8s linear infinite;
}
@keyframes spinSlow{to{transform:rotate(360deg)}}

.sp-name{
  font-family:var(--ff-head);font-size:clamp(26px,4vw,48px);
  font-weight:800;letter-spacing:-1px;color:#fff;text-align:center;
}
.sp-name .it{color:var(--red)}
.sp-name .dot{color:var(--blue-mid)}
.sp-sub{font-size:13px;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:-24px}

.sp-tricolor{
  display:flex;gap:0;border-radius:6px;overflow:hidden;width:200px;height:4px;
}
.sp-tricolor div{flex:1}
.sp-tricolor .tc-b{background:var(--blue-mid)}
.sp-tricolor .tc-w{background:rgba(255,255,255,.9)}
.sp-tricolor .tc-r{background:var(--red)}

.sp-bar-outer{width:220px;height:2px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden}
.sp-bar-inner{height:100%;width:0;background:#fff;animation:loadBar 2.4s .5s var(--ease) forwards}
@keyframes loadBar{to{width:100%}}
/* ══════════════════════════════════════════════
   CINEMATIC SCROLL EXPERIENCE — CSS
══════════════════════════════════════════════ */

/* Hauteur de secours avant JS ; intro.js impose la hauteur réelle (plus courte qu’avant) */
#intro-wrap{height:280vh;position:relative;z-index:2}
#intro{position:sticky;top:0;height:100vh;overflow:hidden;z-index:2}

/* Image zoom */
#intro-img-wrap{
  position:absolute;inset:-12%;
  will-change:transform;transform-origin:center center;
}
#intro-img{width:100%;height:100%;object-fit:cover;display:block}
.intro-overlay{position:absolute;inset:0;transition:background .05s}
.intro-vignette{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at center,transparent 25%,rgba(0,0,0,.5) 100%);
}

/* Scanner line */
.intro-scanner{
  position:absolute;left:0;right:0;height:1px;z-index:10;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);
  pointer-events:none;top:50%;opacity:0;
  box-shadow:0 0 20px rgba(255,255,255,.3);
}

/* Side progress rail */
.intro-prog-rail{
  position:absolute;right:28px;top:50%;transform:translateY(-50%);
  height:200px;width:2px;
  background:rgba(255,255,255,.12);
  border-radius:1px;z-index:20;
  display:flex;flex-direction:column;justify-content:space-between;
  align-items:center;
}
.intro-prog-fill{
  position:absolute;top:0;left:0;right:0;
  background:var(--red);border-radius:1px;height:0%;
  transition:height .1s;box-shadow:0 0 8px var(--red);
}
.intro-chapters{
  position:absolute;top:0;left:0;right:0;bottom:0;
  display:flex;flex-direction:column;justify-content:space-between;align-items:center;
}
.ic{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.25);
  border:1.5px solid rgba(255,255,255,.3);
  cursor:default;position:relative;transition:all .3s;
}
.ic.active{background:var(--red);border-color:var(--red);box-shadow:0 0 10px var(--red)}
.ic::after{
  content:attr(data-label);
  position:absolute;right:18px;top:50%;transform:translateY(-50%);
  font-size:10px;color:rgba(255,255,255,.5);white-space:nowrap;
  letter-spacing:1.5px;text-transform:uppercase;
  opacity:0;transition:opacity .3s;font-family:var(--ff-body);
}
.ic.active::after{opacity:1;color:#fff}

/* Numéro chapitre flottant */
.intro-chap-num{
  position:absolute;left:40px;bottom:48px;z-index:20;
  font-family:var(--ff-head);font-size:100px;font-weight:800;
  color:rgba(255,255,255,.04);line-height:1;letter-spacing:-4px;
  pointer-events:none;transition:opacity .4s;
  user-select:none;
}

/* ── Scènes communes ── */
.iscene{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;padding:20px;
  pointer-events:none;
  opacity:0;will-change:opacity,transform;
}

/* ── SCÈNE 1 : Logo ── */
.iscene1-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  color:rgba(255,255,255,.7);font-size:13px;font-weight:500;
  letter-spacing:3px;text-transform:uppercase;margin-bottom:28px;
  opacity:0;animation:introFadeUp .9s 3.4s var(--ease) forwards;
}
.intro-dot{
  width:7px;height:7px;border-radius:50%;background:var(--red);
  box-shadow:0 0 12px var(--red),0 0 30px rgba(212,43,43,.4);
  animation:blink 2s infinite;flex-shrink:0;
}
.iscene1-logo{
  font-family:var(--ff-head);
  font-size:clamp(44px,9.5vw,116px);
  font-weight:800;color:#fff;
  letter-spacing:-4px;line-height:1;
  text-shadow:0 4px 60px rgba(0,0,0,.5);
  margin-bottom:22px;
  opacity:0;animation:introFadeUp .9s 3.6s var(--ease) forwards;
}
.ild{color:var(--blue-mid);text-shadow:0 0 24px rgba(36,88,200,.45)}
.ilit{color:var(--red);text-shadow:0 0 80px rgba(212,43,43,.7)}
.iscene1-sub{
  font-size:clamp(12px,1.6vw,16px);color:rgba(255,255,255,.55);
  letter-spacing:5px;text-transform:uppercase;font-weight:400;margin-bottom:36px;
  opacity:0;animation:introFadeUp .9s 3.8s var(--ease) forwards;
}
.intro-tricolor{
  display:flex;width:100px;height:3px;border-radius:2px;overflow:hidden;
  opacity:0;animation:introFadeUp .9s 4s var(--ease) forwards;
}
.intro-tricolor div:nth-child(1){flex:1;background:var(--blue-mid)}
.intro-tricolor div:nth-child(2){flex:1;background:rgba(255,255,255,.8)}
.intro-tricolor div:nth-child(3){flex:1;background:var(--red)}

/* ── SCÈNE 2 : Valeurs ── */
.iscene2-top{
  font-size:clamp(13px,1.5vw,16px);color:rgba(255,255,255,.45);
  letter-spacing:5px;text-transform:uppercase;margin-bottom:20px;
}
.iscene2-words{
  display:flex;align-items:center;justify-content:center;
  gap:clamp(10px,2.1vw,28px);
  flex-wrap:wrap;
  margin-bottom:28px;
  max-width:min(92vw,980px);
}
.iw2{
  font-family:var(--ff-head);
  font-size:clamp(24px,5.1vw,66px);
  font-weight:800;color:#fff;
  letter-spacing:-2px;line-height:1;
  will-change:opacity,transform;
  white-space:nowrap;
}
.iw2-sep{
  font-family:var(--ff-head);font-size:clamp(18px,2.9vw,36px);
  color:var(--red);font-weight:800;
}
.iscene2-sub{
  font-size:clamp(15px,1.8vw,20px);color:rgba(255,255,255,.55);
  line-height:1.7;margin-bottom:28px;
}
.iscene2-line{
  width:0;height:2px;
  background:linear-gradient(90deg,var(--blue-mid),var(--red));
  border-radius:1px;transition:width 0s;
}

/* ── SCÈNE 3 : Stats ── */
.iscene3-label{
  display:flex;align-items:center;gap:20px;
  font-size:12px;letter-spacing:4px;text-transform:uppercase;
  color:rgba(255,255,255,.4);margin-bottom:52px;font-weight:500;
}
.isl-line{flex:1;height:1px;background:rgba(255,255,255,.15)}
.iscene3-stats{
  display:flex;align-items:center;gap:0;
  background:rgba(255,255,255,.05);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:24px;padding:40px 52px;
}
.is3{
  display:flex;flex-direction:column;align-items:center;padding:0 40px;
  will-change:opacity,transform;
}
.is3-sep{width:1px;height:64px;background:rgba(255,255,255,.12)}
.is3-num{
  font-family:var(--ff-head);font-size:clamp(42px,6vw,72px);
  font-weight:800;color:#fff;line-height:1;letter-spacing:-2px;
}
.is3-num span{color:var(--red);font-size:.7em}
.is3-lab{
  font-size:clamp(11px,1.1vw,13px);color:rgba(255,255,255,.45);
  letter-spacing:1.5px;text-transform:uppercase;margin-top:10px;
}

/* ── SCÈNE 4 : Pills services ── */
.iscene4-title{
  font-size:12px;letter-spacing:5px;text-transform:uppercase;
  color:rgba(255,255,255,.4);margin-bottom:44px;font-weight:600;
}
.iscene4-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:700px;width:100%;
}
.is4p{
  padding:16px 28px;border-radius:100px;
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;font-size:clamp(13px,1.4vw,16px);font-weight:600;
  will-change:opacity,transform;
  white-space:nowrap;
}

/* ── SCÈNE 5 : Promesse ── */
.iscene5-line1{
  font-family:var(--ff-head);
  font-size:clamp(28px,5.5vw,72px);
  font-weight:800;color:rgba(255,255,255,.7);
  letter-spacing:-2px;line-height:1.05;
  will-change:opacity,transform;
}
.iscene5-line2{
  font-family:var(--ff-head);
  font-size:clamp(30px,6vw,80px);
  font-weight:800;color:#fff;
  letter-spacing:-2.5px;line-height:1.05;
  margin-bottom:32px;
  will-change:opacity,transform;
}
.iscene5-sub{
  font-size:clamp(14px,1.6vw,18px);
  color:rgba(255,255,255,.5);line-height:1.8;margin-bottom:44px;
  will-change:opacity,transform;
}
.iscene5-btns{
  display:flex;gap:16px;flex-wrap:wrap;justify-content:center;
  will-change:opacity,transform;pointer-events:all;
}
.is5-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--red);color:#fff;
  padding:16px 36px;border-radius:12px;
  font-size:15px;font-weight:700;font-family:var(--ff-head);
  text-decoration:none;letter-spacing:-.3px;
  transition:background .3s,transform .3s;
  box-shadow:0 12px 40px rgba(212,43,43,.4);
}
.is5-cta:hover{background:var(--red2);transform:translateY(-3px)}
.is5-cta-ghost{
  display:inline-flex;align-items:center;
  border:1.5px solid rgba(255,255,255,.3);color:#fff;
  padding:15px 34px;border-radius:12px;
  font-size:15px;font-weight:600;font-family:var(--ff-head);
  text-decoration:none;
  transition:border-color .3s,background .3s;
  backdrop-filter:blur(10px);
}
.is5-cta-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.iscene5-award{
  margin-top:36px;
  display:flex;align-items:center;gap:12px;
  color:rgba(255,255,255,.4);font-size:13px;
  will-change:opacity,transform;
}

/* ── Scroll indicator ── */
.intro-scroll{
  position:absolute;bottom:38px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  opacity:0;animation:introFadeUp .9s 4.4s var(--ease) forwards;
  cursor:pointer;z-index:20;
}
.intro-scroll-label{
  color:rgba(255,255,255,.4);font-size:10px;
  letter-spacing:4px;text-transform:uppercase;
}
.intro-mouse{
  width:22px;height:34px;border-radius:11px;
  border:1.5px solid rgba(255,255,255,.3);
  display:flex;justify-content:center;padding-top:7px;
  animation:mouseAppear 1.8s ease-in-out 5s infinite;
}
.intro-mouse-wheel{
  width:3px;height:6px;background:#fff;border-radius:2px;
  animation:mouseWheel 1.8s ease-in-out 5s infinite;
}
@keyframes mouseWheel{
  0%{transform:translateY(0);opacity:1}
  80%{transform:translateY(8px);opacity:0}
  100%{transform:translateY(0);opacity:0}
}
@keyframes mouseAppear{0%,20%{opacity:1}80%,100%{opacity:.3}}

/* ── Badges coins ── */
.intro-badge-tl{
  position:absolute;top:88px;left:32px;z-index:20;
  display:flex;align-items:center;gap:8px;
  color:rgba(255,255,255,.6);font-size:12.5px;font-weight:500;
  opacity:0;animation:introFadeUp .8s 4.1s var(--ease) forwards;
  background:rgba(255,255,255,.07);backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:100px;padding:8px 16px;
}
.ib-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 10px #22c55e;flex-shrink:0}
@keyframes introFadeUp{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:none}
}

/* Nav transparent on intro */
nav.on-intro{
  background:rgba(0,0,0,0)!important;
  border-bottom-color:transparent!important;
  backdrop-filter:none!important;
  box-shadow:none!important;
}
nav.on-intro .logo-txt{color:#fff}
nav.on-intro .logo-txt .logo-dot{color:var(--blue-mid)}
nav.on-intro .logo-txt .it{color:var(--red)}
nav.on-intro .logo-txt .sub{color:rgba(255,255,255,.4)}
nav.on-intro .nav-links a{color:rgba(255,255,255,.6)}
nav.on-intro .nav-links a:hover{color:#fff}
nav.on-intro .logo-icon{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18)}
nav.on-intro .lang-switch--bar{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.22);
  box-shadow:0 1px 3px rgba(0,0,0,.12),inset 0 1px 0 rgba(255,255,255,.12);
}
nav.on-intro .lang-switch--bar .lang-btn{color:rgba(255,255,255,.82)}
nav.on-intro .lang-switch--bar .lang-btn:hover:not(.active){
  color:#fff;background:rgba(255,255,255,.12);
}
nav.on-intro .lang-switch--bar .lang-btn.active{
  background:#fff;color:var(--navy);
  box-shadow:0 1px 5px rgba(0,0,0,.15);
}
nav.on-intro{transition:background .5s,border-color .5s,backdrop-filter .5s,opacity 1.2s,transform 1.2s}

/* Smooth nav fade support during intro */
nav{transition:opacity 1.2s var(--ease),transform 1.2s var(--ease),background .5s,border-color .5s,backdrop-filter .5s}
/* ─── NAV ─── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:72px;padding:0 clamp(12px,4vw,5%);
  display:flex;align-items:center;justify-content:flex-start;gap:12px;
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  min-width:0;
}
.nav-end{
  display:flex;align-items:center;gap:10px;
  margin-left:auto;flex-shrink:0;
  min-width:0;
}
.nav-logo{display:flex;align-items:center;gap:12px;min-width:0}
@media (max-width:768px){
  .nav-logo{max-width:calc(100% - 52px)}
}
.logo-icon{
  width:40px;height:40px;border-radius:10px;
  background:var(--navy);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;position:relative;overflow:hidden;
}
.logo-icon::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:var(--red);
}
.logo-icon svg{display:block}
.logo-txt{font-family:var(--ff-head);font-size:17px;font-weight:800;letter-spacing:-.4px;color:var(--navy);line-height:1.15}
.logo-txt .it{color:var(--blue-mid)}
.logo-txt .logo-dot{color:var(--blue-mid)}
.logo-txt .sub{display:block;font-size:10px;font-weight:500;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase}

.nav-links{display:flex;align-items:center;gap:32px;list-style:none;margin:0;padding:0}
@media (max-width:1180px){
  .nav-links{gap:20px}
  .nav-links a{font-size:13px}
  .nav-end{gap:8px}
}
.nav-links a{font-size:13.5px;font-weight:500;color:var(--muted);transition:color var(--t)}
.nav-links a:hover{color:var(--navy)}
.nav-cta{
  background:var(--red)!important;color:#fff!important;
  padding:9px 22px;border-radius:9px;
  font-size:13px!important;font-weight:700!important;
  transition:background var(--t)!important;
}
.nav-cta:hover{background:var(--red2)!important}

/* Sélecteur langue : pilule segmentée compacte (ne pousse pas le menu) */
.lang-switch{
  display:inline-flex;align-items:stretch;flex-shrink:0;
  padding:2px;
  border-radius:999px;
  background:rgba(26,49,128,.055);
  border:1px solid rgba(26,49,128,.1);
  box-shadow:0 1px 2px rgba(11,31,75,.06),inset 0 1px 0 rgba(255,255,255,.65);
  gap:0;
}
.lang-btn{
  font-family:var(--ff-body);font-size:9px;font-weight:700;
  letter-spacing:.04em;
  min-width:26px;padding:5px 6px;border-radius:999px;cursor:pointer;
  border:none;background:transparent;color:var(--muted);
  line-height:1;
  transition:color .18s,background .18s,box-shadow .18s,transform .12s;
}
.lang-btn:hover:not(.active){
  color:var(--navy);
  background:rgba(255,255,255,.55);
}
.lang-btn.active{
  background:linear-gradient(165deg,#1e3d8f 0%,#1a3280 45%,#142a6e 100%);
  color:#fff;
  box-shadow:0 1px 4px rgba(11,31,75,.22);
}
.lang-btn:focus-visible{
  outline:2px solid var(--red);outline-offset:2px;z-index:1;position:relative;
}
.lang-btn:active:not(.disabled){transform:scale(.96)}

/* Langue : barre desktop uniquement ; menu mobile = .lang-switch--in-menu */
.lang-switch--in-menu{display:none!important}
@media (max-width:768px){
  .lang-switch--bar{display:none!important}
  .lang-switch--in-menu{display:inline-flex!important}
}
/* ─── HERO ─── */
#hero{
  min-height:100vh;padding:100px 5% 80px;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  background:var(--white);position:relative;overflow:hidden;
}
.hero-bg-deco{
  position:absolute;top:0;right:0;width:55%;height:100%;
  background:var(--off);clip-path:polygon(8% 0,100% 0,100% 100%,0 100%);
  z-index:0;
}
.hero-stripe{
  position:absolute;top:0;right:0;width:6px;height:100%;
  background:linear-gradient(180deg,var(--blue-mid) 0%,var(--red) 100%);
  z-index:1;box-shadow:-4px 0 28px rgba(212,43,43,.2);
}
.hero-l{position:relative;z-index:2}
.hero-r{position:relative;z-index:2}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--white);border:1px solid var(--border2);
  border-radius:100px;padding:7px 20px;margin-bottom:32px;
  font-size:12.5px;font-weight:600;color:var(--muted);letter-spacing:.5px;
  box-shadow:0 2px 14px rgba(11,31,75,.08);
}
.hero-dot{width:7px;height:7px;border-radius:50%;background:var(--red);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

.hero-h1{
  font-family:var(--ff-head);
  font-size:clamp(38px,5vw,72px);
  font-weight:800;line-height:1.03;letter-spacing:-2px;
  color:var(--navy);margin-bottom:28px;
}
.hero-h1 .red{color:var(--red)}
.hero-h1 .red.animated-gradient{color:transparent}
.hero-h1 .blue{color:var(--blue-mid)}
.hero-h1 .blue.animated-gradient{color:transparent}

.hero-p{font-size:17px;color:var(--muted);line-height:1.8;max-width:480px;margin-bottom:44px;font-weight:400;letter-spacing:.2px}

.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.btn-red{
  display:inline-flex;align-items:center;gap:9px;
  background:linear-gradient(135deg,var(--red) 0%,#b91c1c 100%);color:#fff;
  padding:14px 30px;border-radius:11px;font-size:15px;font-weight:700;
  transition:transform var(--t),box-shadow var(--t),opacity var(--t);
  box-shadow:0 4px 18px rgba(212,43,43,.35);
  position:relative;overflow:hidden;
}
.btn-red::after{
  content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);
  transform:skewX(-18deg);transition:left .55s var(--ease);pointer-events:none;
}
.btn-red:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(212,43,43,.45);opacity:.95}
.btn-red:hover::after{left:160%}
.btn-navy{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--navy);color:#fff;
  padding:14px 30px;border-radius:11px;font-size:15px;font-weight:600;
  transition:background var(--t),transform var(--t);
}
.btn-navy:hover{background:var(--navy2);transform:translateY(-2px)}
.btn-outline{
  display:inline-flex;align-items:center;gap:9px;
  border:1.5px solid var(--border2);color:var(--navy);
  padding:13px 28px;border-radius:11px;font-size:15px;font-weight:600;
  transition:border-color var(--t),background var(--t);
}
.btn-outline:hover{border-color:var(--blue-mid);background:var(--off)}

.hero-stats{
  display:flex;gap:40px;margin-top:60px;padding-top:36px;
  border-top:1px solid var(--border);
}
.stat-n{
  font-family:var(--ff-head);font-size:42px;font-weight:800;color:var(--navy);line-height:1;
}
.stat-n span{color:var(--red)}
.stat-l{font-size:12px;color:var(--muted);margin-top:6px;font-weight:500}

/* hero image */
.hero-imgs{position:relative;height:580px}
.hi-main{
  position:absolute;right:0;top:0;width:90%;height:450px;
  border-radius:20px;overflow:hidden;border:1px solid var(--border2);
  box-shadow:0 24px 64px rgba(11,31,75,.12);
}
.hi-main img{width:100%;height:100%;object-fit:cover;filter:brightness(.82) saturate(.9)}
.hi-float{
  position:absolute;left:0;bottom:0;width:52%;height:250px;
  border-radius:16px;overflow:hidden;border:2px solid var(--white);
  box-shadow:0 20px 56px rgba(11,31,75,.18);
}
.hi-float img{width:100%;height:100%;object-fit:cover;filter:brightness(.85) saturate(.9)}
.hi-card{
  position:absolute;top:36px;left:-8px;
  background:var(--white);border:1px solid var(--border2);
  border-radius:14px;padding:14px 18px;
  display:flex;align-items:center;gap:12px;
  box-shadow:0 12px 40px rgba(11,31,75,.15);
}
.hi-card-stripe{width:4px;height:40px;border-radius:2px;background:linear-gradient(180deg,var(--blue-mid),var(--red));flex-shrink:0}
.hi-ct{font-size:13px;font-weight:700;color:var(--navy)}
.hi-cs{font-size:11.5px;color:var(--muted);margin-top:3px}
/* ─── BAND ─── */
.triband{display:flex;height:5px}
.triband div{flex:1}
.tb-b{background:var(--blue-mid)}
.tb-w{background:var(--off2)}
.tb-r{background:var(--red)}
/* ─── SECTION BASE ─── */
section{padding:110px 5%;position:relative}
.s-header{position:relative}
.s-label{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;margin-bottom:14px}
.s-label.red{color:var(--red)}
.s-label.blue{color:var(--blue-mid)}
.s-label.navy{color:var(--navy)}
.s-title{
  font-family:var(--ff-head);font-size:clamp(30px,4vw,52px);
  font-weight:800;line-height:1.08;letter-spacing:-1.5px;
  color:var(--navy);margin-bottom:18px;
}
.s-title .red{color:var(--red)}
.s-sub{font-size:16.5px;color:var(--muted);max-width:500px;line-height:1.8;font-weight:400}
.s-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:64px;flex-wrap:wrap;gap:24px}
.s-header::after{
  content:'';
  width:76px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--blue-mid),var(--red));
  opacity:1;
  box-shadow:0 2px 12px rgba(212,43,43,.2);
}
/* ─── DIVIDER PHOTO ─── */
.dp{width:100%;height:400px;overflow:hidden;position:relative}
.dp img{width:100%;height:100%;object-fit:cover;filter:brightness(.38) saturate(.6)}
.dp-over{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(11,31,75,.2) 0%,transparent 40%,transparent 60%,rgba(11,31,75,.35) 100%);
}
.dp-text{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;padding:40px;
}
.dp-text h2{
  font-family:var(--ff-head);font-size:clamp(26px,4.5vw,52px);
  font-weight:800;color:#fff;letter-spacing:-1.5px;margin-bottom:14px;line-height:1.08;
}
.dp-text h2 span{color:#F9A8A8}
.dp-text p{
  font-size:16px;color:rgba(255,255,255,.78);max-width:560px;font-weight:300;
  background:rgba(11,31,75,.28);
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  padding:10px 14px;
  backdrop-filter:blur(6px);
}
.dp-badge{
  position:absolute;bottom:28px;right:32px;
  background:var(--red);color:#fff;
  padding:8px 18px;border-radius:100px;
  font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
}
/* ─── SERVICES ─── */
#services{
  background:linear-gradient(180deg, var(--off), #f6f8fe);
}
.srv-layout{
  display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:stretch;
}
.srv-overview{
  background:#fff;border:1px solid var(--border);border-radius:24px;
  padding:34px 32px;box-shadow:0 14px 38px rgba(11,31,75,.08);
  position:relative;overflow:hidden;
}
.srv-overview::before{
  content:'';
  position:absolute;
  inset:-120px auto auto -120px;
  width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle at center, rgba(36,88,200,.12), transparent 70%);
  pointer-events:none;
}
.srv-tag{
  display:inline-block;padding:6px 12px;border-radius:100px;
  background:rgba(212,43,43,.1);color:var(--red);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
}
.srv-overview h3{
  margin:14px 0 12px;font-family:var(--ff-head);font-size:clamp(28px,3vw,38px);
  line-height:1.12;letter-spacing:-.6px;color:var(--navy);
}
.srv-overview p{font-size:15px;line-height:1.8;color:var(--muted);margin-bottom:18px}
.srv-points{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.srv-points li{position:relative;padding-left:18px;font-size:14px;color:var(--navy)}
.srv-points li::before{
  content:'';position:absolute;left:0;top:8px;width:7px;height:7px;border-radius:50%;
  background:var(--red);
}
.srv-media{
  position:relative;border-radius:24px;overflow:hidden;border:1px solid rgba(11,31,75,.12);
  min-height:320px;box-shadow:0 16px 45px rgba(11,31,75,.12);
}
.srv-media img{width:100%;height:100%;object-fit:cover;filter:brightness(.72)}
.srv-media-card{
  position:absolute;left:16px;right:16px;bottom:16px;
  background:rgba(11,31,75,.78);color:#fff;border-radius:14px;padding:12px 14px;
  border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(10px);
}
.srv-media-card span{display:block;font-size:11px;letter-spacing:1px;text-transform:uppercase;opacity:.72}
.srv-media-card strong{font-size:15px}

.srv-catalog{
  margin-top:20px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;
}
.srv-item{
  background:#fff;border:1px solid var(--border);border-radius:16px;
  padding:18px 18px 16px;transition:transform var(--t),box-shadow var(--t),border-color var(--t);
  position:relative;overflow:hidden;
}
.srv-item::after{
  content:'';
  position:absolute;
  left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,var(--blue-mid),var(--red));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .3s var(--ease);
}
.srv-item:hover{transform:translateY(-4px);box-shadow:0 18px 42px rgba(36,88,200,.14);border-color:rgba(36,88,200,.4)}
.srv-item:hover::after{transform:scaleX(1)}
.srv-item h4{font-family:var(--ff-head);font-size:18px;color:var(--navy);margin-bottom:8px}
.srv-item p{font-size:13.5px;line-height:1.65;color:var(--muted)}
.srv-item-featured{
  grid-column:span 2;
  background:linear-gradient(140deg,#0d2060 0%,#1e3fa0 60%,#1a3280 100%);
  border-color:rgba(255,255,255,.18);
  box-shadow:0 10px 36px rgba(11,31,75,.22);
}
.srv-item-featured h4{color:#fff}
.srv-item-featured p{color:rgba(255,255,255,.82)}
.srv-item-featured::after{display:none}

.srv-actions{
  margin-top:20px;display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap;
}
/* ─── AUDIENCE ─── */
#audience{background:var(--off)}
.aud-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:64px}
.aud-card{
  border-radius:22px;padding:48px 40px;position:relative;overflow:hidden;
  transition:transform var(--t),box-shadow var(--t);
}
.aud-part{background:linear-gradient(145deg,var(--navy) 0%,#0d2455 60%,#1a3280 100%);color:#fff}
.aud-pro{background:var(--off);border:1px solid var(--border2)}
.aud-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 34px rgba(11,31,75,.12);
}
.aud-ghost{
  position:absolute;bottom:-15px;right:16px;
  font-family:var(--ff-head);font-size:130px;font-weight:800;
  opacity:.06;line-height:1;pointer-events:none;user-select:none;
}
.aud-part .aud-ghost{color:#fff}
.aud-pro .aud-ghost{color:var(--navy)}
.aud-chip{
  display:inline-block;padding:5px 14px;border-radius:100px;
  font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:24px;
}
.aud-part .aud-chip{background:var(--red);color:#fff}
.aud-pro .aud-chip{background:var(--navy);color:#fff}
.aud-title{font-family:var(--ff-head);font-size:30px;font-weight:800;margin-bottom:14px;letter-spacing:-.5px}
.aud-part .aud-title{color:#fff}
.aud-pro .aud-title{color:var(--navy)}
.aud-desc{font-size:15px;line-height:1.75;margin-bottom:28px;font-weight:300}
.aud-part .aud-desc{color:rgba(255,255,255,.65)}
.aud-pro .aud-desc{color:var(--muted)}
.aud-list{list-style:none;display:flex;flex-direction:column;gap:11px}
.aud-list li{display:flex;align-items:flex-start;gap:11px;font-size:14px}
.aud-part .aud-list li{color:rgba(255,255,255,.8)}
.aud-pro .aud-list li{color:var(--muted)}
.aud-list li::before{
  content:'';flex-shrink:0;margin-top:7px;
  width:6px;height:6px;border-radius:50%;
}
.aud-part .aud-list li::before{background:var(--red)}
.aud-pro .aud-list li::before{background:var(--blue-mid)}
/* ─── MOSAIC ─── */
.mosaic{
  display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:240px 240px;
  gap:3px;
}
.mc{overflow:hidden;position:relative;cursor:default}
.mc:first-child{grid-row:1/3}
.mc img{width:100%;height:100%;object-fit:cover;filter:brightness(.5) saturate(.65);transition:filter .4s var(--ease),transform .5s var(--ease)}
.mc:hover img{filter:brightness(.65) saturate(.9);transform:scale(1.04)}
.mc-lbl{
  position:absolute;bottom:14px;left:14px;
  background:rgba(11,31,75,.85);backdrop-filter:blur(8px);
  border-radius:8px;padding:6px 12px;
  font-size:11.5px;color:#fff;font-weight:600;letter-spacing:.5px;
}
/* ─── EXPERTISE ─── */
#expertise{background:var(--navy)}
#expertise .s-title{color:#fff}
#expertise .s-sub{color:rgba(255,255,255,.55)}
.exp-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-top:64px}
.exp-list{display:flex;flex-direction:column}
.exp-item{
  padding:26px 0;border-bottom:1px solid rgba(255,255,255,.08);
  display:grid;grid-template-columns:36px 1fr;gap:18px;
  transition:padding var(--t),background var(--t),border-color var(--t);cursor:default;
  border-radius:12px;
}
.exp-item:first-child{border-top:1px solid rgba(255,255,255,.08)}
.exp-item:hover{
  padding:26px 14px;
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.16);
}
.exp-n{font-family:var(--ff-head);font-size:14px;font-weight:700;color:var(--red);padding-top:3px}
.exp-nm{font-family:var(--ff-head);font-size:18px;font-weight:700;color:#fff;margin-bottom:7px}
.exp-d{font-size:14px;color:rgba(255,255,255,.72);line-height:1.75}
.exp-vis{border-radius:22px;overflow:hidden;border:1px solid rgba(255,255,255,.1);position:relative}
.exp-vis img{width:100%;height:460px;object-fit:cover;filter:brightness(.55) saturate(.75);display:block}
.exp-over{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(11,31,75,.96) 100%)}
.exp-cards{position:absolute;bottom:28px;left:24px;right:24px;display:flex;flex-direction:column;gap:10px}
.exp-mini{
  background:rgba(255,255,255,.07);backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.12);border-radius:12px;
  padding:15px 18px;display:flex;align-items:center;gap:13px;
  transition:transform var(--t),background var(--t),box-shadow var(--t);
}
.exp-mini:hover{transform:translateY(-2px);background:rgba(255,255,255,.14);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.em-ico{
  width:36px;height:36px;border-radius:9px;flex-shrink:0;
  background:linear-gradient(135deg,var(--red) 0%,#b91c1c 100%);
  display:flex;align-items:center;justify-content:center;font-size:16px;
  box-shadow:0 3px 10px rgba(212,43,43,.4);
}
.em-t{font-size:13px;font-weight:700;color:#fff}
.em-s{font-size:11px;color:rgba(255,255,255,.5);margin-top:2px}
/* ─── PARTNERS ─── */
#partners{
  background:var(--off);
  padding:72px 5%;
  overflow:hidden;
  position:relative;
}
.pt-lbl{
  text-align:center;
  font-size:11px;
  color:var(--muted);
  letter-spacing:3px;
  text-transform:uppercase;
  margin-bottom:40px;
  font-weight:600;
}
.pt-row{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
  max-width:900px;
  margin:0 auto;
}
.pt-pill{
  display:inline-flex;
  align-items:center;
  gap:9px;
  flex-shrink:0;
  padding:11px 20px;
  border-radius:100px;
  background:var(--white);
  border:1px solid var(--border);
  font-family:var(--ff-head);
  font-size:13px;
  font-weight:700;
  color:var(--navy);
  user-select:none;
  transition:border-color var(--t),transform var(--t),box-shadow var(--t);
}
.pt-pill:hover{
  border-color:var(--blue-mid);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(11,31,75,.1);
}
.pt-dot{
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--red);
  flex-shrink:0;
}
/* ─── TESTIMONIALS ─── */
#testimonials{background:var(--white)}
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:64px}
.tst-card{
  background:var(--off);border:1px solid var(--border);border-radius:20px;
  padding:36px 28px;transition:transform var(--t),box-shadow var(--t),border-color var(--t);
  position:relative;overflow:hidden;
}
.tst-card::before{
  content:'\201C';font-family:var(--ff-head);font-size:96px;line-height:.75;
  color:var(--blue-mid);opacity:.12;
  position:absolute;top:20px;right:22px;pointer-events:none;font-weight:800;
}
.tst-card:hover{
  transform:translateY(-5px);box-shadow:0 24px 56px rgba(11,31,75,.11);
  border-color:rgba(36,88,200,.22);
}
.tst-stars{font-size:14px;margin-bottom:18px;letter-spacing:2px;color:#f59e0b}
.tst-txt{font-size:15px;color:var(--text);line-height:1.8;margin-bottom:24px;font-style:italic;font-weight:400}
.tst-auth{display:flex;align-items:center;gap:12px}
.tst-av{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-head);font-size:13px;font-weight:800;color:#fff;
  box-shadow:0 4px 12px rgba(11,31,75,.25);
}
.tst-nm{font-size:14px;font-weight:700;color:var(--navy)}
.tst-rl{font-size:12px;color:var(--muted)}
/* ─── AGENCE ─── */
#agence{background:var(--off)}
.agence-layout{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.agence-img{border-radius:22px;overflow:hidden;border:1px solid var(--border);box-shadow:0 20px 60px rgba(11,31,75,.1)}
.agence-img img{width:100%;height:500px;object-fit:cover;filter:brightness(.8) saturate(.85);display:block}
.agence-facts{display:flex;flex-direction:column;gap:18px}
.af{
  display:flex;gap:18px;padding:22px 24px;
  background:var(--white);border:1px solid var(--border);border-radius:14px;
  transition:border-color var(--t),transform var(--t),box-shadow var(--t);
}
.af:hover{border-color:var(--blue-mid);transform:translateX(5px);box-shadow:0 8px 28px rgba(11,31,75,.1)}
.af-ico{
  width:48px;height:48px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);
  display:flex;align-items:center;justify-content:center;font-size:21px;
  box-shadow:0 4px 14px rgba(11,31,75,.28);
}
.af-t{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:5px}
.af-d{font-size:13.5px;color:var(--muted);line-height:1.6}
.af-d a{color:var(--blue-mid)}
/* ─── CONTACT ─── */
#contact{background:var(--off)}
.ct-layout{display:grid;grid-template-columns:1fr 1.15fr;gap:72px;margin-top:64px}
.ct-left{display:flex;flex-direction:column;gap:20px}
.ci{
  display:flex;gap:16px;padding:20px 22px;
  background:var(--off);border:1px solid var(--border);border-radius:14px;
}
.ci-ico{
  width:46px;height:46px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);
  display:flex;align-items:center;justify-content:center;font-size:20px;
  box-shadow:0 4px 12px rgba(11,31,75,.28);
}
.ci-lb{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px}
.ci-vl{font-size:15.5px;color:var(--navy);font-weight:600}
.ci-vl a{color:var(--blue-mid)}
.urg-box{
  background:var(--red-light);
  border:1px solid rgba(212,43,43,.22);
  border-left:4px solid var(--red);
  border-radius:0 14px 14px 0;padding:26px;margin-top:4px;
}
.urg-t{font-size:13.5px;font-weight:700;color:var(--red);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.urg-p{font-size:14px;color:var(--muted);line-height:1.65;margin-bottom:18px}

.cf{
  background:
    radial-gradient(560px 180px at 0% 0%,rgba(36,88,200,.09),transparent 70%),
    radial-gradient(420px 170px at 100% 0%,rgba(212,43,43,.08),transparent 70%),
    var(--white);
  border:1px solid var(--border2);
  border-radius:22px;padding:40px 36px;
  box-shadow:0 12px 48px rgba(11,31,75,.07);
}
.cf-h{font-family:var(--ff-head);font-size:22px;font-weight:800;color:var(--navy);margin-bottom:28px}
.form-progress-wrap{margin-bottom:22px}
.form-step-dots{display:flex;gap:8px;justify-content:flex-start;margin-bottom:10px}
.form-dot{
  width:34px;height:34px;border-radius:50%;border:1px solid var(--border2);background:#fff;color:var(--muted);
  font-size:12px;font-weight:700;cursor:pointer;transition:all var(--t);
}
.form-dot.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.form-progress{height:8px;border-radius:999px;background:rgba(11,31,75,.08);overflow:hidden}
.form-progress span{
  display:block;height:100%;width:33.33%;background:linear-gradient(90deg,var(--blue-mid),var(--red));
  transition:width .55s cubic-bezier(.34,1.56,.64,1);
}
.form-step-title{margin-top:10px;font-size:12px;color:var(--muted);font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.fg{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fgg{display:flex;flex-direction:column;gap:7px}
.fgg.full{grid-column:1/-1}
.flb{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:1px;text-transform:uppercase}
.fi,.fs,.ft{
  background:var(--white);border:1px solid var(--border2);border-radius:10px;
  padding:13px 16px;color:var(--navy);
  font-family:var(--ff-body);font-size:15px;outline:none;width:100%;
  min-height:50px;
  transition:border-color var(--t),box-shadow var(--t);
}
.fi:focus,.fs:focus,.ft:focus{border-color:var(--blue-mid);box-shadow:0 0 0 4px rgba(36,88,200,.12)}
.fi::placeholder,.ft::placeholder{color:var(--muted)}
.fs option{background:var(--white);color:var(--navy)}
.ft{resize:vertical;min-height:105px}
.form-step{display:none;animation:formStepIn .25s ease}
.form-step.active{display:block}
@keyframes formStepIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.fld-err{min-height:14px;font-size:11.5px;color:#dc2626;font-weight:600}
.fi.is-invalid,.fs.is-invalid,.ft.is-invalid{border-color:#dc2626;box-shadow:0 0 0 3px rgba(220,38,38,.12)}
.fld-help{font-size:11.5px;color:var(--muted)}
.chk-wrap{
  display:flex;align-items:flex-start;gap:10px;
  background:var(--white);border:1px solid var(--border2);border-radius:10px;
  padding:12px 14px;color:var(--muted);font-size:13px;line-height:1.5;
}
.chk-wrap input{margin-top:2px;accent-color:var(--blue-mid)}
.form-nav{display:flex;gap:10px;justify-content:space-between;align-items:center;margin-top:12px}
.form-btn-prev{display:none}
.form-btn-submit{display:none;margin-top:0}
.form-hint{margin-top:8px;font-size:12px;color:var(--muted)}
.btn-sub{
  width:100%;margin-top:18px;padding:14px;border:none;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);color:#fff;
  border-radius:11px;font-size:15px;font-weight:700;cursor:pointer;
  min-height:48px;
  font-family:var(--ff-head);
  box-shadow:0 4px 16px rgba(11,31,75,.28);
  transition:transform var(--t),box-shadow var(--t),opacity var(--t);
}
.btn-sub:hover{transform:translateY(-2px);box-shadow:0 8px 26px rgba(11,31,75,.38);opacity:.93}
/* ─── FOOTER ─── */
footer{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(900px 260px at 8% -10%, rgba(36,88,200,.24), transparent 62%),
    radial-gradient(780px 240px at 100% 0%, rgba(212,43,43,.18), transparent 60%),
    linear-gradient(180deg,#0c2152 0%, #091a42 100%);
  color:rgba(255,255,255,.72);
  padding:86px 5% 30px;
}
footer::before{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.03), transparent 18%);
}
.ft-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(260px,1.9fr) 1fr 1fr minmax(220px,1.2fr);
  gap:44px;
  padding:10px 0 44px;
  border-bottom:1px solid rgba(255,255,255,.12);
  margin-bottom:22px;
}
.ft-brand .wm{
  font-family:var(--ff-head);
  font-size:24px;
  font-weight:800;
  color:#fff;
  letter-spacing:-.5px;
  margin-bottom:16px;
  display:block;
}
.ft-brand .wm .it{color:var(--red)}
.ft-brand .wm .logo-dot{color:var(--blue-mid)}
.ft-brand p{
  font-size:14px;
  line-height:1.82;
  max-width:430px;
  color:rgba(255,255,255,.76);
}
.ft-socials{display:flex;gap:10px;margin-top:24px;flex-wrap:wrap}
.ft-social{
  width:40px;height:40px;border-radius:11px;border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.02);
  display:flex;align-items:center;justify-content:center;font-size:17px;
  transition:border-color var(--t),background var(--t),transform var(--t),box-shadow var(--t);
}
.ft-social:hover{
  border-color:rgba(255,255,255,.5);
  background:rgba(255,255,255,.08);
  transform:translateY(-2px);
  box-shadow:0 10px 22px rgba(0,0,0,.26);
}
.ft-col h4{
  font-family:var(--ff-head);
  font-size:13px;
  font-weight:700;
  color:#fff;
  margin-bottom:16px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.ft-col a{
  font-size:14px;
  color:rgba(255,255,255,.72);
  transition:color var(--t),transform var(--t);
  display:inline-flex;
}
.ft-col a:hover{color:#fff;transform:translateX(6px)}
.ft-contact-address{
  font-size:13px;
  line-height:1.8;
  color:rgba(255,255,255,.75);
}
.ft-bot{
  position:relative;
  z-index:1;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:12.5px;
  flex-wrap:wrap;
  gap:12px;
  color:rgba(255,255,255,.62);
  padding-bottom:max(4px, env(safe-area-inset-bottom));
}
.ft-bot a{color:rgba(255,255,255,.5);transition:color var(--t)}
.ft-bot a:hover{color:#fff}

@media (max-width:1100px){
  .ft-grid{
    grid-template-columns:1.4fr 1fr 1fr;
    gap:34px;
  }
  .ft-brand{grid-column:1/-1}
}

@media (max-width:768px){
  footer{padding:74px 5% 24px}
  .ft-grid{
    grid-template-columns:1fr;
    gap:24px;
    padding-bottom:30px;
    margin-bottom:16px;
  }
  .ft-col{
    background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.1);
    border-radius:12px;
    padding:14px 14px 12px;
  }
  .ft-col h4{margin-bottom:12px}
  .ft-col ul{gap:8px}
  .ft-col a{font-size:13.5px}
  .ft-brand p{max-width:none}
  .ft-bot{font-size:12px}
}
/* ─── FLOATING WA ─── */
.wa{
  position:fixed;bottom:26px;right:26px;z-index:200;
  width:56px;height:56px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:26px;
  box-shadow:0 8px 28px rgba(37,211,102,.4);
  transition:transform var(--t);text-decoration:none;
}
.wa:hover{transform:scale(1.12)}
/* REVEAL */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.u-delay-1,.d1{transition-delay:.1s}
.u-delay-2,.d2{transition-delay:.2s}
.u-delay-3,.d3{transition-delay:.3s}
/* ─── HAMBURGER BUTTON ─── */
.nav-ham{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  cursor:pointer;background:none;border:none;padding:10px;
  min-width:44px;min-height:44px;
  flex-shrink:0;
}
.nav-ham span{
  display:block;width:22px;height:2px;
  background:var(--navy);border-radius:2px;transition:all .3s var(--ease);
}
nav.on-intro .nav-ham span{background:#fff}
.nav-ham.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-ham.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-ham.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ─── MOBILE NAV OVERLAY ─── */
.nav-mobile-menu{
  display:none;
  position:fixed;inset:0;top:72px;left:0;right:0;bottom:0;z-index:98;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  flex-direction:column;
  align-items:stretch;
  justify-content:flex-start;
  padding:0;
  opacity:0;pointer-events:none;
  transition:opacity .35s var(--ease);
}
.nav-mobile-menu.open{opacity:1;pointer-events:all}

.nav-mobile-scroll{
  flex:1 1 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:clamp(14px,3.5vw,26px);
  width:100%;
  max-width:100%;
  max-height:calc(100vh - 72px - env(safe-area-inset-bottom,0px));
  min-height:0;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  padding:16px 16px max(20px, env(safe-area-inset-bottom));
  box-sizing:border-box;
}

.nav-mobile-menu a{
  font-family:var(--ff-head);font-size:clamp(18px,4.8vw,22px);font-weight:700;
  color:var(--navy);letter-spacing:-.5px;
  transition:color .2s;
  text-align:center;
  width:100%;
  max-width:360px;
  padding:10px 12px;
  box-sizing:border-box;
}
.nav-mobile-menu a:hover{color:var(--red)}
.nav-mobile-menu .nav-cta{
  background:var(--red)!important;color:#fff!important;
  padding:14px 28px;border-radius:11px;font-size:clamp(16px,4vw,18px)!important;
  box-shadow:0 8px 28px rgba(212,43,43,.3);
  margin-top:4px;
}
.nav-mobile-divider{
  width:40px;height:2px;flex-shrink:0;
  background:linear-gradient(90deg,var(--blue-mid),var(--red));
  border-radius:2px;
}

/* Bloc langue dans le menu */
.nav-mobile-lang-block{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  width:100%;
  padding:8px 0 4px;
}
.nav-mobile-lang-h{
  font-size:10px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);
}
.nav-mobile-menu .lang-switch--in-menu{
  flex-shrink:0;
  padding:3px;
  transform:scale(1.05);
}
@media (max-width:380px){
  .nav-mobile-menu .lang-switch--in-menu{transform:scale(1)}
  .nav-mobile-menu a{font-size:17px}
}
/* Utility classes (harmonized naming) */

.u-text-light{color:rgba(255,255,255,.5)}
.u-bg-off{background:var(--off)}
.u-bg-navy{background:var(--navy)}
.u-section-tight{padding:100px 5%}

.u-delay-1{transition-delay:.1s}
.u-delay-2{transition-delay:.2s}
.u-delay-3{transition-delay:.3s}
/* moved from inline style blocks */
@keyframes modalIn{from{opacity:0;transform:scale(.93) translateY(16px)}to{opacity:1;transform:none}}

/* Tarifs : voir assets/css/pricing-section.css */

/* ── DEVIS CALCULATOR — Premium ── */
.section-tight{padding:88px 5%}

#devis{
  background:linear-gradient(155deg,#071525 0%,#0B1F4B 55%,#0d2050 100%);
  position:relative;overflow:hidden;
}
#devis::before{
  content:'';position:absolute;top:-180px;right:-180px;width:520px;height:520px;
  border-radius:50%;background:radial-gradient(circle,rgba(212,43,43,.1) 0%,transparent 70%);
  pointer-events:none;
}
#devis::after{
  content:'';position:absolute;bottom:-120px;left:-100px;width:420px;height:420px;
  border-radius:50%;background:radial-gradient(circle,rgba(36,88,200,.12) 0%,transparent 70%);
  pointer-events:none;
}
#devis .s-title{color:#fff}
#devis .s-sub{color:rgba(255,255,255,.5)}

/* Shell */
.devis-shell{display:grid;grid-template-columns:1.35fr 1fr;gap:52px;position:relative;z-index:1}

/* Steps column */
.devis-steps{display:flex;flex-direction:column;gap:34px}
.devis-step-hd{display:flex;align-items:center;gap:13px;margin-bottom:16px}
.dsn{
  width:28px;height:28px;border-radius:50%;flex-shrink:0;
  background:var(--red);color:#fff;
  font-family:var(--ff-head);font-size:12px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(212,43,43,.45);
}
.devis-step-lbl{font-size:13.5px;font-weight:700;color:#fff;letter-spacing:.3px}

/* Service type cards */
.devis-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.dc{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);
  border-radius:14px;padding:18px 10px 14px;cursor:pointer;
  transition:background .2s,border-color .2s,transform .2s,box-shadow .2s;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  text-align:center;font-family:var(--ff-body);position:relative;
}
.dc:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.22);transform:translateY(-2px)}
.dc.active{
  background:rgba(212,43,43,.14);border-color:rgba(212,43,43,.6);
  box-shadow:0 0 28px rgba(212,43,43,.18),inset 0 1px 0 rgba(255,255,255,.08);
}
.dc-ico{
  width:38px;height:38px;border-radius:10px;flex-shrink:0;
  background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.6);transition:all .2s;
}
.dc:hover .dc-ico{background:rgba(255,255,255,.13);color:rgba(255,255,255,.85)}
.dc.active .dc-ico{background:rgba(212,43,43,.25);border-color:rgba(212,43,43,.4);color:var(--red)}
.dc-lbl{font-size:11.5px;font-weight:600;color:rgba(255,255,255,.6);line-height:1.35}
.dc.active .dc-lbl{color:#fff}
.dc-price{font-size:10px;font-weight:500;color:rgba(255,255,255,.25);letter-spacing:.2px}
.dc.active .dc-price{color:rgba(255,255,255,.5)}

/* Profile — segmented control */
.devis-seg{
  display:flex;background:rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:3px;gap:2px;
}
.ds{
  flex:1;padding:7px 6px;border-radius:7px;border:none;background:none;
  font-size:11.5px;font-weight:600;color:rgba(255,255,255,.45);
  cursor:pointer;transition:all .2s;font-family:var(--ff-body);
  white-space:nowrap;text-align:center;
}
.ds:hover{color:rgba(255,255,255,.8)}
.ds.active{background:var(--blue-mid);color:#fff;box-shadow:0 2px 10px rgba(36,88,200,.45)}

/* Urgency cards */
.devis-urgency{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.du{
  background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.1);
  border-radius:14px;padding:14px 10px;cursor:pointer;
  transition:all .22s var(--ease);text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-family:var(--ff-body);
}
.du:hover{background:rgba(255,255,255,.11);border-color:rgba(255,255,255,.28)}
.du.active{border-color:rgba(255,255,255,.45);background:rgba(255,255,255,.13)}
.du-badge{
  display:inline-block;font-size:9px;font-weight:800;letter-spacing:1.5px;
  text-transform:uppercase;padding:3px 10px;border-radius:100px;
}
.du-green{background:rgba(34,197,94,.18);color:#4ade80}
.du-orange{background:rgba(245,158,11,.18);color:#fbbf24}
.du-red{background:rgba(212,43,43,.2);color:#f87171}
.du-lbl{font-size:12px;font-weight:600;color:rgba(255,255,255,.6);line-height:1.3}
.du.active .du-lbl{color:#fff}

/* Range */
.devis-rng-wrap{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:16px;padding:20px 24px;
}
.devis-rng-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.devis-rng-hint{font-size:12px;color:rgba(255,255,255,.35)}
.devis-rng-num{font-family:var(--ff-head);font-size:26px;font-weight:800;color:#fff;line-height:1}
.devis-rng-unit{font-size:12px;color:rgba(255,255,255,.4);font-weight:400}
.devis-range{
  width:100%;height:5px;appearance:none;-webkit-appearance:none;
  background:linear-gradient(to right,var(--red) var(--pct,2%),rgba(255,255,255,.15) var(--pct,2%));
  border-radius:3px;cursor:pointer;outline:none;
}
.devis-range::-webkit-slider-thumb{
  appearance:none;-webkit-appearance:none;
  width:20px;height:20px;border-radius:50%;
  background:#fff;box-shadow:0 2px 10px rgba(0,0,0,.4);
  cursor:pointer;transition:transform .15s;
}
.devis-range::-webkit-slider-thumb:hover{transform:scale(1.25)}
.devis-range::-moz-range-thumb{
  width:20px;height:20px;border-radius:50%;border:none;
  background:#fff;box-shadow:0 2px 10px rgba(0,0,0,.4);cursor:pointer;
}
.devis-rng-marks{display:flex;justify-content:space-between;margin-top:8px;padding:0 2px}
.devis-rng-marks span{font-size:10px;color:rgba(255,255,255,.3)}

/* Result panel */
.devis-panel{position:sticky;top:90px;align-self:start}
.devis-result-card{
  position:relative;
  background:linear-gradient(160deg,rgba(255,255,255,.1) 0%,rgba(255,255,255,.05) 100%);
  backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);
  border:1px solid rgba(255,255,255,.16);border-radius:24px;padding:32px 28px;
  display:flex;flex-direction:column;gap:0;
  box-shadow:0 24px 64px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.12);
  overflow:hidden;
}
.devis-result-card::before{
  content:'';position:absolute;top:-60px;right:-60px;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,43,43,.15) 0%,transparent 70%);
  pointer-events:none;
}
.drc-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(212,43,43,.12);border:1px solid rgba(212,43,43,.28);
  border-radius:100px;padding:5px 13px;
  font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#f87171;
  margin-bottom:22px;align-self:flex-start;position:relative;
}
.drc-dot{width:5px;height:5px;border-radius:50%;background:var(--red);animation:blink 2s infinite;flex-shrink:0}
.drc-price-val{
  font-family:var(--ff-head);font-size:clamp(44px,5vw,70px);font-weight:800;
  color:#fff;line-height:1;letter-spacing:-2.5px;margin-bottom:5px;position:relative;
}
.drc-price-note{font-size:11px;color:rgba(255,255,255,.35);margin-bottom:26px;letter-spacing:.3px}
.drc-bk{
  background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.07);
  border-radius:12px;padding:14px 16px;
  display:flex;flex-direction:column;gap:9px;margin-bottom:20px;
}
.drc-row{display:flex;justify-content:space-between;align-items:center;font-size:12.5px}
.drc-rl{color:rgba(255,255,255,.38)}
.drc-rv{color:rgba(255,255,255,.9);font-weight:600;font-size:13px}
.drc-row-sep{border-top:1px solid rgba(255,255,255,.08);padding-top:9px;margin-top:1px}
.drc-trust{
  display:flex;gap:0;margin-bottom:22px;
  background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.07);
  border-radius:10px;overflow:hidden;
}
.drc-ti{
  flex:1;display:flex;align-items:center;justify-content:center;gap:5px;
  font-size:10.5px;color:rgba(255,255,255,.45);padding:9px 6px;
  border-right:1px solid rgba(255,255,255,.07);
}
.drc-ti:last-child{border-right:none}
.drc-tdot{width:5px;height:5px;border-radius:50%;background:#4ade80;flex-shrink:0;box-shadow:0 0 6px #4ade80}
.drc-cta{
  display:flex;align-items:center;justify-content:center;gap:9px;
  background:linear-gradient(135deg,var(--red) 0%,#b91c1c 100%);color:#fff;
  padding:15px 24px;border-radius:12px;
  font-size:14px;font-weight:700;font-family:var(--ff-head);
  transition:opacity .2s,transform .2s;text-decoration:none;
  box-shadow:0 8px 32px rgba(212,43,43,.5);
  position:relative;overflow:hidden;
}
.drc-cta::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 60%);
  pointer-events:none;
}
.drc-cta:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 12px 36px rgba(212,43,43,.55)}

/* ── Price flip / count-up animation ── */
@keyframes pf-anim{
  0%{opacity:0;transform:translateY(8px) scale(.95)}
  100%{opacity:1;transform:none}
}
.pf-anim{animation:pf-anim .28s var(--ease) both}

/* ── Blink dot ── */
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

/* ── Du-mult multiplier labels ── */
.du-mult{
  font-size:10px;font-weight:800;letter-spacing:.6px;
  color:rgba(255,255,255,.2);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);
  border-radius:6px;padding:2px 7px;
  font-family:var(--ff-head);
}
.du.active .du-mult{
  color:rgba(255,255,255,.7);background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)
}

/* ── Checkmark on active service card ── */
.dc.active::after{
  content:'';position:absolute;top:8px;right:8px;
  width:16px;height:16px;border-radius:50%;
  background:var(--red) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") no-repeat center / 9px;
  box-shadow:0 2px 8px rgba(212,43,43,.6);
}

/* ── Active nav link ── */
.nav-links a.nav-active{color:var(--red)!important}
.nav-links a.nav-active::after{
  content:'';display:block;height:2px;border-radius:2px;
  background:var(--red);margin-top:1px;
  animation:navUnderIn .25s var(--ease) both;
}
@keyframes navUnderIn{from{transform:scaleX(0)}to{transform:scaleX(1)}}

/* ── Staggered service card entrance ── */
@keyframes dcFadeIn{from{opacity:0}to{opacity:1}}
.devis-shell .dc{opacity:0}
.devis-shell.visible .dc{animation:dcFadeIn .4s var(--ease) both}
.devis-shell.visible .dc:nth-child(1){animation-delay:.35s}
.devis-shell.visible .dc:nth-child(2){animation-delay:.44s}
.devis-shell.visible .dc:nth-child(3){animation-delay:.53s}
.devis-shell.visible .dc:nth-child(4){animation-delay:.62s}
.devis-shell.visible .dc:nth-child(5){animation-delay:.71s}
.devis-shell.visible .dc:nth-child(6){animation-delay:.80s}
@media(prefers-reduced-motion:reduce){
  .devis-shell .dc{opacity:1!important}
  .devis-shell.visible .dc{animation:none!important}
}

/* ── Background dot grid ── */
.devis-bg-grid{
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:28px 28px;
  pointer-events:none;z-index:0;
}

/* ── Service name recap ── */
.drc-svc{
  font-size:10.5px;font-weight:700;color:rgba(255,255,255,.38);
  text-transform:uppercase;letter-spacing:1.4px;margin-bottom:10px;
}

/* ── FAQ ── */
.faq-wrap{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:0}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item:first-child{border-top:1px solid var(--border)}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:20px 8px;background:none;border:none;cursor:pointer;
  font-size:16px;font-weight:600;color:var(--navy);font-family:var(--ff-body);
  text-align:left;transition:color .2s;
}
.faq-q:hover{color:var(--red)}
.faq-arrow{font-size:20px;flex-shrink:0;transition:transform .3s var(--ease);color:var(--red)}
.faq-q.open .faq-arrow{transform:rotate(180deg)}
.faq-a{
  font-size:15px;color:var(--muted);line-height:1.75;
  max-height:0;overflow:hidden;padding:0 8px;
  transition:max-height .4s var(--ease),padding .3s;
}
.faq-a.open{max-height:200px;padding:0 8px 20px}

/* ── COUNTERS ── */
.counters-wrap{
  background:linear-gradient(135deg,#060f24 0%,#0B1F4B 55%,#0c1f48 100%);
  padding:88px 5%;position:relative;overflow:hidden;
}
.counters-wrap::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:32px 32px;pointer-events:none;z-index:0;
}
.counters-pre-label{
  text-align:center;font-size:11px;font-weight:700;letter-spacing:3px;
  text-transform:uppercase;color:rgba(255,255,255,.28);
  margin-bottom:52px;position:relative;z-index:1;
}
.counters-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;text-align:center;
  position:relative;z-index:1;
}
.counter-card{
  padding:32px 20px;position:relative;
  border-right:1px solid rgba(255,255,255,.1);
}
.counter-card:last-child{border-right:none}
.counter-num{
  font-family:var(--ff-head);font-size:clamp(44px,5vw,66px);font-weight:800;color:#fff;
  line-height:1;margin-bottom:14px;
}
.counter-num span.suf{color:var(--red)}
.counter-label{
  font-size:11px;color:rgba(255,255,255,.38);
  letter-spacing:1.8px;text-transform:uppercase;font-weight:600;
}

/* ── CHAT MESSAGES ── */
.chat-msg{
  padding:10px 14px;border-radius:14px;font-size:13.5px;line-height:1.55;max-width:88%;
}
.chat-msg.bot{background:var(--white);border:1px solid var(--border);color:var(--navy);align-self:flex-start;border-bottom-left-radius:4px}
.chat-msg.user{background:var(--navy);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
#chat-msgs{display:flex;flex-direction:column}
.chat-quick{
  padding:7px 13px;border-radius:100px;border:1.5px solid var(--border2);
  background:var(--white);color:var(--navy);font-size:12px;cursor:pointer;
  font-family:var(--ff-body);font-weight:600;transition:all .2s;
}
.chat-quick:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.chat-typing{
  align-self:flex-start;background:var(--white);border:1px solid var(--border);border-radius:12px;
  padding:8px 10px;display:flex;gap:5px;width:max-content;
}
.chat-typing span{
  width:6px;height:6px;border-radius:50%;background:var(--muted);opacity:.45;animation:typingBlink 1.1s infinite;
}
.chat-typing span:nth-child(2){animation-delay:.2s}
.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes typingBlink{
  0%,100%{transform:translateY(0);opacity:.3}
  50%{transform:translateY(-2px);opacity:1}
}

/* ── SVG ICONS ── */
.srv-ico svg{color:var(--navy);display:block}
.af-ico svg,.ci-ico svg{color:#fff;display:block}
.em-ico svg{color:#fff;display:block}
.ft-social svg{display:block;color:rgba(255,255,255,.55);transition:color var(--t)}
.ft-social:hover svg{color:#fff}
.wa svg{color:#fff;display:block}

/* Stars typographiques */
.tst-stars{font-size:14px;letter-spacing:2px;color:#C9A227;margin-bottom:18px}

/* Urgence dot */
.urg-t::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--red);box-shadow:0 0 8px var(--red);
  flex-shrink:0;display:inline-block;
}
.urg-t{gap:10px}

/* Modal icon */
.modal-phone-icon{
  width:52px;height:52px;border-radius:12px;
  background:var(--red-light);border:1px solid rgba(212,43,43,.15);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;
}
/* Section Tarifs — thème sombre, DM Serif + Plus Jakarta (sous .pis-tarif) */
#devis.pricing-section {
  position: relative;
  overflow: hidden;
  margin: 0;
  background: #060E24;
  color: #fff;
  font-family: 'Plus Jakarta Sans', var(--ff-body, sans-serif);
  padding: 100px 5% 120px !important; /* surcharges sections.css */
  -webkit-font-smoothing: antialiased;
  min-height: 0;
}

#devis.pricing-section * {
  box-sizing: border-box;
}

#devis .pis-tarif {
  --navy: #060E24;
  --navy-card: #0C1633;
  --navy-surface: #111D42;
  --navy-hover: #162552;
  --blue: #3B6FE8;
  --blue-bright: #5B8EFF;
  --blue-glow: rgba(59, 111, 232, 0.25);
  --red: #E83B4E;
  --red-deep: #C62D3E;
  --red-glow: rgba(232, 59, 78, 0.2);
  --white: #fff;
  --pri-white-90: rgba(255, 255, 255, 0.9);
  --pri-white-70: rgba(255, 255, 255, 0.7);
  --pri-white-50: rgba(255, 255, 255, 0.5);
  --pri-white-20: rgba(255, 255, 255, 0.2);
  --pri-white-10: rgba(255, 255, 255, 0.1);
  --pri-white-05: rgba(255, 255, 255, 0.05);
  --ff-display: 'DM Serif Display', Georgia, serif;
  --ff-body: 'Plus Jakarta Sans', var(--ff-body, sans-serif);
  --pri-radius: 20px;
  --pri-radius-sm: 12px;
  position: relative;
  z-index: 1;
}

#devis .pricing-grain {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.35;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.06'/%3E%3C/svg%3E");
  background-size: 128px;
  border-radius: inherit;
}

#devis .pis-tarif::before {
  content: '';
  position: absolute;
  width: 800px;
  height: 800px;
  top: -200px;
  left: -200px;
  background: radial-gradient(circle, rgba(59, 111, 232, 0.1) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

#devis .pis-tarif::after {
  content: '';
  position: absolute;
  width: 600px;
  height: 600px;
  bottom: -100px;
  right: -150px;
  background: radial-gradient(circle, rgba(232, 59, 78, 0.08) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

#devis .pri-container {
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

#devis .pis-tarif .header {
  text-align: center;
  margin-bottom: 72px;
}

#devis .pis-tarif .header-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 24px;
}

#devis .pis-tarif .header-label::before,
#devis .pis-tarif .header-label::after {
  content: '';
  width: 32px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--red), transparent);
}

#devis .pis-tarif .header-title {
  font-family: var(--ff-display);
  font-size: clamp(32px, 5vw, 64px);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -1px;
  color: var(--white);
  margin-bottom: 20px;
  font-style: normal;
}

#devis .pis-tarif .header-title em {
  font-style: italic;
  color: var(--red);
}

#devis .pis-tarif .header-sub {
  font-size: 16px;
  color: var(--pri-white-50);
  max-width: 460px;
  margin: 0 auto;
  line-height: 1.8;
  font-weight: 400;
}

#devis .pis-tarif .col-headers {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  max-width: 440px;
  margin: 0 0 24px auto;
  padding-right: 0;
}

#devis .pis-tarif .col-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 20px 12px;
  border-radius: var(--pri-radius);
  text-align: center;
  position: relative;
  overflow: hidden;
}

#devis .pis-tarif .col-header::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid var(--pri-white-10);
}

#devis .pis-tarif .col-header--ind {
  background: linear-gradient(135deg, rgba(59, 111, 232, 0.12), rgba(59, 111, 232, 0.04));
}

#devis .pis-tarif .col-header--ent {
  background: linear-gradient(135deg, rgba(232, 59, 78, 0.12), rgba(232, 59, 78, 0.04));
}

#devis .pis-tarif .col-header-ico {
  width: 40px;
  height: 40px;
  border-radius: var(--pri-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
}

#devis .pis-tarif .col-header--ind .col-header-ico {
  background: var(--blue-glow);
  color: var(--blue-bright);
}

#devis .pis-tarif .col-header--ent .col-header-ico {
  background: var(--red-glow);
  color: var(--red);
}

#devis .pis-tarif .col-header-label {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

#devis .pis-tarif .col-header-from {
  font-size: 11px;
  color: var(--pri-white-50);
  font-weight: 500;
}

#devis .pis-tarif .service-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

#devis .pis-tarif .service-row {
  display: grid;
  grid-template-columns: 1fr 210px 210px;
  gap: 10px;
  align-items: center;
  padding: 6px;
  border-radius: var(--pri-radius);
  transition: background 0.3s ease;
  position: relative;
  opacity: 0;
  transform: translateY(20px);
  animation: priRowReveal 0.6s cubic-bezier(0, 0.8, 0.2, 1) forwards;
}

#devis .pis-tarif .service-row:nth-child(1) { animation-delay: 0.1s; }
#devis .pis-tarif .service-row:nth-child(2) { animation-delay: 0.17s; }
#devis .pis-tarif .service-row:nth-child(3) { animation-delay: 0.24s; }
#devis .pis-tarif .service-row:nth-child(4) { animation-delay: 0.31s; }
#devis .pis-tarif .service-row:nth-child(5) { animation-delay: 0.38s; }
#devis .pis-tarif .service-row:nth-child(6) { animation-delay: 0.45s; }

@keyframes priRowReveal {
  to { opacity: 1; transform: translateY(0); }
}

#devis .pis-tarif .service-row:hover {
  background: var(--pri-white-05);
}

#devis .pis-tarif .service-info {
  padding: 24px 28px;
  border-radius: calc(var(--pri-radius) - 2px);
  background: var(--navy-card);
  border: 1px solid var(--pri-white-05);
  transition: border-color 0.3s ease, background 0.3s ease;
  position: relative;
  overflow: hidden;
}

#devis .pis-tarif .service-info::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--blue), var(--red));
  opacity: 0;
  transition: opacity 0.3s ease;
  border-radius: 3px 0 0 3px;
}

#devis .pis-tarif .service-row:hover .service-info {
  border-color: var(--pri-white-10);
  background: var(--navy-surface);
}

#devis .pis-tarif .service-row:hover .service-info::before {
  opacity: 1;
}

#devis .pis-tarif .service-name {
  font-family: var(--ff-display);
  font-size: 20px;
  font-weight: 400;
  color: var(--white);
  margin-bottom: 6px;
  line-height: 1.2;
}

#devis .pis-tarif .service-desc {
  font-size: 13px;
  color: var(--pri-white-50);
  line-height: 1.6;
  font-weight: 400;
}

#devis .pis-tarif .price-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 22px 16px;
  border-radius: calc(var(--pri-radius) - 2px);
  background: var(--navy-card);
  border: 1px solid var(--pri-white-05);
  transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  min-height: 76px;
}

#devis .pis-tarif .price-mob-lbl {
  display: none;
}

#devis .pis-tarif .price-cell--ind:hover {
  border-color: rgba(59, 111, 232, 0.3);
  background: linear-gradient(135deg, rgba(59, 111, 232, 0.1), var(--navy-card));
  box-shadow: 0 0 30px rgba(59, 111, 232, 0.1);
}

#devis .pis-tarif .price-cell--ent:hover {
  border-color: rgba(232, 59, 78, 0.3);
  background: linear-gradient(135deg, rgba(232, 59, 78, 0.1), var(--navy-card));
  box-shadow: 0 0 30px rgba(232, 59, 78, 0.1);
}

#devis .pis-tarif .price-value {
  font-family: var(--ff-display);
  font-size: 24px;
  font-weight: 400;
  color: var(--white);
  letter-spacing: -0.5px;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

#devis .pis-tarif .price-cell:hover .price-value {
  transform: scale(1.08);
}

#devis .pis-tarif .price-value--text {
  font-family: var(--ff-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--pri-white-70);
}

#devis .pis-tarif .price-value--na {
  font-family: var(--ff-body);
  font-size: 13px;
  color: var(--pri-white-20);
  font-weight: 500;
  letter-spacing: 2px;
}

#devis .pis-tarif .price-value--long {
  font-family: var(--ff-body);
  font-size: 11px;
  font-weight: 600;
  color: var(--pri-white-70);
  text-align: center;
  line-height: 1.5;
  letter-spacing: 0.3px;
}

#devis .pis-tarif .sep {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--pri-white-10), transparent);
  margin: 40px 0;
}

#devis .pis-tarif .benefits {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  list-style: none;
  margin: 0;
  padding: 0;
}

#devis .pis-tarif .benefit {
  position: relative;
  padding: 24px 20px;
  border-radius: var(--pri-radius);
  background: var(--navy-card);
  border: 1px solid var(--pri-white-05);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), border-color 0.3s ease, box-shadow 0.3s ease;
  opacity: 0;
  transform: translateY(16px);
  animation: priRowReveal 0.5s cubic-bezier(0, 0.8, 0.2, 1) forwards;
}

#devis .pis-tarif .benefit:nth-child(1) { animation-delay: 0.55s; }
#devis .pis-tarif .benefit:nth-child(2) { animation-delay: 0.62s; }
#devis .pis-tarif .benefit:nth-child(3) { animation-delay: 0.69s; }
#devis .pis-tarif .benefit:nth-child(4) { animation-delay: 0.76s; }

#devis .pis-tarif .benefit:hover {
  transform: translateY(-4px);
  border-color: var(--blue-glow);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3);
}

#devis .pis-tarif .benefit-ico {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--blue), #1a4ab5);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px var(--blue-glow);
  flex-shrink: 0;
}

#devis .pis-tarif .benefit-ico svg {
  width: 16px;
  height: 16px;
  stroke: var(--white);
  fill: none;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

#devis .pis-tarif .benefit-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--pri-white-90);
}

#devis .pis-tarif .benefit-sub {
  font-size: 12px;
  color: var(--pri-white-50);
  font-weight: 400;
}

#devis .pis-tarif .pricing-foot {
  text-align: center;
  margin-top: 40px;
  font-size: 12px;
  color: var(--pri-white-50);
  letter-spacing: 0.3px;
  font-weight: 500;
}

#devis .pis-tarif .pricing-cta {
  text-align: center;
  margin-top: 40px;
}

#devis .pis-tarif .cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 18px 44px;
  font-size: 15px;
  font-weight: 700;
  font-family: var(--ff-body);
  color: var(--white) !important;
  background: linear-gradient(135deg, var(--red), var(--red-deep));
  border: none;
  border-radius: 60px;
  cursor: pointer;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s ease;
  box-shadow:
    0 4px 20px rgba(232, 59, 78, 0.3),
    0 0 0 1px rgba(232, 59, 78, 0.2);
}

#devis .pis-tarif .cta-btn::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.2), transparent 40%, transparent 60%, rgba(255, 255, 255, 0.1));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}

#devis .pis-tarif .cta-btn:hover {
  transform: translateY(-3px) scale(1.03);
  color: #fff !important;
  box-shadow:
    0 8px 40px rgba(232, 59, 78, 0.4),
    0 0 0 1px rgba(232, 59, 78, 0.3);
}

#devis .pis-tarif .cta-btn:active {
  transform: translateY(0) scale(0.98);
}

#devis .pis-tarif .cta-btn:hover svg {
  transform: translateX(4px);
}

#devis .pis-tarif .cta-note {
  margin-top: 20px;
  font-size: 12px;
  color: var(--pri-white-50);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  font-weight: 500;
  flex-wrap: wrap;
}

#devis .pis-tarif .cta-note span {
  display: flex;
  align-items: center;
  gap: 6px;
}

#devis .pis-tarif .cta-note-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--pri-white-20);
  flex-shrink: 0;
}

@media (max-width: 900px) {
  #devis .pis-tarif .col-headers { display: none; }

  #devis .pis-tarif .service-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  #devis .pis-tarif .col-headers {
    max-width: 100%;
    margin: 0 0 20px;
  }

  #devis .pis-tarif .price-cell {
    min-height: auto;
    padding: 16px;
    justify-content: space-between;
  }

  #devis .pis-tarif .price-mob-lbl {
    display: block;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--pri-white-50);
    margin-right: 12px;
    flex-shrink: 0;
  }

  #devis .pis-tarif .price-cell--ind .price-mob-lbl { color: var(--blue-bright); }
  #devis .pis-tarif .price-cell--ent .price-mob-lbl { color: #ff6b7a; }

  #devis .pis-tarif .price-cell {
    display: flex;
    flex-direction: row;
    align-items: center;
  }

  #devis .pis-tarif .price-value,
  #devis .pis-tarif .price-value--text,
  #devis .pis-tarif .price-value--long { text-align: right; }

  #devis .pis-tarif .benefits { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 560px) {
  #devis.pricing-section { padding: 60px 4% 80px !important; }
  #devis .pis-tarif .benefits { grid-template-columns: 1fr; }
  #devis .pis-tarif .cta-note { flex-direction: column; gap: 6px; }
  #devis .pis-tarif .cta-note-dot { display: none; }
  #devis .pis-tarif .header { margin-bottom: 48px; }
}
/* ═══════════════════════════════════════════
   MEGA ANIMATIONS UPGRADE
═══════════════════════════════════════════ */

/* Canvas particles hero */
#hero-canvas{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.8}
#hero .hero-l,#hero .hero-r{z-index:2;position:relative}

/* Background orbs */
.bg-orb{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none;z-index:0}
#hero .bg-orb-1{width:700px;height:700px;background:rgba(36,88,200,.06);top:-250px;right:-150px;animation:orbFloat 18s ease-in-out infinite}
#hero .bg-orb-2{width:500px;height:500px;background:rgba(212,43,43,.04);bottom:-150px;left:5%;animation:orbFloat 14s ease-in-out infinite reverse}
@keyframes orbFloat{0%,100%{transform:translate(0,0)}25%{transform:translate(40px,-40px)}50%{transform:translate(-30px,30px)}75%{transform:translate(30px,40px)}}

/* Cursor glow */
#cursor-glow{
  pointer-events:none;position:fixed;z-index:9990;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(36,88,200,.05) 0%,transparent 65%);
  transform:translate(-50%,-50%);
  transition:none;
}

/* Button shimmer */
.btn-red,.btn-navy,.nav-cta,.btn-sub{position:relative;overflow:hidden}
.btn-red::after,.btn-navy::after,.nav-cta::after{
  content:'';position:absolute;top:0;left:-60%;width:40%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);
  transform:skewX(-15deg);transition:none;pointer-events:none;
}
.btn-red:hover::after,.btn-navy:hover::after,.nav-cta:hover::after{animation:shimmerBtn .65s ease}
@keyframes shimmerBtn{to{left:140%}}

/* Ripple */
.ripple{
  position:absolute;border-radius:50%;background:rgba(255,255,255,.28);
  width:10px;height:10px;transform:scale(0);pointer-events:none;
  animation:rippleOut .65s linear forwards;
}
@keyframes rippleOut{to{transform:scale(8);opacity:0}}

/* 3D card container perspective */
.srv-grid{perspective:1400px}
.tst-grid{perspective:1400px}

/* Floating hero elements */
.hi-card{animation:floatCard 7s ease-in-out infinite}
@keyframes floatCard{0%,100%{transform:translateY(0) rotate(0deg)}40%{transform:translateY(-14px) rotate(1.5deg)}70%{transform:translateY(-7px) rotate(-.8deg)}}
.hero-eyebrow{animation:floatEyebrow 6s ease-in-out infinite}
@keyframes floatEyebrow{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* Pulse ring on live dot */
.hero-dot{position:relative}
.hero-dot::after{
  content:'';position:absolute;inset:-4px;border-radius:50%;
  background:var(--red);opacity:.35;
  animation:pulseRing 2.2s ease-out infinite;
}
@keyframes pulseRing{0%{transform:scale(1);opacity:.35}100%{transform:scale(3);opacity:0}}

/* Nav link underline slide */
.nav-links a{position:relative}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;right:0;
  height:2px;background:var(--red);border-radius:1px;
  transform:scaleX(0);transform-origin:right;
  transition:transform .3s var(--ease);
}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}

/* Animated gradient text on hero h1 */
.hero-h1 .animated-gradient{
  background:linear-gradient(135deg,var(--red) 0%,#FF6B6B 40%,var(--red2) 60%,var(--red) 100%);
  background-size:250% 250%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:gradFlow 3s ease infinite;
}
.hero-h1 .blue.animated-gradient{
  background:linear-gradient(135deg,var(--blue-mid) 0%,#60A5FA 40%,#2458C8 60%,var(--blue-mid) 100%);
  background-size:250% 250%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:gradFlow 4s ease infinite reverse;
}
@keyframes gradFlow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* S-title decorative underline */
.s-title{position:relative}
.s-title::after{
  content:'';display:block;width:0;height:3px;
  background:linear-gradient(90deg,var(--red),var(--blue-mid));
  border-radius:2px;margin-top:14px;
  transition:width 1s var(--ease);
}
.s-title.ul-active::after{width:64px}

/* Expertise item hover accent line */
.exp-item{position:relative}
.exp-item::after{
  content:'';position:absolute;left:0;bottom:0;height:1px;width:0;
  background:linear-gradient(90deg,var(--red),transparent);
  transition:width .5s var(--ease);
}
.exp-item:hover::after{width:100%}
.exp-item:hover .exp-n{transform:scale(1.25);color:#fff}

/* Testimonial quote mark */
.tst-card{position:relative;overflow:hidden}
.tst-card::before{
  content:'\201C';position:absolute;top:-10px;right:18px;
  font-size:100px;font-family:var(--ff-head);
  color:var(--off2);line-height:1;pointer-events:none;
  transition:color .3s,transform .35s var(--ease);
}
.tst-card:hover::before{color:rgba(212,43,43,.1);transform:scale(1.15) translateY(-5px)}

/* Glow on audience dark card */
.aud-part{transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.aud-part:hover{transform:translateY(-6px);box-shadow:0 28px 70px rgba(212,43,43,.22),0 0 50px rgba(212,43,43,.08)}

/* Counter glow on hover */
.counter-num{transition:text-shadow .3s}
.counter-num:hover{text-shadow:0 0 40px rgba(212,43,43,.5)}

/* Noise texture overlay */
#noise-overlay{
  position:fixed;inset:0;pointer-events:none;z-index:9985;opacity:.022;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px;
}

/* Partner marquee */
.pt-marquee-wrap{overflow:hidden;width:100%}
.pt-marquee-inner{display:flex;gap:14px;width:max-content;animation:marqueeScroll 28s linear infinite}
.pt-marquee-inner:hover{animation-play-state:paused}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Animated aurora in expertise section */
#expertise::before{
  content:'';position:absolute;inset:0;z-index:0;
  background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(36,88,200,.15) 0%,transparent 70%),
             radial-gradient(ellipse 60% 40% at 80% 100%,rgba(212,43,43,.1) 0%,transparent 60%);
  animation:auroraShift 12s ease-in-out infinite alternate;
  pointer-events:none;
}
@keyframes auroraShift{
  from{background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(36,88,200,.15) 0%,transparent 70%),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(212,43,43,.1) 0%,transparent 60%)}
  to{background:radial-gradient(ellipse 80% 60% at 30% 10%,rgba(36,88,200,.2) 0%,transparent 70%),radial-gradient(ellipse 60% 40% at 20% 90%,rgba(212,43,43,.15) 0%,transparent 60%)}
}
#expertise .s-header,#expertise .exp-layout{position:relative;z-index:1}

/* Animated stat numbers glow */
.stat-n{transition:text-shadow .3s,transform .3s}
.stat-n:hover{text-shadow:0 0 30px rgba(212,43,43,.4);transform:scale(1.06)}

/* Agence facts slide */
.af{transition:border-color .3s,transform .3s,box-shadow .3s}
.af:hover{border-color:var(--blue-mid)!important;transform:translateX(6px);box-shadow:0 8px 30px rgba(36,88,200,.1)}

/* Glassmorphism hi-card */
.hi-card{backdrop-filter:blur(20px);background:rgba(255,255,255,.96)}

/* Divider photos parallax container */
.dp img{transition:transform .1s linear}

/* Gradient border on first srv-card */
.srv-card:nth-child(1)::after{
  content:'';position:absolute;inset:0;border-radius:20px;
  background:linear-gradient(135deg,rgba(36,88,200,.12),rgba(212,43,43,.08),transparent);
  opacity:0;transition:opacity .4s;pointer-events:none;z-index:0;
}
.srv-card:nth-child(1):hover::after{opacity:1}

/* Scroll-triggered line reveal for hero stats */
.hero-stats{position:relative}
.hero-stats::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--red),transparent);
  animation:statLine 2s 1.5s var(--ease) both;
}
@keyframes statLine{from{opacity:0;transform:scaleX(0)}to{opacity:1;transform:scaleX(1)}}

/* Fancy loading bar in splash */
.sp-bar-inner{
  background:linear-gradient(90deg,var(--blue-mid),rgba(255,255,255,.9),var(--red));
  background-size:200% 100%;
}
/* Quality pass: migrated inline styles */

#cookie-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:500;
  background:var(--navy);border-top:3px solid var(--red);
  padding:var(--space-4) 5%;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-4);
  transform:translateY(110%);opacity:0;
  transition:transform .4s var(--ease),opacity .4s var(--ease);
}
#cookie-bar.visible{
  transform:translateY(0);opacity:1;
}
#cookie-bar .cookie-text{font-size:13.5px;color:rgba(255,255,255,.75);max-width:600px}
#cookie-bar .cookie-text a{color:var(--red);text-decoration:underline}
#cookie-bar .cookie-actions{display:flex;gap:10px;flex-shrink:0}
#cookie-bar .cookie-btn{
  border-radius:8px;font-size:var(--fs-sm);cursor:pointer;font-family:var(--ff-body);
  padding:8px 20px;
}
#cookie-bar .cookie-btn.reject{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fff}
#cookie-bar .cookie-btn.accept{background:var(--red);border:none;color:#fff;font-weight:700}
#cookie-bar .cookie-btn.custom{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.22);color:#fff}
#cookie-bar .cookie-btn.custom:hover{background:rgba(255,255,255,.16)}

#cookie-prefs{
  width:100%;display:none;grid-template-columns:1fr 1fr auto;gap:12px;
  margin-top:4px;padding-top:8px;border-top:1px solid rgba(255,255,255,.12);
}
#cookie-prefs.open{display:grid}
.cookie-pref-item{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  color:rgba(255,255,255,.82);font-size:12.5px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:8px;padding:8px 10px;
}
.cookie-pref-item input{accent-color:var(--red)}
.cookie-save{white-space:nowrap}

#back-top{
  position:fixed;bottom:26px;right:90px;z-index:200;
  --progress:0%;
  width:52px;height:52px;border-radius:50%;border:1px solid rgba(11,31,75,.14);
  background:linear-gradient(165deg,#ffffff 0%,#f3f6ff 100%);
  color:var(--navy);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(12px);
  transition:opacity .28s,transform .28s,background .28s,box-shadow .28s,border-color .28s;
  box-shadow:0 12px 26px rgba(11,31,75,.18);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  position:fixed;
  isolation:isolate;
}
#back-top::before{
  content:'';
  position:absolute;inset:-3px;border-radius:inherit;z-index:-1;
  background:conic-gradient(var(--red) var(--progress), rgba(11,31,75,.18) var(--progress));
  box-shadow:0 0 0 1px rgba(11,31,75,.06);
}
#back-top::after{
  content:'';
  position:absolute;inset:5px;border-radius:inherit;z-index:-1;
  background:linear-gradient(165deg,#ffffff 0%,#edf2ff 100%);
}
#back-top svg{
  width:20px;height:20px;display:block;
  fill:var(--navy);
  transform:translateY(-1px);
  transition:transform .22s var(--ease), fill .22s var(--ease);
}
#back-top:hover{
  transform:translateY(0) scale(1.07) !important;
  border-color:rgba(36,88,200,.28);
  box-shadow:0 16px 34px rgba(11,31,75,.25);
}
#back-top:hover svg{
  fill:var(--blue-mid);
  transform:translateY(-3px);
}
#back-top:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(36,88,200,.2),0 16px 34px rgba(11,31,75,.25);
}

#chat-bubble{position:fixed;bottom:92px;right:82px;z-index:300}
#chat-bubble .chat-toggle-btn{
  width:52px;height:52px;border-radius:50%;
  background:var(--blue-mid);border:none;color:#fff;font-size:22px;cursor:pointer;
  box-shadow:0 8px 24px rgba(36,88,200,.4);
  display:flex;align-items:center;justify-content:center;
  transition:transform .3s,box-shadow .3s;
}
#chat-bubble .chat-status-dot{
  position:absolute;bottom:-2px;right:-2px;width:14px;height:14px;border-radius:50%;
  background:#22c55e;border:2px solid var(--white);
}

#chat-panel{
  position:fixed;bottom:160px;right:26px;z-index:400;
  width:360px;border-radius:20px;overflow:hidden;
  background:var(--white);border:1px solid var(--border2);
  box-shadow:0 24px 64px rgba(11,31,75,.18);
  display:none;flex-direction:column;
  transform:scale(.95) translateY(12px);opacity:0;
  transition:transform .3s var(--ease),opacity .3s;
}
.chat-panel-head{
  background:linear-gradient(120deg,var(--navy) 0%,#172f74 100%);
  padding:16px 20px;display:flex;align-items:center;justify-content:space-between;
}
.chat-panel-head-main{display:flex;align-items:center;gap:12px}
.chat-panel-head-logo{
  width:36px;height:36px;border-radius:50%;background:var(--red);
  display:flex;align-items:center;justify-content:center;font-size:17px;
}
.chat-panel-head-title{font-size:var(--fs-md);font-weight:700;color:#fff;font-family:var(--ff-head)}
.chat-panel-head-status{font-size:var(--fs-xs);color:rgba(255,255,255,.55);display:flex;align-items:center;gap:5px}
.chat-panel-head-status-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;display:inline-block}
.chat-panel-close{background:none;border:none;color:rgba(255,255,255,.6);font-size:20px;cursor:pointer;line-height:1}
#chat-msgs{padding:16px;display:flex;flex-direction:column;gap:10px;height:300px;overflow-y:auto;background:var(--off)}
#chat-quick-list{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.chat-panel-input-wrap{padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:10px;background:var(--white)}
#chat-input{
  flex:1;border:1px solid var(--border2);border-radius:10px;padding:10px 14px;
  font-size:var(--fs-md);font-family:var(--ff-body);outline:none;color:var(--navy);background:var(--off);
}
.chat-send-btn{
  background:var(--red);border:none;color:#fff;width:40px;height:40px;border-radius:10px;
  font-size:18px;cursor:pointer;flex-shrink:0;
}

#scroll-bar{
  position:fixed;top:72px;left:0;z-index:99;height:3px;width:0%;
  background:linear-gradient(90deg,var(--blue-mid),var(--red));transition:width .1s;
}
#toast{
  position:fixed;top:90px;right:24px;z-index:600;
  background:var(--navy);color:#fff;border-left:4px solid var(--red);
  padding:14px 20px;border-radius:12px;max-width:300px;
  box-shadow:0 12px 36px rgba(11,31,75,.25);
  transform:translateX(120%);transition:transform .4s var(--ease);
  font-size:var(--fs-md);line-height:1.5;
}
#toast .toast-title{font-weight:700;margin-bottom:4px;font-family:var(--ff-head)}
#toast .toast-text{color:rgba(255,255,255,.65);font-size:var(--fs-sm)}

#modal-bg{
  display:none;position:fixed;inset:0;z-index:800;
  background:rgba(11,31,75,.6);backdrop-filter:blur(8px);
  align-items:center;justify-content:center;padding:20px;
}
#modal-bg .modal-card{
  background:var(--white);border-radius:24px;padding:44px 40px;max-width:480px;width:100%;
  position:relative;box-shadow:0 32px 80px rgba(11,31,75,.25);animation:modalIn .35s var(--ease);
}
#modal-bg .modal-close{
  position:absolute;top:16px;right:16px;background:var(--off);border:none;width:32px;height:32px;border-radius:50%;
  font-size:16px;cursor:pointer;color:var(--muted);
}
#modal-bg .modal-title{font-family:var(--ff-head);font-size:24px;font-weight:800;color:var(--navy);margin-bottom:8px}
#modal-bg .modal-sub{font-size:var(--fs-md);color:var(--muted);margin-bottom:28px;line-height:1.6}
#modal-bg .modal-fields{display:flex;flex-direction:column;gap:14px}
#modal-bg .modal-fields .fi,
#modal-bg .modal-fields .fs{
  background:var(--off);border:1px solid var(--border2);border-radius:10px;padding:12px 15px;
  font-family:var(--ff-body);font-size:var(--fs-lg);outline:none;width:100%;color:var(--navy);
}
#modal-bg .modal-submit{
  width:100%;padding:14px;background:var(--red);border:none;color:#fff;border-radius:11px;
  font-size:var(--fs-lg);font-weight:700;cursor:pointer;font-family:var(--ff-head);
}

.recall-fab{
  position:fixed;bottom:90px;right:26px;z-index:200;
  width:44px;height:44px;border-radius:50%;background:var(--red);border:none;color:#fff;cursor:pointer;
  box-shadow:0 6px 20px rgba(212,43,43,.4);display:flex;align-items:center;justify-content:center;transition:transform .3s;
}

.footer-triband{margin-bottom:52px}
.footer-triband .tb-w{background:rgba(255,255,255,.15)}
.ft-contact-address{line-height:1.6;margin-top:4px}
/* ─── RESPONSIVE: 1024px ─── */
@media(max-width:1024px){
  #hero{grid-template-columns:1fr}
  .hero-r{display:none}
  .hero-bg-deco{display:none}
  .exp-layout{grid-template-columns:1fr}
  .agence-layout{grid-template-columns:1fr}
  .ct-layout{grid-template-columns:1fr}
  .ft-grid{grid-template-columns:1fr 1fr}
  .iscene3-stats{padding:32px 32px}
  .is3{padding:0 24px}
  .devis-shell{grid-template-columns:1fr;gap:32px}
  .devis-panel{position:static;order:-1}
}

/* ─── RESPONSIVE: 768px ─── */
@media(max-width:768px){
  /* Nav */
  .nav-links{display:none}
  .nav-ham{display:flex}
  .nav-mobile-menu{display:flex}
  .nav-end{gap:4px}

  /* Boutons flottants bas d'écran : masqués sur mobile (lisibilité, zone de geste, pas de chevauchement) */
  .wa,
  #back-top,
  .recall-fab,
  #chat-bubble,
  #chat-panel{
    display:none!important;
    pointer-events:none!important;
    visibility:hidden!important;
  }

  /* Sections */
  section{padding:72px 5%}

  /* Hero */
  #hero{padding:90px 5% 64px}
  .hero-h1{font-size:clamp(32px,8vw,52px);letter-spacing:-1.5px}
  .hero-p{font-size:15px;max-width:100%}
  .hero-btns{flex-direction:column}
  .hero-btns a{text-align:center;justify-content:center}
  .hero-stats{
    display:grid;grid-template-columns:1fr 1fr;
    gap:20px;margin-top:40px;padding-top:28px;
  }

  /* Services / grids */
  .srv-layout{grid-template-columns:1fr}
  .srv-media{min-height:260px}
  .srv-catalog{grid-template-columns:1fr}
  .srv-item-featured{grid-column:auto}
  .srv-actions{justify-content:stretch}
  .srv-actions .btn-outline,.srv-actions .btn-red{width:100%;justify-content:center}
  .aud-grid{grid-template-columns:1fr}
  .tst-grid{grid-template-columns:1fr}
  .mosaic{grid-template-columns:1fr;grid-template-rows:auto}
  .mc:first-child{grid-row:auto}
  .mc img{height:200px}
  .fg{grid-template-columns:1fr}
  .ci{padding:16px}
  .form-nav{flex-direction:column}
  .form-nav .btn-outline,.form-nav .btn-navy,.form-nav .btn-sub{width:100%;justify-content:center}
  .ft-grid{grid-template-columns:1fr}

  /* Section headers */
  .s-header{flex-direction:column;align-items:flex-start;margin-bottom:40px}

  /* Cinematic intro — progress rail */
  .intro-prog-rail{display:none}
  .intro-chap-num{font-size:64px;left:16px;bottom:56px}

  /* Cinematic intro — badge */
  .intro-badge-tl{top:80px;left:12px;font-size:11px;padding:6px 11px;gap:6px}

  /* Scene 2 — words */
  .iscene2-words{flex-direction:column;gap:4px;align-items:center}
  .iw2-sep{font-size:20px;transform:rotate(90deg)}

  /* Scene 3 — stats card */
  .iscene3-stats{
    flex-direction:column;padding:20px 16px;gap:0;
    border-radius:16px;width:90%;max-width:340px;
  }
  .is3{padding:16px 12px;width:100%}
  .is3-sep{width:80%;height:1px}
  .is3-num{font-size:clamp(32px,9vw,52px)}
  .iscene3-label{margin-bottom:28px}

  /* Scene 4 — pills */
  .iscene4-grid{grid-template-columns:1fr;max-width:300px;gap:10px}
  .is4p{white-space:normal;padding:13px 20px;border-radius:14px}

  /* Scene 5 — CTA buttons */
  .iscene5-btns{flex-direction:column;align-items:center;gap:12px}
  .is5-cta,.is5-cta-ghost{width:100%;max-width:300px;justify-content:center}

  /* Counters section — override inline style */
  #counters-section{grid-template-columns:repeat(2,1fr)!important;gap:20px!important}

  /* Cookie bar */
  #cookie-bar{flex-direction:column!important;gap:14px!important;text-align:center;padding:16px 20px!important}
  #cookie-bar > div{justify-content:center!important}

  /* Toast */
  #toast{right:12px!important;left:12px!important}

  /* Mosaic gallery */
  .mosaic{grid-template-columns:1fr!important}
  .devis-cards{grid-template-columns:repeat(2,1fr)}
  .devis-urgency{grid-template-columns:repeat(3,1fr)}
  .devis-result-card{padding:24px 20px}
  .drc-price-val{font-size:clamp(36px,10vw,52px)}
  .fi,.fs,.ft{font-size:16px}
}

/* ─── RESPONSIVE: 480px ─── */
@media(max-width:480px){
  nav{padding:0 clamp(10px,3vw,4%)}
  .logo-txt .sub{display:none}
  .logo-txt{font-size:15px}
  section{padding:56px 4%}
  #hero{padding:84px 4% 52px}
  .hero-h1{font-size:clamp(28px,9vw,44px)}
  .hero-stats{grid-template-columns:1fr;gap:14px}
  .stat-n{font-size:28px}
  .s-title{font-size:clamp(24px,7vw,38px)}
  #counters-section{grid-template-columns:repeat(2,1fr)!important;gap:16px!important}
  .iscene3-stats{padding:14px 8px;width:95%}
  .is3{padding:12px 6px}
  .is3-num{font-size:clamp(28px,10vw,44px)}
  .is4p{font-size:14px}
  .dp{height:300px}
  .ft-grid{grid-template-columns:1fr}
  .sp-name{font-size:clamp(22px,6vw,36px)}
  .iscene1-logo{font-size:clamp(36px,11vw,72px);letter-spacing:-2px}
  .devis-cards{grid-template-columns:repeat(2,1fr);gap:8px}
  .dc{padding:12px 8px}
  .dc-ico{font-size:18px}
  .devis-urgency{grid-template-columns:repeat(3,1fr);gap:7px}
  .du{padding:11px 6px}
  .devis-rng-wrap{padding:16px 18px}
  .drc-bk{padding:13px 14px}
  .nav-mobile-menu a{max-width:100%}
}
