:root {
  --blue:#0EA5E9; --blue-dark:#0369A1; --blue-light:#BAE6FD;
  --slate:#1E293B; --slate-mid:#334155; --slate-light:#64748B;
  --white:#F8FAFC; --gray:#E2E8F0;
  --radius:12px; --shadow:0 4px 24px rgba(14,165,233,.15);
  --transition:.3s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Inter','Segoe UI',sans-serif;background:var(--white);color:var(--slate);line-height:1.6;}
h1,h2,h3,h4{line-height:1.2;font-weight:700;}
h1{font-size:clamp(2rem,5vw,3.5rem);}
h2{font-size:clamp(1.6rem,3.5vw,2.5rem);}
h3{font-size:1.25rem;}
.section-label{display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);background:rgba(14,165,233,.1);padding:.3rem .9rem;border-radius:100px;margin-bottom:1rem;}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem;}
section{padding:6rem 0;}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2rem;border-radius:100px;font-weight:600;font-size:1rem;cursor:pointer;border:2px solid transparent;transition:var(--transition);text-decoration:none;}
.btn-primary{background:var(--blue);color:#fff;}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(14,165,233,.4);}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.3);}
.btn-ghost:hover{background:rgba(255,255,255,.2);transform:translateY(-2px);}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.5);}
.btn-outline:hover{background:rgba(255,255,255,.1);transform:translateY(-2px);}
.btn-white{background:#fff;color:var(--blue-dark);}
.btn-white:hover{background:var(--blue-light);transform:translateY(-2px);}

/* NAVBAR */
#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:.6rem 0;background:rgba(248,250,252,.97);backdrop-filter:blur(12px);box-shadow:0 2px 16px rgba(0,0,0,.08);transition:var(--transition);}
#navbar.scrolled{padding:.4rem 0;}
.nav-inner{display:flex;align-items:center;justify-content:space-between;}
.nav-logo{display:flex;align-items:center;text-decoration:none;}
.nav-logo-img{
  height:72px;width:auto;
  transition:transform var(--transition),filter var(--transition);
}
.nav-logo-img:hover{transform:scale(1.05);filter:drop-shadow(0 4px 12px rgba(14,165,233,.5));}
#navbar.scrolled .nav-logo-img{height:60px;}
#navbar.scrolled{padding:.4rem 0;}
.web-logo-img{filter:brightness(0) invert(1) drop-shadow(0 0 32px rgba(14,165,233,.6)) !important;}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none;}
.nav-links a{text-decoration:none;font-weight:500;transition:color var(--transition);font-size:.95rem;}
.nav-links a{color:var(--slate);}
.nav-links a:hover{color:var(--blue);}
.nav-cta{margin-left:1rem;background:var(--blue-dark);}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;}
.hamburger span{display:block;width:24px;height:2px;background:var(--slate);border-radius:2px;transition:var(--transition);}

/* HERO */
.hero-wrapper{height:100vh;display:flex;flex-direction:column;}
#hero{flex:1;min-height:0;display:flex;align-items:center;background:linear-gradient(135deg,var(--slate) 0%,#0c4a6e 50%,var(--slate-mid) 100%);position:relative;overflow:hidden;padding:0;}
#hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(14,165,233,.2) 0%,transparent 60%),radial-gradient(circle at 80% 20%,rgba(3,105,161,.3) 0%,transparent 50%);}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1;padding:8rem 0 4rem;}
.hero-content{color:#fff;}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(14,165,233,.2);border:1px solid rgba(14,165,233,.4);color:var(--blue-light);padding:.4rem 1rem;border-radius:100px;font-size:.85rem;font-weight:600;margin-bottom:1.5rem;}
.hero-content h1{margin-bottom:1.5rem;}
.hero-content h1 span{color:var(--blue);}
.hero-content p{font-size:1.15rem;color:rgba(255,255,255,.75);margin-bottom:2rem;max-width:520px;}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;}
.hero-stats{display:flex;gap:2rem;margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);}
.stat{text-align:center;}
.stat-value{display:block;font-size:2rem;font-weight:800;color:var(--blue-light);position:relative;overflow:hidden;}
.stat-value::after{content:'';position:absolute;top:0;left:0;width:60%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.6) 50%,transparent 100%);animation:shimmer 4s ease-in-out infinite;transform:translateX(-160%);}
.stat:nth-child(1) .stat-value::after{animation-delay:0s;}
.stat:nth-child(2) .stat-value::after{animation-delay:1.3s;}
.stat:nth-child(3) .stat-value::after{animation-delay:2.6s;}
@keyframes shimmer{0%{transform:translateX(-160%);}40%{transform:translateX(250%);}100%{transform:translateX(250%);}}
.stat-label{font-size:.8rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.05em;}

