/* ═══════════════════════════════════════════════════════════════
   SAO Studio — Saad Ait Ouali
   MASTER CSS — Toutes les pages  v1.7.0
   Coller dans : Apparence → Personnaliser → CSS additionnel
   OU via functions.php (recommandé — déjà en place)
   ──────────────────────────────────────────────────────────────
   POLICES REQUISES (Google Fonts) :
     Manrope        : 300 400 500 600 700
     Fira Code      : 400 500
   ──────────────────────────────────────────────────────────────
   CORRECTIFS v1.7 :
   • --fd corrigé (était une valeur hex, pas un nom de police)
   • Commentaire CSS non-fermé supprimé (ligne ~552)
   • 7 blocs @media fusionnés en 3 blocs propres
   • Typo CSS : margin-top:-40 px → -40px
   • Lien actif seo-nav corrigé
   • Accessibilité : focus-visible + prefers-reduced-motion
   • SEO : aria-label, rôles ARIA, sémantique nav/main/footer
   • Performance : will-change sur éléments animés
═══════════════════════════════════════════════════════════════ */

/* ─── RESET & VARIABLES ─── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  /* Couleurs de fond */
  --void:#06080F;
  --deep:#0B0E1A;
  --panel:#0F1220;
  --border:rgba(255,255,255,0.06);

  /* Accent — NB : les variables sont nommées par usage visuel dans ce thème  */
  --coral:#00E5FF;    /* bleu cyan — utilisé sur titres, CTA, icônes              */
  --cyan:#FF3D6B;     /* rose vif  — utilisé sur tags, eyebrows, liens secondaires */
  --violet:#7B61FF;

  /* Texte */
  --white:#EEF0F8;
  --muted:#f2fdef;

  /* Polices — CORRIGÉ : --fd était '#EEF0F8' (code couleur, pas une police !) */
  --fd:'Manrope',sans-serif;   /* Display / Headings */
  --fm:'Fira Code',monospace;  /* Mono / Labels */
  --fb:'Manrope',sans-serif;   /* Body */

  /* Espacement & layout */
  --pad-h:56px;
  --pad-v:100px;
}

html{scroll-behavior:smooth}
body{
  background:var(--void);
  color:var(--white);
  font-family:var(--fb);
  overflow-x:hidden;
  cursor:none
}
body::before{
  content:'';
  position:fixed;inset:0;
  background:repeating-linear-gradient(
    0deg,transparent,transparent 2px,
    rgba(255,61,107,0.012) 2px,rgba(255,61,107,0.012) 4px
  );
  pointer-events:none;z-index:9997
}

/* ─── ACCESSIBILITÉ — Focus visible (SEO + UX) ─── */
:focus{outline:none}
:focus-visible{
  outline:2px solid var(--coral);
  outline-offset:3px;
  border-radius:2px
}
/* Skip-to-content pour lecteurs d'écran */
.skip-link{
  position:absolute;top:-100%;left:16px;z-index:99999;
  background:var(--coral);color:var(--void);
  font-family:var(--fm);font-size:11px;letter-spacing:.15em;text-transform:uppercase;
  padding:10px 20px;text-decoration:none;
  transition:top .3s
}
.skip-link:focus-visible{top:8px}

/* ─── ANIMATIONS — Respect de prefers-reduced-motion ─── */
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important
  }
  html{scroll-behavior:auto}
}

/* ─── CURSEUR CUSTOM ─── */
#cur{
  position:fixed;width:8px;height:8px;
  background:var(--coral);border-radius:50%;
  pointer-events:none;z-index:10001;
  transform:translate(-50%,-50%);
  box-shadow:0 0 12px var(--coral),0 0 24px rgba(0,229,255,0.4);
  transition:width .2s,height .2s;
  will-change:transform
}
#cur.big{width:4px;height:4px;background:var(--cyan);box-shadow:0 0 12px var(--cyan)}
#cring{
  position:fixed;width:36px;height:36px;
  border:1px solid rgba(0,229,255,0.4);border-radius:50%;
  pointer-events:none;z-index:10000;
  transform:translate(-50%,-50%);
  transition:border-color .3s,width .35s,height .35s;
  will-change:transform
}
#cring.big{width:56px;height:56px;border-color:rgba(255,61,107,0.5)}

/* ─── BARRE DE PROGRESSION ─── */
#prog{
  position:fixed;top:0;left:0;height:2px;z-index:9999;
  width:0%;background:linear-gradient(90deg,var(--coral),var(--cyan));
  box-shadow:0 0 12px var(--coral);
  will-change:width
}

/* ─── NAVIGATION ─── */
#main-nav{
  position:fixed!important;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;
  padding:0 var(--pad-h);height:64px;
  background:rgba(6,8,15,0.85);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border)
}
.nav-logo{
  font-family:var(--fd);font-weight:700;font-size:18px;
  letter-spacing:.12em;text-transform:uppercase;
  text-decoration:none;color:var(--white);
  display:flex;align-items:center;gap:10px;
  flex-shrink:0;z-index:2
}
.nl-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--coral);box-shadow:0 0 10px var(--coral);
  animation:pulse 2s ease-in-out infinite;flex-shrink:0
}
.nav-links{display:flex;gap:0;list-style:none;margin-left:auto}
.nav-links a{
  font-family:var(--fm);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;
  padding:0 22px;height:64px;
  display:flex;align-items:center;
  border-left:1px solid var(--border);
  position:relative;transition:color .25s
}
.nav-links a::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--coral);transform:scaleX(0);transition:transform .35s
}
.nav-links a:hover,
.nav-links a.active{color:var(--white)}
.nav-links a.active::after,
.nav-links a:hover::after{transform:scaleX(1)}

.nav-cta{
  margin-left:24px;
  font-family:var(--fm);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--coral);border:1px solid rgba(0,229,255,0.4);
  padding:0 28px;height:38px;
  display:flex;align-items:center;
  text-decoration:none;position:relative;overflow:hidden;transition:color .35s
}
.nav-cta::before{
  content:'';position:absolute;inset:0;
  background:var(--coral);transform:translateX(-105%);
  transition:transform .4s cubic-bezier(.7,0,.3,1)
}
.nav-cta:hover{color:var(--void)}
.nav-cta:hover::before{transform:translateX(0)}
.nav-cta span{position:relative;z-index:1}

