/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:17px}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;background-color:#111827;color:#E5E7EB;-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.78}
p,li{text-align:justify;text-justify:inter-word;margin-bottom:.25rem}
h1,h2,h3,h4,h5,h6{font-family:'Space Grotesk',system-ui,sans-serif;letter-spacing:-.01em;line-height:1.1;color:#FFFFFF}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
ul{list-style:none}
::selection{background:#22d3ee40;color:#fff}

/* ===== GLOBAL TEXT HARMONIZATION ===== */
p{color:#E5E7EB}
.sec-p{color:#E5E7EB}
li{color:#E5E7EB}

/* ===== CSS VARS ===== */
:root{
  --bg:#111827;
  --bg2:#131f2e;
  --bg3:#0d1520;
  --card:#1a2535;
  --border:rgba(255,255,255,0.08);
  --borderc:rgba(34,211,238,0.3);
  --cyan:#22d3ee;
  --cyan2:#1791cf;
  --teal:#2dd4bf;
  --muted:#d1d5db;
  --muted2:#e2e8f0;
  --navy:#0B1E3D;
  --gray-light:#F2F4F7;
  --gray-mid:#6B7280;
  --radius:.75rem;
}

/* ===== TEXT SHADOW FOR IMAGE CONTRAST ===== */
.hero-content h1,.hero-content p,.hero-content .hero-sub{text-shadow:0 2px 20px rgba(0,0,0,0.7),0 1px 6px rgba(0,0,0,0.55)}
.page-hero-content h1,.page-hero-content p,.page-hero-content .sec-label{text-shadow:0 2px 20px rgba(0,0,0,0.7),0 1px 6px rgba(0,0,0,0.55)}
.exp-detail-body h2,.exp-detail-body p{text-shadow:0 1px 8px rgba(0,0,0,0.4)}
/* ===== GLASS CARD EFFECT ===== */
.glass-card{background:rgba(20,30,50,0.78);border:1px solid rgba(255,255,255,0.1);border-radius:1.5rem;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 8px 32px rgba(0,0,0,0.4),0 1px 0 rgba(255,255,255,0.08) inset;transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s,border-color .3s}
.glass-card:hover{transform:translateY(-7px);box-shadow:0 24px 52px rgba(0,0,0,0.55),0 0 28px rgba(34,211,238,0.12),0 1px 0 rgba(255,255,255,0.1) inset;border-color:rgba(34,211,238,0.22)}

/* ===== FLOATING CARD EFFECT ===== */
.float-card{box-shadow:0 12px 40px rgba(0,0,0,0.4),0 2px 8px rgba(0,0,0,0.3);transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s}
.float-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 24px 60px rgba(0,0,0,0.5),0 0 28px rgba(34,211,238,0.12)}

/* ===== ENHANCED REVEAL ANIMATIONS ===== */
.nr-reveal{opacity:0;transform:translateY(32px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.nr-reveal-left{opacity:0;transform:translateX(-45px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.nr-reveal-right{opacity:0;transform:translateX(45px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.nr-reveal-scale{opacity:0;transform:scale(0.94);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.nr-visible{opacity:1 !important;transform:none !important}

/* ===== CARD MICRO-ANIMATIONS ===== */
.svc-card{transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s,border-color .3s}
.svc-card:hover .svc-icon{transform:scale(1.12) rotate(-4deg);transition:transform .3s cubic-bezier(.22,1,.36,1)}
.svc-icon{transition:transform .3s cubic-bezier(.22,1,.36,1)}

/* ===== INNO CARD MICRO ===== */
.inno-card{transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s,border-color .3s}

/* ===== HIGHLIGHT TEXT ===== */
.highlight-cyan{color:var(--cyan);font-weight:600}

/* ===== MUTED TEXT OVERRIDE ===== */
.text-muted{color:#d1d5db !important}

/* ===== TOPLINE ANIMÉE ===== */
#topline{position:fixed;top:0;left:0;height:3px;width:100%;background:linear-gradient(90deg,transparent,var(--cyan2),#00e5ff,var(--cyan2),transparent);background-size:200% 100%;animation:topline 3s linear infinite;z-index:9999;pointer-events:none}
@keyframes topline{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ===== SCROLL PROGRESS ===== */
#scrollbar{position:fixed;top:3px;left:0;height:3px;background:rgba(23,145,207,.5);z-index:9998;transition:width .1s linear;pointer-events:none}

/* ===== CURSOR ===== */
#cursor{width:20px;height:20px;border:2px solid rgba(23,145,207,.8);border-radius:50%;position:fixed;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:transform .15s ease,opacity .3s ease,border-color .2s;opacity:0}
#cursor-dot{width:6px;height:6px;background:var(--cyan2);border-radius:50%;position:fixed;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:transform .05s ease}

/* ===== PARTICLES ===== */
#particles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}
.particle{position:absolute;border-radius:50%;background:rgba(23,145,207,.12);animation:float-particle linear infinite}
@keyframes float-particle{0%{transform:translateY(100vh) scale(0);opacity:0}10%{opacity:1}90%{opacity:.5}100%{transform:translateY(-10vh) scale(1);opacity:0}}

/* ===== BG MESH ===== */
.bg-mesh{background-image:radial-gradient(rgba(34,211,238,.05) 1px,transparent 1px);background-size:28px 28px}

/* ===== ANIMATIONS ===== */
@keyframes fade-in-up{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes slide-in-left{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)}}
@keyframes float-slow{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes pulse-soft{0%,100%{opacity:.6}50%{opacity:1}}
.animate-fade-in-up{animation:fade-in-up .9s cubic-bezier(.22,1,.36,1) both}
.animate-slide-in-left{animation:slide-in-left .9s cubic-bezier(.22,1,.36,1) both}
.animate-float-slow{animation:float-slow 6s ease-in-out infinite}
.animate-float{animation:float 4.5s ease-in-out infinite}
.animate-pulse-soft{animation:pulse-soft 4s ease-in-out infinite}

/* ===== REVEAL (base defined above, delays here) ===== */
.nr-delay-1{transition-delay:.1s}.nr-delay-2{transition-delay:.2s}.nr-delay-3{transition-delay:.3s}.nr-delay-4{transition-delay:.4s}.nr-delay-5{transition-delay:.5s}

/* ===== TEXT GRADIENT ===== */
.text-gradient{background:linear-gradient(135deg,var(--cyan),var(--teal));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.text-cyan{color:var(--cyan)}
.text-cyan2{color:var(--cyan2)}
.text-teal{color:var(--teal)}

/* ===== LAYOUT ===== */
.max-w{max-width:1280px;margin:0 auto;padding:0 1.5rem}
@media(min-width:640px){.max-w{padding:0 1.5rem}}
@media(min-width:1024px){.max-w{padding:0 2rem}}

/* ===== DIVIDER ===== */
.nr-divider{height:1px;background:linear-gradient(90deg,transparent,var(--cyan2),transparent);margin:2rem 0;animation:divider-glow 2s ease-in-out infinite alternate}
@keyframes divider-glow{from{opacity:.4}to{opacity:1;box-shadow:0 0 10px var(--cyan2)}}

/* ===== GLASS ===== */
.glass{background:rgba(255,255,255,.03);border:1px solid var(--border);backdrop-filter:blur(12px)}

/* ===== BADGE ===== */
.badge{display:inline-flex;align-items:center;gap:.5rem;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);padding:.375rem 1rem;font-size:.75rem;color:#a5f3fc;letter-spacing:.1em;text-transform:uppercase}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.9rem;padding:.65rem 1.5rem;border-radius:.5rem;border:none;cursor:pointer;transition:all .2s;white-space:nowrap;position:relative;overflow:hidden}
.btn-primary{background:linear-gradient(135deg,var(--cyan2),#0ea5e9);color:#fff}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(23,145,207,.4)}
.btn-ghost{background:rgba(255,255,255,.05);color:#e2e8f0;border:1px solid rgba(255,255,255,.15)}
.btn-ghost:hover{background:rgba(255,255,255,.1);color:#fff}
.btn svg{width:16px;height:16px;flex-shrink:0}

/* ===== CARDS ===== */
.card{background:var(--card);border:1px solid var(--border);border-radius:1rem;transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,.4),0 0 20px rgba(23,145,207,.15)}

/* ===== NAVBAR ===== */
#nav{position:fixed;top:3px;left:0;right:0;z-index:100;transition:all .3s}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;height:4rem}
@media(min-width:768px){.nav-inner{height:5.25rem;padding:0 2rem}}
.nav-logo{display:flex;align-items:center;gap:.75rem}
.nav-logo:hover .nav-logo-icon{filter:brightness(1.18) drop-shadow(0 0 14px rgba(0,188,212,0.65)) drop-shadow(0 2px 8px rgba(0,0,0,0.7))}
.nav-logo-icon{height:3rem;width:auto;border-radius:0;background:transparent;display:flex;align-items:center;justify-content:center;overflow:visible;flex-shrink:0;filter:drop-shadow(0 0 10px rgba(0,188,212,0.40)) drop-shadow(0 2px 5px rgba(0,0,0,0.60))}
.nav-logo-icon img{height:3rem;width:auto;max-width:240px;object-fit:contain;opacity:1 !important;mix-blend-mode:normal !important;transform:none !important;transition:filter .3s ease}
.nav-brand h1{font-size:1.05rem;font-weight:700;color:#fff;line-height:1.1}
.nav-brand p{font-size:.7rem;color:var(--cyan);letter-spacing:.05em}
.nav-links{display:none}
@media(min-width:1024px){.nav-links{display:flex;align-items:center;gap:.5rem}}
.nav-links a{display:inline-block;background:none;border:none;cursor:pointer;padding:.55rem 1.05rem;border-radius:.5rem;font-size:1rem;font-weight:600;color:#f1f5f9;transition:all .25s;font-family:'Plus Jakarta Sans',sans-serif;letter-spacing:.02em}
.nav-links a:hover,.nav-links a.active{background:rgba(34,211,238,.12);color:#22d3ee}
.nav-mob-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:.5rem;color:#f1f5f9}
.nav-mob-btn:hover{background:rgba(255,255,255,.1);color:#fff}
@media(min-width:1024px){.nav-mob-btn{display:none}}
#nav.scrolled{background:rgba(17,24,39,.97);backdrop-filter:blur(20px);box-shadow:0 4px 20px rgba(0,0,0,.3)}

/* Mobile menu */
#mob-menu{position:fixed;inset:0;z-index:200;background:rgba(17,24,39,.98);backdrop-filter:blur(20px);transform:translateX(100%);transition:transform .35s cubic-bezier(.22,1,.36,1);padding:2rem 1.5rem}
#mob-menu.open{transform:translateX(0)}
.mob-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.5rem}
.mob-links{display:flex;flex-direction:column;gap:.25rem}
.mob-links a{display:block;background:none;border:none;cursor:pointer;text-align:left;padding:.875rem .75rem;font-family:'Space Grotesk',sans-serif;font-size:1.1rem;font-weight:600;color:#f1f5f9;border-bottom:1px solid rgba(255,255,255,.06);transition:color .2s;width:100%}
.mob-links a:hover,.mob-links a.active{color:#22d3ee}

/* ===== SECTIONS ===== */
section{position:relative}

/* ===== HERO ===== */
#hero{min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg-img{position:absolute;inset:0}
.hero-bg-img img{width:100%;height:100%;object-fit:cover;mix-blend-mode:normal !important;opacity:.85 !important;transform:scale(1.12) translateY(0);transform-origin:center center;will-change:transform;transition:transform .08s linear}
/* Wrapper Ken Burns sur pseudo-element — sans conflit avec JS parallax */
.hero-bg-img{position:absolute;inset:-6%;overflow:hidden}
.hero-bg-img::after{content:'';position:absolute;inset:0;background:inherit;pointer-events:none}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,20,50,0.52) 0%,rgba(10,20,50,0.45) 60%,rgba(17,24,39,0.92) 100%)}
.hero-orb-1{position:absolute;top:-6rem;left:-5rem;width:18rem;height:18rem;border-radius:50%;background:rgba(34,211,238,.18);filter:blur(60px);animation:float-slow 6s ease-in-out infinite;pointer-events:none}
.hero-orb-2{position:absolute;top:10rem;right:-4rem;width:16rem;height:16rem;border-radius:50%;background:rgba(59,130,246,.18);filter:blur(60px);animation:float 4.5s ease-in-out infinite;pointer-events:none}
.hero-orb-3{position:absolute;bottom:2.5rem;left:33%;width:20rem;height:20rem;border-radius:50%;background:rgba(45,212,191,.16);filter:blur(70px);animation:pulse-soft 4s ease-in-out infinite;pointer-events:none}
.hero-content{position:relative;z-index:2;max-width:1280px;margin:0 auto;padding:8rem 1.5rem 5rem;text-align:center}
.hero-h1{font-size:clamp(2.5rem,7vw,5rem);font-weight:700;color:#fff;line-height:1.05;margin-bottom:1.5rem}
.hero-sub{font-size:clamp(.85rem,.9vw+.5rem,1.1rem);color:var(--cyan);font-weight:500;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1rem}
.hero-p{font-size:clamp(1.05rem,1.6vw,1.25rem);color:#e2e8f0;max-width:50rem;margin:0 auto 2.5rem;text-align:center;line-height:1.85}
.hero-btns{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:4rem}
.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;max-width:36rem;margin:0 auto}
@media(min-width:640px){.hero-stats{grid-template-columns:repeat(4,1fr)}}
.stat-box{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:.75rem;padding:.875rem 1rem;text-align:center}
.stat-val{font-family:'Space Grotesk',sans-serif;font-size:1.8rem;font-weight:700;color:var(--cyan);line-height:1}
.stat-lbl{font-size:.72rem;color:var(--muted);margin-top:.25rem}

/* ===== ABOUT ===== */
#about{padding:6rem 0;background:#111827;overflow:hidden}
.about-img-section{position:absolute;inset:0}
.about-img-section img{width:100%;height:100%;object-fit:cover;opacity:.75 !important;mix-blend-mode:normal !important}
.about-img-section-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(13,36,73,0.82),rgba(13,36,73,0.48),rgba(13,36,73,0.22))}

/* ===== SERVICES ===== */
#services{padding:6rem 0;overflow:hidden}
.svc-card{background:rgba(18,27,46,.90);border:1px solid rgba(255,255,255,.09);border-radius:1.5rem;overflow:hidden;transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s,border-color .3s}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,.4),0 0 20px rgba(23,145,207,.15);border-color:rgba(34,211,238,.2)}
.svc-card-img{position:relative;height:16rem;overflow:hidden}
.svc-card-img img{width:100%;height:100%;object-fit:cover;opacity:.75 !important;transition:opacity .4s,transform .5s !important;mix-blend-mode:normal !important;transform:none !important}
.svc-card:hover .svc-card-img img{opacity:.9 !important;transform:scale(1.06) !important}
.svc-card-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,20,50,0.97) 0%,rgba(10,20,50,0.50) 55%,rgba(10,20,50,0.08) 100%)}
.svc-card-body{padding:1.75rem}
.svc-icon{width:3.5rem;height:3.5rem;border-radius:.875rem;background:linear-gradient(135deg,rgba(34,211,238,.15),rgba(37,99,235,.15));display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;flex-shrink:0}
.svc-icon svg{width:1.75rem;height:1.75rem;stroke:var(--cyan);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.svc-card h3{font-size:1.25rem;font-weight:700;color:#fff;margin-bottom:.75rem}
.svc-card p{font-size:.9rem;color:#d1d5db;line-height:1.8;text-align:left}
.svc-list{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}
.svc-list li{display:flex;align-items:flex-start;gap:.75rem;font-size:.9rem;color:#d1d5db;line-height:1.75}
.svc-list li svg{width:1.25rem;height:1.25rem;stroke:var(--cyan2);flex-shrink:0;margin-top:.1rem;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ===== EXPERTISE ===== */
#expertise{padding:5rem 0;overflow:hidden}
/* ===== SECTION HOVER DYNAMICS ===== */
.section-hover{transition:box-shadow .4s cubic-bezier(.22,1,.36,1)}
.section-hover:hover{box-shadow:0 0 0 1px rgba(34,211,238,0.08) inset}

/* ROI cards */
.roi-card{transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s,border-color .3s,background .3s}

/* Step items */
.step-item{transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s,border-color .3s,background .3s}
.step-item:hover{transform:translateX(6px) translateY(-2px);border-color:rgba(34,211,238,.25);box-shadow:0 12px 32px rgba(0,0,0,.35),0 0 16px rgba(34,211,238,.08)}

/* Roadmap phases */
.roadmap-phase{transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s,border-color .3s,background .3s}
.roadmap-phase:hover{transform:translateY(-5px);border-color:rgba(34,211,238,.25);background:rgba(20,30,55,.9);box-shadow:0 12px 32px rgba(0,0,0,.4),0 0 20px rgba(34,211,238,.1)}

/* Processus glass cards dans approche */
.process-card{transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s,border-color .35s}
.process-card:hover{transform:translateY(-6px) scale(1.01);border-color:rgba(34,211,238,.25);box-shadow:0 20px 44px rgba(0,0,0,.45),0 0 24px rgba(34,211,238,.1)}

/* Service detail blocks hover */
.svc-detail-block{transition:box-shadow .3s,border-color .3s,transform .3s cubic-bezier(.22,1,.36,1)}
.svc-detail-block:hover{transform:translateY(-3px);border-color:rgba(34,211,238,.2) !important;box-shadow:0 16px 40px rgba(0,0,0,.5),0 0 20px rgba(34,211,238,.08)}

/* Ecosystem cards */
.eco-card{transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s,border-color .35s}
.eco-card:hover{transform:translateY(-5px);border-color:rgba(34,211,238,.22);box-shadow:0 16px 36px rgba(0,0,0,.4),0 0 18px rgba(34,211,238,.09)}

/* Défis cards hover enrichi */
.defi-card{transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s,border-color .35s}
.defi-card:hover{transform:translateY(-6px) scale(1.01);box-shadow:0 24px 52px rgba(0,0,0,.5),0 0 24px rgba(34,211,238,.1)}

/* ===== KEN BURNS ===== */
@keyframes ken-burns{0%{transform:scale(1)}100%{transform:scale(1.06)}}
@keyframes ken-burns-r{0%{transform:scale(1.04)}100%{transform:scale(1)}}
.kb-zoom{animation:ken-burns 22s ease-in-out alternate infinite}
.kb-zoom-r{animation:ken-burns-r 20s ease-in-out alternate infinite}

/* ===== PARALLAX BG ===== */
.parallax-bg{will-change:transform;transition:transform .1s linear}

/* ===== SECTION BG HOVER DEPTH ===== */
.bg-section-hover{position:relative;overflow:hidden}
.bg-section-hover::after{content:'';position:absolute;inset:0;background:rgba(34,211,238,0);transition:background .5s ease;pointer-events:none;z-index:1}
.bg-section-hover:hover::after{background:rgba(34,211,238,0.015)}

/* ===== CHIP HOVER ===== */
.chip{transition:background .2s,border-color .2s,color .2s,transform .2s}
.chip:hover{background:rgba(34,211,238,.15);border-color:rgba(34,211,238,.3);transform:translateY(-1px)}

/* ===== INNO CARD OVERLAY DEPTH ===== */
.inno-card:hover .inno-card-img-overlay{background:linear-gradient(to top,rgba(8,18,42,0.97) 0%,rgba(8,18,42,0.35) 60%,transparent 100%)}

/* ===== CONTACT SIDEBAR CARD HOVER ===== */
.contact-info-card{transition:transform .3s cubic-bezier(.22,1,.36,1),border-color .3s,box-shadow .3s}
.contact-info-card:hover{transform:translateY(-3px);border-color:rgba(34,211,238,.2);box-shadow:0 8px 24px rgba(0,0,0,.3)}

/* ===== ABOUT INTRO GRID ===== */
.about-intro-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:2rem;align-items:center;margin-bottom:4.5rem}
.about-intro-section{background:#111827;padding:4rem 0;border-radius:0}
.about-intro-img-col{order:2;padding:0}
.about-intro-text-col{order:1;padding:0 1rem 0 0}
.about-intro-img-col img{max-width:100%;width:100%;border-radius:12px;box-shadow:0 8px 30px rgba(0,0,0,0.4);object-fit:contain;display:block}
.about-intro-title-wrap{text-align:center;margin-bottom:1.5rem;position:relative;display:flex;align-items:stretch;justify-content:center;gap:1rem}
.about-intro-title-wrap::before{content:'';width:4px;background:var(--cyan);border-radius:2px;flex-shrink:0}
@media(max-width:768px){
  .about-intro-grid{grid-template-columns:1fr !important}
  .about-intro-img-col{order:1}
  .about-intro-text-col{order:2;padding:0 20px}
  .about-intro-img-col img{max-width:100%;margin:0 auto}
}

/* ===== APPROACH ===== */
#approach{padding:6rem 0;overflow:hidden}
.step-item{display:flex;gap:1.5rem;align-items:flex-start;padding:1.75rem;background:rgba(20,28,42,.82);border:1px solid rgba(255,255,255,.07);border-radius:1.25rem;transition:all .3s}
.step-item:hover{border-color:rgba(34,211,238,.2);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.step-num{width:3rem;height:3rem;border-radius:50%;background:linear-gradient(135deg,rgba(34,211,238,.15),rgba(37,99,235,.15));border:1px solid rgba(34,211,238,.2);display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;font-size:.8rem;font-weight:700;color:var(--cyan);flex-shrink:0}
.step-item h3{font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:.4rem}
.step-item p{font-size:.9rem;color:#d1d5db;line-height:1.78}

/* ===== INNOVATION ===== */
#innovation{padding:6rem 0;overflow:hidden}
.inno-card{background:rgba(18,27,46,.90);border:1px solid rgba(255,255,255,.09);border-radius:1.5rem;overflow:hidden;transition:all .3s}
.inno-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,.4),0 0 20px rgba(23,145,207,.12);border-color:rgba(34,211,238,.18)}
.inno-card-img{position:relative;height:12rem;overflow:hidden}
.inno-card-img img{width:100%;height:100%;object-fit:cover;opacity:.75 !important;transition:opacity .4s,transform .5s !important;mix-blend-mode:normal !important;transform:none !important}
.inno-card:hover .inno-card-img img{opacity:.90 !important;transform:scale(1.05) !important}
.inno-card-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,36,73,0.88) 0%,rgba(13,36,73,0.22) 60%,transparent 100%)}
.inno-card-body{padding:1.5rem}
.inno-status{font-size:.65rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--cyan);margin-bottom:.5rem}
.inno-card-body h3{font-size:1rem;font-weight:700;color:#fff;margin-bottom:.6rem;line-height:1.3}
.inno-card-body p{font-size:.9rem;color:#d1d5db;line-height:1.82}
.roadmap-phase{background:rgba(20,28,42,.82);border:1px solid rgba(255,255,255,.07);border-radius:1rem;padding:1.5rem;text-align:center;transition:all .3s}
.roadmap-phase:hover{border-color:rgba(34,211,238,.18)}
.phase-num{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:.5rem}

/* ===== ABOUT PAGE ===== */
#apropos{padding:5rem 0}
.about-stat{text-align:center}
.about-stat-val{font-family:'Space Grotesk',sans-serif;font-size:2.5rem;font-weight:700;line-height:1}
.about-stat-lbl{font-size:.8rem;color:var(--muted2);margin-top:.3rem}

/* ===== CONTACT ===== */
#contact{padding:5rem 0}
.form-label{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#d1d5db;margin-bottom:.5rem;display:block}
.form-input{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:.5rem;padding:.7rem 1rem;color:#f9fafb;font-family:'Plus Jakarta Sans',sans-serif;font-size:.95rem;outline:none;transition:border-color .2s,box-shadow .2s}
.form-input:focus{border-color:rgba(34,211,238,.5);box-shadow:0 0 0 3px rgba(34,211,238,.1)}
.form-input::placeholder{color:#4b5563}
select.form-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2322d3ee' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:12px;background-color:rgba(20,28,42,0.95)}
select.form-input option{background-color:#131f2e;color:#E5E7EB}
textarea.form-input{resize:vertical;min-height:130px}
.contact-info-card{background:var(--card);border:1px solid var(--border);border-radius:1rem;padding:1.5rem;margin-bottom:1.25rem}
.info-row{display:flex;gap:.875rem;align-items:flex-start;margin-bottom:.875rem}
.info-row:last-child{margin-bottom:0}
.info-icon{width:2.25rem;height:2.25rem;border-radius:.5rem;background:rgba(34,211,238,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.info-icon svg{width:.9rem;height:.9rem;stroke:var(--cyan);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.info-text{font-size:.875rem;color:#d1d5db;line-height:1.65}
.info-text a{color:#d1d5db;transition:color .2s}.info-text a:hover{color:var(--cyan)}
#form-success{display:none;text-align:center;padding:3rem 1rem}
#form-success.show{display:block}

/* ===== PAGE HEADERS ===== */
/* ✅ CORRECTION — padding-top ajusté pour compenser la navbar fixe */
.page-hero{position:relative;padding:7rem 0 5.5rem;overflow:hidden}
.page-hero-bg{position:absolute;inset:0}
.page-hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.75 !important;mix-blend-mode:normal !important;animation:ken-burns 28s ease-in-out alternate infinite}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,20,50,0.56) 0%,rgba(10,20,50,0.50) 60%,rgba(17,24,39,0.94) 100%)}
.page-hero-mesh{position:absolute;inset:0;background-image:radial-gradient(rgba(34,211,238,.05) 1px,transparent 1px);background-size:28px 28px;opacity:.7}

/* ===== FOOTER ===== */
footer{background:#0d1520;border-top:1px solid rgba(255,255,255,.06);padding:3.5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2.5rem}
@media(min-width:768px){.footer-grid{grid-template-columns:2fr 1fr 1fr}}
.footer-nav-title{font-size:.85rem;font-weight:600;color:#fff;margin-bottom:1rem}
.footer-nav-links{display:flex;flex-direction:column;gap:.5rem}
.footer-nav-links a{display:block;background:none;border:none;cursor:pointer;text-align:left;font-size:.95rem;color:#9ca3af;transition:color .2s;font-family:'Plus Jakarta Sans',sans-serif;padding:.1rem 0;line-height:1.75}
.footer-nav-links a:hover{color:var(--cyan)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.05)}
.footer-bottom p{font-size:.82rem;color:#9ca3af}

/* ===== CHIPS ===== */
.chip{display:inline-flex;padding:.25rem .75rem;border-radius:999px;font-size:.72rem;font-weight:500;background:rgba(34,211,238,.08);border:1px solid rgba(34,211,238,.15);color:#67e8f9;white-space:nowrap}

/* ===== GRIDS ===== */
.grid-2{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
.grid-3{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:768px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.grid-3{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.grid-2{grid-template-columns:1fr 1fr;gap:3rem}}

/* ===== SECTION HEADERS ===== */
.sec-label{font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);margin-bottom:.875rem}
.sec-h2{font-size:clamp(1.85rem,3.5vw,2.85rem);font-weight:700;color:#fff;margin-bottom:1.1rem;letter-spacing:-.01em}
.sec-p{font-size:1.1rem;color:#d1d5db;max-width:42rem;line-height:1.9}

/* ===== RESPONSIVE ===== */
@media(max-width:1023px){
  #hero .hero-content{padding:7rem 1.5rem 4rem}
  #about .grid-2,#approach .grid-2{gap:2rem}
  .nav-links a{display:inline-block;font-size:.92rem;padding:.45rem .8rem}
}
@media(max-width:767px){
  .hero-h1{font-size:2.4rem}
  .hero-stats{grid-template-columns:1fr 1fr}
  .sec-h2{font-size:1.75rem}
  .svc-card-body{padding:1.25rem}
  .step-item{padding:1.25rem;gap:1rem}
  /* ✅ CORRECTION mobile — padding-top augmenté pour compenser la navbar */
  .page-hero{padding:8.5rem 0 4rem}
  .glass-card{padding:1.25rem}
}
@media(max-width:479px){
  .hero-h1{font-size:2rem}
  .max-w{padding:0 1rem}
  .btn{font-size:.85rem;padding:.6rem 1.25rem}
}

/* ===== SEPARATOR ===== */
.sep{height:1px;background:rgba(255,255,255,.06);margin:0}

/* ===== ACTIVE PAGE ===== */
.page-section{display:none}
.page-section.active{display:block}

/* ===== FLOATING MESSAGES ===== */
#floating-msgs{position:fixed;bottom:5.5rem;right:1.25rem;z-index:500;display:flex;flex-direction:column;gap:.625rem;pointer-events:none}
.fmsg{background:rgba(17,24,39,.96);border:1px solid rgba(34,211,238,.2);border-radius:.875rem;padding:.875rem 1.1rem;backdrop-filter:blur(20px);display:flex;align-items:flex-start;gap:.625rem;max-width:255px;box-shadow:0 8px 28px rgba(0,0,0,.5),0 0 16px rgba(34,211,238,.06);opacity:0;transform:translateX(16px);transition:opacity .45s cubic-bezier(.22,1,.36,1),transform .45s cubic-bezier(.22,1,.36,1)}
.fmsg.show{opacity:1;transform:translateX(0)}
.fmsg.hide{opacity:0;transform:translateX(16px)}
.fmsg-icon{width:1.875rem;height:1.875rem;border-radius:.45rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem}
.fmsg-title{font-size:.73rem;font-weight:600;color:#fff;font-family:'Space Grotesk',sans-serif;line-height:1.2;margin-bottom:.18rem}
.fmsg-sub{font-size:.66rem;color:#9ca3af;line-height:1.35}
.fmsg-live{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:.3rem;position:relative}
.fmsg-live::before{content:'';position:absolute;inset:-3px;border-radius:50%;animation:ping-msg 1.6s cubic-bezier(0,0,.2,1) infinite}
@keyframes ping-msg{0%{transform:scale(1);opacity:.7}80%,100%{transform:scale(2.4);opacity:0}}

/* ===== URGENCY PILL ===== */
.urgency-pill{display:inline-flex;align-items:center;gap:.5rem;background:rgba(23,145,207,.08);border:1px solid rgba(23,145,207,.22);border-radius:999px;padding:.35rem 1rem;font-size:.72rem;font-weight:600;color:#1791cf;letter-spacing:.06em;text-transform:uppercase;font-family:'Space Grotesk',sans-serif}
.live-dot{position:relative;display:inline-flex;width:8px;height:8px}
.live-dot::before{content:'';position:absolute;inset:0;border-radius:50%;background:#22d3ee;animation:ping-live 1.4s cubic-bezier(0,0,.2,1) infinite}
.live-dot::after{content:'';display:inline-flex;width:8px;height:8px;border-radius:50%;background:#22d3ee;position:relative}
@keyframes ping-live{0%{transform:scale(1);opacity:.9}80%,100%{transform:scale(2.2);opacity:0}}

/* ===== SHIMMER TEXT ===== */
@keyframes shimmer-pan{0%{background-position:-200% center}100%{background-position:200% center}}
.shimmer-text{background:linear-gradient(90deg,#fff 0%,#22d3ee 25%,#fff 50%,#2dd4bf 75%,#fff 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer-pan 5s linear infinite}

/* ===== HERO ROI NUMBERS ===== */
@keyframes count-pop{0%{opacity:0;transform:scale(.6)}100%{opacity:1;transform:scale(1)}}
.stat-box.animated .stat-val{animation:count-pop .6s cubic-bezier(.22,1,.36,1) both}

/* ===== HERO AMÉLIORÉ ===== */
.hero-h1{letter-spacing:-.02em;text-shadow:0 4px 32px rgba(0,0,0,0.6),0 2px 8px rgba(0,0,0,0.4)}
.hero-sub{letter-spacing:.14em}

/* Hero scan line */
@keyframes scan-line{0%{top:-10%}100%{top:110%}}
.hero-scan{position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(34,211,238,0.18),transparent);animation:scan-line 7s linear infinite;pointer-events:none;z-index:2}

/* Hero circuit */
@keyframes circuit-fade{0%,100%{opacity:.04}50%{opacity:.10}}
.hero-circuit{position:absolute;inset:0;background-image:
  radial-gradient(circle,rgba(34,211,238,.06) 1px,transparent 1px),
  radial-gradient(circle,rgba(23,145,207,.04) 1px,transparent 1px);
background-size:32px 32px,64px 64px;
background-position:0 0,16px 16px;
animation:circuit-fade 6s ease-in-out infinite;pointer-events:none;z-index:1}

/* Hero orbs enrichis */
@keyframes orb-drift{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(12px,-18px) scale(1.06)}66%{transform:translate(-8px,10px) scale(.96)}}
.hero-orb-1{animation:orb-drift 9s ease-in-out infinite}
.hero-orb-2{animation:orb-drift 11s ease-in-out infinite reverse}
.hero-orb-3{animation:orb-drift 7s ease-in-out infinite 2s}

/* Staggered hero entrance */
@keyframes hero-entry-title{0%{opacity:0;transform:translateY(40px) scale(.97);filter:blur(4px)}100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}
@keyframes hero-entry-sub{0%{opacity:0;transform:translateY(20px)}100%{opacity:1;transform:translateY(0)}}
@keyframes hero-entry-p{0%{opacity:0;transform:translateY(16px)}100%{opacity:1;transform:translateY(0)}}
@keyframes hero-entry-btns{0%{opacity:0;transform:translateY(12px)}100%{opacity:1;transform:translateY(0)}}

.hero-h1-anim{animation:hero-entry-title .85s cubic-bezier(.22,1,.36,1) .1s both}
.hero-sub-anim{animation:hero-entry-sub .7s cubic-bezier(.22,1,.36,1) 0s both}
.hero-p-anim{animation:hero-entry-p .7s cubic-bezier(.22,1,.36,1) .35s both}
.hero-btns-anim{animation:hero-entry-btns .65s cubic-bezier(.22,1,.36,1) .55s both}
.hero-stats-anim{animation:hero-entry-btns .65s cubic-bezier(.22,1,.36,1) .7s both}

/* ===== BOUTONS PREMIUM ===== */
.btn{position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.1),transparent);opacity:0;transition:opacity .25s}
.btn:hover::after{opacity:1}
.btn-primary{background:linear-gradient(135deg,#0ea5e9,#1791cf,#22d3ee);background-size:200% 200%;transition:transform .25s cubic-bezier(.22,1,.36,1),box-shadow .25s,background-position .4s !important}
.btn-primary:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 12px 32px rgba(23,145,207,.5),0 0 20px rgba(34,211,238,.2);background-position:100% 0 !important}
.btn-ghost{transition:transform .25s cubic-bezier(.22,1,.36,1),box-shadow .25s,background .25s,border-color .25s !important}
.btn-ghost:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.25),0 0 16px rgba(34,211,238,.1);border-color:rgba(34,211,238,.35) !important}

/* ===== ROI CARDS ENRICHIES ===== */
.roi-card{position:relative;overflow:hidden}
.roi-card::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(34,211,238,.06),transparent 70%);opacity:0;transition:opacity .3s}
.roi-card:hover::before{opacity:1}
.roi-number{transition:transform .3s cubic-bezier(.22,1,.36,1),text-shadow .3s}
.roi-card:hover .roi-number{transform:scale(1.08);text-shadow:0 0 24px currentColor}

/* ===== ROI COUNTERS ANIMÉS AU SCROLL ===== */
@keyframes count-up-scale{0%{opacity:0;transform:scale(.7) translateY(10px)}100%{opacity:1;transform:scale(1) translateY(0)}}
.roi-card.nr-visible .roi-number{animation:count-up-scale .55s cubic-bezier(.22,1,.36,1) both}
.roi-card.nr-visible:nth-child(2) .roi-number{animation-delay:.1s}
.roi-card.nr-visible:nth-child(3) .roi-number{animation-delay:.2s}
.roi-card.nr-visible:nth-child(4) .roi-number{animation-delay:.3s}

/* ===== STAT BOX HOVER ===== */
.stat-box{transition:transform .3s cubic-bezier(.22,1,.36,1),border-color .3s,box-shadow .3s,background .3s}
.stat-box:hover{transform:translateY(-4px) scale(1.03);border-color:rgba(34,211,238,.25);box-shadow:0 8px 24px rgba(0,0,0,.3),0 0 12px rgba(34,211,238,.08);background:rgba(255,255,255,.07)}
.stat-val{transition:color .3s}
.stat-box:hover .stat-val{color:#67e8f9}

/* ===== SECTIONS — RESPIRENT MIEUX ===== */
#about{padding:7rem 0 !important}
section[style*="padding:5rem 0;overflow:hidden;position:relative"]{padding:7rem 0 !important}

/* ===== TICKER AMÉLIORÉ ===== */
.results-ticker-inner span[style*="color:#6b7280"]{transition:color .2s}
.results-ticker-inner:hover span[style*="color:#6b7280"]{color:#94a3b8}

/* ===== SECTION CTA RAFFINÉE ===== */
@keyframes cta-glow{0%,100%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}
#page-accueil section:last-of-type [style*="border-radius:50%;background:radial-gradient"]{animation:cta-glow 5s ease-in-out infinite}

/* ===== HERO STATS ENRICHIS ===== */
.hero-stats{margin-top:1rem}
.stat-box{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}

/* ===== CONTACT COORDONNÉES — HARMONISATION ===== */
.info-text > span {
  color: #22d3ee !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
}
.info-text > a[href^="mailto:"] {
  color: #d1d5db !important;
  font-size: .8rem !important;
  font-weight: 400 !important;
}
.info-text > a[href^="mailto:"]:hover {
  color: var(--cyan) !important;
}

/* ===== NDA BUTTON ===== */
.nda-button{display:inline-flex;align-items:center;gap:.625rem;margin-top:1rem;padding:.7rem 1.25rem;border-radius:.6rem;text-decoration:none;font-weight:600;font-size:.85rem;font-family:'Plus Jakarta Sans',sans-serif;background:linear-gradient(135deg,rgba(34,211,238,.12),rgba(23,145,207,.1));border:1px solid rgba(34,211,238,.3);color:#67e8f9;transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s,background .3s,border-color .3s;letter-spacing:.01em;cursor:pointer}
.nda-button:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(23,145,207,.25),0 0 16px rgba(34,211,238,.12);background:linear-gradient(135deg,rgba(34,211,238,.18),rgba(23,145,207,.15));border-color:rgba(34,211,238,.5);color:#a5f3fc}
.nda-button svg{width:15px;height:15px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ===== SECTION DIVIDERS AMÉLIORÉS ===== */
.nr-divider{height:1px;background:linear-gradient(90deg,transparent,var(--cyan2),rgba(34,211,238,.5),var(--cyan2),transparent);margin:0;animation:divider-glow 3s ease-in-out infinite alternate}

/* ===== GLASS CARD INNER GLOW AU HOVER ===== */
.glass-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);border-radius:1.5rem 1.5rem 0 0;opacity:0;transition:opacity .3s}
.glass-card{position:relative;overflow:hidden}
.glass-card:hover::before{opacity:1}

/* ===== MOBILE RESPONSIVENESS ===== */
@media(max-width:640px){
  .hero-h1-anim{animation-duration:.7s}
  .nda-button{width:100%;justify-content:center}
}

@keyframes btn-pulse{0%,100%{box-shadow:0 0 0 0 rgba(23,145,207,.4)}70%{box-shadow:0 0 0 12px rgba(23,145,207,0)}}
.btn-pulse-anim{animation:btn-pulse 2.5s ease-in-out infinite}

/* ===== RESULTS TICKER ===== */
.results-ticker{overflow:hidden;white-space:nowrap}
.results-ticker-inner{display:inline-flex;gap:3rem;animation:ticker 28s linear infinite}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== TRUST BADGES ===== */
.trust-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;color:#d1d5db}
.trust-badge svg{width:14px;height:14px;stroke:#22d3ee;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}

/* ===== ROI CARDS ===== */
.roi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;max-width:60rem;margin:0 auto}
@media(min-width:768px){.roi-grid{grid-template-columns:repeat(4,1fr)}}
.roi-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:1rem;padding:1.5rem;text-align:center;transition:all .3s}
.roi-card:hover{border-color:rgba(34,211,238,.2);transform:translateY(-4px);background:rgba(34,211,238,.04)}
.roi-number{font-family:'Space Grotesk',sans-serif;font-size:2.5rem;font-weight:700;line-height:1}
.roi-label{font-size:.72rem;color:#9ca3af;margin-top:.35rem;line-height:1.4}

/* ===== SVC TOP ROW GRID ===== */
@media(min-width:640px){#svc-top-row{grid-template-columns:repeat(2,1fr) !important}}
@media(min-width:1024px){#svc-top-row{grid-template-columns:repeat(4,1fr) !important}}