/* Toile d'araignée canvas */
.hero-visual{display:flex;justify-content:center;align-items:center;}
.web-animation{position:relative;width:100%;max-width:520px;aspect-ratio:1;}
#webCanvas{position:absolute;inset:0;width:100%;height:100%;border-radius:50%;}
.web-logo-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;}
.web-logo-center picture{display:contents;}
.web-logo-img{width:52%;height:52%;object-fit:contain;filter:drop-shadow(0 0 32px rgba(14,165,233,.5));animation:webFloat 5s ease-in-out infinite;}
@keyframes webFloat{0%,100%{transform:translateY(0) scale(1);}50%{transform:translateY(-10px) scale(1.03);}}
.tech-tags{position:absolute;inset:0;pointer-events:none;}
.tech-tag{position:absolute;background:rgba(255,255,255,.08);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);color:#fff;padding:.35rem .8rem;border-radius:100px;font-size:.75rem;font-weight:600;animation:float 5s ease-in-out infinite;}
.tech-tag:nth-child(2){animation-delay:1.2s;}
.tech-tag:nth-child(3){animation-delay:2.4s;}
.tech-tag:nth-child(4){animation-delay:0.6s;}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}

/* SERVICES */
#services{background:#fff;}
.section-header{text-align:center;margin-bottom:4rem;}
.section-header p{color:var(--slate-light);font-size:1.1rem;max-width:600px;margin:1rem auto 0;}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;}
.service-card{background:var(--white);border:1px solid var(--gray);border-radius:var(--radius);padding:2rem;transition:var(--transition);position:relative;overflow:hidden;}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--blue-dark));transform:scaleX(0);transition:transform var(--transition);}
.service-card:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-4px);}
.service-card:hover::before{transform:scaleX(1);}
.service-icon{width:56px;height:56px;border-radius:var(--radius);background:rgba(14,165,233,.1);display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin-bottom:1.25rem;transition:var(--transition);}
.service-card:hover .service-icon{background:var(--blue);}
.service-card h3{margin-bottom:.75rem;}
.service-card p{color:var(--slate-light);font-size:.95rem;}
.service-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1rem;}
.tag{font-size:.72rem;font-weight:600;background:rgba(14,165,233,.08);color:var(--blue-dark);padding:.2rem .6rem;border-radius:100px;}

/* POURQUOI */
#why{background:linear-gradient(135deg,var(--slate) 0%,#0c4a6e 100%);color:#fff;}
#why .section-label{color:var(--blue-light);background:rgba(186,230,253,.1);}
#why .section-header p{color:rgba(255,255,255,.7);}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;}
.why-list{list-style:none;display:flex;flex-direction:column;gap:1.25rem;}
.why-item{display:flex;gap:1rem;padding:1.25rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);transition:var(--transition);}
.why-item:hover{background:rgba(14,165,233,.15);border-color:rgba(14,165,233,.3);}
.why-icon{font-size:1.5rem;flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:rgba(14,165,233,.2);border-radius:8px;}
.why-item h3,.why-item h4{font-size:1rem;margin-bottom:.25rem;font-weight:600;}
.why-item p{font-size:.9rem;color:rgba(255,255,255,.65);}
.why-visual{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.metric-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:1.5rem;text-align:center;transition:var(--transition);}
.metric-card:hover{background:rgba(14,165,233,.15);}
.metric-card .value{font-size:2.2rem;font-weight:800;color:var(--blue);display:block;}
.metric-card .label{font-size:.8rem;color:rgba(255,255,255,.6);margin-top:.25rem;}
.metric-card.featured{grid-column:1/-1;background:rgba(14,165,233,.15);border-color:rgba(14,165,233,.3);}
.metric-card.featured .value{font-size:3rem;}