/* ─── DROPDOWN DESKTOP SERVICES ─── */
.nav-has-dropdown{position:relative}
ul.nav-dropdown{
  position:absolute;top:100%;left:0;
  list-style:none;
  background:rgba(11,14,26,0.97);
  backdrop-filter:blur(20px);
  border:1px solid var(--border);
  border-top:2px solid var(--coral);
  min-width:270px;
  opacity:0;visibility:hidden;
  transform:translateY(-8px);
  transition:opacity .3s,transform .3s,visibility .3s;
  z-index:9999;padding:0;margin:0;display:block
}
.nav-has-dropdown:hover ul.nav-dropdown,
.nav-has-dropdown:focus-within ul.nav-dropdown{
  opacity:1;visibility:visible;transform:translateY(0)
}
ul.nav-dropdown>li{
  display:block;border-bottom:1px solid var(--border);padding:0;margin:0
}
ul.nav-dropdown>li:last-child{border-bottom:none}
nav ul.nav-dropdown>li>a,
ul.nav-dropdown>li>a{
  display:block!important;height:auto!important;
  padding:13px 20px!important;
  font-family:var(--fm)!important;font-size:9px!important;
  letter-spacing:.15em!important;text-transform:uppercase!important;
  color:var(--muted)!important;text-decoration:none!important;
  border-left:none!important;border-bottom:none!important;
  position:static!important;
  transition:color .2s,background .2s!important;
  white-space:nowrap
}
nav ul.nav-dropdown>li>a:hover,
ul.nav-dropdown>li>a:hover{
  color:var(--white)!important;
  background:rgba(0,229,255,.06)!important
}
nav ul.nav-dropdown>li>a::after,
ul.nav-dropdown>li>a::after{display:none!important}

/* ─── HERO — ACCUEIL ─── */
.hero{
  min-height:100vh;padding-top:64px;
  display:flex;flex-direction:column;justify-content:center;
  padding-left:var(--pad-h);padding-right:var(--pad-h);
  position:relative;overflow:hidden
}
.hero-glow-a{
  position:absolute;top:-10%;left:-10%;width:600px;height:600px;
  background:radial-gradient(ellipse,rgba(0,229,255,.07) 0%,transparent 70%);
  pointer-events:none
}
.hero-glow-b{
  position:absolute;bottom:0;right:5%;width:500px;height:500px;
  background:radial-gradient(ellipse,rgba(255,61,107,.05) 0%,transparent 70%);
  pointer-events:none
}
.hero-grid-bg{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,61,107,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,61,107,.025) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%)
}
.hero-kicker{
  font-family:var(--fm);font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--cyan);display:flex;align-items:center;gap:16px;
  margin-bottom:40px;opacity:0;transform:translateY(12px)
}
.hero-kicker::before{content:'';width:32px;height:1px;background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.hero-h1{
  font-family:var(--fd);font-weight:700;
  font-size:clamp(64px,10.5vw,168px);
  line-height:.88;letter-spacing:.01em;text-transform:uppercase;
  position:relative;z-index:2
}
.h1-row{display:block;overflow:hidden}
.h1-row>span{display:block;transform:translateY(110%);will-change:transform}
.h1-coral{color:var(--coral);text-shadow:0 0 40px rgba(0,229,255,.35)}
.h1-outline{-webkit-text-stroke:1.5px rgba(238,240,248,0.25);color:transparent}
.hero-bottom{
  margin-top:64px;display:grid;grid-template-columns:1fr auto;
  align-items:end;gap:64px;opacity:0;transform:translateY(20px);
  position:relative;z-index:2
}
.hero-desc{font-size:16px;line-height:1.8;color:var(--muted);max-width:500px;font-weight:300}
.hero-desc strong{color:var(--white);font-weight:500}
.hero-btns{display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.hero-stats{
  margin-top:80px;display:flex;gap:0;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  position:relative;z-index:2;opacity:0
}
.h-stat{
  flex:1;padding:28px 0;
  border-right:1px solid var(--border);
  display:flex;align-items:baseline;gap:8px;padding-left:32px
}
.h-stat:last-child{border-right:none}
.hs-n{font-family:var(--fd);font-weight:700;font-size:44px;color:var(--coral);text-shadow:0 0 20px rgba(0,229,255,.4)}
.hs-suf{font-size:22px;color:var(--coral)}
.hs-l{font-family:var(--fm);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}

/* ─── TICKER ─── */
.ticker{overflow:hidden;background:var(--deep);border-top:1px solid var(--border)}
.ticker-in{
  display:flex;animation:tick 22s linear infinite;white-space:nowrap;
  will-change:transform
}
.t-item{
  display:inline-flex;align-items:center;gap:18px;padding:16px 36px;flex-shrink:0;
  font-family:var(--fd);font-size:14px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(238,240,248,.18);border-right:1px solid var(--border)
}
.t-sym{color:var(--coral);font-size:10px}

/* ─── SECTIONS COMMUNES ─── */
.s-wrap{padding:var(--pad-v) var(--pad-h);max-width:1440px;margin:0 auto}
.wrap{padding:var(--pad-v) var(--pad-h);max-width:1440px;margin:0 auto}
.s-eyebrow{
  font-family:var(--fm);font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--cyan);display:flex;align-items:center;gap:16px;margin-bottom:24px
}
.s-eyebrow::before{content:'';width:28px;height:1px;background:var(--cyan);box-shadow:0 0 6px var(--cyan)}
.s-title{
  font-family:var(--fd);font-weight:700;
  font-size:clamp(44px,6vw,84px);
  line-height:.9;letter-spacing:.01em;text-transform:uppercase;margin-bottom:64px
}
.s-title .ac{color:var(--coral)}
.s-title .cy{color:var(--cyan)}
.reveal{opacity:0;transform:translateY(36px)}

/* ─── BOUTONS ─── */
.btn-coral{
  background:var(--coral);color:var(--void);
  font-family:var(--fm);font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  padding:16px 40px;text-decoration:none;
  position:relative;overflow:hidden;
  display:inline-flex;align-items:center;
  box-shadow:0 0 30px rgba(0,229,255,.25);transition:box-shadow .35s
}
.btn-coral::before{
  content:'';position:absolute;inset:0;
  background:rgba(255,255,255,.15);transform:translateX(-105%);
  transition:transform .4s cubic-bezier(.7,0,.3,1)
}
.btn-coral:hover::before{transform:translateX(0)}
.btn-coral:hover{box-shadow:0 0 50px rgba(0,229,255,.5)}
.btn-coral span{position:relative;z-index:1}

.btn-ghost-c{
  font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--cyan);text-decoration:none;
  display:inline-flex;align-items:center;gap:10px;
  padding-bottom:3px;border-bottom:1px solid rgba(255,61,107,.3);transition:border-color .3s
}
.btn-ghost-c:hover{border-color:var(--cyan)}
.btn-ghost{
  font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--cyan);text-decoration:none;
  border:1px solid rgba(255,61,107,.3);padding:18px 32px;transition:all .3s
}
.btn-ghost:hover{background:rgba(255,61,107,.07);border-color:var(--cyan)}
.btn-outline-c{
  font-family:var(--fm);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--coral);border:1px solid rgba(0,229,255,.4);
  padding:14px 28px;text-decoration:none;display:block;text-align:center;transition:all .35s
}
.btn-outline-c:hover{background:var(--coral);color:var(--void)}

