*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#070b18;
  --bg-2:#0d1530;
  --ink:#0a0f1f;
  --ink-2:#1a2138;
  --muted:#7a86a4;
  --line:rgba(20,30,60,.08);
  --line-d:rgba(255,255,255,.08);
  --accent:#ff5f3c;
  --accent-2:#ffb547;
  --primary:#5b8def;
  --primary-2:#3461d8;
  --violet:#8b5cf6;
  --cyan:#22d3ee;
  --success:#22c55e;
  --r:18px;
}
html{scroll-behavior:auto}
body{font-family:'Inter','Segoe UI',-apple-system,BlinkMacSystemFont,sans-serif;color:var(--ink);background:#fff;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:clip}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1280px;margin:0 auto;padding:0 28px;position:relative;z-index:2}

/* === CUSTOM CURSOR === */

.h-display{font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:-1.5px;line-height:1.02}

/* === TOPBAR === */
.topbar{background:#070b18;color:#a8b6cf;font-size:13px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.06);position:relative;z-index:99}
.topbar .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;align-items:center}
.topbar a{color:#fff;font-weight:500}
.topbar .bullet{display:inline-flex;align-items:center;gap:8px}
.topbar .bullet::before{content:"";width:6px;height:6px;background:var(--success);border-radius:50%;box-shadow:0 0 0 3px rgba(34,197,94,.18);animation:pulse 2s infinite}
.topbar .pill{background:rgba(255,255,255,.06);padding:3px 10px;border-radius:20px;font-size:12px}

/* === HEADER === */
header{position:sticky;top:0;z-index:90;padding:14px 0;transition:.25s;background:#070b18}
header.scrolled{background:rgba(7,11,24,.92);backdrop-filter:saturate(160%) blur(18px);border-bottom:1px solid rgba(255,255,255,.08)}
header.scrolled .menu a{color:#fff}
header.scrolled .logo,header.scrolled .logo small{color:#fff}
header.scrolled .menu a:hover{background:rgba(255,255,255,.08)}
.nav{display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:14px;color:#fff;text-decoration:none}
.logo-img{height:42px;width:auto;display:block;filter:brightness(0) invert(1);flex-shrink:0}
.logo:hover .logo-img{filter:brightness(0) invert(1)}
.logo-tag{font-size:10px;font-weight:600;color:var(--muted);letter-spacing:1.2px;text-transform:uppercase;line-height:1.3;font-family:'Inter';max-width:180px;border-left:2px solid rgba(255,255,255,.15);padding-left:14px}
@media (max-width:900px){.logo-tag{display:none}}
@media (max-width:680px){.logo-img{height:34px}}
.menu{display:flex;gap:4px;align-items:center}
.menu a{padding:9px 14px;border-radius:10px;font-size:14px;font-weight:500;color:#fff;transition:.2s}
.menu a:hover{background:rgba(255,255,255,.08)}
.cta-btn{background:linear-gradient(135deg,#ff5f3c,#ff8050);color:#fff !important;padding:11px 20px !important;border-radius:11px;font-weight:600 !important;box-shadow:0 10px 28px rgba(255,95,60,.42);transition:.25s}
.cta-btn:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(255,95,60,.55);background:linear-gradient(135deg,#ff5f3c,#ff8050)}
.burger{
  display:none;background:none;border:0;cursor:pointer;color:#fff;
  width:44px;height:44px;padding:0;position:relative;
  -webkit-tap-highlight-color:transparent;
}
.burger span{
  position:absolute;left:10px;right:10px;height:2px;
  background:#fff;border-radius:2px;
  transition:transform .35s cubic-bezier(.6,-0.3,.4,1.3),opacity .25s,top .35s,background .25s;
}
.burger span:nth-child(1){top:14px}
.burger span:nth-child(2){top:21px}
.burger span:nth-child(3){top:28px}
.burger:hover span{background:#ff5f3c}
body.menu-open .burger span{background:#fff}
body.menu-open .burger span:nth-child(1){top:21px;transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0;transform:scaleX(0)}
body.menu-open .burger span:nth-child(3){top:21px;transform:rotate(-45deg)}

/* === HERO === */
.hero{position:relative;background:#070b18;color:#fff;overflow:hidden;min-height:100vh;display:flex;align-items:center;padding:80px 0 100px;margin-top:-72px;padding-top:130px}
#hero-canvas{position:absolute;inset:0;z-index:1;opacity:.7}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(ellipse 70% 60% at 70% 50%,rgba(91,141,239,.22),transparent 60%),
  radial-gradient(ellipse 50% 80% at 20% 90%,rgba(255,95,60,.2),transparent 50%),
  radial-gradient(ellipse 60% 40% at 90% 10%,rgba(139,92,246,.2),transparent 50%);
  z-index:1;pointer-events:none;animation:auroraShift 16s ease-in-out infinite alternate}
@keyframes auroraShift{0%{transform:scale(1) rotate(0deg)}100%{transform:scale(1.15) rotate(2deg)}}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,transparent 60%,#070b18);z-index:1;pointer-events:none}

/* Floating tech tags */
.float-tags{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.float-tag{position:absolute;font-family:'JetBrains Mono','Space Grotesk',monospace;font-weight:600;font-size:13px;color:rgba(255,255,255,.06);white-space:nowrap;animation:floatTag 22s ease-in-out infinite}
.float-tag.s2{font-size:18px;color:rgba(91,141,239,.1)}
.float-tag.s3{font-size:11px;color:rgba(255,95,60,.1)}
@keyframes floatTag{0%,100%{transform:translate(0,0)}50%{transform:translate(20px,-25px)}}

.hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center;z-index:3;position:relative}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:6px 14px;border-radius:30px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);font-size:13px;font-weight:500;color:#cdd6e8;margin-bottom:30px;backdrop-filter:blur(10px)}
.hero-eyebrow .dot{width:8px;height:8px;background:var(--success);border-radius:50%;box-shadow:0 0 0 4px rgba(34,197,94,.25);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}

.hero h1{font-size:clamp(40px,6.2vw,86px);line-height:1;letter-spacing:-2.5px;margin-bottom:28px;font-family:'Space Grotesk';font-weight:700}

/* Word rotator */
.rotator{display:inline-block;position:relative;height:1.05em;vertical-align:bottom;overflow:hidden;min-width:9em}
.rotator-list{display:block;position:absolute;left:0;top:0;will-change:transform;transition:transform .65s cubic-bezier(.7,0,.2,1)}
.rotator-list span{display:block;height:1.05em;line-height:1.05em;background:linear-gradient(120deg,#5b8def 0%,#22d3ee 30%,#ff5f3c 70%,#ffb547 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradMove 5s ease infinite;padding-right:.1em}
@keyframes gradMove{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

.hero p.lead{font-size:clamp(15px,1.4vw,18px);color:#a8b6cf;max-width:540px;margin-bottom:36px;line-height:1.6}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:42px}
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:12px;font-weight:600;font-size:15px;cursor:pointer;border:0;transition:.25s;font-family:inherit;position:relative;overflow:hidden}
.btn-accent{background:linear-gradient(135deg,#ff5f3c,#ff8050);color:#fff;box-shadow:0 14px 36px rgba(255,95,60,.42)}
.btn-accent:hover{transform:translateY(-2px);box-shadow:0 18px 44px rgba(255,95,60,.55)}
.btn-accent::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.4) 50%,transparent 70%);transform:translateX(-100%);transition:transform .6s}
.btn-accent:hover::after{transform:translateX(100%)}
.btn-ghost{background:rgba(255,255,255,.04);color:#fff;border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(10px)}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.3)}

.hero-trust{display:flex;gap:28px;flex-wrap:wrap;color:#7e8aa8;font-size:13px;align-items:center}
.hero-trust strong{color:#fff;font-weight:700;font-size:20px;font-family:'Space Grotesk';display:block;margin-bottom:2px}
.hero-trust .sep{width:1px;height:38px;background:rgba(255,255,255,.12)}

/* Hero card glass */
.hero-card{background:rgba(255,255,255,.04);backdrop-filter:blur(24px) saturate(180%);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:24px;box-shadow:0 30px 80px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.06);position:relative;transform-style:preserve-3d;perspective:1000px;transition:transform .15s ease}
.hc-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.08)}
.hc-h .live{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--success);font-weight:600;text-transform:uppercase;letter-spacing:1px}
.hc-h .live::before{content:"";width:6px;height:6px;background:var(--success);border-radius:50%;animation:pulse 2s infinite;box-shadow:0 0 8px var(--success)}
.hc-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px}
.hc-stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:14px}
.hc-stat .lbl{font-size:11px;color:#8696b8;text-transform:uppercase;letter-spacing:.8px;font-weight:600}
.hc-stat .val{font-size:24px;font-weight:700;color:#fff;margin-top:4px;font-family:'Space Grotesk'}
.hc-stat .delta{font-size:11px;color:var(--success);font-weight:500;margin-top:2px}
.hc-list{display:flex;flex-direction:column;gap:8px}
.hc-item{display:flex;align-items:center;gap:12px;padding:11px 13px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:12px;font-size:13px;color:#cdd6e8}
.hc-item .ico{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;font-weight:700}
.hc-item .ico.ok{background:rgba(34,197,94,.16);color:var(--success)}
.hc-item .ico.warn{background:rgba(255,181,71,.16);color:var(--accent-2)}
.hc-item .ico.run{background:rgba(91,141,239,.16);color:var(--primary)}
.hc-item small{display:block;color:#7e8aa8;font-size:11px;margin-top:2px}
.hc-item .sparkle{margin-left:auto;font-size:10px;color:#7e8aa8}

/* === MARQUEE LOGOS === */
.marquee{background:#070b18;border-block:1px solid rgba(255,255,255,.06);padding:48px 0;overflow:hidden;position:relative;z-index:5}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:160px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,#070b18,transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg,#070b18,transparent)}
.marquee-label{text-align:center;font-size:11px;color:#7e8aa8;text-transform:uppercase;letter-spacing:.22em;font-weight:600;margin-bottom:28px;font-family:'Space Grotesk'}
.marquee-label::before{content:"●";color:var(--success);margin-right:8px;font-size:8px;vertical-align:middle}
.marquee-track{display:flex;gap:60px;width:fit-content;align-items:center;padding:8px 0}
.marquee-track:hover{animation-play-state:paused}
.marquee-track--top{animation:scrollLeft 50s linear infinite}
.marquee-track--bottom{animation:scrollRight 50s linear infinite;margin-top:8px}
@keyframes scrollLeft{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes scrollRight{0%{transform:translateX(-50%)}100%{transform:translateX(0)}}
.client-logo{flex-shrink:0;width:240px;height:110px;display:flex;align-items:center;justify-content:center;padding:14px 18px;background:#fff;border-radius:10px;border:1px solid rgba(255,255,255,.06);transition:transform .35s cubic-bezier(.2,.9,.3,1),box-shadow .35s}
.client-logo:hover{transform:scale(1.06);box-shadow:0 16px 40px rgba(0,0,0,.35),0 0 0 1px rgba(91,141,239,.4)}
.client-logo img{max-height:80px;max-width:200px;object-fit:contain;width:auto}

/* === SECTIONS === */
.section{padding:120px 0;position:relative}
.section.alt{background:#f6f8fc}
.section.dark{background:#070b18;color:#fff}
.eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--primary);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:2px;margin-bottom:18px;padding:6px 12px;background:rgba(91,141,239,.1);border-radius:20px}
.eyebrow::before{content:"";width:6px;height:6px;background:var(--primary);border-radius:50%}
h2.title{font-size:clamp(32px,4.5vw,58px);line-height:1.05;letter-spacing:-1.5px;font-family:'Space Grotesk';font-weight:700;max-width:820px}
.section.dark h2.title{color:#fff}
h2.title .grad{background:linear-gradient(120deg,#5b8def,#8b5cf6 50%,#ff5f3c);-webkit-background-clip:text;background-clip:text;color:transparent}
.section-h{display:grid;grid-template-columns:1.5fr 1fr;gap:60px;align-items:end;margin-bottom:70px}
.section-h .desc{font-size:17px;color:var(--muted);max-width:480px;justify-self:end}
.section.dark .section-h .desc{color:#a8b6cf}

/* === BENTO === */
.bento{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(220px,auto);gap:14px}
.svc{background:#fff;border:1px solid var(--line);border-radius:24px;padding:30px;transition:.3s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden;cursor:pointer;will-change:transform}
.svc::before{content:"";position:absolute;inset:0;background:radial-gradient(circle 240px at var(--mx,50%) var(--my,50%),rgba(91,141,239,.18),transparent 50%);opacity:0;transition:.3s}
.svc:hover::before{opacity:1}
.svc:hover{border-color:rgba(91,141,239,.3);box-shadow:0 30px 60px rgba(20,40,90,.1);transform:translateY(-4px)}
.svc-1{grid-column:span 3;background:linear-gradient(135deg,#070b18,#13205a);color:#fff;border-color:transparent}
.svc-1::after{content:"";position:absolute;right:-100px;bottom:-100px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(255,95,60,.4),transparent 70%)}
.svc-1 .meta-pill{background:rgba(255,255,255,.1);color:#fff}
.svc-2{grid-column:span 3;background:linear-gradient(135deg,#ff5f3c,#ffb547);color:#fff;border-color:transparent}
.svc-2 .meta-pill{background:rgba(255,255,255,.18);color:#fff}
.svc-3{grid-column:span 2}
.svc-4{grid-column:span 2}
.svc-5{grid-column:span 2}
.svc-6{grid-column:span 6;background:linear-gradient(135deg,#0a1228 0%,#1a2d56 100%);color:#fff;border-color:transparent;display:grid;grid-template-columns:1.2fr .8fr;gap:30px;align-items:center}
.svc-6 .ill{height:200px;background:url('site/3cx-bureau.webp') center/cover;border-radius:16px;position:relative;overflow:hidden}
.svc-6 .ill::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(7,11,24,.4),transparent 50%);}
.svc > *{position:relative;z-index:2}
.s-ico{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,#eef2fe,#fef3f0);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:18px}
.svc-1 .s-ico,.svc-2 .s-ico,.svc-6 .s-ico{background:rgba(255,255,255,.14);backdrop-filter:blur(10px)}
.svc h3{font-size:24px;font-weight:700;letter-spacing:-.5px;margin-bottom:10px;font-family:'Space Grotesk'}
.svc p{color:var(--muted);font-size:15px;margin-bottom:18px}
.svc-1 p,.svc-2 p,.svc-6 p{color:rgba(255,255,255,.85)}
.meta-pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;padding:5px 11px;border-radius:20px;background:rgba(91,141,239,.1);color:var(--primary);margin-bottom:14px}
.s-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.s-list span{font-size:12px;padding:5px 10px;border-radius:8px;background:#f6f8fc;color:#374151;font-weight:500}
.svc-1 .s-list span,.svc-2 .s-list span,.svc-6 .s-list span{background:rgba(255,255,255,.1);color:#fff}
.s-link{font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:6px;margin-top:18px;color:var(--primary)}
.svc-1 .s-link,.svc-2 .s-link,.svc-6 .s-link{color:#fff}
.s-link::after{content:"→";transition:transform .25s}
.svc:hover .s-link::after{transform:translateX(4px)}

/* === STATS STRIP === */
.stats-strip{background:#070b18;color:#fff;padding:60px 0;border-radius:32px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;overflow:hidden}
.stats-strip::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(91,141,239,.25),transparent 70%);pointer-events:none}
.stat{padding:30px 40px;border-right:1px solid rgba(255,255,255,.08);text-align:left;position:relative;z-index:1}
.stat:last-child{border-right:0}
.stat .num{font-size:60px;font-weight:700;letter-spacing:-2px;font-family:'Space Grotesk';line-height:1;background:linear-gradient(120deg,#fff,#a8b6cf);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lbl{font-size:13px;color:#8696b8;margin-top:8px;font-weight:500}
.stat .symbol{color:var(--accent);font-weight:300}

/* === SPOTLIGHT (Why) — photo équipe non rognée === */
.spotlight{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
.spotlight-img{position:relative;border-radius:24px;overflow:hidden;background:#0f1e3d;box-shadow:0 30px 80px rgba(0,0,0,.18);width:100%}
.spotlight-img img{width:100%;height:auto;display:block;object-fit:contain;max-width:100%;will-change:transform}
.spotlight-img::after{content:"";position:absolute;left:0;right:0;bottom:0;height:130px;background:linear-gradient(180deg,transparent,rgba(7,11,24,.85));pointer-events:none}
.spotlight-badge{position:absolute;bottom:24px;left:24px;right:24px;background:rgba(7,11,24,.7);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:18px 22px;color:#fff;display:flex;align-items:center;gap:14px;z-index:2}
.spotlight-badge .ico{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#5b8def,#22d3ee);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.spotlight-badge strong{display:block;font-size:14px;margin-bottom:2px}
.spotlight-badge small{display:block;color:#a8b6cf;font-size:12px}
.why-list{display:flex;flex-direction:column;gap:24px;margin-top:40px}
.why-item{display:flex;gap:18px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--line)}
.why-item:last-child{border-bottom:0}
.why-item .ico{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#eef2fe,#fef3f0);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:22px}
.why-item h4{font-size:18px;font-weight:700;margin-bottom:6px;font-family:'Space Grotesk'}
.why-item p{color:var(--muted);font-size:15px}

/* === PROCESS — animation "data pipeline" === */
.process-wrap{position:relative}
/* Particules tech background */
.process-particles{position:absolute;inset:-40px 0;pointer-events:none;z-index:0;overflow:hidden}
.process-particles span{position:absolute;width:4px;height:4px;border-radius:50%;background:radial-gradient(circle,#5b8def,transparent 70%);opacity:.4;animation:particleUp 8s linear infinite}
.process-particles span:nth-child(odd){background:radial-gradient(circle,#ff5f3c,transparent 70%);width:3px;height:3px}
@keyframes particleUp{
  0%{transform:translateY(0) scale(.5);opacity:0}
  10%{opacity:.6}
  90%{opacity:.4}
  100%{transform:translateY(-300px) scale(1);opacity:0}
}

.process{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;z-index:1}

/* Ligne pipeline (gradient running) */
.process::before{
  content:"";position:absolute;top:50px;left:6%;right:6%;height:3px;
  background:linear-gradient(90deg,
    rgba(91,141,239,0) 0%,
    rgba(91,141,239,.5) 15%,
    rgba(139,92,246,.7) 35%,
    rgba(255,95,60,.9) 55%,
    rgba(255,181,71,.7) 75%,
    rgba(91,141,239,0) 100%);
  background-size:200% 100%;
  animation:flow 4s linear infinite;
  border-radius:3px;z-index:0;
  box-shadow:0 0 20px rgba(91,141,239,.3);
}
@keyframes flow{0%{background-position:200% 50%}100%{background-position:-200% 50%}}

/* Bille lumineuse qui voyage le long du pipeline */
.process::after{
  content:"";position:absolute;top:46px;
  width:14px;height:14px;border-radius:50%;
  background:radial-gradient(circle,#fff 0%,#ffb547 35%,#ff5f3c 80%);
  box-shadow:0 0 18px #ff5f3c,0 0 36px rgba(255,95,60,.6),0 0 60px rgba(255,181,71,.3);
  animation:ride 6s cubic-bezier(.5,0,.5,1) infinite;
  z-index:2;left:6%;
}
@keyframes ride{
  0%{left:6%;opacity:0}
  5%{opacity:1}
  95%{opacity:1}
  100%{left:94%;opacity:0}
}

.step{position:relative;z-index:1;text-align:left;background:rgba(255,255,255,.04);padding:28px;border-radius:20px;border:1px solid rgba(255,255,255,.08);transition:transform .35s cubic-bezier(.2,.8,.2,1),border-color .25s,box-shadow .25s;will-change:transform;backdrop-filter:blur(10px)}
.step::before{content:"";position:absolute;inset:-1px;border-radius:20px;padding:1px;background:linear-gradient(135deg,#5b8def,#ff5f3c);opacity:0;-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;transition:.3s;pointer-events:none}
.step:hover{transform:translateY(-8px);box-shadow:0 30px 60px rgba(91,141,239,.18)}
.step:hover::before{opacity:1}

.step .num{
  display:inline-flex;align-items:center;justify-content:center;
  width:54px;height:54px;border-radius:16px;
  background:linear-gradient(135deg,#5b8def,#3461d8);
  color:#fff;font-weight:700;margin-bottom:20px;font-size:17px;
  font-family:'Space Grotesk';
  box-shadow:0 10px 24px rgba(91,141,239,.4),inset 0 1px 0 rgba(255,255,255,.2);
  transition:.4s cubic-bezier(.5,1.5,.5,1);
  position:relative;
  animation:numPulse 6s ease-in-out infinite;
}
.step:nth-child(1) .num{animation-delay:.5s}
.step:nth-child(2) .num{animation-delay:2s}
.step:nth-child(3) .num{animation-delay:3.5s}
.step:nth-child(4) .num{animation-delay:5s}
@keyframes numPulse{
  0%,90%,100%{box-shadow:0 10px 24px rgba(91,141,239,.4),inset 0 1px 0 rgba(255,255,255,.2)}
  10%,15%{box-shadow:0 10px 24px rgba(91,141,239,.4),0 0 0 8px rgba(255,95,60,.3),0 0 30px rgba(255,95,60,.5),inset 0 1px 0 rgba(255,255,255,.2);transform:scale(1.08)}
}

.step:hover .num{
  transform:rotate(-8deg) scale(1.12);
  background:linear-gradient(135deg,#ff5f3c,#ffb547);
  box-shadow:0 16px 36px rgba(255,95,60,.55),inset 0 1px 0 rgba(255,255,255,.3)
}

.step h4{font-size:19px;font-weight:700;margin-bottom:10px;font-family:'Space Grotesk';transition:.25s}
.step:hover h4{background:linear-gradient(120deg,#5b8def,#ff5f3c);-webkit-background-clip:text;background-clip:text;color:transparent}
.step p{color:#a8b6cf;font-size:14px}

/* Pictos de connexion sous les numéros (data flow) */
.step .num::after{
  content:"";position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);
  width:6px;height:6px;border-radius:50%;background:#5b8def;
  box-shadow:0 0 8px #5b8def;opacity:.6;
}

/* === TESTIMONIALS === */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.testi{background:#fff;border:1px solid var(--line);border-radius:24px;padding:32px;display:flex;flex-direction:column;gap:20px;position:relative;transition:.3s}
.testi:hover{transform:translateY(-4px);box-shadow:0 30px 60px rgba(20,40,90,.08)}
.testi::before{content:"\201C";position:absolute;top:18px;right:28px;font-size:88px;line-height:1;color:#eef2fe;font-family:Georgia;font-weight:700}
.testi .stars{color:var(--accent-2);font-size:14px;letter-spacing:3px}
.testi p{font-size:16px;color:#1f2b44;line-height:1.65;position:relative;z-index:1}
.testi .who{display:flex;align-items:center;gap:14px;margin-top:auto;padding-top:18px;border-top:1px solid var(--line)}
.testi .ava{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,#5b8def,#ff5f3c);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Space Grotesk'}
.testi .who strong{display:block;font-size:14px;font-weight:700}
.testi .who small{color:var(--muted);font-size:12px}

/* === CTA STRIP === */
.cta-strip{background:#070b18;color:#fff;border-radius:32px;padding:70px;display:grid;grid-template-columns:1.5fr 1fr;gap:50px;align-items:center;position:relative;overflow:hidden;box-shadow:0 40px 80px rgba(7,11,24,.2)}
.cta-strip::before{content:"";position:absolute;inset:0;background:
  radial-gradient(circle 500px at 90% 50%,rgba(255,95,60,.35),transparent 60%),
  radial-gradient(circle 400px at 20% 100%,rgba(91,141,239,.4),transparent 60%);
  pointer-events:none}
.cta-strip h3{font-size:46px;font-weight:700;letter-spacing:-1.2px;margin-bottom:16px;line-height:1.05;position:relative;z-index:1;font-family:'Space Grotesk'}
.cta-strip p{color:#a8b6cf;font-size:17px;position:relative;z-index:1;max-width:440px}
.cta-strip .actions{position:relative;z-index:1;display:flex;flex-direction:column;gap:10px}

/* === BLOG === */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;transition:.3s;display:flex;flex-direction:column}
.post:hover{transform:translateY(-4px);box-shadow:0 30px 60px rgba(20,40,90,.1)}
.post-img{aspect-ratio:16/10;position:relative;overflow:hidden;background:#f6f8fc}
.post-img img{width:100%;height:100%;object-fit:cover;transition:.5s}
.post:hover .post-img img{transform:scale(1.06)}
.post-tag{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);color:var(--ink);padding:6px 12px;border-radius:30px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px}
.post-body{padding:26px;flex:1;display:flex;flex-direction:column}
.post-meta{font-size:12px;color:var(--muted);margin-bottom:10px;font-weight:500}
.post h4{font-size:19px;font-weight:700;line-height:1.3;margin-bottom:12px;letter-spacing:-.3px;font-family:'Space Grotesk'}
.post p{font-size:14px;color:var(--muted);margin-bottom:20px;flex:1;line-height:1.65}
.post .read{font-size:13px;font-weight:600;color:var(--primary);display:inline-flex;align-items:center;gap:6px}

/* === FAQ === */
.faq{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:.2s}
.faq-item:hover{border-color:rgba(91,141,239,.2)}
.faq-item.open{border-color:var(--primary);box-shadow:0 20px 40px rgba(91,141,239,.08)}
.faq-q{padding:24px 28px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:16px;gap:20px;font-family:'Space Grotesk'}
.faq-q::after{content:"+";font-size:30px;color:var(--primary);font-weight:300;flex-shrink:0;transition:.3s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--muted);font-size:15px;line-height:1.7}
.faq-a-inner{padding:0 28px 26px}
.faq-item.open .faq-a{max-height:500px}

/* === CONTACT === */
.contact{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:18px}
.ci-block{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;display:flex;gap:16px;align-items:flex-start;transition:.2s}
.ci-block:hover{border-color:rgba(91,141,239,.2);transform:translateX(4px)}
.ci-block .ico{width:50px;height:50px;border-radius:14px;background:linear-gradient(135deg,#eef2fe,#fef3f0);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px}
.ci-block strong{display:block;font-size:15px;margin-bottom:4px;font-weight:700}
.ci-block p,.ci-block a{color:var(--muted);font-size:14px;line-height:1.6}
.ci-block a:hover{color:var(--primary)}
.form{background:#fff;border:1px solid var(--line);border-radius:24px;padding:40px;box-shadow:0 30px 60px rgba(20,40,90,.06)}
.form h3{font-size:26px;font-weight:700;margin-bottom:6px;font-family:'Space Grotesk';letter-spacing:-.5px}
.form .lead{color:var(--muted);font-size:14px;margin-bottom:28px}
.fg{margin-bottom:16px}
.fg label{display:block;font-size:12px;font-weight:600;margin-bottom:6px;color:#374151;text-transform:uppercase;letter-spacing:.5px}
.fg input,.fg select,.fg textarea{width:100%;padding:13px 16px;border:1px solid var(--line);border-radius:12px;font-size:14px;font-family:inherit;background:#f6f8fc;transition:.2s}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px rgba(91,141,239,.12)}
.fg textarea{min-height:110px;resize:vertical}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form .btn{width:100%;justify-content:center;margin-top:8px;padding:16px}

/* === FOOTER === */
footer{background:#040712;color:#a8b6cf;padding:90px 0 30px;position:relative;overflow:hidden}
footer::before{content:"";position:absolute;inset:0;background:
  radial-gradient(ellipse 80% 60% at 50% 0%,rgba(91,141,239,.15),transparent 50%),
  radial-gradient(ellipse 60% 50% at 100% 100%,rgba(255,95,60,.1),transparent 60%);
  pointer-events:none}
.foot{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:50px;margin-bottom:50px;position:relative}
.foot h5{color:#fff;font-size:13px;font-weight:700;margin-bottom:20px;text-transform:uppercase;letter-spacing:1.5px;font-family:'Space Grotesk'}
.foot a{display:block;font-size:14px;padding:6px 0;color:#a8b6cf;transition:.2s}
.foot a:hover{color:#fff;transform:translateX(4px)}
.foot p{font-size:14px;margin-bottom:16px;line-height:1.7}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;padding:0;font-size:14px;transform:translateX(0) !important}
.socials a:hover{background:linear-gradient(135deg,#ff5f3c,#5b8def)}
.foot-bottom{padding-top:30px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:13px;position:relative}

/* === REVEAL — fail-safe : opacity:0 only when JS active === */
html.js .reveal{opacity:0;transform:translateY(40px);will-change:transform,opacity}

/* === RESPONSIVE === */
@media (max-width:1024px){

  .hero .wrap,.spotlight,.cta-strip,.contact{grid-template-columns:1fr;gap:40px}
  .hero{min-height:auto;padding:80px 0}
  .stats-strip{grid-template-columns:repeat(2,1fr)}
  .stat{border-bottom:1px solid rgba(255,255,255,.08);border-right:0}
  .stat:nth-child(odd){border-right:1px solid rgba(255,255,255,.08)}
  .bento{grid-template-columns:repeat(2,1fr)}
  .svc-1,.svc-2,.svc-6{grid-column:span 2}
  .svc-3,.svc-4,.svc-5{grid-column:span 1}
  .svc-6{grid-template-columns:1fr}
  .testimonials,.posts{grid-template-columns:repeat(2,1fr)}
  .process{grid-template-columns:repeat(2,1fr)}
  .process::before{
    top:0;bottom:0;left:50%;right:auto;width:3px;height:auto;
    background:linear-gradient(180deg,
      rgba(91,141,239,0) 0%,rgba(91,141,239,.5) 15%,
      rgba(139,92,246,.7) 50%,rgba(255,95,60,.9) 75%,rgba(255,181,71,.5) 100%);
    background-size:100% 200%;
    animation:flowV 4s linear infinite;transform:translateX(-50%)
  }
  @keyframes flowV{0%{background-position:50% 200%}100%{background-position:50% -200%}}
  .process::after{top:0;left:50%;transform:translateX(-50%);animation:rideV 6s cubic-bezier(.5,0,.5,1) infinite}
  @keyframes rideV{
    0%{top:0;opacity:0}
    5%{opacity:1}
    95%{opacity:1}
    100%{top:100%;opacity:0}
  }
  .section-h{grid-template-columns:1fr;gap:14px;margin-bottom:40px}
  .section-h .desc{justify-self:start}
  .foot{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:680px){
  /* La règle complète .menu mobile est définie plus bas dans la section "MENU MOBILE — slide-in panel" */
  .burger{display:block}
  .bento,.testimonials,.posts,.process,.foot{grid-template-columns:1fr}
  .svc-1,.svc-2,.svc-6{grid-column:span 1}
  .cta-strip{padding:40px 30px}
  .cta-strip h3{font-size:32px}
  .section{padding:70px 0}
  .stats-strip{grid-template-columns:1fr;border-radius:20px}
  .stat{border-right:0;text-align:center}
  .form{padding:24px}
  .topbar .wrap{justify-content:center;font-size:12px}
}

/* === SKIP LINK (a11y) === */
.skip-link{position:absolute;top:-40px;left:0;background:var(--accent);color:#fff;padding:10px 16px;z-index:99999;font-weight:600;border-radius:0 0 8px 0;transition:top .2s}
.skip-link:focus{top:0;outline:2px solid #fff;outline-offset:-4px}

/* === FAMILIES B2B PREMIUM (remplace .bento sur la home) === */
.fam-section{padding:100px 0;position:relative;background:#fff;overflow:hidden}
.fam-section::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 15% 20%,rgba(91,141,239,.05),transparent 40%),radial-gradient(circle at 85% 80%,rgba(255,95,60,.05),transparent 40%);pointer-events:none}

.fam-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;position:relative;z-index:2}

.fam-card{
  --acc:#5b8def;
  position:relative;
  display:flex;flex-direction:column;
  background:linear-gradient(155deg,#0a0f1f 0%,#13205a 100%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  padding:36px 30px 30px;
  color:#fff;
  overflow:hidden;
  isolation:isolate;
  text-decoration:none;
  min-height:340px;
  transition:transform .4s cubic-bezier(.2,.9,.3,1), box-shadow .4s, border-color .3s;
  cursor:pointer;
}
.fam-card::before{
  content:"";
  position:absolute;
  top:-120px;right:-120px;
  width:340px;height:340px;
  border-radius:50%;
  background:var(--acc);
  filter:blur(70px);
  opacity:.28;
  z-index:-1;
  transition:opacity .5s, transform .8s cubic-bezier(.2,.9,.3,1);
}
.fam-card::after{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),color-mix(in srgb,var(--acc) 18%,transparent),transparent 50%);
  opacity:0;transition:opacity .35s;
  pointer-events:none;
  z-index:0;
}
.fam-card:hover{
  transform:translateY(-8px);
  border-color:color-mix(in srgb,var(--acc) 50%,transparent);
  box-shadow:0 30px 70px rgba(0,0,0,.4),0 0 80px color-mix(in srgb,var(--acc) 25%,transparent);
}
.fam-card:hover::before{opacity:.45;transform:scale(1.15) translate(-20px,20px)}
.fam-card:hover::after{opacity:1}

.fam-num{
  font-family:'Space Grotesk','JetBrains Mono',monospace;
  font-size:11px;font-weight:700;
  color:color-mix(in srgb,var(--acc) 80%,#fff);
  letter-spacing:.32em;text-transform:uppercase;
  margin-bottom:18px;display:flex;align-items:center;gap:10px;
}
.fam-num::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,color-mix(in srgb,var(--acc) 40%,transparent),transparent)}

.fam-icon{
  width:54px;height:54px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:color-mix(in srgb,var(--acc) 18%,transparent);
  border:1px solid color-mix(in srgb,var(--acc) 35%,transparent);
  color:#fff;
  margin-bottom:22px;
  position:relative;z-index:1;
  transition:transform .35s;
}
.fam-card:hover .fam-icon{transform:scale(1.08) rotate(-4deg)}
.fam-icon svg{width:26px;height:26px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}

.fam-name{
  font-family:'Space Grotesk',sans-serif;
  font-size:30px;font-weight:700;
  letter-spacing:-1px;line-height:1;
  margin-bottom:10px;
  position:relative;z-index:1;
}

.fam-tag{
  color:rgba(255,255,255,.65);
  font-size:14.5px;line-height:1.55;
  margin-bottom:22px;
  flex:1;
  position:relative;z-index:1;
}

.fam-tags{
  display:flex;flex-wrap:wrap;gap:6px;
  margin-bottom:22px;
  position:relative;z-index:1;
}
.fam-tags span{
  font-size:11.5px;font-weight:500;
  padding:5px 10px;
  border-radius:30px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.85);
  white-space:nowrap;
}

.fam-arrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Space Grotesk';font-weight:600;font-size:13px;
  color:color-mix(in srgb,var(--acc) 80%,#fff);
  letter-spacing:.08em;text-transform:uppercase;
  margin-top:auto;padding-top:8px;
  position:relative;z-index:1;
  transition:gap .3s, color .25s;
}
.fam-arrow::after{content:"→";font-size:18px;transition:transform .3s}
.fam-card:hover .fam-arrow{gap:14px;color:#fff}
.fam-card:hover .fam-arrow::after{transform:translateX(4px)}

/* Responsive */
@media (max-width:1080px){.fam-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.fam-grid{grid-template-columns:1fr;gap:12px}.fam-card{min-height:auto;padding:28px 24px}}

/* =====================================================
   PAGES INTERNES — Hero compact + breadcrumb + sections
   ===================================================== */

/* Hero page interne (court, sombre, avec aurora) */
.page-hero{
  position:relative;
  background:#070b18;
  color:#fff;
  padding:80px 0 80px;
  overflow:hidden;
  isolation:isolate;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 80% 20%,rgba(91,141,239,.18),transparent 60%),
    radial-gradient(ellipse 50% 60% at 20% 90%,rgba(255,95,60,.16),transparent 50%),
    radial-gradient(ellipse 50% 40% at 50% 100%,rgba(139,92,246,.15),transparent 50%);
  z-index:-1;animation:auroraShift 16s ease-in-out infinite alternate;
}
.page-hero{padding-bottom:90px}
.page-hero .wrap{position:relative;z-index:2}

.page-hero h1{
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(34px,5vw,68px);
  line-height:1.05;letter-spacing:-1.5px;font-weight:700;
  margin-bottom:18px;max-width:18ch;
}
.page-hero .lead{
  color:#a8b6cf;font-size:clamp(15px,1.4vw,18px);
  max-width:62ch;line-height:1.6;
}

/* Breadcrumb */
.breadcrumb{
  font-size:13px;color:#7e8aa8;font-weight:500;
  margin-bottom:24px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.breadcrumb a{color:#a8b6cf;transition:color .2s}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{color:#fff;font-weight:600}
.breadcrumb-sep{color:#3e4866}

.page-hero .eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:30px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent-2);
  margin-bottom:20px;
}

/* Hero CTA buttons row */
.page-hero .actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}

/* === FAMILY HERO (couleur signature) === */
.fam-hero{
  position:relative;background:#070b18;color:#fff;
  padding:60px 0 80px;overflow:hidden;isolation:isolate;
}
.fam-hero::before{
  content:"";position:absolute;
  top:-200px;right:-100px;width:600px;height:600px;border-radius:50%;
  background:var(--famc,#5b8def);
  filter:blur(120px);opacity:.35;z-index:-1;
}
.fam-hero{padding-bottom:90px}
.fam-hero .wrap{position:relative;z-index:2}
.fam-hero .badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;border-radius:30px;
  background:color-mix(in srgb,var(--famc) 18%,transparent);
  border:1px solid color-mix(in srgb,var(--famc) 35%,transparent);
  color:var(--famc);font-weight:600;font-size:13px;
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:24px;
}
.fam-hero .verb{
  font-family:'Space Grotesk';
  font-size:clamp(48px,8vw,110px);
  font-weight:700;line-height:.95;letter-spacing:-3px;
  color:#fff;margin-bottom:18px;
  background:linear-gradient(135deg,#fff 0%,var(--famc) 100%);
  -webkit-background-clip:text;background-clip:text;
}
.fam-hero .lead{color:#a8b6cf;font-size:18px;max-width:60ch;line-height:1.6}

/* === SERVICE LIST (grid des services dans une famille ou en spotlight) === */
.svc-list{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:60px}
.svc-card{
  background:#fff;border:1px solid rgba(20,30,60,.08);
  border-radius:20px;padding:28px;
  transition:all .35s cubic-bezier(.2,.9,.3,1);
  text-decoration:none;color:var(--ink);
  display:flex;flex-direction:column;gap:8px;
  position:relative;overflow:hidden;
}
.svc-card::before{
  content:"";position:absolute;top:0;right:0;width:100px;height:100px;
  background:var(--svcc,#5b8def);border-radius:50%;
  filter:blur(50px);opacity:0;transition:opacity .3s;
}
.svc-card:hover{transform:translateY(-4px);border-color:var(--svcc,#5b8def);box-shadow:0 20px 50px rgba(0,0,0,.08)}
.svc-card:hover::before{opacity:.18}
.svc-card .pill{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--svcc,#5b8def);
}
.svc-card h3{font-family:'Space Grotesk';font-size:22px;font-weight:700;letter-spacing:-.5px;margin-top:6px}
.svc-card p{color:var(--muted);font-size:14.5px;line-height:1.5;flex:1}
.svc-card .cta{
  display:inline-flex;align-items:center;gap:6px;
  font-family:'Space Grotesk';font-weight:600;font-size:13px;
  color:var(--svcc,#5b8def);margin-top:14px;letter-spacing:.06em;text-transform:uppercase;
}
.svc-card .cta::after{content:"→";font-size:16px;transition:transform .3s}
.svc-card:hover .cta::after{transform:translateX(4px)}

/* === SERVICE PAGE — Hero icon + content === */
.svc-hero-row{
  display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:center;
  position:relative;z-index:2;
}
.svc-hero-ico{
  width:140px;height:140px;border-radius:32px;
  display:flex;align-items:center;justify-content:center;
  background:color-mix(in srgb,var(--svcc,#5b8def) 22%,transparent);
  border:1px solid color-mix(in srgb,var(--svcc,#5b8def) 40%,transparent);
  color:var(--svcc,#5b8def);
  position:relative;
  box-shadow:0 30px 80px color-mix(in srgb,var(--svcc,#5b8def) 30%,transparent);
}
.svc-hero-ico::before{
  content:"";position:absolute;inset:-2px;border-radius:34px;
  background:linear-gradient(135deg,var(--svcc,#5b8def),transparent 60%);
  z-index:-1;opacity:.5;
}
.svc-hero-ico svg{width:64px;height:64px;stroke:currentColor;stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
@media (max-width:900px){.svc-hero-row{grid-template-columns:1fr;gap:30px}.svc-hero-ico{width:96px;height:96px}.svc-hero-ico svg{width:42px;height:42px}}

/* Layout article-like (content + sticky sidebar) */
.content-grid{display:grid;grid-template-columns:1fr 320px;gap:60px;align-items:start;margin-top:40px}
@media (max-width:900px){.content-grid{grid-template-columns:1fr;gap:30px}}

.prose{font-size:17px;line-height:1.75;color:var(--ink-2)}
.prose > * + *{margin-top:1.1em}
.prose h2{font-family:'Space Grotesk';font-size:30px;font-weight:700;letter-spacing:-.5px;margin-top:1.8em;color:var(--ink)}
.prose h3{font-family:'Space Grotesk';font-size:22px;font-weight:600;letter-spacing:-.3px;margin-top:1.6em;color:var(--ink)}
.prose p{color:var(--ink-2)}
.prose strong{color:var(--ink)}
.prose a{color:var(--primary);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.prose a:hover{color:var(--accent)}
.prose ul,.prose ol{padding-left:1.4em;color:var(--muted)}
.prose li{margin-bottom:.5em}
.prose blockquote{
  border-left:3px solid var(--accent);
  padding:.4em 0 .4em 1.5em;margin:1.5em 0;
  font-style:italic;color:var(--ink);
  background:rgba(255,95,60,.04);border-radius:0 14px 14px 0;
}
.prose code{background:#f1f4fa;padding:.15em .4em;border-radius:6px;font-size:.9em;font-family:'JetBrains Mono',monospace}

.sticky-aside{position:sticky;top:100px;display:flex;flex-direction:column;gap:18px}
.aside-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px;
  box-shadow:0 4px 20px rgba(0,0,0,.04);
}
.aside-card h3{font-family:'Space Grotesk';font-size:16px;font-weight:600;margin-bottom:14px;color:var(--ink)}
.aside-card p{color:var(--muted);font-size:14px;margin-bottom:16px}
.aside-card.cta{
  background:linear-gradient(135deg,#070b18,#13205a);color:#fff;border:0;
  position:relative;overflow:hidden;
}
.aside-card.cta::before{
  content:"";position:absolute;right:-50px;top:-50px;width:180px;height:180px;
  background:var(--accent);border-radius:50%;filter:blur(60px);opacity:.3;
}
.aside-card.cta h3{color:#fff;font-size:20px}
.aside-card.cta p{color:rgba(255,255,255,.7)}
.feature-list{list-style:none;padding:0}
.feature-list li{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.feature-list li:last-child{border-bottom:0}
.feature-list svg{flex-shrink:0;width:18px;height:18px;color:var(--success);margin-top:3px}

/* === BLOG INDEX === */
.blog-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:30px}
.blog-pills a{
  padding:8px 16px;border-radius:30px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  color:#cdd6e8;font-size:13px;font-weight:500;
  transition:all .25s;
}
.blog-pills a:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-1px)}

.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
@media (max-width:900px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.blog-grid{grid-template-columns:1fr}}

.blog-card{
  background:#fff;border-radius:18px;overflow:hidden;
  border:1px solid var(--line);
  transition:all .35s cubic-bezier(.2,.9,.3,1);
  display:flex;flex-direction:column;
}
.blog-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.1);border-color:var(--primary)}
.blog-card .cover{position:relative;aspect-ratio:16/10;overflow:hidden;background:#f1f4fa}
.blog-card .cover img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.blog-card:hover .cover img{transform:scale(1.05)}
.blog-card .tag{
  position:absolute;top:14px;left:14px;
  padding:4px 12px;border-radius:30px;
  background:rgba(7,11,24,.85);color:#fff;
  font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  backdrop-filter:blur(8px);
}
.blog-card .body{padding:24px;flex:1;display:flex;flex-direction:column;gap:8px}
.blog-card .meta{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px}
.blog-card h3{font-family:'Space Grotesk';font-size:19px;font-weight:600;line-height:1.3;letter-spacing:-.3px;color:var(--ink);flex:1}
.blog-card p{font-size:14px;color:var(--muted);line-height:1.5}
.blog-card .read{
  font-family:'Space Grotesk';font-size:13px;font-weight:600;
  color:var(--primary);letter-spacing:.06em;text-transform:uppercase;
  margin-top:4px;
}
.blog-card .read::after{content:" →";transition:margin-left .3s}
.blog-card:hover .read::after{margin-left:6px}

/* === ARTICLE PAGE === */
.article-hero{
  position:relative;background:#070b18;color:#fff;
  padding:60px 0 60px;overflow:hidden;
}
.article-hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 50% 60% at 80% 30%,rgba(91,141,239,.18),transparent 60%),
    radial-gradient(ellipse 40% 50% at 20% 80%,rgba(255,95,60,.15),transparent 50%);
  z-index:0;animation:auroraShift 16s ease-in-out infinite alternate;
}
.article-hero .wrap{position:relative;z-index:2;max-width:880px}
.article-hero .tag{
  display:inline-flex;align-items:center;
  padding:6px 14px;border-radius:30px;
  background:rgba(255,95,60,.18);border:1px solid rgba(255,95,60,.4);
  color:var(--accent-2);font-size:12px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:20px;
}
.article-hero h1{
  font-family:'Space Grotesk';font-size:clamp(30px,4vw,52px);
  line-height:1.1;letter-spacing:-1px;font-weight:700;margin-bottom:20px;
}
.article-hero .excerpt{font-size:19px;color:#a8b6cf;line-height:1.5;max-width:60ch}
.article-hero .meta{
  display:flex;flex-wrap:wrap;gap:18px;align-items:center;
  margin-top:30px;color:#7e8aa8;font-size:14px;
}
.article-hero .meta::before{content:"";width:32px;height:1px;background:rgba(255,255,255,.2);display:none}

.article-cover{margin:-30px auto 0;max-width:880px;padding:0 28px;position:relative;z-index:5}
.article-cover img{width:100%;border-radius:24px;box-shadow:0 30px 80px rgba(0,0,0,.3);aspect-ratio:21/9;object-fit:cover}

.article-body{background:#fff;padding:80px 0}
.article-share{
  display:flex;align-items:center;gap:14px;
  padding:24px 0;margin-top:40px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.article-share span{font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.article-share a{
  padding:8px 14px;border-radius:30px;
  background:#f1f4fa;color:var(--ink);font-size:13px;font-weight:600;
  transition:all .25s;
}
.article-share a:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}

/* === CONTACT PAGE === */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;margin-top:50px;align-items:start}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;gap:30px}}
.contact-info-card{
  background:linear-gradient(135deg,#070b18,#13205a);color:#fff;
  border-radius:24px;padding:40px;position:relative;overflow:hidden;
}
.contact-info-card::before{
  content:"";position:absolute;top:-100px;right:-100px;width:300px;height:300px;
  background:var(--accent);border-radius:50%;filter:blur(80px);opacity:.3;
}
.contact-info-card h2{font-family:'Space Grotesk';font-size:32px;letter-spacing:-1px;margin-bottom:14px;position:relative}
.contact-info-card .lead{color:rgba(255,255,255,.7);font-size:15px;margin-bottom:32px;position:relative}
.contact-block{display:flex;gap:14px;padding:18px 0;border-top:1px solid rgba(255,255,255,.08);position:relative}
.contact-block:first-of-type{border-top:0}
.contact-block .ico{
  width:42px;height:42px;border-radius:12px;
  background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;
}
.contact-block strong{display:block;font-size:14px;margin-bottom:4px}
.contact-block p,.contact-block a{color:rgba(255,255,255,.75);font-size:14px;line-height:1.5}
.contact-block a:hover{color:#fff}

/* === EQUIPE GRID (compact + premium) === */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:50px}
@media (max-width:900px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.team-grid{grid-template-columns:1fr}}
.team-card{
  background:#fff;border:1px solid var(--line);border-radius:20px;padding:28px;
  text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;
  transition:all .35s cubic-bezier(.2,.9,.3,1);
  position:relative;overflow:hidden;
}
.team-card::before{
  content:"";position:absolute;top:-50px;left:50%;transform:translateX(-50%);
  width:160px;height:160px;
  background:linear-gradient(135deg,var(--primary),var(--violet));
  border-radius:50%;filter:blur(60px);opacity:0;transition:opacity .35s;
}
.team-card:hover{transform:translateY(-4px);border-color:var(--primary);box-shadow:0 20px 50px rgba(91,141,239,.15)}
.team-card:hover::before{opacity:.2}
.team-avatar{
  width:80px;height:80px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary) 0%,var(--violet) 50%,var(--accent) 100%);
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk';font-size:32px;font-weight:700;color:#fff;
  margin-bottom:10px;
  box-shadow:0 10px 30px rgba(91,141,239,.3);
  position:relative;z-index:1;
}

/* Portrait photo individuel — carré arrondi, plus grand */
.team-photo-wrap{
  width:100%;max-width:240px;
  aspect-ratio:4/5;
  border-radius:20px;
  overflow:hidden;
  margin-bottom:18px;
  position:relative;z-index:1;
  box-shadow:0 16px 40px rgba(91,141,239,.18),0 4px 12px rgba(15,23,42,.08);
  background:linear-gradient(135deg,var(--primary),var(--accent));
  transition:transform .4s cubic-bezier(.2,.9,.3,1),box-shadow .4s;
}
.team-photo-wrap::after{
  content:"";position:absolute;inset:0;border-radius:20px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);
  pointer-events:none;
}
.team-card:hover .team-photo-wrap{
  transform:translateY(-2px);
  box-shadow:0 22px 50px rgba(91,141,239,.28),0 6px 16px rgba(15,23,42,.12);
}
.team-portrait{
  width:100%;height:100%;
  object-fit:cover;object-position:center 20%;
  display:block;
  transition:transform .6s cubic-bezier(.2,.9,.3,1);
}
.team-card:hover .team-portrait{transform:scale(1.05)}
.team-name{font-family:'Space Grotesk';font-size:18px;font-weight:700;letter-spacing:-.3px;color:var(--ink);position:relative;z-index:1}
.team-role{color:var(--muted);font-size:13px;line-height:1.4;position:relative;z-index:1}
.team-cat{
  font-family:'Space Grotesk';font-size:10px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  padding:4px 10px;border-radius:30px;margin-top:6px;
  border:1px solid var(--line);position:relative;z-index:1;
}
.team-cat--technique{color:var(--primary);border-color:rgba(91,141,239,.3);background:rgba(91,141,239,.08)}
.team-cat--commerce{color:var(--accent);border-color:rgba(255,95,60,.3);background:rgba(255,95,60,.08)}
.team-cat--administratif{color:var(--success);border-color:rgba(34,197,94,.3);background:rgba(34,197,94,.08)}
.team-bio{font-size:13px;color:var(--muted);line-height:1.5;margin-top:8px;position:relative;z-index:1}

/* === LOCAL PAGE === */
.local-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:30px}
@media (max-width:680px){.local-cards{grid-template-columns:1fr}}
.local-card{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:14px;padding:18px;color:#fff;
  display:flex;align-items:center;gap:14px;
}
.local-card .ico{
  width:42px;height:42px;border-radius:12px;
  background:rgba(91,141,239,.18);color:var(--primary);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px;
}
.local-card strong{display:block;font-size:14px;margin-bottom:2px}
.local-card span{font-size:13px;color:#a8b6cf}

/* === 404 === */
.error-404{
  min-height:80vh;display:flex;align-items:center;justify-content:center;
  background:#070b18;color:#fff;text-align:center;padding:80px 28px;
  position:relative;overflow:hidden;
}
.error-404::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 50%,rgba(91,141,239,.2),transparent 60%);
}
.error-404 .num{
  font-family:'Space Grotesk';font-size:clamp(120px,20vw,260px);
  font-weight:700;line-height:1;letter-spacing:-6px;
  background:linear-gradient(135deg,var(--primary),var(--accent),var(--violet));
  background-size:200% 200%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:gradMove 4s ease infinite;
}
.error-404 h1{font-family:'Space Grotesk';font-size:32px;letter-spacing:-1px;margin:20px 0 14px}
.error-404 p{color:#a8b6cf;font-size:17px;max-width:50ch;margin:0 auto 30px}
.error-404 .actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative}

/* === SECTION CTA dégradé === */
.section-cta{
  background:linear-gradient(135deg,#070b18 0%,#13205a 60%,#1a2138 100%);
  color:#fff;padding:80px 0;position:relative;overflow:hidden;
}
.section-cta::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 50% 50% at 30% 30%,rgba(255,95,60,.18),transparent 50%),
    radial-gradient(ellipse 50% 50% at 80% 70%,rgba(91,141,239,.18),transparent 50%);
}
.section-cta .wrap{position:relative;z-index:2;text-align:center}
.section-cta h2{font-family:'Space Grotesk';font-size:clamp(28px,3.5vw,42px);letter-spacing:-1px;line-height:1.1;margin-bottom:14px}
.section-cta p{color:rgba(255,255,255,.75);font-size:17px;max-width:50ch;margin:0 auto 30px}
.section-cta .actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* =====================================================
   BOUTON D'APPEL FLOTTANT (bottom right)
   ===================================================== */
.float-call{
  position:fixed;bottom:24px;right:24px;z-index:200;
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 20px 14px 18px;
  background:linear-gradient(135deg,#ff5f3c,#ff8050);
  color:#fff;border-radius:50px;
  box-shadow:0 14px 36px rgba(255,95,60,.5),0 4px 12px rgba(0,0,0,.2);
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px;
  text-decoration:none;
  transition:transform .25s,box-shadow .25s;
}
.float-call:hover{
  color:#fff;
  transform:translateY(-3px) scale(1.04);
  box-shadow:0 20px 50px rgba(255,95,60,.65),0 8px 16px rgba(0,0,0,.25);
}
.float-call svg{width:22px;height:22px;flex-shrink:0;animation:phoneRing 3s ease-in-out infinite}
@keyframes phoneRing{
  0%,90%,100%{transform:rotate(0)}
  92%{transform:rotate(-12deg)}
  94%{transform:rotate(12deg)}
  96%{transform:rotate(-8deg)}
  98%{transform:rotate(8deg)}
}
.float-call__pulse{
  position:absolute;inset:-4px;border-radius:50px;
  border:2px solid #ff5f3c;opacity:0;
  animation:floatPulse 2.4s ease-out infinite;
}
@keyframes floatPulse{
  0%{opacity:.7;transform:scale(.95)}
  100%{opacity:0;transform:scale(1.2)}
}
@media (max-width:680px){
  .float-call{bottom:16px;right:16px;padding:14px;border-radius:50%}
  .float-call__label{display:none}
  .float-call svg{width:24px;height:24px}
}

/* =====================================================
   COOKIE BANNER
   ===================================================== */
.cookie-banner{
  position:fixed;bottom:24px;left:24px;z-index:199;
  max-width:480px;
  background:rgba(13,21,48,.92);color:#fff;
  border:1px solid rgba(255,255,255,.15);
  border-radius:18px;padding:20px 22px;
  backdrop-filter:saturate(180%) blur(20px);
  box-shadow:0 30px 80px rgba(0,0,0,.5);
  font-size:14px;line-height:1.5;
  transform:translateY(20px);opacity:0;
  transition:transform .4s cubic-bezier(.2,.9,.3,1),opacity .4s;
}
.cookie-banner.is-visible{transform:translateY(0);opacity:1}
.cookie-banner[hidden]{display:none}
.cookie-banner__inner{display:flex;flex-direction:column;gap:14px}
.cookie-banner__text strong{font-family:'Space Grotesk';font-size:15px;display:block;margin-bottom:6px}
.cookie-banner__text p{color:#a8b6cf;font-size:13px;line-height:1.5}
.cookie-banner__actions{display:flex;gap:8px;flex-wrap:wrap}
.cookie-btn{
  flex:1;min-width:120px;
  padding:10px 16px;border-radius:10px;
  font-family:'Space Grotesk';font-weight:600;font-size:13px;
  cursor:pointer;border:0;transition:all .2s;
}
.cookie-btn--refuse{
  background:rgba(255,255,255,.06);color:#fff;
  border:1px solid rgba(255,255,255,.15);
}
.cookie-btn--refuse:hover{background:rgba(255,255,255,.12)}
.cookie-btn--accept{
  background:linear-gradient(135deg,#ff5f3c,#ff8050);color:#fff;
  box-shadow:0 8px 24px rgba(255,95,60,.4);
}
.cookie-btn--accept:hover{transform:translateY(-1px);box-shadow:0 12px 30px rgba(255,95,60,.55)}
.cookie-banner__link{
  font-size:12px;color:#7e8aa8;text-decoration:underline;text-underline-offset:3px;align-self:flex-start;
}
.cookie-banner__link:hover{color:var(--accent-2)}

@media (max-width:680px){
  .cookie-banner{
    left:12px;right:12px;bottom:12px;max-width:none;
    padding:16px;
  }
  /* Si le cookie banner est visible ET le bouton call aussi → décale le bouton call */
  .cookie-banner:not([hidden]) ~ .float-call,
  body.has-cookie .float-call{bottom:200px}
}

/* =====================================================
   OUTILS INTERACTIFS (lead-gen embarqués dans articles)
   ===================================================== */
.tool{
  position:relative;
  margin:50px 0;
  background:linear-gradient(155deg,#0a0f1f 0%,#13205a 100%);
  border-radius:24px;padding:36px 32px;color:#fff;
  border:1px solid rgba(255,255,255,.08);
  overflow:hidden;isolation:isolate;
}
.tool::before{
  content:"";position:absolute;top:-100px;right:-100px;
  width:340px;height:340px;border-radius:50%;
  background:var(--tool-acc,#5b8def);
  filter:blur(80px);opacity:.3;z-index:-1;
}
.tool::after{
  content:"";position:absolute;bottom:-150px;left:-50px;
  width:280px;height:280px;border-radius:50%;
  background:#ff5f3c;filter:blur(80px);opacity:.18;z-index:-1;
}

.tool__head{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.tool__icon{
  width:48px;height:48px;border-radius:14px;
  background:color-mix(in srgb,var(--tool-acc,#5b8def) 22%,transparent);
  border:1px solid color-mix(in srgb,var(--tool-acc,#5b8def) 40%,transparent);
  display:flex;align-items:center;justify-content:center;
  color:var(--tool-acc,#5b8def);flex-shrink:0;
}
.tool__icon svg{width:22px;height:22px;stroke:currentColor;stroke-width:2;fill:none}
.tool__badge{
  font-family:'Space Grotesk';font-size:10px;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--tool-acc,#5b8def);
}
.tool__title{
  font-family:'Space Grotesk';font-size:26px;font-weight:700;
  letter-spacing:-.5px;line-height:1.15;margin-bottom:8px;color:#fff;
}
.tool__lead{color:rgba(255,255,255,.7);font-size:15px;margin-bottom:24px}

/* Progress bar */
.tool__progress{
  height:4px;border-radius:2px;
  background:rgba(255,255,255,.08);
  overflow:hidden;margin-bottom:24px;
}
.tool__progress-bar{
  height:100%;width:0%;
  background:linear-gradient(90deg,var(--tool-acc,#5b8def),#ff5f3c);
  transition:width .4s cubic-bezier(.2,.9,.3,1);
}
.tool__step-counter{
  font-family:'Space Grotesk';font-size:12px;color:rgba(255,255,255,.5);
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px;
}

/* Question */
.tool__q{
  font-family:'Space Grotesk';font-size:20px;font-weight:600;
  margin-bottom:20px;line-height:1.35;color:#fff;
}
.tool__step{display:none}
.tool__step.is-active{display:block;animation:toolFadeIn .35s ease}
@keyframes toolFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* Answers */
.tool__answers{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.tool__answer{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  cursor:pointer;transition:all .2s;
  font-size:15px;color:#e8edf7;text-align:left;
}
.tool__answer:hover{background:rgba(255,255,255,.08);border-color:var(--tool-acc,#5b8def);transform:translateX(4px)}
.tool__answer.is-selected{
  background:color-mix(in srgb,var(--tool-acc,#5b8def) 18%,transparent);
  border-color:var(--tool-acc,#5b8def);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--tool-acc,#5b8def) 20%,transparent);
}
.tool__answer-mark{
  width:22px;height:22px;border-radius:50%;
  border:2px solid rgba(255,255,255,.3);
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.tool__answer.is-selected .tool__answer-mark{
  border-color:var(--tool-acc,#5b8def);
  background:var(--tool-acc,#5b8def);
}
.tool__answer.is-selected .tool__answer-mark::after{
  content:"";width:8px;height:8px;border-radius:50%;background:#fff;
}

/* Slider/Input */
.tool__input{
  width:100%;padding:14px 16px;border-radius:12px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  color:#fff;font-size:16px;font-family:inherit;
  transition:border-color .2s;
}
.tool__input:focus{outline:none;border-color:var(--tool-acc,#5b8def);background:rgba(255,255,255,.08)}
.tool__slider-row{display:flex;justify-content:space-between;font-size:13px;color:rgba(255,255,255,.6);margin-bottom:6px}
.tool__slider-val{
  font-family:'Space Grotesk';font-weight:700;color:var(--tool-acc,#5b8def);
  font-size:18px;
}
.tool__range{
  width:100%;-webkit-appearance:none;appearance:none;height:6px;
  background:rgba(255,255,255,.1);border-radius:3px;outline:none;
}
.tool__range::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:22px;height:22px;border-radius:50%;
  background:var(--tool-acc,#5b8def);cursor:pointer;
  box-shadow:0 0 0 4px color-mix(in srgb,var(--tool-acc,#5b8def) 25%,transparent);
}
.tool__range::-moz-range-thumb{
  width:22px;height:22px;border-radius:50%;border:0;
  background:var(--tool-acc,#5b8def);cursor:pointer;
}

/* Nav buttons */
.tool__nav{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}
.tool__btn{
  padding:11px 20px;border-radius:11px;
  font-family:'Space Grotesk';font-weight:600;font-size:14px;
  cursor:pointer;border:0;transition:all .2s;
}
.tool__btn--ghost{
  background:rgba(255,255,255,.06);color:#fff;
  border:1px solid rgba(255,255,255,.1);
}
.tool__btn--ghost:hover{background:rgba(255,255,255,.1)}
.tool__btn--ghost:disabled{opacity:.4;cursor:not-allowed}
.tool__btn--primary{
  background:linear-gradient(135deg,var(--tool-acc,#5b8def),#ff5f3c);
  color:#fff;box-shadow:0 8px 24px color-mix(in srgb,var(--tool-acc,#5b8def) 40%,transparent);
}
.tool__btn--primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px color-mix(in srgb,var(--tool-acc,#5b8def) 55%,transparent)}
.tool__btn--primary:disabled{opacity:.4;cursor:not-allowed;transform:none}

/* Result */
.tool__result-score{
  display:inline-flex;align-items:baseline;gap:8px;
  margin:20px 0 12px;
}
.tool__result-num{
  font-family:'Space Grotesk';font-size:64px;font-weight:700;line-height:1;
  background:linear-gradient(135deg,var(--tool-acc,#5b8def),#ff5f3c);
  -webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-2px;
}
.tool__result-num--small{font-size:38px}
.tool__result-out{font-size:18px;color:rgba(255,255,255,.5);font-weight:500}
.tool__result-level{
  display:inline-block;padding:6px 14px;border-radius:30px;
  font-family:'Space Grotesk';font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  margin-bottom:14px;
}
.tool__result-level--critical{background:rgba(248,113,113,.18);color:#fca5a5;border:1px solid rgba(248,113,113,.4)}
.tool__result-level--warning{background:rgba(251,191,36,.18);color:#fcd34d;border:1px solid rgba(251,191,36,.4)}
.tool__result-level--good{background:rgba(52,211,153,.18);color:#6ee7b7;border:1px solid rgba(52,211,153,.4)}

.tool__result-msg{
  font-size:16px;line-height:1.55;color:rgba(255,255,255,.85);margin-bottom:22px;
}
.tool__recos{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:14px;padding:18px 20px;margin-bottom:24px;
}
.tool__recos-title{
  font-family:'Space Grotesk';font-size:13px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--tool-acc,#5b8def);
  margin-bottom:14px;
}
.tool__recos-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:10px}
.tool__recos-list li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:14.5px;color:rgba(255,255,255,.85);line-height:1.5;
}
.tool__recos-list li::before{
  content:"→";color:var(--tool-acc,#5b8def);font-weight:700;flex-shrink:0;
}

.tool__cta{
  background:rgba(255,95,60,.08);
  border:1px solid rgba(255,95,60,.3);
  border-radius:16px;padding:24px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.tool__cta-text{flex:1}
.tool__cta-text strong{font-family:'Space Grotesk';font-size:17px;display:block;margin-bottom:4px}
.tool__cta-text span{color:rgba(255,255,255,.7);font-size:14px}
.tool__cta .btn{flex-shrink:0;background:linear-gradient(135deg,#ff5f3c,#ff8050);color:#fff;padding:13px 22px;border-radius:11px;font-weight:600;font-family:'Space Grotesk';text-decoration:none;transition:transform .2s,box-shadow .2s;display:inline-flex;align-items:center;gap:8px;font-size:14px}
.tool__cta .btn:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(255,95,60,.5);color:#fff}

@media (max-width:680px){
  .tool{padding:26px 22px;margin:40px -10px}
  .tool__title{font-size:22px}
  .tool__q{font-size:17px}
  .tool__cta{flex-direction:column;text-align:center}
  .tool__nav{flex-direction:column-reverse}
  .tool__btn{width:100%}
}

/* =====================================================
   FAQ 2 COLONNES (lisibilité home)
   ===================================================== */
.faq--cols{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.faq--cols .faq-item{margin:0}
@media (max-width:900px){
  .faq--cols{grid-template-columns:1fr}
}

/* =====================================================
   FORCE TEXTE CLAIR DANS LES TOOLS (override .prose)
   Spécificité supérieure à .prose h3, .prose p, etc.
   ===================================================== */
.tool h1, .tool h2, .tool h3, .tool h4, .tool h5, .tool h6,
.tool p, .tool span, .tool li, .tool label, .tool a{
  color:#fff;
}
.tool .tool__title{color:#fff !important;font-size:26px;font-weight:700;letter-spacing:-.5px;line-height:1.15;margin-bottom:8px}
.tool .tool__lead{color:rgba(255,255,255,.7) !important;font-size:15px;margin-bottom:24px}
.tool .tool__q{color:#fff !important;font-size:20px;font-weight:600;line-height:1.35;margin-bottom:20px}
.tool .tool__step-counter{color:rgba(255,255,255,.5) !important;letter-spacing:.12em;text-transform:uppercase;font-size:12px;margin-bottom:10px}
.tool .tool__answer{color:#e8edf7 !important}
.tool .tool__answer:hover{color:#fff !important}
.tool .tool__result-msg{color:rgba(255,255,255,.85) !important;font-size:16px;line-height:1.55;margin-bottom:22px}
.tool .tool__recos-list li{color:rgba(255,255,255,.85) !important;font-size:14.5px;line-height:1.5}
.tool .tool__cta-text strong{color:#fff !important;font-family:'Space Grotesk';font-size:17px}
.tool .tool__cta-text span{color:rgba(255,255,255,.7) !important;font-size:14px}
.tool .tool__badge{font-family:'Space Grotesk';font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase}
.tool .tool__recos-title{font-family:'Space Grotesk';font-size:13px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;margin-bottom:14px}

/* =====================================================
   ARTICLE COVER FALLBACK (si pas de cover_image)
   ===================================================== */
.article-cover-fallback{
  display:flex;align-items:center;justify-content:center;
  aspect-ratio:21/9;width:100%;
  background:linear-gradient(135deg,#0a0f1f,#13205a);
  border-radius:18px;overflow:hidden;position:relative;
}
.article-cover-fallback::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%,var(--cat-color,#5b8def),transparent 60%),radial-gradient(circle at 80% 70%,#ff5f3c,transparent 50%);
  opacity:.45;
}
.article-cover-fallback svg{
  width:55%;height:auto;max-width:260px;
  position:relative;z-index:2;
  filter:drop-shadow(0 10px 30px rgba(0,0,0,.4));
}

.blog-card .cover-fallback{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#0a0f1f,#13205a);
}
.blog-card .cover-fallback::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%,var(--cat-color,#5b8def),transparent 60%),radial-gradient(circle at 80% 70%,#ff5f3c,transparent 50%);
  opacity:.4;
}
.blog-card .cover-fallback svg{
  width:50%;height:auto;max-width:140px;
  position:relative;z-index:2;
}

/* =====================================================
   MEGA MENU SERVICES (header dropdown)
   ===================================================== */
.menu-item{position:relative}
.menu-link{
  padding:9px 14px;border-radius:10px;
  font-size:14px;font-weight:500;color:#fff;
  display:inline-flex;align-items:center;gap:6px;
  transition:.2s;cursor:pointer;
}
.menu-link:hover{background:rgba(255,255,255,.08);color:#fff}
.menu-caret{font-size:10px;opacity:.6;transition:transform .25s}
.menu-item--has-mega:hover .menu-caret,
.menu-item--has-mega:focus-within .menu-caret{transform:rotate(180deg)}

.mega{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-8px);
  min-width:760px;max-width:920px;
  background:rgba(7,11,24,.96);
  border:1px solid rgba(255,255,255,.1);
  border-radius:18px;
  padding:24px;
  box-shadow:0 30px 80px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.04);
  backdrop-filter:saturate(180%) blur(20px);
  opacity:0;pointer-events:none;
  transition:opacity .25s,transform .3s cubic-bezier(.2,.9,.3,1);
  z-index:200;
}
.menu-item--has-mega:hover .mega,
.menu-item--has-mega:focus-within .mega{
  opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);
}
/* Bridge invisible pour ne pas perdre le hover entre le link et la mega */
.menu-item--has-mega::after{
  content:"";position:absolute;left:0;top:100%;width:100%;height:14px;
}

.mega__cols{
  display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:24px;
}
.mega__col{display:flex;flex-direction:column;gap:6px}
.mega__col--cta{
  background:linear-gradient(160deg,rgba(255,95,60,.12),rgba(91,141,239,.08));
  border-radius:14px;padding:18px;
  border:1px solid rgba(255,95,60,.18);
}
.mega__title{
  font-family:'Space Grotesk';font-size:11px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-2);margin-bottom:10px;
  display:block;
}
.mega__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}
.mega__list--small{font-size:13px;margin-top:8px}
.mega__link{
  display:flex;align-items:flex-start;gap:10px;
  padding:8px 10px;border-radius:8px;
  font-size:14px;color:#cdd6e8;text-decoration:none;
  transition:all .2s;line-height:1.35;
}
.mega__link:hover{background:rgba(255,255,255,.06);color:#fff;transform:translateX(2px)}
.mega__link strong{display:block;font-weight:600;font-size:14px;color:#fff;font-family:'Space Grotesk'}
.mega__link small{display:block;font-size:12px;color:#7e8aa8;margin-top:2px;line-height:1.4}
.mega__link--simple{padding:6px 10px;font-weight:500}

.mega__bullet{
  width:8px;height:8px;border-radius:50%;
  background:var(--ac,#5b8def);
  flex-shrink:0;margin-top:6px;
  box-shadow:0 0 0 3px color-mix(in srgb,var(--ac,#5b8def) 18%,transparent);
}
.mega__bullet--alt{background:var(--accent-2)}

.mega__desc{
  color:#a8b6cf;font-size:13px;line-height:1.5;
}

@media (max-width:980px){
  .mega{min-width:auto;width:calc(100vw - 40px);left:50%;transform:translateX(-50%)}
  .mega__cols{grid-template-columns:1fr;gap:18px}
  .mega__col--cta{order:99}
}
@media (max-width:680px){
  .menu-item--has-mega{display:none} /* Masqué mobile : remplacé par burger */
}

/* =====================================================
   FAQ : améliorations pour FAQ générées dans .prose
   ===================================================== */
.faq-item.open .faq-a{max-height:2000px}
.faq-a-inner > *:first-child{margin-top:0}
.faq-a-inner > *:last-child{margin-bottom:0}
.faq-a-inner p{margin:.6em 0;color:var(--muted);line-height:1.65}
.faq-a-inner p:first-child{margin-top:0}
.faq-a-inner ul,.faq-a-inner ol{margin:.8em 0 .8em 1.4em;color:var(--muted)}
.faq-a-inner li{margin-bottom:.4em}
.faq-a-inner strong{color:var(--ink)}
.faq-a-inner a{color:var(--primary);text-decoration:underline;text-underline-offset:3px}
/* Marge entre prose normale et bloc FAQ pour respiration */
.prose .faq{margin:30px 0}

/* =====================================================
   FAQ DARK : fond sombre dégradé (override default white)
   ===================================================== */
.prose .faq{margin:32px 0}
.prose .faq-item,
.faq--cols .faq-item,
.faq .faq-item{
  background:linear-gradient(155deg,#0a0f1f 0%,#13205a 100%);
  border:1px solid rgba(255,255,255,.1);
  color:#e8edf7;
  position:relative;overflow:hidden;
}
.faq .faq-item::before{
  content:"";position:absolute;top:-60px;right:-60px;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(91,141,239,.25),transparent 70%);
  opacity:0;transition:opacity .35s;pointer-events:none;
}
.faq .faq-item:hover::before,
.faq .faq-item.open::before{opacity:1}
.faq .faq-item:hover{border-color:rgba(91,141,239,.4)}
.faq .faq-item.open{border-color:#5b8def;box-shadow:0 25px 60px rgba(91,141,239,.25),0 0 60px rgba(255,95,60,.15)}

.faq .faq-q{color:#fff;font-weight:600;font-size:16px;font-family:'Space Grotesk';position:relative;z-index:2}
.faq .faq-q::after{
  content:"+";color:var(--accent);font-size:32px;font-weight:300;
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,95,60,.12);
  display:flex;align-items:center;justify-content:center;
  transition:all .3s;flex-shrink:0;
}
.faq .faq-item:hover .faq-q::after{background:rgba(255,95,60,.22)}
.faq .faq-item.open .faq-q::after{transform:rotate(45deg);background:var(--accent);color:#fff}

.faq .faq-a{color:rgba(255,255,255,.78);position:relative;z-index:2}
.faq .faq-a-inner p{color:rgba(255,255,255,.78)}
.faq .faq-a-inner strong{color:#fff}
.faq .faq-a-inner a{color:var(--accent-2);text-decoration:underline;text-underline-offset:3px}
.faq .faq-a-inner a:hover{color:#fff}
.faq .faq-a-inner ul,.faq .faq-a-inner ol{color:rgba(255,255,255,.78)}
.faq .faq-a-inner code{background:rgba(255,255,255,.08);color:var(--accent-2);padding:.15em .4em;border-radius:6px}
.faq .faq-a-inner h2,.faq .faq-a-inner h3,.faq .faq-a-inner h4{color:#fff}

/* Dans .prose : retire les styles prose qui interfèrent */
.prose .faq h2,.prose .faq h3,.prose .faq h4{color:#fff;margin-top:0}

/* =====================================================
   INLINE CTA (remplace les "Je souhaite être conseillé(e)")
   ===================================================== */
.inline-cta{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  margin:32px 0;
  padding:22px 26px;
  background:linear-gradient(135deg,rgba(255,95,60,.08),rgba(91,141,239,.06));
  border:1px solid rgba(255,95,60,.25);
  border-radius:18px;
  position:relative;overflow:hidden;
}
.inline-cta::before{
  content:"";position:absolute;top:-30px;right:-30px;
  width:140px;height:140px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,95,60,.18),transparent 70%);
  pointer-events:none;
}
.inline-cta__icon{
  font-size:32px;flex-shrink:0;
  filter:drop-shadow(0 4px 12px rgba(255,95,60,.4));
}
.inline-cta__text{flex:1;min-width:200px;position:relative;z-index:2}
.inline-cta__text strong{
  display:block;font-family:'Space Grotesk';font-size:17px;font-weight:700;
  color:var(--ink);letter-spacing:-.3px;margin-bottom:4px;
}
.inline-cta__text span{color:var(--muted);font-size:14px;line-height:1.5}
.inline-cta__btn{
  flex-shrink:0;
  background:linear-gradient(135deg,#ff5f3c,#ff8050);
  color:#fff !important;
  padding:13px 22px;border-radius:11px;
  font-family:'Space Grotesk';font-weight:600;font-size:14px;
  text-decoration:none !important;
  box-shadow:0 10px 28px rgba(255,95,60,.42);
  transition:all .25s;display:inline-flex;align-items:center;gap:6px;
  position:relative;z-index:2;
}
.inline-cta__btn:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(255,95,60,.55);color:#fff !important}

@media (max-width:680px){
  .inline-cta{flex-direction:column;align-items:flex-start;text-align:left}
  .inline-cta__btn{width:100%;justify-content:center}
}

/* =====================================================
   FAQ : ESPACEMENT UNIFORME PARTOUT (override final)
   ===================================================== */
.faq{display:flex;flex-direction:column;gap:12px;margin:24px 0}
.faq .faq-item{margin:0 !important}
.prose .faq{margin:24px 0}
.prose .faq + .faq{margin-top:12px}
.prose .faq:first-child{margin-top:0}
.prose .faq:last-child{margin-bottom:0}
/* Le box-shadow open n'affecte pas la box */
.faq .faq-item.open{margin:0 !important}

/* =====================================================
   FAQ 2 COLONNES — override final (plus spécifique que .faq flex)
   ===================================================== */
.faq.faq--cols{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.faq.faq--cols .faq-item{margin:0 !important}
@media (max-width:900px){
  .faq.faq--cols{grid-template-columns:1fr}
}

/* =====================================================
   PAGINATION (blog + catégories)
   ===================================================== */
.pagination{
  display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;
  margin:60px 0 0;
  padding-top:40px;
  border-top:1px solid var(--line);
}
.pagination__list{
  display:flex;align-items:center;gap:6px;list-style:none;padding:0;margin:0;
}
.pagination__btn,.pagination__num,.pagination__current,.pagination__ellipsis{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;height:42px;padding:0 14px;
  border-radius:11px;
  font-family:'Space Grotesk',sans-serif;
  font-weight:600;font-size:14px;letter-spacing:.01em;
  text-decoration:none;
  transition:all .2s;
}
.pagination__btn{
  gap:8px;
  background:#fff;
  border:1px solid var(--line);
  color:var(--ink);
  padding:0 18px;
}
.pagination__btn:hover{
  background:var(--primary);
  color:#fff !important;
  border-color:var(--primary);
  transform:translateY(-1px);
  box-shadow:0 8px 20px rgba(91,141,239,.25);
}
.pagination__btn--disabled{
  opacity:.4;pointer-events:none;background:transparent;
}
.pagination__num{
  background:transparent;
  color:var(--muted);
  border:1px solid transparent;
}
.pagination__num:hover{
  background:rgba(91,141,239,.08);
  color:var(--primary);
  border-color:rgba(91,141,239,.2);
}
.pagination__current{
  background:linear-gradient(135deg,var(--primary),var(--violet));
  color:#fff;
  box-shadow:0 8px 20px rgba(91,141,239,.35);
}
.pagination__ellipsis{
  color:var(--muted);min-width:22px;padding:0 4px;
}

@media (max-width:680px){
  .pagination{gap:10px}
  .pagination__btn{padding:0 12px;font-size:13px}
  .pagination__btn span{display:none}
  .pagination__num,.pagination__current{min-width:36px;height:36px;padding:0 8px;font-size:13px}
}

/* =====================================================
   BLOG PILLS — état actif (catégorie courante)
   ===================================================== */
.blog-pills a.is-active{
  background:linear-gradient(135deg,var(--primary),var(--violet));
  border-color:transparent;
  color:#fff;
  box-shadow:0 8px 20px rgba(91,141,239,.35);
  font-weight:600;
}
.blog-pills a.is-active:hover{
  background:linear-gradient(135deg,var(--primary-2),var(--violet));
  color:#fff;
  transform:translateY(-1px);
}

/* =====================================================
   MENU QUIZ — pill spécial dans la nav
   ===================================================== */
.menu-quiz{
  display:inline-flex !important;align-items:center;gap:8px;
  background:linear-gradient(135deg,rgba(255,95,60,.12),rgba(91,141,239,.12));
  border:1px solid rgba(255,95,60,.3) !important;
  color:var(--accent-2) !important;
  font-weight:600 !important;
  border-radius:20px !important;
  padding:7px 14px !important;
}
.menu-quiz:hover{background:linear-gradient(135deg,rgba(255,95,60,.22),rgba(91,141,239,.22)) !important;border-color:var(--accent) !important;color:#fff !important}
.menu-quiz__badge{
  background:rgba(255,95,60,.18);color:var(--accent);
  font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:2px 7px;border-radius:10px;
}

/* =====================================================
   QUIZ DIAGNOSTIC IT
   ===================================================== */
.quiz-section{padding:40px 0 100px;background:#070b18}
.quiz-app{
  background:linear-gradient(155deg,#0a0f1f 0%,#13205a 100%);
  border-radius:28px;
  padding:48px 40px;
  color:#fff;
  border:1px solid rgba(255,255,255,.08);
  position:relative;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.3);
}
.quiz-app::before{
  content:"";position:absolute;top:-150px;right:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,95,60,.18),transparent 60%);
  pointer-events:none;
}
.quiz-app::after{
  content:"";position:absolute;bottom:-150px;left:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(91,141,239,.18),transparent 60%);
  pointer-events:none;
}
.quiz-app > *{position:relative;z-index:2}

/* Intro */
.quiz-intro{text-align:center}
.quiz-intro__badge{
  display:inline-block;
  padding:6px 14px;border-radius:30px;
  background:rgba(255,95,60,.18);border:1px solid rgba(255,95,60,.4);
  color:var(--accent-2);font-size:12px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px;
}
.quiz-intro__title{
  font-family:'Space Grotesk';font-size:clamp(28px,4vw,42px);
  letter-spacing:-1px;line-height:1.1;margin-bottom:14px;font-weight:700;
}
.quiz-intro__lead{color:#a8b6cf;font-size:17px;max-width:48ch;margin:0 auto 32px;line-height:1.5}
.quiz-intro__axes{
  display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:32px;
}
.quiz-axis-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:30px;
  background:color-mix(in srgb,var(--ac) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--ac) 30%,transparent);
  color:var(--ac);font-size:13px;font-weight:500;
}
.quiz-axis-pill__icon{font-size:14px}
.quiz-intro__cta{font-size:16px !important;padding:16px 28px !important}
.quiz-intro__hint{color:#7e8aa8;font-size:12px;margin-top:18px}

/* Step */
.quiz-step__progress{
  height:5px;border-radius:3px;background:rgba(255,255,255,.08);
  overflow:hidden;margin-bottom:28px;
}
.quiz-step__bar{
  height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));
  transition:width .5s cubic-bezier(.2,.9,.3,1);
  box-shadow:0 0 12px rgba(255,95,60,.5);
}
.quiz-step__head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:18px;flex-wrap:wrap;gap:10px;
}
.quiz-step__counter{
  font-family:'Space Grotesk';font-size:11px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:#7e8aa8;
}
.quiz-step__axis{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:20px;
  background:color-mix(in srgb,var(--ac) 14%,transparent);
  border:1px solid color-mix(in srgb,var(--ac) 35%,transparent);
  color:var(--ac);font-size:12px;font-weight:600;
}
.quiz-step__q{
  font-family:'Space Grotesk';font-size:clamp(20px,2.6vw,26px);
  font-weight:600;line-height:1.3;margin-bottom:24px;color:#fff;
}
.quiz-step__options{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.quiz-option{
  display:flex;align-items:center;gap:14px;
  padding:16px 20px;border-radius:14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:#e8edf7;text-align:left;font-size:15px;cursor:pointer;
  transition:all .2s;
  font-family:inherit;
}
.quiz-option:hover{
  background:rgba(255,255,255,.08);
  border-color:var(--primary);
  transform:translateX(4px);
}
.quiz-option.is-picked{
  background:color-mix(in srgb,var(--primary) 18%,transparent);
  border-color:var(--primary);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 25%,transparent);
}
.quiz-option__mark{
  width:22px;height:22px;border-radius:50%;
  border:2px solid rgba(255,255,255,.3);
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.quiz-option.is-picked .quiz-option__mark{
  border-color:var(--primary);background:var(--primary);
}
.quiz-option.is-picked .quiz-option__mark::after{
  content:"";width:8px;height:8px;border-radius:50%;background:#fff;
}
.quiz-option__label{flex:1}
.quiz-step__nav{display:flex;justify-content:flex-start}
.quiz-step__back{padding:10px 18px !important;font-size:13px !important}

/* Result */
.quiz-result__head{text-align:center;margin-bottom:36px}
.quiz-result__level{
  display:inline-block;padding:8px 18px;border-radius:30px;
  background:color-mix(in srgb,var(--ac) 18%,transparent);
  border:1px solid color-mix(in srgb,var(--ac) 40%,transparent);
  color:var(--ac);font-family:'Space Grotesk';font-weight:600;font-size:13px;
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:20px;
}
.quiz-result__score-row{
  display:inline-flex;align-items:baseline;gap:8px;margin-bottom:14px;
}
.quiz-result__score{
  font-family:'Space Grotesk';font-size:80px;font-weight:700;line-height:1;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  -webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-3px;
}
.quiz-result__out{font-size:22px;color:#7e8aa8;font-weight:500}
.quiz-result__msg{color:#cdd6e8;font-size:16px;line-height:1.6;max-width:60ch;margin:0 auto;}
.quiz-result__chart{margin-bottom:36px}
.quiz-result__chart-title{
  font-family:'Space Grotesk';font-size:13px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--accent-2);margin-bottom:18px;
}
.quiz-bars{display:flex;flex-direction:column;gap:12px}
.quiz-bar{}
.quiz-bar__head{
  display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;
}
.quiz-bar__name{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Space Grotesk';font-weight:600;font-size:14px;color:#fff;
}
.quiz-bar__icon{font-size:14px}
.quiz-bar__val{
  font-family:'Space Grotesk';font-weight:700;font-size:14px;color:var(--ac);
}
.quiz-bar__track{
  height:8px;border-radius:4px;background:rgba(255,255,255,.06);overflow:hidden;
}
.quiz-bar__fill{
  height:100%;background:var(--ac);border-radius:4px;
  transition:width 1.2s cubic-bezier(.2,.9,.3,1);
  box-shadow:0 0 12px var(--ac);
}

.quiz-result__priorities{margin-bottom:36px}
.quiz-priorities{list-style:none;padding:0;display:flex;flex-direction:column;gap:14px;counter-reset:prio}
.quiz-priority{
  display:flex;gap:16px;align-items:flex-start;
  padding:18px 20px;border-radius:14px;
  background:rgba(255,255,255,.04);
  border:1px solid color-mix(in srgb,var(--ac) 25%,rgba(255,255,255,.08));
  border-left:3px solid var(--ac);
}
.quiz-priority__num{
  width:32px;height:32px;border-radius:50%;
  background:color-mix(in srgb,var(--ac) 22%,transparent);
  color:var(--ac);
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk';font-weight:700;font-size:14px;flex-shrink:0;
}
.quiz-priority strong{
  display:block;font-family:'Space Grotesk';font-size:16px;color:#fff;margin-bottom:4px;
}
.quiz-priority p{color:#a8b6cf;font-size:14px;line-height:1.5;margin:0}

.quiz-result__cta{
  background:rgba(255,95,60,.1);border:1px solid rgba(255,95,60,.3);
  border-radius:18px;padding:28px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  margin-bottom:20px;
}
.quiz-result__cta-text h3{
  font-family:'Space Grotesk';font-size:18px;color:#fff;margin-bottom:4px;
}
.quiz-result__cta-text p{color:#a8b6cf;font-size:14px;line-height:1.5;margin:0}
.quiz-result__cta-btn{flex-shrink:0}
.quiz-result__actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}

@media (max-width:680px){
  .quiz-app{padding:30px 22px;border-radius:20px}
  .quiz-result__cta{flex-direction:column;text-align:center}
  .quiz-result__cta-btn{width:100%}
  .quiz-result__score{font-size:60px}
}

/* =====================================================
   PAGE APPLE — design premium Apple-style
   ===================================================== */

/* Reset reveal */
[data-apple-reveal]{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
[data-apple-reveal].is-visible{opacity:1;transform:translateY(0)}

.apple-wrap{max-width:1280px;margin:0 auto;padding:0 28px;position:relative}
.apple-wrap--narrow{max-width:920px}

/* ─── HERO FULLSCREEN ─── */
.apple-hero{
  position:relative;background:#000;color:#fff;
  min-height:88vh;display:flex;align-items:center;
  overflow:hidden;isolation:isolate;
  padding-top:60px;padding-bottom:40px;
}
.apple-hero__noise{
  position:absolute;inset:0;
  background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.04),transparent 50%),
             linear-gradient(180deg,#000 0%,#0a0a0a 100%);
  z-index:-2;
}
.apple-hero__glow{
  position:absolute;border-radius:50%;filter:blur(120px);z-index:-1;
}
.apple-hero__glow--1{
  top:-200px;left:-100px;width:600px;height:600px;
  background:radial-gradient(circle,rgba(255,95,60,.2),transparent 70%);
}
.apple-hero__glow--2{
  bottom:-200px;right:-100px;width:600px;height:600px;
  background:radial-gradient(circle,rgba(91,141,239,.18),transparent 70%);
}
.apple-hero__inner{
  position:relative;z-index:2;width:100%;
  max-width:1280px;margin:0 auto;padding:0 28px;
  text-align:center;
}
.apple-hero__kicker{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 18px;border-radius:30px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.15);
  color:#fff;font-size:13px;font-weight:500;
  backdrop-filter:blur(20px);
}
.apple-hero__title{
  font-family:'Space Grotesk','SF Pro Display',sans-serif;
  font-size:clamp(48px,8vw,110px);
  line-height:1.0;letter-spacing:-3px;font-weight:700;
  margin:30px 0 24px;color:#fff;
}
.apple-hero__title-em{font-style:normal}
.apple-hero__title-em--gradient{
  background:linear-gradient(135deg,#fff 0%,#a8b6cf 50%,#5b8def 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.apple-hero__lead{
  color:#a8b6cf;font-size:clamp(17px,1.6vw,21px);
  max-width:60ch;margin:0 auto 36px;line-height:1.5;
}
.apple-hero__cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:60px}
.apple-hero__devices{
  position:relative;display:flex;justify-content:center;align-items:flex-end;
  gap:30px;flex-wrap:wrap;margin-top:30px;
  filter:drop-shadow(0 30px 60px rgba(0,0,0,.6));
}
.apple-hero__device{
  max-height:280px;width:auto;
  transition:transform .8s cubic-bezier(.2,.9,.3,1);
}
.apple-hero__device--macbook{max-height:240px}
.apple-hero__device--ipad{max-height:220px}
@media (max-width:680px){
  .apple-hero__devices{gap:14px}
  .apple-hero__device{max-height:140px}
}

/* ─── BOUTONS APPLE ─── */
.apple-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 26px;border-radius:30px;
  font-family:'Space Grotesk','SF Pro',sans-serif;
  font-weight:600;font-size:15px;letter-spacing:-.01em;
  text-decoration:none;transition:all .25s cubic-bezier(.2,.9,.3,1);
  border:0;cursor:pointer;
}
.apple-btn--lg{padding:16px 30px;font-size:16px}
.apple-btn--primary{background:#fff;color:#000;box-shadow:0 10px 30px rgba(255,255,255,.15)}
.apple-btn--primary:hover{background:#fff;color:#000;transform:translateY(-2px);box-shadow:0 14px 40px rgba(255,255,255,.25)}
.apple-section--white .apple-btn--primary,
.apple-section--gray .apple-btn--primary{background:#000;color:#fff;box-shadow:0 10px 30px rgba(0,0,0,.18)}
.apple-section--white .apple-btn--primary:hover,
.apple-section--gray .apple-btn--primary:hover{background:#000;color:#fff;box-shadow:0 14px 40px rgba(0,0,0,.28)}
.apple-btn--ghost{
  background:transparent;color:#fff;
  border:1px solid rgba(255,255,255,.3);
}
.apple-btn--ghost:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.5)}

/* ─── SECTIONS ─── */
.apple-section{padding:120px 0;position:relative}
.apple-hero + .apple-section{padding-top:160px}
.apple-section--white{background:#fff;color:#000}
.apple-section--gray{background:#f5f5f7;color:#000}
.apple-section--dark{background:#000;color:#fff}
.apple-section--cta{background:linear-gradient(180deg,#000 0%,#13205a 100%);color:#fff}

.apple-section__head{margin-bottom:60px}

/* Typo Apple */
.apple-h2{
  font-family:'Space Grotesk','SF Pro Display',sans-serif;
  font-size:clamp(34px,5vw,64px);
  line-height:1.05;letter-spacing:-2px;font-weight:700;
  margin-bottom:18px;color:#000;
}
.apple-h2--center{text-align:center}
.apple-h2--white{color:#fff}
.apple-h2--clean{margin-bottom:14px}
.apple-em{
  background:linear-gradient(120deg,#5b8def,#a78bfa,#ff5f3c);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.apple-h3{
  font-family:'Space Grotesk','SF Pro Display',sans-serif;
  font-size:clamp(20px,2vw,26px);
  font-weight:600;letter-spacing:-.5px;
  margin-bottom:14px;color:#000;
}
.apple-lead{
  font-size:clamp(17px,1.4vw,21px);
  line-height:1.5;color:#5a6582;
}
.apple-lead--white{color:#a8b6cf}
.apple-lead--center{text-align:center;max-width:60ch;margin:0 auto}
.apple-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.apple-list li{
  position:relative;padding-left:22px;font-size:15.5px;color:#5a6582;line-height:1.55;
}
.apple-list li::before{
  content:"";position:absolute;left:0;top:.65em;
  width:6px;height:6px;border-radius:50%;
  background:linear-gradient(135deg,#5b8def,#a78bfa);
}

/* ─── PRODUITS (4 cards) ─── */
.apple-products{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:60px;
}
.apple-product{
  background:#fff;border-radius:24px;
  display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;
  border:1px solid rgba(0,0,0,.06);
  transition:transform .4s cubic-bezier(.2,.9,.3,1),box-shadow .4s,border-color .4s;
  cursor:default;
  position:relative;overflow:hidden;
  min-height:240px;
}
.apple-product:nth-child(even){grid-template-columns:1fr 1fr}
.apple-product:nth-child(even) .apple-product__visual{order:2}
.apple-product:nth-child(even) .apple-product__body{order:1}
.apple-product:hover{
  box-shadow:0 30px 60px rgba(0,0,0,.1);
  transform:translateY(-4px);
  border-color:rgba(0,0,0,.12);
}
.apple-product__visual{
  position:relative;
  background:linear-gradient(135deg,#fafafa 0%,#eef0f5 100%);
  display:flex;align-items:center;justify-content:center;
  padding:30px;overflow:hidden;
  min-height:240px;
}
.apple-product__visual::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%,rgba(91,141,239,.12),transparent 60%);
  opacity:.6;
}
.apple-product__visual img{
  max-width:90%;max-height:200px;width:auto;height:auto;object-fit:contain;
  filter:drop-shadow(0 20px 30px rgba(0,0,0,.18));
  transition:transform .6s cubic-bezier(.2,.9,.3,1);
  position:relative;z-index:1;
}
.apple-product:hover .apple-product__visual img{
  transform:scale(1.06) translateY(-4px);
}
.apple-product__visual--icon{
  background:linear-gradient(135deg,#e0e7ff,#eef0f5);
  color:#5b8def;
}
.apple-product__visual--icon svg{width:96px;height:96px;position:relative;z-index:1}
.apple-product__body{
  padding:36px 32px;display:flex;flex-direction:column;justify-content:center;gap:14px;
}
@media (max-width:760px){
  .apple-product{grid-template-columns:1fr}
  .apple-product:nth-child(even){grid-template-columns:1fr}
  .apple-product:nth-child(even) .apple-product__visual{order:1}
  .apple-product:nth-child(even) .apple-product__body{order:2}
  .apple-product__visual{min-height:200px;padding:24px}
  .apple-product__body{padding:24px}
}
.apple-product__body{display:flex;flex-direction:column;gap:10px}
@media (max-width:760px){
  .apple-products{grid-template-columns:1fr}
  .apple-product{grid-template-columns:1fr;padding:28px;text-align:center}
  .apple-product__visual{height:120px;margin:0 auto}
}

/* ─── CONFIG GRID (4 cards sur fond noir) ─── */
.apple-config-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:50px;
}
.apple-config-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;padding:32px;
  transition:all .35s;
}
.apple-config-card:hover{
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.15);
  transform:translateY(-2px);
}
.apple-config-card__icon{
  width:48px;height:48px;border-radius:14px;
  background:linear-gradient(135deg,#5b8def,#a78bfa);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;margin-bottom:18px;
}
.apple-config-card__title{
  font-family:'Space Grotesk';font-size:19px;font-weight:600;
  margin-bottom:14px;color:#fff;
}
.apple-config-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.apple-config-card li{
  position:relative;padding-left:18px;font-size:14.5px;color:#a8b6cf;line-height:1.5;
}
.apple-config-card li::before{content:"→";position:absolute;left:0;color:#5b8def}
@media (max-width:760px){.apple-config-grid{grid-template-columns:1fr}}

/* ─── PROCESS (texte + ol) ─── */
.apple-process{}
.apple-process-steps{
  list-style:none;padding:0;counter-reset:proc;margin-top:30px;display:flex;flex-direction:column;gap:14px;
}
.apple-process-steps li{
  counter-increment:proc;
  position:relative;padding:18px 18px 18px 70px;
  background:#f5f5f7;border-radius:16px;
  font-size:15.5px;color:#1a1a1a;line-height:1.5;
}
.apple-process-steps li::before{
  content:counter(proc);
  position:absolute;left:18px;top:50%;transform:translateY(-50%);
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,#5b8def,#a78bfa);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk';font-weight:700;font-size:15px;
}

/* ─── TIP CARD (Le Saviez-vous) ─── */
.apple-tip-card{
  background:#fff;border-radius:24px;padding:48px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 30px 60px rgba(0,0,0,.06);
  position:relative;overflow:hidden;
}
.apple-tip-card::before{
  content:"";position:absolute;top:-100px;right:-100px;
  width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(91,141,239,.12),transparent 70%);
}
.apple-tip-card > *{position:relative}
.apple-tip-card__label{
  display:inline-block;
  padding:6px 14px;border-radius:30px;
  background:rgba(91,141,239,.12);
  color:#3461d8;font-size:12px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px;
}
.apple-tip-card p{font-size:16px;line-height:1.65;color:#5a6582;margin-top:14px}
.apple-tip-card strong{color:#000;font-weight:600}

/* ─── SHOWCASE PRODUITS ─── */
.apple-showcase{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:70px;
  padding-top:60px;
}
.apple-showcase-card{
  display:flex;flex-direction:column;position:relative;
  background:linear-gradient(180deg,#fafafa 0%,#f0f0f3 100%);
  border-radius:24px;
  text-decoration:none;color:#000;
  transition:all .5s cubic-bezier(.2,.9,.3,1);
  cursor:pointer;
  padding-top:80px;
  isolation:isolate;
}
.apple-showcase-card::before{
  content:"";position:absolute;inset:0;border-radius:24px;
  background:linear-gradient(135deg,rgba(255,95,60,.08),rgba(91,141,239,.06));
  opacity:0;transition:opacity .5s;z-index:-1;
}
.apple-showcase-card__media{
  position:absolute;top:-60px;left:50%;transform:translateX(-50%);
  width:90%;height:180px;
  display:flex;align-items:center;justify-content:center;
  z-index:2;
  pointer-events:none;
}
.apple-showcase-card img{
  max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;
  filter:drop-shadow(0 22px 32px rgba(0,0,0,.18));
  transition:transform .6s cubic-bezier(.2,.9,.3,1);
  will-change:transform;
}
.apple-showcase-card:hover{
  transform:translateY(-6px);
  box-shadow:0 30px 60px rgba(0,0,0,.12);
}
.apple-showcase-card:hover::before{opacity:1}
.apple-showcase-card:hover img{
  transform:translateY(-10px) scale(1.04);
  filter:drop-shadow(0 32px 40px rgba(0,0,0,.22));
}
.apple-showcase-card__body{
  padding:24px 20px 26px;
  text-align:center;
}
.apple-showcase-card h3{
  font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:700;
  margin:0 0 4px;color:#000;letter-spacing:-.5px;
}
.apple-showcase-card p{
  font-size:13px;color:#86868b;margin:0;letter-spacing:.2px;
}
@media (max-width:880px){.apple-showcase{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.apple-showcase{grid-template-columns:1fr}}

/* ─── CTA FINAL ─── */
.apple-cta{
  text-align:center;max-width:680px;margin:0 auto;
}
.apple-cta h2{
  font-family:'Space Grotesk';font-size:clamp(32px,4vw,52px);
  letter-spacing:-1.5px;font-weight:700;line-height:1.1;margin-bottom:14px;color:#fff;
}
.apple-cta p{color:#a8b6cf;font-size:18px;line-height:1.5;margin-bottom:32px}
.apple-cta__buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ─── Menu Apple link ─── */
.menu-apple{
  display:inline-flex !important;align-items:center;gap:6px;
}
.menu-apple svg{width:14px;height:14px;flex-shrink:0;opacity:.85}

/* =====================================================
   FIX : ligne blanche entre topbar et header (margin-top header)
   ===================================================== */
header{margin-top:0 !important}
.topbar + header{margin-top:0}
body{margin:0}

/* =====================================================
   MEGA MENU : link Apple stylé + card Quiz visuelle
   ===================================================== */
.mega__link--apple{
  color:#fff !important;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:8px;
  padding:8px 12px !important;
  font-weight:500;
  margin-top:6px;
}
.mega__link--apple:hover{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.2);
}
.mega__link--apple svg{flex-shrink:0;opacity:.9}

.mega-quiz-card{
  display:flex;flex-direction:column;gap:6px;
  padding:18px;border-radius:14px;
  background:linear-gradient(135deg,rgba(255,95,60,.15),rgba(91,141,239,.15));
  border:1px solid rgba(255,95,60,.3);
  text-decoration:none;color:#fff;
  transition:all .25s;cursor:pointer;
  position:relative;overflow:hidden;
}
.mega-quiz-card::before{
  content:"";position:absolute;top:-30px;right:-30px;
  width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,95,60,.3),transparent 70%);
  pointer-events:none;
}
.mega-quiz-card:hover{
  background:linear-gradient(135deg,rgba(255,95,60,.25),rgba(91,141,239,.22));
  border-color:rgba(255,95,60,.5);
  transform:translateY(-2px);color:#fff;
}
.mega-quiz-card__badge{
  display:inline-block;align-self:flex-start;
  padding:3px 10px;border-radius:20px;
  background:rgba(255,95,60,.25);color:var(--accent-2);
  font-family:'Space Grotesk';font-size:10px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
}
.mega-quiz-card strong{
  font-family:'Space Grotesk';font-size:15px;font-weight:600;color:#fff;letter-spacing:-.02em;
}
.mega-quiz-card__lead{color:#a8b6cf;font-size:12.5px;line-height:1.45}
.mega-quiz-card__cta{
  font-family:'Space Grotesk';font-size:12px;font-weight:600;
  color:var(--accent-2);letter-spacing:.05em;
  margin-top:4px;
}

/* =====================================================
   CENTRAGE FAQ GÉNÉRALE & sections "centrées"
   ===================================================== */
.faq-generale .faq--cols,
.section .faq--cols{max-width:1100px;margin-left:auto !important;margin-right:auto !important}
.faq-generale .section-h{margin-left:auto;margin-right:auto;max-width:780px}
.faq-generale .desc{margin-left:auto;margin-right:auto;max-width:54ch}

/* =====================================================
   MENU MOBILE — slide-in panel + accordéon Services
   ===================================================== */
@media (max-width:880px){
  /* Backdrop sombre quand menu ouvert */
  body.menu-open{overflow:hidden}
  body.menu-open::before{
    content:"";position:fixed;inset:0;
    background:rgba(0,0,0,.6);
    z-index:9997;
    animation:menuFadeIn .3s ease;
    pointer-events:none; /* Le clic backdrop est géré en JS via document */
  }
  /* Promeut le header pour qu'il sorte du stacking context du body
     et passe AU-DESSUS du ::before backdrop */
  body.menu-open header{z-index:9999 !important;}
  @keyframes menuFadeIn{from{opacity:0}to{opacity:1}}

  /* Panel slide-in — display:flex en permanence pour permettre la transition right */
  .menu{
    display:flex !important;
    position:fixed !important;
    top:0 !important;
    left:auto !important;
    right:-110% !important;
    bottom:0 !important;
    width:100% !important;
    max-width:380px !important;
    background:#070b18 !important;
    flex-direction:column !important;
    align-items:stretch !important;
    padding:80px 28px 40px !important;
    z-index:9998 !important;
    transition:right .35s cubic-bezier(.2,.9,.3,1) !important;
    overflow-y:auto;overflow-x:clip;
    gap:0;
    border-left:1px solid rgba(255,255,255,.08);
    backdrop-filter:none !important;
    -webkit-font-smoothing:antialiased;
  }
  .menu.open{right:0 !important}

  /* Liens mobile */
  .menu > a,
  .menu .menu-link{
    padding:16px 0 !important;
    font-size:17px !important;
    color:#fff !important;
    background:transparent !important;
    border:0 !important;
    border-bottom:1px solid rgba(255,255,255,.08) !important;
    border-radius:0 !important;
    width:100%;
    text-align:left;
    display:flex !important;
    align-items:center;justify-content:space-between;
    gap:8px;
  }
  .menu > a:hover,
  .menu .menu-link:hover{
    background:rgba(255,255,255,.04) !important;
    padding-left:8px !important;
  }

  /* CTA bouton (Quiz diagnostic) en bas du panel */
  .menu .cta-btn{
    margin-top:24px !important;
    background:linear-gradient(135deg,#ff5f3c,#ff8050) !important;
    color:#fff !important;
    padding:14px 22px !important;
    border-radius:11px !important;
    font-weight:600 !important;
    border-bottom:0 !important;
    justify-content:center !important;
    box-shadow:0 10px 28px rgba(255,95,60,.42);
  }

  /* Item parent du mega menu */
  .menu-item--has-mega{display:block !important;width:100%}
  .menu-item--has-mega::after{display:none !important}
  .menu-link{cursor:pointer}
  .menu-caret{
    transition:transform .3s;
    font-size:14px !important;opacity:.8 !important;
  }
  .menu-item--has-mega.is-open .menu-caret{transform:rotate(180deg)}

  /* Mega devient accordéon */
  .mega{
    position:static !important;transform:none !important;
    opacity:1 !important;pointer-events:auto !important;
    min-width:0 !important;width:100% !important;max-width:none !important;
    background:transparent !important;border:0 !important;
    box-shadow:none !important;backdrop-filter:none !important;
    padding:0 !important;margin-top:0 !important;
    max-height:0;overflow:hidden;
    transition:max-height .4s cubic-bezier(.2,.9,.3,1);
  }
  .menu-item--has-mega.is-open .mega{
    max-height:2000px;
    padding:8px 0 16px 12px !important;
  }
  .mega__cols{
    grid-template-columns:1fr !important;
    gap:18px !important;
  }
  .mega__col--cta{
    background:rgba(255,95,60,.08) !important;
    border:1px solid rgba(255,95,60,.2) !important;
    border-radius:14px;
    padding:14px !important;
  }
  .mega-quiz-card{padding:14px !important}
  .mega__link{padding:8px 10px !important;font-size:14px !important}
  .mega__title{font-size:10px !important;margin-bottom:6px !important}

  /* Burger toujours visible et z-index supérieur au panel */
  .burger{
    display:inline-flex !important;
    position:relative;z-index:9999 !important;
    color:#fff !important;
    font-size:28px !important;
    padding:8px;
    transition:transform .25s;
  }

  /* Cache le bouton d'appel flottant quand le menu est ouvert */
  body.menu-open .float-call{display:none !important}
}

/* Tablet : conserve quand même mega menu desktop si > 880px mais < 1024px */
@media (max-width:880px) and (min-width:680px){
  .menu{max-width:50%}
}

/* =====================================================
   PHOTO ÉQUIPE — section pleine largeur sur /equipe
   ===================================================== */
.team-photo-section{
  padding:40px 0 20px;
}
.team-photo{
  margin:0;border-radius:24px;overflow:hidden;
  position:relative;
  box-shadow:0 30px 80px rgba(7,11,24,.35),0 8px 24px rgba(7,11,24,.18);
  background:#0f172a;
  isolation:isolate;
}
.team-photo img{
  width:100%;height:auto;display:block;
  object-fit:cover;object-position:center 30%;
  aspect-ratio:16/9;
  transition:transform 1.2s cubic-bezier(.2,.9,.3,1);
}
.team-photo:hover img{transform:scale(1.02)}
.team-photo::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:50%;
  background:linear-gradient(180deg,transparent,rgba(7,11,24,.85));
  pointer-events:none;z-index:1;
}
.team-photo figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:20px 28px;color:#fff;font-size:14px;font-weight:500;
  letter-spacing:.2px;z-index:2;
  display:flex;align-items:center;gap:10px;
}
.team-photo figcaption::before{
  content:"📍";font-size:18px;
}
@media (max-width:680px){
  .team-photo-section{padding:24px 0 10px}
  .team-photo{border-radius:16px}
  .team-photo img{aspect-ratio:4/3}
  .team-photo figcaption{padding:14px 18px;font-size:12.5px}
}

/* =====================================================
   QUIZ v2 — Badge souverain + audit budget
   ===================================================== */
.quiz-option__badge{
  display:inline-flex;align-items:center;gap:4px;
  background:linear-gradient(135deg,#fef3c7,#fff);
  color:#92400e;
  font-size:11px;font-weight:600;
  padding:3px 8px;border-radius:99px;
  margin-left:auto;
  border:1px solid #fcd34d;
  letter-spacing:.2px;
  flex-shrink:0;
}

.quiz-result__budget{
  margin-top:30px;
}
.quiz-budget-card{
  background:linear-gradient(135deg,#eff6ff,#f0f9ff);
  border:1px solid #bfdbfe;
  border-radius:16px;
  padding:22px 24px;
  display:flex;flex-direction:column;gap:10px;
}
.quiz-budget-card strong{
  font-size:16px;color:#1e40af;
  font-family:'Space Grotesk',sans-serif;
}
.quiz-budget-card p{
  margin:0;color:#334155;font-size:14px;line-height:1.55;
}
.quiz-budget-card__note{
  font-size:13px !important;
  color:#1e40af !important;
  font-style:italic;
  border-top:1px solid #bfdbfe;
  padding-top:10px;
  margin-top:6px !important;
}

/* =====================================================
   QUIZ v3 — Formulaire lead inline
   ===================================================== */
.quiz-lead-form{
  display:flex;flex-direction:column;gap:14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;padding:24px;margin-top:16px;
  position:relative;
}
.quiz-lead-form__row{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
.quiz-lead-form label{
  display:flex;flex-direction:column;gap:6px;
  font-size:13px;font-weight:500;color:rgba(255,255,255,.85);
}
.quiz-lead-form__full{width:100%}
.quiz-lead-form input[type="text"],
.quiz-lead-form input[type="email"],
.quiz-lead-form input[type="tel"],
.quiz-lead-form textarea{
  font-family:inherit;font-size:14px;
  padding:10px 14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  background:rgba(255,255,255,.05);
  color:#fff;
  transition:.2s;
  width:100%;
}
.quiz-lead-form input:focus,
.quiz-lead-form textarea:focus{
  outline:none;
  border-color:var(--accent);
  background:rgba(255,255,255,.08);
  box-shadow:0 0 0 3px rgba(255,95,60,.15);
}
.quiz-lead-form textarea{resize:vertical;min-height:80px}
.quiz-lead-form__consent{
  display:flex;flex-direction:row !important;align-items:flex-start;gap:10px;
  font-size:12.5px !important;
  line-height:1.5;color:rgba(255,255,255,.7) !important;
}
.quiz-lead-form__consent input[type="checkbox"]{
  width:18px;height:18px;flex-shrink:0;margin-top:2px;
  accent-color:var(--accent);
}
.quiz-lead-form__consent a{color:var(--accent);text-decoration:underline}
.quiz-lead-form .quiz-result__cta-btn{
  margin-top:6px;align-self:flex-start;
}
.quiz-lead-form__error{
  background:rgba(220,38,38,.15);
  border-left:3px solid #dc2626;
  color:#fca5a5;
  padding:10px 14px;border-radius:8px;
  font-size:13.5px;margin:0;
}

.quiz-lead-form__success{
  text-align:center;padding:36px 24px;
  background:linear-gradient(135deg,rgba(52,211,153,.08),rgba(34,211,238,.08));
  border:1px solid rgba(52,211,153,.25);
  border-radius:16px;
  display:flex;flex-direction:column;align-items:center;gap:12px;
}
.quiz-lead-form__success-icon{
  width:60px;height:60px;border-radius:50%;
  background:linear-gradient(135deg,#34d399,#22d3ee);
  color:#fff;font-size:32px;font-weight:bold;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 32px rgba(52,211,153,.3);
}
.quiz-lead-form__success h3{
  margin:0;font-size:22px;color:#34d399;
  font-family:'Space Grotesk',sans-serif;
}
.quiz-lead-form__success p{
  margin:0;color:rgba(255,255,255,.85);max-width:480px;
}
.quiz-lead-form__success p.muted{color:rgba(255,255,255,.55);font-size:13px}
.quiz-lead-form__success a{color:var(--accent)}

@media (max-width:680px){
  .quiz-lead-form__row{grid-template-columns:1fr}
}

/* =====================================================
   MODAL — Cloud souverain (et générique)
   ===================================================== */
.mdm-modal{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;
  transition:opacity .3s,visibility .3s;
}
.mdm-modal.is-open{opacity:1;visibility:visible}
.mdm-modal__backdrop{
  position:absolute;inset:0;
  background:rgba(7,11,24,.85);backdrop-filter:blur(8px);
  cursor:pointer;
}
.mdm-modal__panel{
  position:relative;z-index:1;
  background:#fff;color:#0f172a;
  max-width:880px;width:calc(100% - 32px);
  max-height:90vh;overflow-y:auto;
  border-radius:20px;
  padding:32px 36px;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
  animation:modalSlideUp .35s cubic-bezier(.2,.9,.3,1);
}
@keyframes modalSlideUp{
  from{transform:translateY(30px);opacity:0}
  to{transform:translateY(0);opacity:1}
}
.mdm-modal__close{
  position:absolute;top:14px;right:14px;
  width:36px;height:36px;border-radius:50%;
  border:0;background:#f1f5f9;color:#475569;
  font-size:24px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:.2s;
}
.mdm-modal__close:hover{background:#e2e8f0;color:#0f172a}
.mdm-modal__head{margin-bottom:20px;text-align:center}
.mdm-modal__badge{
  display:inline-block;
  background:linear-gradient(135deg,#fef3c7,#fff);
  color:#92400e;
  font-size:11px;font-weight:700;
  padding:5px 12px;border-radius:99px;
  border:1px solid #fcd34d;
  letter-spacing:.4px;text-transform:uppercase;
  margin-bottom:10px;
}
.mdm-modal__head h2{
  margin:0 0 8px;
  font-family:'Space Grotesk',sans-serif;
  font-size:26px;letter-spacing:-.5px;color:#0f172a;
}
.mdm-modal__head p{margin:0;color:#475569;font-size:14px;line-height:1.6;max-width:720px;margin:0 auto}
.mdm-modal__schema{
  background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;
  padding:14px;margin:20px 0;
}
.mdm-modal__schema svg{width:100%;height:auto;display:block}
.mdm-modal__highlights{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px;
  margin-bottom:24px;
}
.mdm-modal__pill{
  background:linear-gradient(135deg,#dbeafe,#f0f9ff);
  color:#1e40af;font-size:13px;font-weight:600;
  padding:10px 14px;border-radius:10px;
  border:1px solid #bfdbfe;text-align:center;
}
.mdm-modal__cta-row{
  display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;
  border-top:1px solid #e2e8f0;padding-top:18px;
}
@media (max-width:680px){
  .mdm-modal__panel{padding:24px 18px;border-radius:14px;max-height:95vh}
  .mdm-modal__head h2{font-size:20px}
  .mdm-modal__cta-row{flex-direction:column-reverse}
  .mdm-modal__cta-row .btn{width:100%;justify-content:center}
}

/* Badge cliquable maintenant */
.quiz-option__badge[data-info]{cursor:pointer;transition:.2s}
.quiz-option__badge[data-info]:hover{
  background:linear-gradient(135deg,#fef3c7,#fde68a);
  border-color:#f59e0b;
  transform:scale(1.05);
}

/* Audit financier — grille à 2 colonnes */
.quiz-audit-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px;
}
.quiz-audit-grid__col{
  background:rgba(255,255,255,.6);
  border:1px solid #cbd5e1;
  border-radius:10px;
  padding:12px 14px;
}
.quiz-audit-grid__col strong{
  display:block;font-size:13px;color:#1e40af;margin-bottom:6px;
  font-family:'Space Grotesk',sans-serif;
}
.quiz-audit-grid__col ul{
  margin:0;padding-left:18px;list-style:disc;
  font-size:12.5px;color:#475569;line-height:1.6;
}
@media (max-width:680px){
  .quiz-audit-grid{grid-template-columns:1fr}
}

/* =====================================================
   HERO H1 SEO — discret mais sémantiquement principal
   ===================================================== */
.hero .hero-h1-seo,
h1.hero-h1-seo{
  font-family:Inter,sans-serif !important;
  font-size:13px !important;
  font-weight:600 !important;
  color:rgba(255,255,255,.55) !important;
  text-transform:uppercase !important;
  letter-spacing:1.8px !important;
  line-height:1.3 !important;
  margin:0 0 14px !important;
  padding-bottom:14px !important;
  border-bottom:1px solid rgba(255,255,255,.08) !important;
  max-width:560px;
}

/* Rotator transformé en p — reprend la taille géante hero */
.hero .hero-display,
p.hero-display{
  font-size:clamp(40px,6.2vw,86px);
  line-height:1;
  letter-spacing:-2.5px;
  margin-bottom:28px;
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  color:#fff;
}
@media (max-width:680px){
  .hero-h1-seo{font-size:11px;letter-spacing:1.4px;margin-bottom:10px;padding-bottom:10px}
}

/* =====================================================
   APPLE GALLERY — Bento immersive (produits + réparation)
   ===================================================== */
.apple-gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:240px;
  gap:18px;margin-top:60px;
}
.apple-gallery--products{
  /* 5 items : 1 large + 3 normaux + 1 wide */
  grid-template-areas:
    "lg lg b"
    "lg lg c"
    "wide wide d";
}
.apple-gallery--products .apple-gallery__item:nth-child(1){grid-area:lg}
.apple-gallery--products .apple-gallery__item:nth-child(2){grid-area:b}
.apple-gallery--products .apple-gallery__item:nth-child(3){grid-area:c}
.apple-gallery--products .apple-gallery__item:nth-child(4){grid-area:d}
.apple-gallery--products .apple-gallery__item:nth-child(5){grid-area:wide}

.apple-gallery--repair{
  /* 4 items : 1 tall + 2 normaux + 1 wide */
  grid-template-areas:
    "tall b c"
    "tall wide wide";
}
.apple-gallery--repair .apple-gallery__item:nth-child(1){grid-area:tall}
.apple-gallery--repair .apple-gallery__item:nth-child(2){grid-area:b}
.apple-gallery--repair .apple-gallery__item:nth-child(3){grid-area:c}
.apple-gallery--repair .apple-gallery__item:nth-child(4){grid-area:wide}

.apple-gallery__item{
  position:relative;
  border-radius:22px;
  overflow:hidden;
  text-decoration:none;color:#fff;
  background:#1a1a1f;
  box-shadow:0 16px 40px rgba(0,0,0,.08);
  transition:transform .5s cubic-bezier(.2,.9,.3,1),box-shadow .5s;
  isolation:isolate;
}
.apple-gallery__item img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s cubic-bezier(.2,.9,.3,1),filter .4s;
  z-index:1;
}
.apple-gallery__item::before{
  content:"";position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.05) 50%,rgba(0,0,0,.75) 100%);
  transition:background .4s;
}
.apple-gallery__item:hover{
  transform:translateY(-4px);
  box-shadow:0 30px 60px rgba(0,0,0,.18);
}
.apple-gallery__item:hover img{
  transform:scale(1.08);
  filter:brightness(1.05);
}
.apple-gallery__item:hover::before{
  background:linear-gradient(180deg,rgba(0,0,0,.1) 0%,rgba(0,0,0,.3) 50%,rgba(0,0,0,.85) 100%);
}
.apple-gallery__overlay{
  position:absolute;left:0;right:0;bottom:0;
  z-index:3;
  padding:24px 26px 22px;
  color:#fff;
  transform:translateY(8px);
  transition:transform .5s cubic-bezier(.2,.9,.3,1);
}
.apple-gallery__item:hover .apple-gallery__overlay{transform:translateY(0)}
.apple-gallery__overlay h3{
  font-family:'Space Grotesk',sans-serif;
  font-size:24px;font-weight:700;letter-spacing:-.5px;
  margin:0 0 4px;color:#fff;
  text-shadow:0 2px 12px rgba(0,0,0,.5);
}
.apple-gallery__overlay p{
  font-size:14px;color:rgba(255,255,255,.88);margin:0;
  text-shadow:0 1px 8px rgba(0,0,0,.5);
}

/* Tablette */
@media (max-width:1024px){
  .apple-gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:220px}
  .apple-gallery--products{
    grid-template-areas:
      "lg lg"
      "b c"
      "d wide";
  }
  .apple-gallery--repair{
    grid-template-areas:
      "tall b"
      "tall c"
      "wide wide";
  }
}

/* Mobile */
@media (max-width:640px){
  .apple-gallery{grid-template-columns:1fr;grid-auto-rows:200px;gap:14px}
  .apple-gallery--products,
  .apple-gallery--repair{grid-template-areas:none}
  .apple-gallery__item{grid-area:auto !important;border-radius:18px}
  .apple-gallery__overlay{padding:18px 20px 16px}
  .apple-gallery__overlay h3{font-size:20px}
}

/* =====================================================
   APPLE PINNED — Scroll horizontal au scroll vertical
   ===================================================== */
.apple-pinned{
  position:relative;
  background:#000;color:#fff;
  height:220vh; /* hauteur de la zone scrollée — détermine la durée du défilement */
}
.apple-pinned__sticky{
  position:sticky;top:0;
  height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  overflow:hidden;
}
.apple-pinned__head{
  text-align:center;padding:0 40px;margin-bottom:50px;
}
.apple-pinned__kicker{
  display:inline-block;
  padding:6px 16px;border-radius:30px;
  background:rgba(255,255,255,.08);
  font-size:12px;font-weight:600;letter-spacing:1.6px;text-transform:uppercase;
  color:rgba(255,255,255,.85);
  margin:0 0 16px;
}
.apple-pinned__title{
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(32px,4.5vw,56px);
  font-weight:700;letter-spacing:-1.5px;line-height:1.05;
  margin:0;color:#fff;
  background:linear-gradient(135deg,#fff 0%,#a8b6cf 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.apple-pinned__track{
  display:flex;gap:24px;
  padding:0 5vw;
  will-change:transform;
  /* Le translateX est piloté par JS */
}
.apple-pinned__card{
  flex:0 0 360px;
  background:linear-gradient(180deg,#1a1a1f 0%,#0f0f15 100%);
  border:1px solid rgba(255,255,255,.06);
  border-radius:24px;
  padding:30px 26px 26px;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  transition:transform .4s,border-color .4s;
}
.apple-pinned__card:hover{transform:translateY(-6px);border-color:rgba(255,95,60,.4)}
.apple-pinned__card img{
  width:auto;max-width:90%;height:220px;object-fit:contain;
  margin-bottom:20px;
  filter:drop-shadow(0 18px 30px rgba(0,0,0,.5));
}
.apple-pinned__card h3{
  font-family:'Space Grotesk',sans-serif;
  font-size:22px;font-weight:700;margin:0 0 4px;color:#fff;letter-spacing:-.4px;
}
.apple-pinned__card p{
  font-size:13px;color:rgba(255,255,255,.6);margin:0;letter-spacing:.2px;
}

/* Barre de progression */
.apple-pinned__progress{
  position:absolute;bottom:50px;left:50%;transform:translateX(-50%);
  width:200px;height:3px;border-radius:2px;
  background:rgba(255,255,255,.12);overflow:hidden;
}
.apple-pinned__progress span{
  display:block;height:100%;width:0%;
  background:linear-gradient(90deg,#ff5f3c,#5b8def);
  border-radius:2px;
  transition:width .1s linear;
}

/* Mobile : scroll horizontal natif au lieu de pinned (évite jacky behaviors) */
@media (max-width:880px){
  .apple-pinned{height:auto}
  .apple-pinned__sticky{position:static;height:auto;padding:80px 0;display:block}
  .apple-pinned__head{margin-bottom:30px}
  .apple-pinned__track{
    overflow-x:auto;scroll-snap-type:x mandatory;
    padding:10px 5vw 30px;
    scrollbar-width:none;
  }
  .apple-pinned__track::-webkit-scrollbar{display:none}
  .apple-pinned__card{flex:0 0 280px;scroll-snap-align:center}
  .apple-pinned__card img{height:160px}
  .apple-pinned__progress{display:none}
}

/* Croix mobile : position fixed en haut à droite quand menu ouvert */
@media (max-width:880px){
  body.menu-open .burger{
    position:fixed !important;
    top:18px !important;
    right:18px !important;
    width:48px !important;
    height:48px !important;
    z-index:10000 !important;
    background:rgba(7,11,24,.6) !important;
    backdrop-filter:blur(8px);
    border-radius:50% !important;
    box-shadow:0 4px 16px rgba(0,0,0,.5);
  }
  body.menu-open .burger span{
    left:12px;right:12px;
  }
}


/* =====================================================
   SOCIALS — Icones modernes (footer + contact)
   ===================================================== */
.socials{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.socials a{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.08);
  color:#fff;
  border:1px solid rgba(255,255,255,.12);
  transition:all .25s cubic-bezier(.2,.9,.3,1);
  text-decoration:none;
}
.socials a:hover{
  background:linear-gradient(135deg,#5b8def,#ff5f3c);
  border-color:transparent;
  transform:translateY(-2px) scale(1.08);
  box-shadow:0 8px 18px rgba(91,141,239,.35);
  color:#fff;
}
.socials a svg{display:block}

/* Variante claire (page contact, fond clair) */
.socials--light a{
  background:#f1f5f9;color:#0f172a;border-color:#e2e8f0;
}
.socials--light a:hover{
  background:linear-gradient(135deg,#5b8def,#ff5f3c);
  color:#fff;border-color:transparent;
}
.socials--lg a{width:48px;height:48px}
.socials--lg a svg{width:22px;height:22px}

/* =====================================================
   FIX MOBILE — Reveal toujours visible + sticky garanti
   ===================================================== */
@media (max-width:880px){
  html.js .reveal{opacity:1 !important;transform:none !important}
}
/* Header sticky robuste */
header{position:sticky;top:0;z-index:90;-webkit-position:sticky}
@supports (-webkit-touch-callout: none){
  /* iOS Safari : assurer sticky avec will-change */
  header{will-change:transform}
}


/* =====================================================
   FIX MOBILE — Sticky robuste + counters forcés
   ===================================================== */
html,body{overflow-x:clip}
@media (max-width:880px){
  /* Sticky garanti partout */
  header{
    position:-webkit-sticky !important;
    position:sticky !important;
    top:0 !important;
    z-index:100 !important;
    background:#070b18 !important;
  }
  /* Counter : si pas animé via JS, on affiche directement la valeur cible */
  [data-counter]{opacity:1 !important}
}

/* =====================================================
   MENU DROPDOWN — Support (standalone, pas mega)
   ===================================================== */
.menu-item--has-dropdown{position:relative}
.menu-item--has-dropdown > .menu-link{
  display:inline-flex;align-items:center;gap:4px;
  padding:9px 14px;border-radius:10px;font-size:14px;font-weight:500;color:#fff;
  text-decoration:none;cursor:pointer;
}
.menu-item--has-dropdown > .menu-link:hover{background:rgba(255,255,255,.08)}
.menu-dropdown{
  position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-6px);
  min-width:280px;background:rgba(7,11,24,.96);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.08);border-radius:14px;
  padding:8px;
  box-shadow:0 20px 50px rgba(0,0,0,.5);
  opacity:0;pointer-events:none;
  transition:opacity .25s,transform .25s;
  z-index:100;
}
@media (min-width:881px){
.menu-item--has-dropdown:hover .menu-dropdown,
.menu-item--has-dropdown:focus-within .menu-dropdown{
  opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);
}
}
.menu-dropdown__link{
  display:block;padding:10px 14px;border-radius:8px;
  color:rgba(255,255,255,.85);font-size:13.5px;font-weight:500;
  text-decoration:none;transition:.15s;
}
.menu-dropdown__link:hover{background:rgba(255,255,255,.08);color:#fff}
.menu-item--has-dropdown:hover .menu-caret{transform:rotate(180deg)}
/* Pont invisible entre link et dropdown pour eviter fermeture */
.menu-item--has-dropdown::after{
  content:"";position:absolute;left:0;right:0;top:100%;height:12px;
}

/* Mobile : dropdown accordeon */
@media (max-width:880px){
  .menu-item--has-dropdown{width:100%}
  .menu-item--has-dropdown > .menu-link{
    width:100%;padding:16px 0 !important;
    background:transparent !important;border-bottom:1px solid rgba(255,255,255,.08) !important;
    border-radius:0 !important;font-size:17px !important;
    justify-content:space-between !important;
  }
  .menu-dropdown{
    position:static !important;
    transform:none !important;
    left:auto !important;top:auto !important;
    min-width:0;width:100%;
    background:transparent;border:0;box-shadow:none;backdrop-filter:none;
    padding:0;margin:0;
    max-height:0;overflow:hidden;opacity:1;pointer-events:auto;
    transition:max-height .35s ease;
  }
  .menu-item--has-dropdown.is-open .menu-dropdown{max-height:500px;padding:6px 0 10px 16px}
  .menu-item--has-dropdown.is-open .menu-caret{transform:rotate(180deg)}
  .menu-dropdown__link{padding:12px 0;border-bottom:1px solid rgba(255,255,255,.04)}
}

/* Dropdown ouvert par clic (desktop + tablette) */
@media (min-width:881px){
  .menu-item--has-dropdown.is-open .menu-dropdown{
    opacity:1 !important;
    pointer-events:auto !important;
    transform:translateX(-50%) translateY(0) !important;
  }
  .menu-item--has-dropdown.is-open .menu-caret{transform:rotate(180deg)}
}

/* Contact block en mode lien cliquable */
.contact-block--link{display:flex;gap:14px;align-items:flex-start;text-decoration:none;color:inherit;transition:transform .2s ease,background .2s ease;cursor:pointer;border-radius:14px;padding:14px;margin:-14px}
.contact-block--link:hover{transform:translateX(4px);background:rgba(249,115,22,.08)}
.contact-block--link:hover strong{color:#f97316}

/* Bulletproof : tous les boutons accent (incl. liens dans contenus CMS) */
a.btn-accent,
.btn-accent,
.btn-accent:link,
.btn-accent:visited,
.btn-accent:hover,
.btn-accent:active{
  color:#fff !important;
  text-decoration:none !important;
}
a.btn-accent *,
.btn-accent *{color:#fff !important;text-decoration:none !important}

/* Fix bug : l attribut HTML hidden était écrasé par display:flex */
.quiz-lead-form__success[hidden],
.quiz-lead-form__error[hidden],
[data-lead-success][hidden],
[data-lead-error][hidden]{display:none !important}

/* =====================================================
   FAQ : FIX BULLETPROOF — couleurs forcées + espacement uniforme
   ===================================================== */

/* Espacement uniforme entre les items, partout sur le site */
.faq{display:flex !important;flex-direction:column !important;gap:12px !important;margin:24px 0 !important;max-width:860px}
.faq + .faq{margin-top:12px !important}

/* Tout le texte intérieur des FAQ est CLAIR sur fond sombre, !important pour battre Divi/Prose */
.faq .faq-item,
.faq .faq-q,
.faq .faq-a,
.faq .faq-a-inner,
.faq .faq-a-inner p,
.faq .faq-a-inner li,
.faq .faq-a-inner ul,
.faq .faq-a-inner ol,
.faq .faq-a-inner span,
.faq .faq-a-inner em{color:rgba(255,255,255,.85) !important}

/* Le titre de la question reste blanc pur */
.faq .faq-q{color:#fff !important}

/* Les <strong> dans les FAQ sombres : BLANC pur (pas noir hérité de .prose strong) */
.faq .faq-a-inner strong,
.faq .faq-a-inner b{color:#fff !important;font-weight:700}

/* Les <h3>/<h4> dans le contenu FAQ : blanc */
.faq .faq-a-inner h2,
.faq .faq-a-inner h3,
.faq .faq-a-inner h4,
.faq .faq-a-inner h5{color:#fff !important}

/* Les liens dans les FAQ : couleur accent orange (lisible sur fond sombre) */
.faq .faq-a-inner a{color:#ffb547 !important;text-decoration:underline !important;text-underline-offset:3px}
.faq .faq-a-inner a:hover{color:#fff !important}

/* Nettoyer les <hr> hérités de WordPress dans les FAQ legacy */
.faq .faq-a-inner hr{border:0 !important;border-top:1px solid rgba(255,255,255,.1) !important;margin:18px 0 !important}

/* Les <h3>/<h4> qui apparaissent dans .prose hors FAQ avec fond sombre legacy (cas Divi) */
.prose .et-l h3,
.prose .et-l h4{color:var(--ink) !important}

/* =====================================================
   FAQ : FIX BULLETPROOF V2 - sélecteurs ultra-larges
   ===================================================== */
.faq .faq-item strong,
.faq .faq-item b,
.faq strong,
.faq b,
.prose .faq strong,
.prose .faq .faq-item strong,
.prose .faq-item strong,
.et-l .faq strong,
.et-l .faq-item strong{
  color:#fff !important;
  -webkit-text-fill-color:#fff !important;
  font-weight:700 !important;
}

.faq .faq-item p,
.faq .faq-item li,
.faq .faq-item span,
.faq p,
.faq li,
.prose .faq p,
.prose .faq li,
.et-l .faq p,
.et-l .faq li{
  color:rgba(255,255,255,.85) !important;
  -webkit-text-fill-color:rgba(255,255,255,.85) !important;
}

.faq .faq-item a,
.prose .faq a,
.et-l .faq a{
  color:#ffb547 !important;
  -webkit-text-fill-color:#ffb547 !important;
}
.faq .faq-item a strong,
.prose .faq a strong{
  color:#ffb547 !important;
  -webkit-text-fill-color:#ffb547 !important;
}

/* =====================================================
   REFONTE PAGES SERVICES — blocs cards + grilles
   ===================================================== */
@media (max-width:880px){
  .svc-grid{grid-template-columns:1fr !important}
  .svc-grid > .svc-card{grid-column:span 1 !important}
  .avantages-grid{grid-template-columns:1fr !important}
}
.svc-card:hover{transform:translateY(-4px);transition:transform .3s ease}
.svc-card{transition:transform .3s ease}

/* =====================================================
   .btn-accent : TOUJOURS blanc, partout (même dans FAQ/prose)
   ===================================================== */
.faq .faq-a-inner a.btn-accent,
.faq .faq-item a.btn-accent,
.prose .faq a.btn-accent,
.prose a.btn-accent,
.faq a.btn-accent,
a.btn-accent,
a.btn.btn-accent{
  color:#fff !important;
  -webkit-text-fill-color:#fff !important;
  text-decoration:none !important;
  background:linear-gradient(135deg,#ff5f3c,#ff8050) !important;
}
.faq a.btn-accent:hover,
a.btn-accent:hover{
  color:#fff !important;
  -webkit-text-fill-color:#fff !important;
}

/* =====================================================
   PROSE LONGS PAVÉS : 2 colonnes sur desktop
   Wrapper class : .prose-cols
   ===================================================== */
.prose-cols{
  column-count:2;
  column-gap:42px;
  column-rule:1px solid rgba(91,141,239,.12);
  margin:24px 0;
}
.prose-cols p{
  break-inside:avoid;
  margin:0 0 14px;
}
.prose-cols p:last-child{margin-bottom:0}
@media (max-width:880px){
  .prose-cols{column-count:1;column-gap:0;column-rule:0}
}

/* Auto-wrap les blocs de 3+ <p> consécutifs dans .prose */
.prose .long-text-block{
  column-count:2;
  column-gap:42px;
  margin:24px 0;
}
.prose .long-text-block p{break-inside:avoid;margin:0 0 14px}
@media (max-width:880px){
  .prose .long-text-block{column-count:1}
}

/* =====================================================
   PROSE PREMIUM : style page services modernes
   ===================================================== */
.prose-hero-img{
  max-width:none !important;
  width:calc(100% + 40px) !important;
  margin-left:-20px !important;
  margin-right:-20px !important;
  margin-bottom:60px !important;
  border-radius:24px !important;
  box-shadow:0 40px 80px rgba(7,11,24,.4) !important;
  overflow:hidden !important;
}
.prose-hero-img img{
  max-height:520px !important;
  object-fit:cover !important;
  display:block !important;
  width:100% !important;
}
@media (max-width:880px){
  .prose-hero-img{
    width:100% !important;
    margin-left:0 !important;
    margin-right:0 !important;
    margin-bottom:30px !important;
  }
  .prose-hero-img img{max-height:280px !important}
}

/* Espacement entre sections de prose */
.prose h2{
  margin-top:64px !important;
  font-size:34px !important;
  letter-spacing:-.5px !important;
  position:relative !important;
  padding-top:24px !important;
}
.prose h2::before{
  content:"" !important;
  position:absolute !important;
  top:0 !important;
  left:0 !important;
  width:60px !important;
  height:4px !important;
  background:linear-gradient(90deg,#ff5f3c,#ffb547) !important;
  border-radius:2px !important;
}
.prose h2:first-child,
.prose .prose-hero-img + h2{margin-top:16px !important}
.prose h3{font-size:22px !important;margin-top:32px !important}
.prose h4{font-size:18px !important;margin-top:24px !important;color:#5b8def !important;text-transform:uppercase !important;letter-spacing:1px !important;font-size:13px !important;font-weight:700 !important}

/* Long pavés de paragraphes sur 2 colonnes desktop (3+ <p> consécutifs) */
@media (min-width:881px){
  .prose p + p + p{column-span:none}
}

/* CTA inline sortie de la prose */
.prose .inline-cta{
  max-width:none !important;
  width:calc(100% + 40px) !important;
  margin-left:-20px !important;
  margin-right:-20px !important;
  margin-top:60px !important;
}
@media (max-width:880px){
  .prose .inline-cta{
    width:100% !important;
    margin-left:0 !important;
    margin-right:0 !important;
  }
}

/* =====================================================
   SLOGAN MANIFESTO — text reveal au scroll
   ===================================================== */
.slogan-reveal{
  position:relative;
  background:linear-gradient(180deg,#070b18 0%,#0a1228 50%,#070b18 100%);
  color:#fff;
  padding:160px 0 180px;
  overflow:hidden;
}
.slogan-reveal::before{
  content:"";
  position:absolute;
  top:50%;left:50%;
  width:1100px;height:1100px;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(91,141,239,.13),transparent 60%);
  pointer-events:none;
  z-index:0;
}
.slogan-reveal::after{
  content:"";
  position:absolute;
  bottom:-180px;right:-180px;
  width:520px;height:520px;
  background:radial-gradient(circle,rgba(255,95,60,.18),transparent 65%);
  pointer-events:none;
  z-index:0;
}
.slogan-reveal .wrap{position:relative;z-index:1;text-align:center}

.slogan-reveal__eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Space Grotesk",sans-serif;
  font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  color:#5b8def;
  margin-bottom:48px;
  padding:8px 18px;
  border:1px solid rgba(91,141,239,.3);
  border-radius:50px;
  background:rgba(91,141,239,.08);
}
.slogan-reveal__eyebrow span{
  width:8px;height:8px;border-radius:50%;
  background:#5b8def;
  box-shadow:0 0 0 4px rgba(91,141,239,.2);
  animation:pulseBlue 2s ease infinite;
}
@keyframes pulseBlue{
  0%,100%{box-shadow:0 0 0 4px rgba(91,141,239,.2)}
  50%{box-shadow:0 0 0 8px rgba(91,141,239,.05)}
}

.slogan-reveal__title{
  font-family:"Space Grotesk",sans-serif;
  font-size:clamp(38px,7vw,96px);
  font-weight:700;
  line-height:1.05;
  letter-spacing:-2px;
  margin:0 auto;
  max-width:1100px;
  color:rgba(255,255,255,.13);
  transition:none;
}
.slogan-line{
  display:block;
  margin-bottom:10px;
}
.slogan-line:last-child{
  background:linear-gradient(120deg,#5b8def 0%,#22d3ee 30%,#ff5f3c 70%,#ffb547 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
  opacity:.13;
  animation:gradMoveSlow 8s ease infinite;
}
@keyframes gradMoveSlow{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}

.slogan-reveal__title .word{
  display:inline-block;
  color:rgba(255,255,255,.13);
  transition:color .6s cubic-bezier(.2,.8,.2,1);
}
.slogan-reveal__title .word.is-revealed{
  color:#fff;
}
.slogan-line:last-child .word.is-revealed{
  -webkit-text-fill-color:initial;
  opacity:1;
}
.slogan-line:last-child.is-revealed-line{
  opacity:1;
}

.slogan-reveal__pills{
  display:flex;flex-wrap:wrap;justify-content:center;gap:14px;
  margin-top:60px;
}
.slogan-pill{
  padding:10px 22px;
  border-radius:50px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.78);
  font-size:14px;
  font-weight:500;
  font-family:"Inter",sans-serif;
  backdrop-filter:blur(8px);
  transition:all .3s ease;
  opacity:0;
  transform:translateY(10px);
}
.slogan-pill.is-visible{
  opacity:1;
  transform:translateY(0);
}
.slogan-pill:hover{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.2);
  transform:translateY(-2px);
}

@media (max-width:880px){
  .slogan-reveal{padding:100px 0 110px}
  .slogan-reveal__eyebrow{margin-bottom:32px;font-size:11px}
  .slogan-reveal__title{letter-spacing:-1px}
  .slogan-reveal__pills{margin-top:40px;gap:10px}
  .slogan-pill{padding:8px 16px;font-size:13px}
}

/* =====================================================
   WHY-LIST mobile scroll horizontal (pages villes)
   ===================================================== */
.why-list-wrap{position:relative}

@media (max-width:880px){
  .why-list-wrap{
    margin-left:-20px;
    margin-right:-20px;
  }
  .why-list-wrap::after{
    content:"";
    position:absolute;
    top:0;right:0;
    width:80px;height:calc(100% - 32px);
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.95));
    pointer-events:none;
    z-index:2;
  }
  .why-list--scrollable{
    display:flex !important;
    flex-direction:row !important;
    grid-template-columns:unset !important;
    overflow-x:auto;
    overflow-y:visible;
    scroll-snap-type:x mandatory;
    scroll-padding-left:20px;
    padding:8px 60px 24px 20px;
    gap:14px !important;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    overscroll-behavior-x:contain;
  }
  .why-list--scrollable::-webkit-scrollbar{display:none}
  .why-list--scrollable .why-item{
    flex:0 0 78% !important;
    scroll-snap-align:start;
    min-width:280px;
    max-width:340px;
    margin:0 !important;
  }
  
  /* Petit indicateur "swipez" qui s anime puis disparait */
  .scroll-hint-mobile{
    text-align:center;
    margin-top:14px;
    font-size:12px;
    font-weight:600;
    letter-spacing:1px;
    color:#5b8def;
    text-transform:uppercase;
    opacity:.7;
    animation:hintSwipe 2.5s ease infinite;
  }
  .scroll-hint-mobile span{
    display:inline-block;
    padding:6px 14px;
    background:rgba(91,141,239,.08);
    border:1px solid rgba(91,141,239,.2);
    border-radius:50px;
  }
  @keyframes hintSwipe{
    0%,100%{transform:translateX(0)}
    50%{transform:translateX(8px)}
  }
}

@media (min-width:881px){
  /* Desktop : grille classique 3 colonnes */
  .why-list--scrollable{
    display:grid !important;
    flex-direction:initial !important;
    grid-template-columns:repeat(3,1fr) !important;
    gap:24px;
  }
  .scroll-hint-mobile{display:none}
}

/* =====================================================
   STACK TECHNIQUE — Slide-over cards (Ninja/Zyxel/TP-Link)
   ===================================================== */
.stack-section{
  position:relative;
  background:linear-gradient(180deg,#070b18 0%,#0a1228 40%,#0e1936 100%);
  color:#fff;
  padding:130px 0 220px;
  margin-bottom:80px;
  overflow:hidden;
}
.stack-section::before{
  content:"";
  position:absolute;top:20%;left:-10%;
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(91,141,239,.15),transparent 65%);
  pointer-events:none;z-index:0;
}
.stack-section::after{
  content:"";
  position:absolute;bottom:-100px;right:-10%;
  width:560px;height:560px;
  background:radial-gradient(circle,rgba(255,95,60,.12),transparent 65%);
  pointer-events:none;z-index:0;
}
.stack-section .wrap{position:relative;z-index:1}

.stack-section__head{text-align:center;max-width:760px;margin:0 auto 60px}

.stack-section__eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Space Grotesk",sans-serif;
  font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  color:#5b8def;
  margin-bottom:28px;
  padding:8px 18px;
  border:1px solid rgba(91,141,239,.3);
  border-radius:50px;
  background:rgba(91,141,239,.08);
}
.stack-section__eyebrow span{
  width:8px;height:8px;border-radius:50%;
  background:#5b8def;
  box-shadow:0 0 0 4px rgba(91,141,239,.2);
  animation:pulseBlue 2s ease infinite;
}

.stack-section__title{
  font-family:"Space Grotesk",sans-serif;
  font-size:clamp(32px,5vw,52px);
  font-weight:700;line-height:1.1;letter-spacing:-1px;
  margin:0 0 20px;color:#fff;
}
.stack-section__title .grad{
  background:linear-gradient(120deg,#5b8def,#22d3ee 40%,#ff5f3c);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.stack-section__lead{
  font-size:17px;line-height:1.6;color:rgba(255,255,255,.7);margin:0;
}

/* Scroller container */
.stack-scroller-wrap{position:relative}
.stack-scroller{
  display:flex;gap:24px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-padding-left:40px;
  padding:20px 80px 40px 40px;
  margin:0 -40px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  overscroll-behavior-x:contain;
  scroll-behavior:smooth;
}
.stack-scroller::-webkit-scrollbar{display:none}

/* Gradient mask droite */
.stack-scroller-wrap::after{
  content:"";
  position:absolute;
  top:0;right:0;
  width:120px;height:calc(100% - 60px);
  background:linear-gradient(90deg,transparent,#0a1228 80%);
  pointer-events:none;z-index:3;
}

/* Cards */
.stack-card{
  position:relative;
  flex:0 0 460px;
  min-height:560px;
  scroll-snap-align:start;
  border-radius:24px;
  overflow:hidden;
  padding:36px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(20px);
  transition:transform .4s cubic-bezier(.2,.8,.2,1), border-color .3s;
  display:flex;flex-direction:column;
  cursor:default;
}
.stack-card:hover{
  transform:translateY(-6px);
  border-color:rgba(91,141,239,.4);
}
.stack-card__bg{
  position:absolute;top:0;left:0;right:0;bottom:0;
  z-index:0;
  opacity:.4;
  transition:opacity .4s;
  pointer-events:none;
}
.stack-card:hover .stack-card__bg{opacity:.6}
.stack-card--ninja .stack-card__bg{
  background:radial-gradient(ellipse at top right,rgba(74,222,128,.25),transparent 60%);
}
.stack-card--zyxel .stack-card__bg{
  background:radial-gradient(ellipse at top right,rgba(244,114,182,.2),transparent 60%);
}
.stack-card--tplink .stack-card__bg{
  background:radial-gradient(ellipse at top right,rgba(34,211,238,.22),transparent 60%);
}

.stack-card__logo{
  position:relative;z-index:1;
  height:48px;margin-bottom:30px;
  display:flex;align-items:center;
}
.stack-card__logo img{
  height:100%;width:auto;max-width:200px;
  filter:brightness(1.1);
}

.stack-card__body{position:relative;z-index:1;flex:1;display:flex;flex-direction:column}

.stack-card__pill{
  display:inline-flex;
  align-self:flex-start;
  padding:6px 14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:50px;
  font-size:12.5px;font-weight:600;
  color:rgba(255,255,255,.85);
  margin-bottom:18px;
  letter-spacing:.3px;
}

.stack-card h3{
  font-family:"Space Grotesk",sans-serif;
  font-size:32px;font-weight:700;letter-spacing:-.5px;
  margin:0 0 14px;color:#fff;
}

.stack-card p{
  font-size:14.5px;line-height:1.6;
  color:rgba(255,255,255,.75);
  margin:0 0 22px;
}

.stack-card__points{
  list-style:none;padding:0;margin:0 0 26px;
  display:grid;gap:10px;
}
.stack-card__points li{
  position:relative;
  padding-left:24px;
  font-size:14px;line-height:1.5;
  color:rgba(255,255,255,.85);
}
.stack-card__points li::before{
  content:"";
  position:absolute;left:0;top:6px;
  width:14px;height:14px;border-radius:50%;
  background:linear-gradient(135deg,#5b8def,#22d3ee);
  box-shadow:0 0 12px rgba(91,141,239,.4);
}
.stack-card--ninja .stack-card__points li::before{background:linear-gradient(135deg,#4ade80,#22d3ee)}
.stack-card--zyxel .stack-card__points li::before{background:linear-gradient(135deg,#f472b6,#a78bfa)}
.stack-card--tplink .stack-card__points li::before{background:linear-gradient(135deg,#22d3ee,#5b8def)}

.stack-card__cta{
  margin-top:auto;
  align-self:flex-start;
  padding:12px 22px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.15);
  border-radius:50px;
  color:#fff;text-decoration:none;
  font-size:14px;font-weight:600;
  transition:all .3s;
}
.stack-card__cta:hover{
  background:rgba(91,141,239,.18);
  border-color:rgba(91,141,239,.4);
  transform:translateX(4px);
}

/* Indicateur swipe + barre de progression */
.stack-scroller__hint{
  text-align:center;
  margin-top:24px;
  font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  color:rgba(91,141,239,.85);
}
.stack-scroller__hint span{
  display:inline-block;
  padding:8px 18px;
  background:rgba(91,141,239,.08);
  border:1px solid rgba(91,141,239,.25);
  border-radius:50px;
  animation:hintSwipe 2.5s ease infinite;
}
.stack-scroller__progress{
  margin:18px auto 0;
  max-width:260px;height:3px;
  background:rgba(255,255,255,.06);
  border-radius:50px;overflow:hidden;
}
.stack-scroller__progress span{
  display:block;height:100%;
  width:33%;
  background:linear-gradient(90deg,#5b8def,#22d3ee,#ff5f3c);
  border-radius:50px;
  transition:width .3s ease;
}

@media (max-width:880px){
  .stack-section{padding:80px 0 100px}
  .stack-section__head{margin-bottom:36px}
  .stack-scroller{
    padding:14px 60px 30px 20px;
    margin:0 -20px;
    gap:14px;
  }
  .stack-card{
    flex:0 0 82vw;
    min-height:520px;
    padding:28px;
  }
  .stack-card h3{font-size:26px}
  .stack-section__title{font-size:30px}
  .stack-scroller-wrap::after{width:60px}
}

/* Flèches navigation desktop */
.stack-nav{
  position:absolute;
  top:50%;transform:translateY(-50%);
  width:52px;height:52px;
  display:none;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.18);
  border-radius:50%;
  color:#fff;cursor:pointer;
  z-index:5;
  transition:all .3s ease;
}
.stack-nav:hover{
  background:rgba(91,141,239,.3);
  border-color:rgba(91,141,239,.5);
  transform:translateY(-50%) scale(1.08);
}
.stack-nav:disabled{
  opacity:.25;
  cursor:not-allowed;
}
.stack-nav:disabled:hover{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.18);
  transform:translateY(-50%);
}
.stack-nav--prev{left:-12px}
.stack-nav--next{right:-12px}

@media (min-width:881px){
  .stack-nav{display:inline-flex}
}

/* Synology accent */
.stack-card--synology .stack-card__bg{
  background:radial-gradient(ellipse at top right,rgba(255,95,60,.22),transparent 60%);
}
.stack-card--synology .stack-card__points li::before{
  background:linear-gradient(135deg,#ff5f3c,#ffb547);
}

/* =====================================================
   FIX MENU MOBILE iOS 26 — dvh + safe area + scroll fix
   ===================================================== */
@media (max-width:880px){
  /* Utiliser dvh (dynamic viewport height) pour s adapter à la barre URL iOS */
  .menu{
    height:100dvh !important;
    max-height:100dvh !important;
    bottom:auto !important;
    /* Safe area iOS pour le notch */
    padding-top:max(80px, calc(env(safe-area-inset-top, 0px) + 70px)) !important;
    padding-bottom:max(40px, env(safe-area-inset-bottom, 40px)) !important;
    /* Désactiver le scroll bounce iOS */
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
    /* Force le panel à occuper toute la hauteur */
    display:flex !important;
  }
  
  /* Le backdrop doit aussi utiliser dvh */
  body.menu-open::before{
    height:100dvh !important;
  }
  
  /* Scroll lock plus robuste pour iOS 26 */
  body.menu-open{
    position:fixed;
    width:100%;
    overflow:hidden !important;
    /* Empêche le scroll bounce sur le body */
    overscroll-behavior:none;
  }
  
  /* S assurer que les items menu sont bien empilés sans gap */
  .menu > *{
    flex-shrink:0;
    width:100%;
  }
  
  /* Forcer le rendu correct des items sur iOS 26 */
  .menu .menu-item--has-mega,
  .menu > a,
  .menu .menu-link{
    transform:translateZ(0); /* Force GPU layer pour éviter bugs Safari */
  }
}

/* iOS spécifique : -webkit-fill-available pour vieilles versions, dvh pour 26+ */
@supports (height: 100dvh) {
  @media (max-width:880px){
    .menu{height:100dvh !important}
  }
}
@supports not (height: 100dvh) {
  @media (max-width:880px){
    .menu{height:-webkit-fill-available !important}
  }
}