/* PROCESS */
#process{background:var(--white);}
.process-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;position:relative;}
.process-steps::before{content:'';position:absolute;top:2.5rem;left:10%;right:10%;height:2px;background:linear-gradient(90deg,var(--blue),var(--blue-dark));opacity:.15;}
.process-step{text-align:center;position:relative;}
.step-number{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;font-size:1.25rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 4px 16px rgba(14,165,233,.4);position:relative;z-index:1;}
.process-step h3{margin-bottom:.5rem;}
.process-step p{color:var(--slate-light);font-size:.9rem;}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;}
.contact-items{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem;}
.contact-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:1px solid var(--gray);border-radius:var(--radius);}
.ci-icon{width:40px;height:40px;border-radius:8px;background:rgba(14,165,233,.1);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.ci-text{font-size:.9rem;}
.ci-text strong{display:block;font-size:.72rem;color:var(--slate-light);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.15rem;}

/* RDV Calendar */
.rdv-section{background:linear-gradient(135deg,var(--slate) 0%,#0c4a6e 100%);border-radius:var(--radius);padding:1.5rem;color:#fff;}
.rdv-section h4{margin-bottom:1rem;font-size:1rem;}
.calendar-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;}
.calendar-nav button{background:rgba(255,255,255,.1);border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1rem;transition:var(--transition);}
.calendar-nav button:hover{background:rgba(14,165,233,.4);}
.calendar-month{font-weight:700;font-size:.95rem;}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:1rem;}
.cal-header{text-align:center;font-size:.62rem;font-weight:700;color:rgba(255,255,255,.45);text-transform:uppercase;padding:.3rem 0;}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:.8rem;cursor:pointer;transition:var(--transition);color:rgba(255,255,255,.75);}
.cal-day.empty,.cal-day.past{pointer-events:none;}
.cal-day.past{color:rgba(255,255,255,.2);}
.cal-day.weekend{color:rgba(255,255,255,.3);pointer-events:none;}
.cal-day.today{background:rgba(14,165,233,.2);color:var(--blue);font-weight:700;}
.cal-day.available:hover{background:rgba(14,165,233,.3);color:#fff;}
.cal-day.selected{background:var(--blue);color:#fff;font-weight:700;}
.time-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem;}
.time-slot{padding:.4rem;text-align:center;font-size:.78rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;transition:var(--transition);color:rgba(255,255,255,.8);}
.time-slot:hover{background:rgba(14,165,233,.3);}
.time-slot.selected{background:var(--blue);border-color:var(--blue);color:#fff;font-weight:600;}
.rdv-confirm{margin-top:1rem;padding:.75rem;background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.3);border-radius:8px;font-size:.85rem;text-align:center;display:none;}

/* Form */
.form-group{margin-bottom:1.25rem;}
.form-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.4rem;color:var(--slate-mid);}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.85rem 1rem;border:1.5px solid var(--gray);border-radius:var(--radius);font-size:.95rem;font-family:inherit;color:var(--slate);background:#fff;transition:var(--transition);outline:none;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(14,165,233,.15);}
.form-group textarea{resize:vertical;min-height:100px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.captcha-box{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;border:1.5px solid var(--gray);border-radius:var(--radius);background:#fff;}
.captcha-question{font-size:1rem;font-weight:700;color:var(--slate);white-space:nowrap;background:rgba(14,165,233,.08);padding:.4rem .8rem;border-radius:6px;font-family:'Courier New',monospace;}
.captcha-box input{flex:1;border:none;outline:none;font-size:.95rem;}
.captcha-refresh{background:none;border:none;cursor:pointer;font-size:1.1rem;color:var(--blue);padding:.2rem;transition:transform var(--transition);}
.captcha-refresh:hover{transform:rotate(180deg);}
.captcha-error{color:#EF4444;font-size:.8rem;margin-top:.3rem;display:none;}
.form-submit-msg{display:none;padding:1rem;border-radius:var(--radius);text-align:center;font-weight:600;margin-top:1rem;}
.form-submit-msg.success{background:rgba(34,197,94,.1);border:1.5px solid rgba(34,197,94,.3);color:#15803d;}
.form-submit-msg.error{background:rgba(239,68,68,.1);border:1.5px solid rgba(239,68,68,.3);color:#b91c1c;}

/* CTA */
#cta{background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue) 100%);padding:5rem 0;color:#fff;}

/* FOOTER */
footer{background:var(--slate);color:rgba(255,255,255,.65);padding:3rem 0 1.5rem;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2.5rem;}
.footer-col h3,.footer-col h4{color:#fff;font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;font-weight:600;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.5rem;}
.footer-col ul li a{color:rgba(255,255,255,.5);text-decoration:none;font-size:.9rem;transition:color var(--transition);}
.footer-col ul li a:hover{color:var(--blue);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;font-size:.85rem;}
.social-links{display:flex;gap:.75rem;}
.social-link{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);text-decoration:none;font-size:.85rem;transition:var(--transition);}
.social-link:hover{background:var(--blue);color:#fff;}

/* Scroll top */
#scrollTop{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;border-radius:50%;background:var(--blue);color:#fff;border:none;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(14,165,233,.4);opacity:0;transform:translateY(20px);transition:var(--transition);z-index:500;}
#scrollTop.visible{opacity:1;transform:translateY(0);}
#scrollTop:hover{background:var(--blue-dark);}

/* Mobile menu */
.mobile-menu{display:none;position:fixed;inset:0;z-index:999;background:rgba(30,41,59,.97);backdrop-filter:blur(8px);flex-direction:column;align-items:center;justify-content:center;gap:2rem;}
.mobile-menu.open{display:flex;}
.mobile-menu a{color:#fff;text-decoration:none;font-size:1.5rem;font-weight:700;transition:color var(--transition);}
.mobile-menu a:hover{color:var(--blue);}
.mobile-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;}

/* Fade-in */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;}
.fade-in.visible{opacity:1;transform:none;}

/* RESPONSIVE */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr;}
  .why-grid{grid-template-columns:1fr;}
}
@media(max-width:768px){
  .nav-links,.nav-cta{display:none;}
  .hamburger{display:flex;}
  .hero-grid{grid-template-columns:1fr;text-align:center;padding:7rem 0 3rem;}
  .hero-visual{order:-1;width:100%;display:flex;justify-content:center;}
  .web-animation{max-width:260px;opacity:.7;transition:opacity .3s;}
  .hero-actions{justify-content:center;}
  .hero-stats{justify-content:center;}
  .contact-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;gap:1rem;text-align:center;}
  .form-row{grid-template-columns:1fr;}
  .why-visual{grid-template-columns:1fr 1fr;}
  section{padding:4rem 0;}
  .process-steps::before{display:none;}
}
@media(max-width:480px){
  .hero-stats{flex-wrap:wrap;}
  .web-animation{max-width:200px;opacity:.5;}
  .time-slots{grid-template-columns:repeat(2,1fr);}
  .why-visual{grid-template-columns:1fr;}
}

/* ══ MEGA MENU ══════════════════════════════════ */
.has-mega{position:relative;}
.nav-link-btn{background:none;border:none;cursor:pointer;font-weight:500;font-size:.95rem;transition:color var(--transition);display:flex;align-items:center;gap:.3rem;padding:0;text-decoration:none;}
.nav-link-btn{color:var(--slate);}
.nav-link-btn:hover{color:var(--blue);}
.nav-arrow{font-size:.65rem;transition:transform .25s;}
.has-mega:hover .nav-arrow{transform:rotate(180deg);}

.mega-menu{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(-8px);
  background:transparent;border-radius:16px;
  padding-top:1rem;width:520px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .25s ease,transform .25s ease,visibility .25s;
  z-index:200;
}
.mega-menu-inner-wrap{
  background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.15);
  border:1px solid var(--gray);padding:1.25rem;
}
.has-mega:hover .mega-menu{
  opacity:1;visibility:visible;pointer-events:all;
  transform:translateX(-50%) translateY(0);
}
/* triangle */
.mega-menu-inner-wrap::before{
  content:'';position:absolute;top:-7px;left:50%;transform:translateX(-50%);
  width:14px;height:7px;
  background:#fff;clip-path:polygon(50% 0,0 100%,100% 100%);
}
.mega-menu-inner-wrap{position:relative;}
.mega-inner{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;}
.mega-item{
  display:flex;align-items:flex-start;gap:.75rem;
  padding:.75rem;border-radius:10px;text-decoration:none;color:var(--slate);
  transition:background .2s;
}
.mega-item:hover{background:rgba(14,165,233,.06);}
.mega-icon{font-size:1.4rem;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(14,165,233,.08);border-radius:8px;}
.mega-item strong{display:block;font-size:.9rem;color:var(--slate);margin-bottom:.15rem;}
.mega-item p{font-size:.78rem;color:var(--slate-light);margin:0;}

/* Stagger d'apparition des items */
.mega-item{opacity:0;transform:translateY(6px);transition:opacity .2s,transform .2s,background .2s;}
.has-mega:hover .mega-item{opacity:1;transform:none;}
.has-mega:hover .mega-item:nth-child(1){transition-delay:.05s;}
.has-mega:hover .mega-item:nth-child(2){transition-delay:.08s;}
.has-mega:hover .mega-item:nth-child(3){transition-delay:.11s;}
.has-mega:hover .mega-item:nth-child(4){transition-delay:.14s;}
.has-mega:hover .mega-item:nth-child(5){transition-delay:.17s;}
.has-mega:hover .mega-item:nth-child(6){transition-delay:.20s;}

/* ══ TRUST BAR ══════════════════════════════════ */
.trust-bar{background:#fff;border-bottom:1px solid var(--gray);padding:.75rem 0;}
.trust-inner{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap;font-size:.85rem;font-weight:600;color:var(--slate-mid);}
.trust-sep{color:var(--gray);font-size:1.2rem;}

/* ══ ÉQUIPE & BUREAUX ════════════════════════════ */
#equipe{background:#fff;}
.equipe-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;}
.equipe-card{background:var(--white);border-radius:20px;overflow:hidden;box-shadow:0 4px 32px rgba(14,165,233,.10);transition:transform var(--transition),box-shadow var(--transition);}
.equipe-card:hover{transform:translateY(-6px);box-shadow:0 12px 48px rgba(14,165,233,.18);}
.equipe-img-wrap{position:relative;overflow:hidden;height:280px;}
.equipe-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.equipe-card:hover .equipe-img{transform:scale(1.04);}
.equipe-badge{position:absolute;top:1rem;left:1rem;background:rgba(14,165,233,.92);color:#fff;padding:.35rem .9rem;border-radius:100px;font-size:.8rem;font-weight:700;backdrop-filter:blur(6px);}
.equipe-info{padding:1.75rem;}
.equipe-info h3{font-size:1.2rem;margin-bottom:.75rem;color:var(--slate);}
.equipe-info p{color:var(--slate-light);font-size:.95rem;line-height:1.65;margin-bottom:1.25rem;}
.equipe-values{list-style:none;display:flex;flex-direction:column;gap:.5rem;}
.equipe-values li{font-size:.88rem;font-weight:500;color:var(--slate-mid);}

/* ══ EXPERTISE SECTIONS ═════════════════════════ */
.expertise-section{padding:6rem 0;}
.expertise-section.alt-bg{background:#f8fafc;}
.expertise-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.expertise-grid.reverse{direction:rtl;}
.expertise-grid.reverse > *{direction:ltr;}

.expertise-content .section-label{margin-bottom:.75rem;}
.expertise-content h2{margin-bottom:1rem;}
.expertise-content p{color:var(--slate-light);font-size:1.05rem;margin-bottom:1.5rem;line-height:1.7;}
.text-blue{color:var(--blue);}

.expertise-list{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem;}
.expertise-list li{display:flex;align-items:center;gap:.75rem;font-size:.95rem;color:var(--slate-mid);}
.check{width:22px;height:22px;border-radius:50%;background:rgba(14,165,233,.12);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:900;flex-shrink:0;}

.expertise-actions{display:flex;gap:1rem;flex-wrap:wrap;}
.btn-outline-dark{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2rem;border-radius:100px;font-weight:600;font-size:1rem;cursor:pointer;border:2px solid var(--slate-mid);color:var(--slate-mid);text-decoration:none;transition:var(--transition);background:transparent;}
.btn-outline-dark:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px);}

/* Mockup browser */
.expertise-mockup{position:relative;padding:1rem;}
.mockup-browser{background:#fff;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.12);overflow:hidden;border:1px solid var(--gray);}
.browser-bar{background:#f1f5f9;padding:.6rem 1rem;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid var(--gray);}
.dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.dot.red{background:#FF5F57;}.dot.yellow{background:#FFBD2E;}.dot.green{background:#28CA41;}
.browser-url{flex:1;background:#fff;border-radius:100px;font-size:.72rem;padding:.25rem .75rem;color:var(--slate-light);text-align:center;margin:0 .5rem;}
.browser-content{padding:1.5rem;}
.mockup-line{border-radius:100px;background:#e2e8f0;}
.mockup-line.w80{width:80%;}.mockup-line.w60{width:60%;}
.mockup-line.h12{height:12px;}.mockup-line.h8{height:8px;}
.mockup-line.blue{background:linear-gradient(90deg,var(--blue),var(--blue-dark));}
.mockup-line.light{background:#e2e8f0;}
.mt4{margin-top:4px;}.mt8{margin-top:8px;}.mt12{margin-top:12px;}.mt16{margin-top:16px;}
.mockup-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem;}
.mockup-card{height:48px;border-radius:8px;}
.blue-card{background:linear-gradient(135deg,rgba(14,165,233,.15),rgba(3,105,161,.1));}
.mockup-btn{height:32px;width:40%;border-radius:100px;background:linear-gradient(90deg,var(--blue),var(--blue-dark));}

.expertise-badge-float{
  position:absolute;background:#fff;border:1px solid var(--gray);border-radius:100px;
  padding:.45rem 1rem;font-size:.8rem;font-weight:700;color:var(--slate);
  box-shadow:0 4px 16px rgba(0,0,0,.1);white-space:nowrap;
}
.badge-top{top:-10px;right:-20px;}
.badge-bottom{bottom:20px;left:-20px;}
.badge-right{top:30%;right:-20px;}
.badge-left2{bottom:25%;left:-20px;}

/* Phone mockup */
.mobile-mockup-wrap{position:relative;display:flex;justify-content:center;padding:2rem;}
.phone-mockup{width:200px;background:var(--slate);border-radius:32px;padding:12px;box-shadow:0 30px 60px rgba(0,0,0,.2);}
.phone-screen{background:#fff;border-radius:22px;overflow:hidden;min-height:360px;}
.phone-header{height:20px;background:var(--slate);border-radius:0 0 16px 16px;margin:0 30%;}
.phone-content{padding:1rem;}
.phone-card{height:60px;border-radius:10px;background:linear-gradient(135deg,rgba(14,165,233,.1),rgba(3,105,161,.05));border:1px solid rgba(14,165,233,.15);}
.phone-tabs{display:flex;gap:.5rem;justify-content:center;}
.tab{width:36px;height:5px;border-radius:100px;background:#e2e8f0;}
.active-tab{background:var(--blue);}

/* DevOps pipeline visual */
.devops-visual{background:var(--slate);border-radius:16px;padding:2rem;box-shadow:0 20px 60px rgba(0,0,0,.2);}
.pipeline{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:.5rem;}
.pipe-step{display:flex;flex-direction:column;align-items:center;gap:.4rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.75rem .9rem;transition:.3s;}
.pipe-step.active-pipe{background:rgba(14,165,233,.2);border-color:rgba(14,165,233,.4);}
.pipe-icon{font-size:1.4rem;}
.pipe-label{font-size:.7rem;font-weight:700;color:rgba(255,255,255,.7);text-transform:uppercase;}
.pipe-arrow{color:rgba(14,165,233,.5);font-size:1.2rem;font-weight:900;}
.devops-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
.d-metric{text-align:center;background:rgba(255,255,255,.04);border-radius:10px;padding:1rem .5rem;}
.d-val{display:block;font-size:1.5rem;font-weight:800;color:var(--blue);}
.d-lbl{font-size:.7rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.05em;}

/* Pipeline animation */
@keyframes pipeActivate{0%,100%{opacity:.4}50%{opacity:1}}
.pipe-step:not(.active-pipe){animation:pipeActivate 3s ease-in-out infinite;}
.pipe-step:nth-child(3){animation-delay:.5s;}
.pipe-step:nth-child(5){animation-delay:1s;}
.pipe-step:nth-child(7){animation-delay:1.5s;}
.pipe-step:nth-child(9){animation-delay:2s;}

/* ══ RÉALISATIONS ═══════════════════════════════ */
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.project-card{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray);transition:var(--transition);}
.project-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,.1);}
.project-img{height:180px;position:relative;overflow:hidden;}
.web-thumb{background:linear-gradient(135deg,#0EA5E9 0%,#0369A1 100%);}
.mobile-thumb{background:linear-gradient(135deg,#8B5CF6 0%,#6D28D9 100%);}
.devops-thumb{background:linear-gradient(135deg,#1E293B 0%,#0c4a6e 100%);}
.proj-overlay{position:absolute;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;opacity:0;transition:.3s;}
.proj-overlay span{color:#fff;font-weight:700;font-size:.95rem;}
.project-card:hover .proj-overlay{opacity:1;}
.proj-cat{position:absolute;top:.75rem;left:.75rem;background:rgba(255,255,255,.2);backdrop-filter:blur(4px);color:#fff;font-size:.72rem;font-weight:700;padding:.2rem .7rem;border-radius:100px;}
.project-info{padding:1.25rem;}
.project-info h3{font-size:1rem;margin-bottom:.4rem;}
.project-info p{font-size:.85rem;color:var(--slate-light);margin-bottom:.75rem;}
.proj-tags{display:flex;flex-wrap:wrap;gap:.3rem;}
.proj-tags span{font-size:.72rem;font-weight:600;background:rgba(14,165,233,.08);color:var(--blue-dark);padding:.15rem .5rem;border-radius:100px;}

/* ══ CHATBOT ═════════════════════════════════════ */
.chatbot-wrap{background:#fff;border-radius:16px;border:1px solid var(--gray);box-shadow:0 4px 32px rgba(14,165,233,.10);display:flex;flex-direction:column;height:520px;overflow:hidden;}
.chatbot-header{display:flex;align-items:center;gap:.85rem;padding:1rem 1.25rem;background:linear-gradient(135deg,var(--slate) 0%,#0c4a6e 100%);color:#fff;}
.chatbot-avatar{font-size:1.6rem;background:rgba(255,255,255,.15);border-radius:50%;width:42px;height:42px;display:flex;align-items:center;justify-content:center;}
.chatbot-header strong{display:block;font-size:.95rem;}
.chatbot-status{font-size:.75rem;color:#86efac;}
.chatbot-messages{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;scroll-behavior:smooth;}
.chat-msg{max-width:82%;padding:.7rem 1rem;border-radius:14px;font-size:.9rem;line-height:1.5;animation:chatIn .25s ease;}
@keyframes chatIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
.chat-msg.bot{background:var(--white);border:1px solid var(--gray);color:var(--slate);border-bottom-left-radius:4px;align-self:flex-start;}
.chat-msg.user{background:var(--blue);color:#fff;border-bottom-right-radius:4px;align-self:flex-end;}
.chatbot-choices{padding:.75rem 1rem;display:flex;flex-wrap:wrap;gap:.5rem;border-top:1px solid var(--gray);}
.chat-choice{background:var(--white);border:1.5px solid var(--blue);color:var(--blue);padding:.4rem .9rem;border-radius:100px;font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition);}
.chat-choice:hover{background:var(--blue);color:#fff;}
.chatbot-input-row{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--gray);}
.chatbot-input-row input{flex:1;padding:.55rem .9rem;border:1.5px solid var(--gray);border-radius:100px;font-size:.9rem;outline:none;transition:border-color var(--transition);}
.chatbot-input-row input:focus{border-color:var(--blue);}
.chatbot-input-row button{background:var(--blue);color:#fff;border:none;border-radius:50%;width:38px;height:38px;cursor:pointer;font-size:1rem;transition:background var(--transition);}
.chatbot-input-row button:hover{background:var(--blue-dark);}
.chat-typing{display:flex;gap:5px;align-items:center;padding:.5rem .75rem;}
.chat-typing span{width:7px;height:7px;background:var(--slate-light);border-radius:50%;animation:typing .9s infinite;}
.chat-typing span:nth-child(2){animation-delay:.2s;}
.chat-typing span:nth-child(3){animation-delay:.4s;}
@keyframes typing{0%,60%,100%{transform:translateY(0);}30%{transform:translateY(-6px);}}
.chat-success{text-align:center;padding:1.5rem;color:var(--blue-dark);}
.chat-success .check{font-size:2.5rem;display:block;margin-bottom:.5rem;}

/* ══ RESPONSIVE NOUVELLES SECTIONS ══════════════ */
@media(max-width:1024px){
  .expertise-grid{grid-template-columns:1fr;gap:3rem;}
  .expertise-grid.reverse{direction:ltr;}
  .projects-grid{grid-template-columns:1fr 1fr;}
  .mega-menu{width:380px;}
}
@media(max-width:768px){
  .equipe-grid{grid-template-columns:1fr;}
  .trust-bar{display:none;}
  .projects-grid{grid-template-columns:1fr;}
  .pipeline{justify-content:center;}
  .pipe-arrow{display:none;}
  .devops-metrics{grid-template-columns:1fr 1fr 1fr;}
  .mega-menu{display:none;}
}