/* ─── GRILLE SERVICES ─── */
.srv-bg{background:var(--deep)}
.srv-intro{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end;margin-bottom:72px
}
.srv-right-text{font-size:15px;line-height:1.75;color:var(--muted);font-weight:300;align-self:end}
.srv-right-text strong{color:var(--white);font-weight:500}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.srv{
  background:var(--panel);padding:44px 36px;
  position:relative;overflow:hidden;transition:background .4s
}
.srv::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--coral),var(--violet));
  transform:scaleX(0);transform-origin:left;
  transition:transform .5s cubic-bezier(.7,0,.3,1);box-shadow:0 0 20px var(--coral)
}
.srv:hover{background:rgba(0,229,255,.04)}
.srv:hover::before{transform:scaleX(1)}
.srv-icon{
  width:42px;height:42px;margin-bottom:28px;color:var(--coral);
  filter:drop-shadow(0 0 8px rgba(0,229,255,.4))
}
.srv-num{
  position:absolute;top:20px;right:24px;
  font-family:var(--fm);font-size:10px;letter-spacing:.2em;color:rgba(255,255,255,.07)
}
.srv-title{
  font-family:var(--fd);font-weight:700;font-size:22px;
  text-transform:uppercase;letter-spacing:.04em;margin-bottom:14px;color:var(--white)
}
.srv-desc{font-size:13px;line-height:1.7;color:var(--muted)}
.srv-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.srv-tag{
  font-family:var(--fm);font-size:9px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--cyan);border:1px solid rgba(255,61,107,.2);padding:4px 10px
}
.srv-link{
  display:inline-block;margin-top:20px;
  font-family:var(--fm);font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--coral);text-decoration:none;transition:opacity .25s
}
.srv-link:hover{opacity:.7}

/* ─── PROCESS (accueil) ─── */
.proc-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--border);margin-top:72px
}
.proc{background:var(--void);padding:44px 32px;position:relative;overflow:hidden}
.proc-n{
  font-family:var(--fd);font-weight:700;font-size:80px;line-height:1;
  color:rgba(0,229,255,.07);position:absolute;top:16px;right:20px
}
.proc-line{
  width:32px;height:2px;
  background:linear-gradient(90deg,var(--coral),var(--violet));
  margin-bottom:28px;box-shadow:0 0 12px var(--coral)
}
.proc-title{
  font-family:var(--fd);font-size:18px;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;color:var(--white);margin-bottom:12px
}
.proc-desc{font-size:13px;line-height:1.65;color:var(--muted)}

/* ─── PROCESS LIST (pages services) ─── */
.proc-list{display:flex;flex-direction:column;gap:1px;background:var(--border);margin-top:80px}
.proc-row{
  background:var(--void);padding:36px 48px;
  display:grid;grid-template-columns:72px 1fr auto;
  align-items:center;gap:40px;
  position:relative;overflow:hidden;
  transition:background .35s,padding-left .35s
}
.proc-row::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:0;
  background:rgba(0,229,255,.04);transition:width .45s cubic-bezier(.7,0,.3,1)
}
.proc-row:hover{padding-left:64px}
.proc-row:hover::before{width:100%}
.pr-n{
  font-family:var(--fd);font-weight:700;font-size:32px;
  color:rgba(0,229,255,.2);transition:color .35s
}
.proc-row:hover .pr-n{color:var(--coral)}
.pr-title{
  font-family:var(--fd);font-size:22px;font-weight:600;
  text-transform:uppercase;letter-spacing:.04em;color:var(--white)
}
.pr-desc{font-size:13px;color:var(--muted);line-height:1.55;margin-top:4px}
.pr-time{
  font-family:var(--fm);font-size:9px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--cyan);white-space:nowrap
}

/* ─── TÉMOIGNAGES ─── */
.tp-bg{background:var(--deep)}
.tp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin-top:72px}
.tp{background:var(--panel);padding:40px 32px;transition:background .3s}
.tp:hover{background:rgba(255,61,107,.03)}
.tp-quote{
  font-family:Georgia,serif;font-style:italic;
  font-size:14px;line-height:1.75;color:var(--muted);margin-bottom:28px
}
.tp-quote::before{
  content:'"';font-size:48px;color:rgba(0,229,255,.2);
  font-family:var(--fd);line-height:1;display:block;margin-bottom:8px
}
.tp-author{display:flex;align-items:center;gap:16px;padding-top:20px;border-top:1px solid var(--border)}
.tp-avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--coral),var(--violet));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fd);font-weight:700;font-size:16px;color:var(--void);flex-shrink:0
}
.tp-name{
  font-family:var(--fd);font-weight:600;font-size:15px;
  text-transform:uppercase;letter-spacing:.04em;color:var(--white)
}
.tp-role{font-family:var(--fm);font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.tp-stars{color:var(--coral);font-size:10px;letter-spacing:2px;margin-left:auto;align-self:flex-end}

/* ─── CTA ─── */
.cta-section{text-align:center;padding:180px var(--pad-h);position:relative;overflow:hidden}
.cta-glow{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:800px;height:400px;
  background:radial-gradient(ellipse,rgba(0,229,255,.06) 0%,rgba(255,61,107,.04) 50%,transparent 70%);
  pointer-events:none
}
.cta-eyebrow{font-family:var(--fm);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--cyan);margin-bottom:36px;position:relative}
.cta-h{
  font-family:var(--fd);font-weight:700;
  font-size:clamp(60px,10vw,148px);
  text-transform:uppercase;line-height:.88;position:relative;margin-bottom:56px
}
.cta-h .ac{color:var(--coral)}
.cta-sub{font-size:15px;color:var(--muted);margin-bottom:48px;position:relative;font-weight:300}
.cta-sub a{color:var(--coral);text-decoration:none;font-weight:500}
.cta-band{
  background:var(--deep);padding:120px var(--pad-h);
  text-align:center;position:relative;overflow:hidden
}
.cta-band::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:700px;height:300px;
  background:radial-gradient(ellipse,rgba(0,229,255,.06) 0%,transparent 70%);
  pointer-events:none
}

/* ─── PAGE HERO INTÉRIEURE ─── */
.page-hero{
  padding-top:64px;min-height:52vh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding-bottom:80px;padding-left:var(--pad-h);padding-right:var(--pad-h);
  position:relative;overflow:hidden;border-bottom:1px solid var(--border)
}
.ph-glow-a{
  position:absolute;top:-20%;left:-10%;width:600px;height:600px;
  background:radial-gradient(ellipse,rgba(0,229,255,.07) 0%,transparent 70%);pointer-events:none
}
.ph-glow-b{
  position:absolute;bottom:-20%;right:0;width:500px;height:500px;
  background:radial-gradient(ellipse,rgba(255,61,107,.05) 0%,transparent 70%);pointer-events:none
}
.ph-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,61,107,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,61,107,.02) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 80% at 30% 60%,black 30%,transparent 100%)
}
.ph-eyebrow{
  font-family:var(--fm);font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--cyan);display:flex;align-items:center;gap:16px;
  margin-bottom:28px;opacity:0;transform:translateY(12px)
}
.ph-eyebrow::before{content:'';width:28px;height:1px;background:var(--cyan);box-shadow:0 0 6px var(--cyan)}
.ph-h1{
  font-family:var(--fd);font-weight:700;
  font-size:clamp(60px,10vw,148px);
  line-height:.88;letter-spacing:.01em;text-transform:uppercase;
  position:relative;z-index:2
}
.ph-row{display:block;overflow:hidden}
.ph-row>span{display:block;transform:translateY(110%);will-change:transform}
.ph-coral{color:var(--coral);text-shadow:0 0 40px rgba(0,229,255,.35)}
.ph-outline{-webkit-text-stroke:1.5px rgba(238,240,248,0.2);color:transparent}
.ph-desc{
  margin-top:48px;max-width:560px;font-size:16px;line-height:1.8;
  color:var(--muted);font-weight:300;position:relative;z-index:2;
  opacity:0;transform:translateY(16px)
}
.ph-desc strong{color:var(--white);font-weight:500}

/* ─── STATS STRIP ─── */
.nums-strip,.stats-row{display:flex;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.num-c,.stat{
  flex:1;padding:56px 40px;border-right:1px solid var(--border);
  display:flex;flex-direction:column;gap:8px
}
.num-c:last-child,.stat:last-child{border-right:none}
.nc-n,.stat-n{
  font-family:var(--fd);font-weight:700;
  color:var(--coral);line-height:1
}
.nc-n{font-size:64px;text-shadow:0 0 24px rgba(0,229,255,.35)}
.stat-n{font-size:56px;text-shadow:0 0 24px rgba(0,229,255,.35)}
.nc-suf{font-size:36px}
.stat-suf{font-size:32px}
.nc-l,.stat-l{
  font-family:var(--fm);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted)
}

/* ─── PAGE À PROPOS ─── */
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:96px;
  align-items:center;padding:100px var(--pad-h)
}
.about-visual{
  position:relative;background:var(--panel);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  padding:60px 40px;overflow:hidden;min-height:500px
}
.about-visual::before{
  content:'';position:absolute;top:-40%;left:-40%;width:80%;height:80%;
  background:radial-gradient(ellipse,rgba(0,229,255,.12) 0%,transparent 70%)
}
.about-visual::after{
  content:'';position:absolute;bottom:-30%;right:-30%;width:70%;height:70%;
  background:radial-gradient(ellipse,rgba(255,61,107,.08) 0%,transparent 70%)
}
.av-inner{position:relative;z-index:2;text-align:center}
.av-name{
  font-family:var(--fd);font-weight:700;font-size:52px;
  text-transform:uppercase;letter-spacing:.04em;line-height:.9;color:var(--white)
}
.av-name .coral{color:var(--coral)}
.av-role{font-family:var(--fm);font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--cyan);margin-top:20px;display:block}
.av-location{font-family:var(--fm);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:12px;display:block}
.av-badge{
  display:inline-flex;align-items:center;gap:8px;margin-top:28px;
  background:rgba(255,61,107,.07);border:1px solid rgba(255,61,107,.2);
  padding:10px 20px;
  font-family:var(--fm);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan)
}
.av-badge-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--coral);box-shadow:0 0 8px var(--coral);
  animation:pulse 1.8s ease-in-out infinite
}
.av-socials{display:flex;gap:12px;margin-top:28px;justify-content:center}
.av-soc{
  width:40px;height:40px;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fm);font-size:9px;letter-spacing:.1em;
  text-decoration:none;color:var(--muted);transition:all .25s;text-transform:uppercase
}
.av-soc:hover{border-color:var(--coral);color:var(--coral)}
.about-quote{
  font-family:Georgia,serif;font-size:24px;font-style:italic;
  line-height:1.5;color:var(--white);margin-bottom:32px;
  padding-left:24px;border-left:2px solid var(--coral)
}
.about-body{font-size:15px;line-height:1.85;color:var(--muted);margin-bottom:40px;font-weight:300}
.about-body strong{color:var(--white);font-weight:500}
.about-chips{display:flex;flex-wrap:wrap;gap:10px}
.a-chip{
  font-family:var(--fm);font-size:9px;letter-spacing:.15em;text-transform:uppercase;
  padding:8px 16px;border:1px solid var(--border);color:var(--muted);
  transition:border-color .3s,color .3s
}
.a-chip:hover{border-color:var(--coral);color:var(--coral)}

/* ─── TIMELINE ─── */
.tl-bg{background:var(--deep)}
.timeline{position:relative;padding-left:48px}
.timeline::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:1px;
  background:linear-gradient(to bottom,var(--coral),var(--cyan),transparent)
}
.tl-item{position:relative;margin-bottom:64px}
.tl-item:last-child{margin-bottom:0}
.tl-dot{
  position:absolute;left:-55px;top:6px;
  width:14px;height:14px;border-radius:50%;
  background:var(--coral);box-shadow:0 0 16px var(--coral);border:2px solid var(--void)
}
.tl-year{font-family:var(--fm);font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--coral);margin-bottom:12px}
.tl-title{
  font-family:var(--fd);font-size:26px;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;color:var(--white);margin-bottom:10px
}
.tl-desc{font-size:14px;line-height:1.75;color:var(--muted);max-width:620px}

/* ─── VALEURS ─── */
.val-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.val{background:var(--panel);padding:44px 36px;position:relative;overflow:hidden;transition:background .4s}
.val::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--coral),var(--violet));
  transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.7,0,.3,1)
}
.val:hover{background:rgba(0,229,255,.04)}
.val:hover::before{transform:scaleX(1)}
.val-num{font-family:var(--fd);font-weight:700;font-size:56px;line-height:1;color:rgba(0,229,255,.1);margin-bottom:20px}
.val-title{font-family:var(--fd);font-size:20px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--white);margin-bottom:12px}
.val-desc{font-size:13px;line-height:1.7;color:var(--muted)}

/* ─── STACK TECH ─── */
.stack-bg{background:var(--deep)}
.stack-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border)}
.stk{background:var(--panel);padding:32px 28px;display:flex;flex-direction:column;gap:14px;transition:background .35s}
.stk:hover{background:rgba(255,61,107,.04)}
.stk-cat{font-family:var(--fm);font-size:9px;letter-spacing:.25em;text-transform:uppercase;color:var(--cyan);padding-bottom:14px;border-bottom:1px solid var(--border)}
.stk-item{
  font-family:var(--fd);font-size:16px;font-weight:600;text-transform:uppercase;
  letter-spacing:.04em;color:rgba(238,240,248,.6);
  transition:color .25s;display:flex;align-items:center;gap:10px
}
.stk-item::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--coral);flex-shrink:0}
.stk-item:hover{color:var(--white)}

/* ─── PORTFOLIO ─── */
.filters{
  padding:40px var(--pad-h);border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:var(--deep)
}
.filter-label{font-family:var(--fm);font-size:9px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);margin-right:8px}
.f-btn{
  font-family:var(--fm);font-size:9px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);border:1px solid var(--border);padding:8px 20px;
  background:none;cursor:none;transition:all .25s
}
.f-btn:hover{color:var(--white);border-color:rgba(255,255,255,.2)}
.f-btn.on{color:var(--coral);border-color:var(--coral);box-shadow:0 0 12px rgba(0,229,255,.2)}
.p-wrap{padding:56px;max-width:1440px;margin:0 auto}
.p-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.proj{
  background:var(--panel);position:relative;overflow:hidden;
  aspect-ratio:4/3;display:flex;flex-direction:column;justify-content:flex-end;transition:opacity .4s
}
.proj.featured{grid-column:span 2;aspect-ratio:16/7}
.proj-bg{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--fd);font-weight:700;font-size:100px;text-transform:uppercase;letter-spacing:.02em;
  transition:transform .6s cubic-bezier(.2,0,0,1);will-change:transform
}
.proj:hover .proj-bg{transform:scale(1.06)}
.proj-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(6,8,15,.97) 0%,rgba(6,8,15,.4) 60%,transparent 100%);
  transition:opacity .4s
}
.proj:hover .proj-overlay{opacity:.8}
.proj-content{position:relative;z-index:2;padding:28px;transform:translateY(20px);transition:transform .4s ease;will-change:transform}
.proj:hover .proj-content{transform:translateY(0)}
.proj-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.proj-tag{font-family:var(--fm);font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);border:1px solid rgba(255,61,107,.25);padding:3px 8px}
.proj-title{font-family:var(--fd);font-weight:700;font-size:20px;text-transform:uppercase;letter-spacing:.04em;color:var(--white);margin-bottom:6px}
.proj-sub{font-size:12px;color:var(--muted);line-height:1.55;max-height:0;overflow:hidden;opacity:0;transition:max-height .5s ease,opacity .4s}
.proj:hover .proj-sub{max-height:80px;opacity:1}
.proj-cta{
  display:inline-flex;align-items:center;gap:8px;margin-top:14px;
  font-family:var(--fm);font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--coral);text-decoration:none;
  opacity:0;transform:translateY(8px);transition:opacity .4s .1s,transform .4s .1s
}
.proj:hover .proj-cta{opacity:1;transform:translateY(0)}
.proj-flag{font-size:14px}
.proj-bg.vtc{color:rgba(255,61,107,.04)}
.proj-bg.ecom{color:rgba(0,229,255,.04)}
.proj-bg.sante{color:rgba(123,97,255,.04)}
.proj-bg.assoc{color:rgba(255,61,107,.03)}
.proj-bg.immo{color:rgba(0,229,255,.03)}
.proj-bg.beaute{color:rgba(123,97,255,.05)}

/* ─── CONTACT ─── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;min-height:70vh}
.c-left{padding:80px 64px;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:48px}
.c-right{padding:80px 64px;background:var(--deep)}
.info-block{display:flex;flex-direction:column;gap:12px}
.ib-label{font-family:var(--fm);font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:var(--cyan)}
.ib-val{font-family:var(--fd);font-size:20px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--white)}
.ib-val a{color:inherit;text-decoration:none;transition:color .25s}
.ib-val a:hover{color:var(--coral)}
.ib-sub{font-size:13px;color:var(--muted);line-height:1.6}
.avail-badge{
  display:inline-flex;align-items:center;gap:10px;
  border:1px solid rgba(255,61,107,.2);background:rgba(255,61,107,.05);
  padding:14px 24px;width:fit-content
}
.ab-dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan);flex-shrink:0;animation:pulse 1.8s ease-in-out infinite}
.ab-text{font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan)}
.socials{display:flex;flex-direction:column;gap:0}
.soc{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 0;border-bottom:1px solid var(--border);
  text-decoration:none;transition:padding-left .3s
}
.soc:last-child{border-bottom:none}
.soc:hover{padding-left:12px}
.soc-name{font-family:var(--fd);font-size:17px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--white);transition:color .25s}
.soc:hover .soc-name{color:var(--coral)}
.soc-handle{font-family:var(--fm);font-size:9px;letter-spacing:.15em;color:var(--muted)}
.soc-arr{color:var(--muted);font-size:14px;transition:transform .35s,color .25s}
.soc:hover .soc-arr{transform:translate(4px,-4px);color:var(--coral)}

/* ─── FORMULAIRE ─── */
.form-title{font-family:var(--fd);font-weight:700;font-size:30px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:36px}
.form-title span{color:var(--coral)}
.fgroup{margin-bottom:28px;position:relative}
.flabel{font-family:var(--fm);font-size:9px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;display:block;transition:color .25s}
.fgroup:focus-within .flabel{color:var(--cyan)}
.finput,.ftextarea{
  width:100%;background:transparent;border:none;border-bottom:1px solid var(--border);
  color:var(--white);font-family:var(--fb);font-size:15px;font-weight:300;
  padding:12px 0;outline:none;transition:border-color .3s
}
.finput::placeholder,.ftextarea::placeholder{color:rgba(107,112,128,.5);font-size:14px}
.finput:focus,.ftextarea:focus{border-color:var(--coral)}
.ftextarea{resize:none;min-height:120px}
.funderline{position:absolute;bottom:0;left:0;width:0;height:1px;background:linear-gradient(90deg,var(--coral),var(--cyan));transition:width .5s cubic-bezier(.7,0,.3,1);box-shadow:0 0 8px var(--coral)}
.fgroup:focus-within .funderline{width:100%}
.fselect{
  width:100%;background:transparent;border:none;border-bottom:1px solid var(--border);
  color:var(--white);font-family:var(--fb);font-size:15px;font-weight:300;
  padding:12px 0;outline:none;cursor:none;-webkit-appearance:none;appearance:none;transition:border-color .3s
}
.fselect option{background:var(--deep);color:var(--white)}
.fselect:focus{border-color:var(--coral)}
.budget-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.b-opt{
  border:1px solid var(--border);padding:14px 18px;
  font-family:var(--fm);font-size:9px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);cursor:none;transition:all .25s;text-align:center;background:none
}
.b-opt:hover{color:var(--white);border-color:rgba(255,255,255,.2)}
.b-opt.sel{color:var(--coral);border-color:var(--coral);box-shadow:0 0 12px rgba(0,229,255,.15)}
.f-submit{
  width:100%;margin-top:36px;
  background:var(--coral);color:var(--void);
  font-family:var(--fm);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  padding:20px;border:none;cursor:none;
  position:relative;overflow:hidden;
  box-shadow:0 0 30px rgba(0,229,255,.2);transition:box-shadow .35s
}
.f-submit::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,.15);transform:translateX(-105%);transition:transform .4s cubic-bezier(.7,0,.3,1)}
.f-submit:hover::before{transform:translateX(0)}
.f-submit:hover{box-shadow:0 0 50px rgba(0,229,255,.45)}
.f-submit span{position:relative;z-index:1}
.success-msg{display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:20px;padding:48px;border:1px solid rgba(255,61,107,.2);background:rgba(255,61,107,.04)}

/* ─── FAQ ─── */
.faq-section{background:var(--deep);padding:100px var(--pad-h)}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);margin-top:64px}
.faq-item{background:var(--panel);padding:32px 28px;cursor:none;transition:background .3s}
.faq-item:hover{background:rgba(0,229,255,.03)}
.faq-q{font-family:var(--fd);font-size:17px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--white);display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.faq-ico{color:var(--coral);font-size:20px;transition:transform .35s;flex-shrink:0;margin-top:2px}
.faq-item.open .faq-ico{transform:rotate(45deg)}
.faq-a{font-size:13px;color:var(--muted);line-height:1.7;max-height:0;overflow:hidden;transition:max-height .5s ease,margin-top .35s}
.faq-item.open .faq-a{max-height:200px;margin-top:16px}

/* ─── PAGE SERVICE — HERO ─── */
.srv-hero{
  padding:72px var(--pad-h) 100px;
  display:grid;grid-template-columns:1fr 400px;gap:80px;
  align-items:end;position:relative;overflow:hidden;border-bottom:1px solid var(--border)
}
.sh-glow{position:absolute;top:-10%;right:0;width:500px;height:500px;background:radial-gradient(ellipse,rgba(0,229,255,.07) 0%,transparent 70%);pointer-events:none}
.sh-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,61,107,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,61,107,.02) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 70% 70% at 80% 50%,black 20%,transparent 100%)
}
.sh-eyebrow{font-family:var(--fm);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--cyan);display:flex;align-items:center;gap:16px;margin-bottom:28px}
.sh-eyebrow::before{content:'';width:28px;height:1px;background:var(--cyan);box-shadow:0 0 6px var(--cyan)}
.sh-h1{
  font-family:var(--fd);font-weight:700;
  font-size:clamp(52px,8vw,120px);
  line-height:.88;letter-spacing:.01em;text-transform:uppercase;position:relative;z-index:2
}
.sh-row{display:block;overflow:hidden}
.sh-row>span{display:block;transform:translateY(110%);will-change:transform}
.sh-coral{color:var(--coral);text-shadow:0 0 40px rgba(0,229,255,.3)}
.sh-desc{margin-top:36px;font-size:16px;line-height:1.8;color:var(--muted);font-weight:300;max-width:560px;position:relative;z-index:2}
.sh-desc strong{color:var(--white);font-weight:500}
.sh-actions{margin-top:44px;display:flex;gap:16px;flex-wrap:wrap;position:relative;z-index:2}
.sh-card{background:var(--panel);border:1px solid var(--border);padding:40px 32px;position:relative;z-index:2;display:flex;flex-direction:column;gap:18px}
.sc-tag{font-family:var(--fm);font-size:9px;letter-spacing:.25em;text-transform:uppercase;color:var(--cyan)}
.sc-price{font-family:var(--fd);font-weight:700;font-size:52px;line-height:1;color:var(--white)}
.sc-price sup{font-size:20px;color:var(--muted)}
.sc-price sub{font-size:16px;color:var(--muted)}
.sc-sep{height:1px;background:var(--border)}
.sc-features{list-style:none;display:flex;flex-direction:column;gap:10px}
.sc-features li{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:10px;line-height:1.4}
.sc-features li::before{content:'✦';color:var(--coral);font-size:8px;flex-shrink:0}

/* ─── LIVRABLES ─── */
.del-bg{background:var(--deep)}
.del-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.del{background:var(--panel);padding:40px 32px;position:relative;overflow:hidden;transition:background .35s}
.del::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--cyan),var(--violet));transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.7,0,.3,1);box-shadow:0 0 16px var(--cyan)}
.del:hover{background:rgba(255,61,107,.04)}
.del:hover::before{transform:scaleX(1)}
.del-num{font-family:var(--fd);font-size:60px;font-weight:700;color:rgba(255,61,107,.07);line-height:1;margin-bottom:16px}
.del-title{font-family:var(--fd);font-size:19px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--white);margin-bottom:10px}
.del-desc{font-size:13px;line-height:1.7;color:var(--muted)}

/* ─── OFFRES / TARIFS ─── */
.offers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.offer{background:var(--panel);padding:40px 32px;position:relative;display:flex;flex-direction:column;gap:18px;transition:background .35s}
.offer.featured{background:rgba(0,229,255,.06);border:1px solid rgba(0,229,255,.2)}
.offer-badge{position:absolute;top:-1px;right:28px;font-family:var(--fm);font-size:8px;letter-spacing:.2em;text-transform:uppercase;background:var(--coral);color:var(--void);padding:5px 14px}
.offer-name{font-family:var(--fd);font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--cyan)}
.offer-price{font-family:var(--fd);font-weight:700;font-size:48px;line-height:1;color:var(--white)}
.offer-price sup{font-size:20px;color:var(--muted)}
.offer-desc{font-size:12px;color:var(--muted);padding-top:14px;border-top:1px solid var(--border);line-height:1.6}
.offer-list{list-style:none;display:flex;flex-direction:column;gap:9px;flex:1}
.offer-list li{font-size:12px;color:var(--muted);display:flex;align-items:flex-start;gap:10px;line-height:1.4}
.offer-list li.yes::before{content:'✓';color:var(--cyan);flex-shrink:0;font-weight:700;margin-top:1px}
.offer-list li.no{opacity:.4}
.offer-list li.no::before{content:'✕';color:var(--muted);flex-shrink:0;margin-top:1px}

/* ─── SERVICES CONNEXES ─── */
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin-top:64px}
.rel{background:var(--panel);padding:32px 28px;text-decoration:none;display:block;position:relative;overflow:hidden;transition:background .35s}
.rel::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--coral),var(--violet));transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.7,0,.3,1)}
.rel:hover{background:rgba(0,229,255,.04)}
.rel:hover::before{transform:scaleX(1)}
.rel-tag{font-family:var(--fm);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px}
.rel-title{font-family:var(--fd);font-size:20px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--white);margin-bottom:8px}
.rel-desc{font-size:12px;color:var(--muted);line-height:1.6}
.rel-arr{color:var(--coral);font-size:16px;margin-top:16px;display:block;opacity:0;transform:translateX(-8px);transition:opacity .35s,transform .35s}
.rel:hover .rel-arr{opacity:1;transform:translateX(0)}

/* ─── BREADCRUMB & SERVICE NAV ─── */
.breadcrumb{padding:80px var(--pad-h) 0;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.bc-link{font-family:var(--fm);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .25s}
.bc-link:hover{color:var(--coral)}
.bc-sep{color:var(--border)}
.bc-cur{font-family:var(--fm);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--coral)}
.srv-nav{padding:28px var(--pad-h) 0;display:flex;gap:8px;flex-wrap:wrap;border-bottom:1px solid var(--border)}
.sn-link{
  font-family:var(--fm);font-size:9px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;padding:12px 20px;
  border-bottom:2px solid transparent;transition:all .25s;display:block
}
.sn-link:hover{color:var(--white)}
.sn-link.active{color:var(--coral);border-bottom-color:var(--coral)}

/* ─── FOOTER ─── */
footer#main-footer{
  border-top:1px solid var(--border);padding:28px var(--pad-h);
  display:flex;align-items:center;justify-content:space-between;background:var(--deep)
}
.f-logo{
  font-family:var(--fd);font-weight:700;font-size:16px;letter-spacing:.1em;text-transform:uppercase;
  text-decoration:none;color:var(--white);display:flex;align-items:center;gap:10px
}
.f-dot{width:6px;height:6px;border-radius:50%;background:var(--coral);box-shadow:0 0 8px var(--coral)}
.f-copy{font-family:var(--fm);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.f-links{display:flex;list-style:none}
.f-links a{
  font-family:var(--fm);font-size:9px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;
  padding:0 20px;border-left:1px solid var(--border);transition:color .25s
}
.f-links a:hover{color:var(--coral)}

/* ─── NEUTRALISER ELEMENTOR ─── */
.elementor-section-wrap>.elementor-section,
.elementor-top-section{padding:0!important;margin:0!important}
.elementor-container{max-width:100%!important;padding:0!important}
body,body *{cursor:none!important}

/* ═══════════════════════════════════════════════════
   HAMBURGER + MENUS MOBILES
   Version consolidée — remplace les 3 blocs précédents
═══════════════════════════════════════════════════ */

/* --- Bouton hamburger (caché par défaut sur desktop) --- */
.nav-burger{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  width:48px;height:48px;gap:6px;
  background:rgba(255,61,107,0.1);
  border:1px solid rgba(255,61,107,0.3);
  border-radius:8px;
  cursor:none;padding:12px 10px;
  margin-left:auto;
  z-index:100;transition:all .3s
}
.nav-burger:hover{
  background:rgba(255,61,107,0.2);
  border-color:#FF3D6B;
  box-shadow:0 0 15px rgba(255,61,107,0.3)
}
.nav-burger span{
  display:block;width:24px;height:3px;
  background:#FF3D6B;border-radius:2px;
  transition:all .3s cubic-bezier(.4,0,.2,1);transform-origin:center
}
.nav-burger:hover span{background:#FF6B8A}
.nav-burger.active,.nav-burger.open{
  background:rgba(0,229,255,0.1);border-color:#00E5FF
}
.nav-burger.active span,.nav-burger.open span{background:#00E5FF}
.nav-burger.active span:nth-child(1),.nav-burger.open span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}
.nav-burger.active span:nth-child(2),.nav-burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.active span:nth-child(3),.nav-burger.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}

/* --- Overlay fond menu mobile --- */
.mm-overlay{
  position:fixed;inset:0;
  background:rgba(6,8,15,0.75);backdrop-filter:blur(4px);
  z-index:1998;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s
}
.mm-overlay.active{opacity:1;visibility:visible}

/* --- Panel menu mobile --- */
.mobile-menu{
  position:fixed;top:0;left:0;right:0;bottom:0;
  width:100%;background:var(--deep);
  z-index:1999;display:flex;flex-direction:column;
  transform:translateX(-100%);transition:transform .45s cubic-bezier(.7,0,.3,1);
  overflow-y:auto
}
.mobile-menu.open{transform:translateX(0)}

.mm-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;border-bottom:1px solid var(--border);
  height:64px;width:100%;flex-shrink:0;background:var(--deep)
}
.mm-close{
  width:40px;height:40px;background:none;
  border:1px solid var(--border);color:var(--muted);
  font-size:16px;cursor:none;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:border-color .25s,color .25s
}
.mm-close:hover{border-color:var(--coral);color:var(--coral)}

.mm-links{list-style:none;flex:1;padding:8px 0;margin:0}
.mm-links li{border-bottom:1px solid var(--border)}
.mm-links a{
  display:flex;align-items:center;gap:18px;padding:18px 24px;
  text-decoration:none;color:var(--muted);
  font-family:var(--fd);font-size:20px;font-weight:600;
  text-transform:uppercase;letter-spacing:.04em;
  transition:color .25s,padding-left .3s;width:100%;box-sizing:border-box
}
.mm-links a:hover{color:var(--white);padding-left:32px}
.mm-num{font-family:var(--fm);font-size:9px;letter-spacing:.2em;color:var(--coral);flex-shrink:0;width:22px}

.mm-cta{
  display:block;margin:20px 24px;padding:18px 20px;
  background:var(--coral);color:var(--void);
  font-family:var(--fm);font-size:11px;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;text-decoration:none;text-align:center;
  box-shadow:0 0 20px rgba(0,229,255,.3);flex-shrink:0
}
.mm-contacts{display:flex;flex-direction:column;gap:8px;padding:0 24px 32px;flex-shrink:0}
.mm-contacts a{
  font-family:var(--fm);font-size:10px;letter-spacing:.15em;
  color:var(--muted);text-decoration:none;transition:color .25s
}
.mm-contacts a:hover{color:var(--cyan)}

/* --- Sous-menu mobile accordéon --- */
.mm-dropdown-toggle{
  display:flex;align-items:center;width:100%;background:transparent;border:none;
  padding:18px 24px;color:var(--muted);
  font-family:var(--fd);font-size:20px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  cursor:none;transition:color .25s,padding-left .3s;text-align:left
}
.mm-dropdown-toggle:hover,
.mm-dropdown-toggle[aria-expanded="true"]{color:var(--white);padding-left:32px}
.mm-caret{margin-left:auto;font-size:14px;transition:transform .3s ease}
.mm-dropdown-toggle[aria-expanded="true"] .mm-caret{transform:rotate(180deg);color:var(--coral)}
.mm-dropdown-menu{
  list-style:none;padding:0;margin:0;
  max-height:0;overflow:hidden;transition:max-height .4s ease;
  background:rgba(255,61,107,.03);
  display:grid;grid-template-columns:1fr 1fr;gap:5px
}
.mm-dropdown-menu li:first-child{
  grid-column:span 2;
  border-bottom:1px solid rgba(255,255,255,.05);margin-bottom:5px;padding-bottom:5px
}
.mm-dropdown-menu a{
  display:block;font-size:12px;padding:10px 10px 10px 24px;
  font-family:var(--fb);font-weight:400;line-height:1.3;
  letter-spacing:normal;text-transform:none;
  transition:color .3s,padding-left .3s
}
.mm-dropdown-menu a:hover{padding-left:28px;color:var(--coral)}

/* ═══════════════════════════════════════════════════
   RESPONSIVE — 3 blocs consolidés (était 7 blocs)
═══════════════════════════════════════════════════ */

/* ── Tablette large : 1100px ── */
@media(max-width:1100px){
  .srv-hero{grid-template-columns:1fr}
  .sh-card{display:none}
  .stack-grid{grid-template-columns:1fr 1fr}
  .offers-grid{grid-template-columns:1fr}
  .tp-grid{grid-template-columns:1fr}
}

/* ── Tablette / Mobile : 991px ── */
@media(max-width:991px){
  #main-nav{
    padding:0 20px;
    justify-content:space-between;
    width:100%;box-sizing:border-box
  }
  .nav-links,.nav-cta{display:none!important}
  .nav-burger{display:flex!important;margin-left:0}

  .mobile-menu{left:auto;right:0;width:100%;border-left:1px solid var(--border);transform:translateX(100%)}
  .mobile-menu.open{transform:translateX(0)}

  .srv-nav{display:none!important}

  :root{--pad-h:24px}

  .hero-bottom,.srv-intro{grid-template-columns:1fr}
  .hero-btns{align-items:flex-start}
  .srv-grid,.del-grid,.rel-grid,.val-grid,.faq-grid{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:1fr 1fr}
  .proc-row{grid-template-columns:48px 1fr;gap:20px}
  .pr-time{display:none}
  .stack-grid{grid-template-columns:1fr 1fr}
  .about-grid{grid-template-columns:1fr;gap:48px;padding:60px 24px}
  .nums-strip,.stats-row{flex-direction:column}
  .num-c,.stat{border-right:none;border-bottom:1px solid var(--border)}
  .num-c:last-child,.stat:last-child{border-bottom:none}
  .contact-grid{grid-template-columns:1fr}
  .c-left{border-right:none;padding:56px 24px}
  .c-right{padding:56px 24px}
  .p-grid{grid-template-columns:1fr}
  .proj.featured{grid-column:span 1;aspect-ratio:4/3}
  .budget-grid{grid-template-columns:1fr 1fr}
  footer#main-footer{flex-direction:column;gap:16px;text-align:center}
  .f-links{display:none}
}

/* ── Mobile : 768px ── */
@media(max-width:768px){
  .hero-stats{
    display:grid;grid-template-columns:1fr 1fr;
    gap:10px 0;padding:0;justify-items:center
  }
  .h-stat{margin:0!important;width:100%}
  .hs-n{font-size:50px!important;margin-top:-40px}
  .hs-l{font-size:11px!important;display:block;white-space:normal}

  .mobile-menu{width:100%;left:0;right:0;transform:translateX(-100%)}
  .mobile-menu.open{transform:translateX(0)}
}


/* Réduction H1 mobile */
h1{
  font-size:clamp(50px, 7vw, 42px) !important;
  line-height:1.1;
}