/* ═══════════════════════════════════════════
   MOTIONLAB — SHARED STYLESHEET v2
   Poppins · White body · Green accent rgb(120,184,74)
   Dark nav/dark → rgb(21,30,45)
════════════════════════════════════════════ */
:root {
  --white:        #ffffff;
  --off-white:    #f7f9f6;
  --gray-50:      #f3f5f2;
  --gray-100:     #e6ebe4;
  --gray-200:     #cdd6ca;
  --gray-400:     #8a9e88;
  --gray-600:     #4a5e48;
  --gray-900:     #151e2d;

  --accent:       #78b84a;
  --accent-dark:  #5f9836;
  --accent-light: #96cc6a;
  --accent-soft:  rgba(120,184,74,.09);
  --accent-mid:   rgba(120,184,74,.18);

  --dark-bg:      #151e2d;
  --dark-bg2:     #1c2840;
  --dark-border:  rgba(255,255,255,.08);
  --dark-text:    #e0ecd8;
  --dark-muted:   #6a8060;

  --font: 'Poppins', sans-serif;
  --nav-h: 72px;
  --r-sm: 8px; --r: 14px; --r-lg: 22px; --r-xl: 32px; --r-pill: 999px;
  --shadow-sm: 0 1px 4px rgba(21,30,45,.06);
  --shadow:    0 4px 18px rgba(21,30,45,.09);
  --shadow-lg: 0 16px 48px rgba(21,30,45,.13);
  --shadow-xl: 0 32px 80px rgba(21,30,45,.16);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--white);color:var(--gray-900);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}
button{font-family:var(--font);cursor:pointer}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--off-white)}::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:3px}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:900;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 3rem;background:transparent;transition:background .3s,box-shadow .3s}
.navDark{background: rgba(21,30,45,.92);}
nav.scrolled{background:rgba(255,255,255,.96);backdrop-filter:blur(16px);box-shadow:0 1px 0 var(--gray-100)}
nav.always-white{background:rgba(255,255,255,.97);box-shadow:0 1px 0 var(--gray-100)}
.nav-logo{display:flex;align-items:center;gap:.2rem;font-size:1.55rem;font-weight:700;letter-spacing:-.03em;color:var(--white);transition:color .3s;flex-shrink:0}
nav.scrolled .nav-logo,nav.always-white .nav-logo{color:var(--gray-900)}
.nav-logo-icon{width:80px;height:80px;}
.nav-logo-icon svg{width:20px;height:20px}
.logo-dot{color:var(--accent);margin: 0;  padding: 0; }
.nav-links{display:flex;align-items:center;gap:.2rem;list-style:none}
.nav-links>li{position:relative}
.nav-links>li>a{display:flex;align-items:center;gap:.3rem;padding:.55rem .9rem;font-size:.82rem;font-weight:500;color:rgba(255,255,255,.85);border-radius:var(--r-pill);transition:color .2s,background .2s;white-space:nowrap}
nav.scrolled .nav-links>li>a,nav.always-white .nav-links>li>a{color:var(--gray-600)}
.nav-links>li>a:hover{color:var(--gray-900);background:var(--gray-50)}
nav:not(.scrolled):not(.always-white) .nav-links>li>a:hover{color:#fff;background:rgba(255,255,255,.12)}
.arrow-icon{width:11px;height:11px;opacity:.6;transition:transform .2s}
.dropdown:hover .arrow-icon{transform:rotate(180deg)}
.dropdown{position:relative}
.dropdown-menu{
  display:none;
  position:absolute;
  /* No gap — sit flush under the <li>, use padding-top as visual spacing */
  top:100%;
  left:0;
  /* Transparent top padding acts as a hover bridge so mouse can travel without dropdown closing */
  padding-top:10px;
  min-width:230px;
  z-index:910;
}
.dropdown-menu-inner{
  background:var(--white);
  border:1px solid var(--gray-100);
  border-radius:var(--r-lg);
  padding:.6rem;
  box-shadow:var(--shadow-xl);
}
.dropdown:hover .dropdown-menu{display:block}
.dropdown-menu-inner a{display:flex;align-items:center;gap:.8rem;padding:.6rem .85rem;font-size:.83rem;font-weight:500;color:var(--gray-600);border-radius:var(--r-sm);transition:all .15s}
.dropdown-menu-inner a:hover{color:var(--gray-900);background:var(--gray-50)}
.dm-icon{width:30px;height:30px;border-radius:8px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0}
.badge-new{margin-left:auto;font-size:.6rem;font-weight:600;padding:2px 7px;border-radius:var(--r-pill);background:var(--accent);color:#fff}
.nav-right{display:flex;align-items:center;gap:.8rem}
.nav-contact{font-size:.82rem;font-weight:500;color:rgba(255,255,255,.8);transition:color .3s}
nav.scrolled .nav-contact,nav.always-white .nav-contact{color:var(--gray-600)}
.nav-contact:hover{color:var(--accent)}
.btn-nav-cta{padding:.52rem 1.3rem;background:var(--accent);color:#fff;font-size:.82rem;font-weight:600;border:none;border-radius:var(--r-pill);transition:all .2s;white-space:nowrap;box-shadow:0 4px 14px rgba(120,184,74,.35)}
.btn-nav-cta:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(120,184,74,.45)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px}
.burger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:all .3s}
nav.scrolled .burger span,nav.always-white .burger span{background:var(--gray-900)}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:var(--white);z-index:800;padding:2rem;overflow-y:auto}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:.9rem 0;font-size:1.05rem;font-weight:600;border-bottom:1px solid var(--gray-100);color:var(--gray-900)}
.mobile-submenu a{font-size:.88rem;font-weight:400;color:var(--gray-600);padding-left:1rem}

/* ── HERO CAROUSEL ── */
.hero{position:relative;height:100vh;min-height:620px;overflow:hidden}
.carousel{position:absolute;inset:0}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease}
.slide.active{opacity:1}
.slide-img{width:100%;height:100%;object-fit:cover;object-position:center}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(21,30,45,.82) 0%,rgba(21,30,45,.5) 50%,rgba(21,30,45,.18) 100%)}
.hero-content{position:absolute;inset:0;z-index:3;display:flex;align-items:center;padding:0 5rem 0 8rem;padding-top:var(--nav-h)}
.hero-inner{max-width:600px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:1.2rem}
.hero-eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{transform:scale(1);box-shadow:0 0 6px var(--accent)}50%{transform:scale(1.4);box-shadow:0 0 16px rgba(120,184,74,.6)}}
.slide-title{font-size:clamp(2.2rem,5vw,4.4rem);font-weight:800;line-height:1.07;letter-spacing:-.035em;color:var(--white);opacity:0;transform:translateY(28px);transition:opacity .85s ease .25s,transform .85s ease .25s}
.slide.active .slide-title{opacity:1;transform:translateY(0)}
.slide-title em{font-style:normal;color:var(--accent-light)}
.slide-sub{font-size:1rem;font-weight:300;line-height:1.65;color:rgba(255,255,255,.72);margin-top:1rem;max-width:500px;opacity:0;transform:translateY(20px);transition:opacity .85s ease .45s,transform .85s ease .45s}
.slide.active .slide-sub{opacity:1;transform:translateY(0)}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2.2rem;opacity:0;transform:translateY(16px);transition:opacity .85s ease .65s,transform .85s ease .65s}
.slide.active .hero-btns{opacity:1;transform:translateY(0)}
.btn-primary{display:inline-flex;align-items:center;gap:.45rem;padding:.76rem 1.8rem;background:var(--accent);color:#fff;font-size:.88rem;font-weight:600;border:none;border-radius:var(--r-pill);transition:all .22s;box-shadow:0 8px 24px rgba(120,184,74,.4);cursor:pointer}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 12px 32px rgba(120,184,74,.5)}
.btn-ghost-white{display:inline-flex;align-items:center;gap:.45rem;padding:.76rem 1.8rem;background:rgba(255,255,255,.12);color:#fff;font-size:.88rem;font-weight:500;border:1px solid rgba(255,255,255,.28);border-radius:var(--r-pill);backdrop-filter:blur(8px);transition:all .22s}
.btn-ghost-white:hover{background:rgba(255,255,255,.22);transform:translateY(-2px)}
.btn-secondary{display:inline-flex;align-items:center;gap:.45rem;padding:.76rem 1.8rem;background:transparent;color:var(--accent);font-size:.88rem;font-weight:600;border:1.5px solid var(--accent);border-radius:var(--r-pill);transition:all .22s;cursor:pointer}
.btn-secondary:hover{background:var(--accent-soft);transform:translateY(-1px)}
.carousel-arrow{position:absolute;top:50%;z-index:5;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.22);color:#fff;font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.carousel-arrow:hover{background:rgba(255,255,255,.25)}
.carousel-prev{left:2.5rem}.carousel-next{right:2.5rem}
.carousel-dots{position:absolute;bottom:2rem;left:8rem;z-index:5;display:flex;gap:.5rem}
.dot-btn{height:3px;width:24px;border-radius:2px;background:rgba(255,255,255,.3);border:none;cursor:pointer;transition:all .3s;padding:0}
.dot-btn.active{background:#fff;width:40px}
.scroll-hint{position:absolute;bottom:2rem;right:3rem;z-index:5;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.scroll-arrow{width:26px;height:26px;border:1px solid rgba(255,255,255,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.45);animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* Page hero (secondary pages) */
.page-hero{background:var(--dark-bg);padding:calc(var(--nav-h)+4rem) 3rem 4rem;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 60% 40%,rgba(120,184,74,.12),transparent 65%)}
.page-hero-inner{position:relative;z-index:1;max-width:700px;margin:0 auto}
.page-hero-label{display:inline-flex;align-items:center;gap:.5rem;font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.page-hero-title{font-size:clamp(2rem,5vw,3.6rem);font-weight:800;line-height:1.08;letter-spacing:-.035em;color:var(--white);margin-bottom:1rem}
.page-hero-title em{font-style:normal;color:var(--accent-light)}
.page-hero-desc{font-size:1rem;font-weight:300;color:rgba(255,255,255,.6);line-height:1.7;max-width:540px;margin:0 auto}

/* ── SHARED SECTION ── */
.section{padding:7rem 3rem;background:var(--white)}
.section.bg-off{background:var(--off-white)}
.section-inner{max-width:1200px;margin:0 auto}
.section-eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:.9rem}
.section-eyebrow::before{content:'';display:block;width:18px;height:2px;background:var(--accent);border-radius:2px}
.section-title{font-size:clamp(1.85rem,3.5vw,2.9rem);font-weight:800;line-height:1.1;letter-spacing:-.03em;color:var(--gray-900);margin-bottom:.9rem}
.section-title em{font-style:normal;color:var(--accent)}
.section-desc{font-size:1rem;font-weight:300;color:var(--gray-600);max-width:520px;line-height:1.7}
.reveal{opacity:0;transform:translateY(36px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.rd1{transition-delay:.1s}.rd2{transition-delay:.2s}.rd3{transition-delay:.3s}.rd4{transition-delay:.4s}

/* ── TRUSTED BY ── */
.trusted-section{padding:6rem 3rem;background:var(--white)}
.trusted-inner{max-width:1300px;margin:0 auto}
.trusted-card{background:var(--gray-50);border:1px solid var(--gray-100);border-radius:var(--r-xl);padding:3.5rem 3rem;text-align:center}
.trusted-title{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;letter-spacing:-.025em;color:var(--gray-900);margin-bottom:.6rem}
.trusted-title em{font-style:normal;color:var(--accent)}
.trusted-subtitle{font-size:.88rem;font-weight:300;color:var(--gray-600);margin-bottom:2.5rem}
.trusted-subtitle em{font-style:normal; font-size:clamp(1.4rem,2.0vw,1.7rem);font-weight:600;color:var(--gray-700);margin-bottom:2.5rem}
.trusted-logos-wrap{position:relative;overflow:hidden}
.trusted-logos{display:flex;align-items:flex-start;gap:2.5rem;transition:transform .45s cubic-bezier(.4,0,.2,1);will-change:transform}
.trusted-logo-item{display:flex;flex-direction:column;align-items:center;gap:.7rem;font-size:.82rem;font-weight:600;color:var(--gray-500);opacity:.55;transition:all .25s;text-align:center;min-width:100px;flex-shrink:0}
.trusted-logo-item:hover{opacity:1;filter:none;color:var(--gray-900)}
.tl-icon{width:160px;height:160px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:2rem;transition:all .25s}
.trusted-logo-item:hover .tl-icon{background:var(--accent-soft);box-shadow:0 4px 16px rgba(120,184,74,.15)}
.trusted-nav{display:none;align-items:center;justify-content:center;gap:.8rem;margin-top:2rem}
.trusted-nav.visible{display:flex}
.trusted-arrow{width:38px;height:38px;border-radius:50%;background:var(--white);border:1.5px solid var(--gray-200);display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;transition:all .2s;color:var(--gray-600)}
.trusted-arrow:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px rgba(120,184,74,.2)}
.trusted-arrow:disabled{opacity:.3;cursor:default;transform:none;box-shadow:none}
.trusted-dots-row{display:flex;gap:.4rem}
.trusted-dot{width:6px;height:6px;border-radius:50%;background:var(--gray-200);border:none;cursor:pointer;padding:0;transition:all .25s}
.trusted-dot.active{background:var(--accent);width:20px;border-radius:3px}

/* ── PRESTATION — rounded card inside white section ── */
.prestation-section{padding:0 3rem 5rem;background:var(--white)}
.prestation-card-outer{max-width:1400px;margin:0 auto;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-xl)}
.prestation-hero{position:relative;overflow:hidden;min-height:540px;display:flex;align-items:center;border-radius:var(--r-xl)}
.prestation-hero-img{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;filter:brightness(.32) saturate(.65)}
.prestation-hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(135deg,rgba(21,30,45,.92) 0%,rgba(21,30,45,.65) 55%,rgba(120,184,74,.1) 100%)}
.prestation-hero-content{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:6rem 3rem;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.ph-text .section-eyebrow{color:var(--accent-light)}
.ph-text .section-eyebrow::before{background:var(--accent-light)}
.ph-title{font-size:clamp(2rem,4vw,3.5rem);font-weight:800;line-height:1.07;letter-spacing:-.035em;color:var(--white);margin-bottom:1rem}
.ph-title em{font-style:normal;color:var(--accent-light)}
.ph-desc{font-size:1rem;font-weight:300;color:rgba(255,255,255,.72);line-height:1.7;max-width:440px;margin-bottom:0.75rem}
.ph-features{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1rem}
.ph-feat{display:flex;align-items:center;gap:.8rem;font-size:.88rem;color:rgba(255,255,255,.8)}
.ph-feat-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}
.ph-mockup{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-xl);padding:1.8rem;backdrop-filter:blur(12px);box-shadow:0 32px 80px rgba(0,0,0,.4)}
.mockup-bar{display:flex;align-items:center;gap:.5rem;margin-bottom:1.2rem}
.mb-dot{width:9px;height:9px;border-radius:50%}
.mb-dot:nth-child(1){background:#ff5f57}.mb-dot:nth-child(2){background:#febc2e}.mb-dot:nth-child(3){background:#28c840}
.mb-title{flex:1;height:20px;background:rgba(255,255,255,.06);border-radius:4px}
.mb-search{width:70px;height:20px;background:rgba(255,255,255,.06);border-radius:4px}
.gesture-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.55rem}
.gesture-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:.75rem;display:flex;flex-direction:column;align-items:center;gap:.35rem;text-align:center;transition:all .3s;cursor:pointer}
.gesture-card:hover{background:rgba(120,184,74,.15);border-color:rgba(120,184,74,.4);transform:translateY(-2px)}
.gesture-card.featured{grid-column:span 2;flex-direction:row;gap:.9rem;text-align:left;background:rgba(120,184,74,.1);border-color:rgba(120,184,74,.3)}
.gc-emoji{font-size:1.7rem}.gesture-card.featured .gc-emoji{font-size:2.4rem}
.gc-label{font-size:.58rem;color:rgba(255,255,255,.5);font-weight:500}
.gc-info strong{display:block;font-size:.82rem;color:#fff;font-weight:600}
.gc-info span{font-size:.7rem;color:rgba(255,255,255,.5)}
.gc-badges{display:flex;gap:.3rem;flex-wrap:wrap;margin-top:.4rem}
.gc-badge{font-size:.56rem;font-weight:600;padding:2px 6px;border-radius:4px;background:rgba(120,184,74,.2);color:#b0e080;border:1px solid rgba(120,184,74,.3)}

/* ── SERVICES ── */
.services-section{padding:7rem 3rem;background:var(--white)}
.services-header{max-width:1200px;margin:0 auto 4rem;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:end}
.services-header-right{display:flex;align-items:flex-end;justify-content:flex-end}
.services-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.service-card{background:var(--gray-50);border:1px solid var(--gray-100);border-radius:var(--r-xl);padding:2.4rem 2rem;display:flex;flex-direction:column;transition:all .3s;cursor:pointer;position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-light));opacity:0;transition:opacity .3s;border-radius:var(--r-xl) var(--r-xl) 0 0}
.service-card:hover{background:var(--white);box-shadow:var(--shadow-xl);transform:translateY(-6px);border-color:transparent}
.service-card:hover::before{opacity:1}
.service-img-wrap{width:100%;aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;margin-bottom:1.7rem;background:var(--gray-100)}
.service-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.service-card:hover .service-img{transform:scale(1.05)}
.service-num{font-size:.66rem;font-weight:600;letter-spacing:.12em;color:var(--accent);text-transform:uppercase;margin-bottom:.7rem}
.service-name{font-size:1.2rem;font-weight:700;letter-spacing:-.02em;color:var(--gray-900);margin-bottom:.7rem}
.service-desc{font-size:.87rem;font-weight:300;color:var(--gray-600);line-height:1.65;flex:1}
.service-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.3rem}
.stag{font-size:.63rem;font-weight:500;padding:3px 10px;border-radius:var(--r-pill);background:var(--accent-soft);color:var(--accent-dark);border:1px solid rgba(120,184,74,.2)}
.service-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1.5rem;font-size:.82rem;font-weight:600;color:var(--accent);transition:gap .2s}
.service-link:hover{gap:.7rem}
.sectors-strip{max-width:1200px;margin:3.5rem auto 0;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding-top:2.5rem;border-top:1px solid var(--gray-100)}
.sectors-label{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-400)}
.sector-pill{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.1rem;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-pill);font-size:.82rem;font-weight:500;color:var(--gray-600);transition:all .2s}
.sector-pill:hover{border-color:var(--accent);color:var(--accent-dark);background:var(--accent-soft);transform:translateY(-2px)}

/* ── MASONRY GALLERY ── */
.projects-section{padding:7rem 3rem;background:var(--off-white); background-color:rgb(255, 255, 255);}
.projects-inner{max-width:1200px;margin:0 auto}
.filter-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:2.5rem;margin-bottom:3rem}
.filter-btn{padding:.44rem 1.1rem;font-size:.78rem;font-weight:500;font-family:var(--font);border:1.5px solid var(--gray-200);border-radius:var(--r-pill);background:var(--white);color:var(--gray-600);cursor:pointer;transition:all .2s}
.filter-btn:hover{border-color:var(--accent);color:var(--accent-dark)}
.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 12px rgba(120,184,74,.3)}
.reload-btn {    background: #111;    color: #fff;    border: 1px solid #333;    margin-right: 10px;}
.reload-btn:hover {    background: #222;}
.masonry{columns:3;column-gap:1.2rem}
.masonry-item{break-inside:avoid;margin-bottom:1.2rem;border-radius:var(--r-lg);overflow:hidden;background:var(--white);border:1px solid var(--gray-100);box-shadow:var(--shadow-sm);cursor:pointer;position:relative;transition:transform .3s,box-shadow .3s,border-color .3s}
.masonry-item:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:rgba(120,184,74,.25)}
.proj-thumb-wrap{overflow:hidden;width:100%}
.proj-thumb{width:100%;display:block;object-fit:cover;transition:transform .5s}
.masonry-item:hover .proj-thumb{transform:scale(1.04)}
.masonry-info{padding:1.1rem 1.3rem 1.4rem}
.proj-cat{font-size:.63rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:.35rem}
.proj-title{font-size:.97rem;font-weight:700;letter-spacing:-.02em;color:var(--gray-900);margin-bottom:.45rem;line-height:1.35}
.proj-desc{font-size:.81rem;font-weight:300;color:var(--gray-600);line-height:1.55}
.proj-tags{display:flex;gap:.35rem;flex-wrap:wrap;margin-top:.8rem}
.ptag{font-size:.61rem;font-weight:500;padding:2px 8px;border-radius:var(--r-pill);background:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-200)}
.masonry-item .proj-overlay{position:absolute;inset:0;background:rgba(120,184,74,.06);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;border-radius:var(--r-lg)}
.proj-overlay-btn{background:var(--accent);color:#fff;font-size:.76rem;font-weight:600;padding:.55rem 1.1rem;border-radius:var(--r-pill);box-shadow:0 6px 18px rgba(120,184,74,.4)}
.masonry-item:hover .proj-overlay{opacity:1}

/* ── CONTACT (dark bg) ── */
.contact-section{padding:7rem 3rem;background:var(--dark-bg)}
.contact-inner{max-width:760px;margin:0 auto;text-align:center}
.contact-inner .section-eyebrow{justify-content:center;color:var(--accent-light)}
.contact-inner .section-eyebrow::before{background:var(--accent-light)}
.contact-inner .section-title{color:var(--white)}
.contact-inner .section-title em{color:var(--accent-light)}
.contact-inner .section-desc{color:rgba(255,255,255,.6);margin:0 auto 2rem}
.contact-form{margin-top:2.5rem;display:flex;flex-direction:column;gap:1rem;max-width:520px;margin-inline:auto}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-input,.form-textarea{width:100%;padding:.88rem 1.1rem;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.1);border-radius:var(--r);color:var(--white);font-family:var(--font);font-size:.88rem;font-weight:300;outline:none;transition:border-color .2s,box-shadow .2s}
.form-input:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(120,184,74,.15)}
.form-input::placeholder,.form-textarea::placeholder{color:rgba(255,255,255,.3)}
.form-textarea{resize:vertical;min-height:130px}
.form-submit{width:100%;padding:1rem;background:var(--accent);color:#fff;font-family:var(--font);font-size:.9rem;font-weight:600;border:none;border-radius:var(--r-pill);cursor:pointer;transition:all .22s;box-shadow:0 6px 20px rgba(120,184,74,.35)}
.form-submit:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 10px 28px rgba(120,184,74,.45)}

/* ── FOOTER ── */
footer{background:var(--dark-bg);border-top:1px solid var(--dark-border);padding:5.5rem 3rem 2.5rem;color:var(--white)}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:4rem}
.footer-logo{display:flex;align-items:center;gap:.6rem;font-size:1.4rem;font-weight:700;letter-spacing:-.03em;color:var(--white);margin-bottom:1rem}
.footer-logo-icon{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;}
.footer-brand-desc{font-size:1rem;font-weight:300;line-height:1.7;color:var(--white);max-width:280px;margin-bottom:1.5rem;opacity:.85}
.footer-social{display:flex;gap:.6rem}
.social-btn{width:34px;height:34px;border:1px solid var(--dark-border);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.82rem;color:var(--white);transition:all .2s;opacity:.7}
.social-btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);opacity:1}
.footer-col h4{font-size:.82rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--white);margin-bottom:1.2rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer-col a{font-size:1rem;font-weight:300;color:var(--white);transition:color .15s;opacity:.75}
.footer-col a:hover{color:var(--accent-light);opacity:1}
.contact-entry{display:flex;align-items:flex-start;gap:.6rem;font-size:1rem;font-weight:300;color:var(--white);margin-bottom:.65rem;opacity:.8}
.ci-icon{font-size:.88rem;margin-top:.1rem}
.footer-divider{height:1px;background:var(--dark-border);margin-bottom:2rem}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:.85rem;font-weight:300;color:var(--white);opacity:.65}
.footer-legal{display:flex;gap:1.5rem}
.footer-legal a{font-size:.85rem;font-weight:300;color:var(--white);transition:color .15s;opacity:.65}
.footer-legal a:hover{color:var(--accent-light);opacity:1}

/* ── PROJECT DETAIL ── */
.project-hero{position:relative;min-height:520px;overflow:hidden}
.project-hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.32) saturate(.7)}
.project-hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(21,30,45,.9) 0%,rgba(21,30,45,.55) 60%,rgba(21,30,45,.2) 100%)}
.project-hero-content{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:calc(var(--nav-h)+4rem) 3rem 4rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.project-category{display:inline-flex;align-items:center;gap:.5rem;font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-light);margin-bottom:1rem}
.project-title{font-size:clamp(2rem,4.5vw,3.8rem);font-weight:800;line-height:1.07;letter-spacing:-.03em;color:#fff;margin-bottom:1rem}
.project-subtitle{font-size:1rem;font-weight:300;color:rgba(255,255,255,.65);line-height:1.65}
.project-meta{display:flex;flex-direction:column;gap:1rem}
.meta-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:1.4rem;backdrop-filter:blur(8px)}
.meta-label{font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-light);margin-bottom:.5rem}
.meta-value{font-size:.9rem;font-weight:500;color:#fff}
.meta-tags{display:flex;gap:.4rem;flex-wrap:wrap}
.meta-tag{font-size:.65rem;font-weight:500;padding:3px 10px;border-radius:var(--r-pill);background:rgba(120,184,74,.15);color:#b0e080;border:1px solid rgba(120,184,74,.25)}
.project-section{padding:6rem 3rem;background:var(--white)}
.project-section:nth-child(even){background:var(--off-white)}
.project-section-inner{max-width:1100px;margin:0 auto}
.step-grid{display:grid;grid-template-columns:220px 1fr;gap:5rem;align-items:start}
.step-left{position:sticky;top:calc(var(--nav-h)+2rem)}
.step-num{font-size:3.5rem;font-weight:800;color:var(--gray-100);letter-spacing:-.05em;line-height:1;margin-bottom:.5rem}
.step-label{font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.step-right h3{font-size:1.55rem;font-weight:700;letter-spacing:-.025em;margin-bottom:1rem}
.step-right p{font-size:.95rem;font-weight:300;color:var(--gray-600);line-height:1.75;margin-bottom:1rem}
.step-list{display:flex;flex-direction:column;gap:.8rem;margin-top:1rem}
.step-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.1rem;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r)}
.project-section:nth-child(even) .step-item{background:var(--gray-50)}
.step-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:.55rem}
.step-item-text strong{display:block;font-size:.88rem;font-weight:600;margin-bottom:.2rem}
.step-item-text p{font-size:.82rem;font-weight:300;color:var(--gray-600)}
.step-image{width:100%;border-radius:var(--r-xl);overflow:hidden;margin-top:2.5rem;box-shadow:var(--shadow-lg)}
.step-image img{width:100%;height:320px;object-fit:cover}
.partners-section{padding:5rem 3rem;background:var(--white);border-top:1px solid var(--gray-100)}
.partners-inner{max-width:1100px;margin:0 auto;text-align:center}
.partners-grid{display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap;margin-top:2.5rem}
.partner-item{display:flex;align-items:center;justify-content:center;padding:1rem 1.5rem;background:var(--gray-50);border:1px solid var(--gray-100);border-radius:var(--r-lg);min-width:130px;transition:all .2s}
.partner-item:hover{border-color:rgba(120,184,74,.3);box-shadow:var(--shadow);transform:translateY(-2px)}
.partner-name{font-size:.86rem;font-weight:600;color:var(--gray-600)}
.publications-section{padding:5rem 3rem;background:var(--off-white)}
.publications-inner{max-width:1100px;margin:0 auto}
.pub-list{display:flex;flex-direction:column;gap:1rem;margin-top:2.5rem}
.pub-item{display:flex;align-items:flex-start;gap:1.2rem;padding:1.5rem;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--r-lg);transition:all .2s}
.pub-item:hover{border-color:rgba(120,184,74,.25);box-shadow:var(--shadow)}
.pub-icon{width:40px;height:40px;border-radius:10px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.pub-type{font-size:.63rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.3rem}
.pub-title{font-size:.95rem;font-weight:700;color:var(--gray-900);margin-bottom:.3rem}
.pub-authors{font-size:.82rem;font-weight:300;color:var(--gray-600);font-style:italic;margin-bottom:.3rem}
.pub-desc{font-size:.82rem;font-weight:300;color:var(--gray-600)}

/* ── COOKIE ── */
.cookie-overlay{position:fixed;inset:0;z-index:9998;background:rgba(0,0,0,.3);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;padding:0 1.5rem 2rem;opacity:0;pointer-events:none;transition:opacity .4s ease}
.cookie-overlay.visible{opacity:1;pointer-events:all}
.cookie-box{width:100%;max-width:760px;background:var(--white);border-radius:var(--r-xl);padding:2rem 2.4rem;box-shadow:var(--shadow-xl),0 0 0 1px var(--gray-100);display:grid;grid-template-columns:1fr auto;gap:1.5rem 2.5rem;align-items:center;transform:translateY(24px);transition:transform .4s ease}
.cookie-overlay.visible .cookie-box{transform:translateY(0)}
.cookie-icon{font-size:1.8rem;margin-bottom:.3rem}
.cookie-title{font-size:1rem;font-weight:700;margin-bottom:.3rem}
.cookie-desc{font-size:.83rem;font-weight:300;color:var(--gray-600);line-height:1.6}
.cookie-desc a{color:var(--accent-dark);text-decoration:underline;text-underline-offset:2px}
.cookie-btns{display:flex;flex-direction:column;gap:.7rem;min-width:155px}
.btn-cookie-accept{padding:.72rem 1.4rem;background:var(--accent);color:#fff;font-family:var(--font);font-size:.83rem;font-weight:600;border:none;border-radius:var(--r-pill);cursor:pointer;transition:all .2s;text-align:center}
.btn-cookie-accept:hover{background:var(--accent-dark)}
.btn-cookie-decline{padding:.72rem 1.4rem;background:transparent;color:var(--gray-600);font-family:var(--font);font-size:.83rem;font-weight:500;border:1.5px solid var(--gray-200);border-radius:var(--r-pill);cursor:pointer;transition:all .2s;text-align:center}
.btn-cookie-decline:hover{border-color:var(--gray-400);color:var(--gray-900)}
.cookie-customize{font-size:.76rem;font-weight:400;color:var(--gray-400);text-align:center;cursor:pointer;text-decoration:underline;text-underline-offset:2px}
.cookie-customize:hover{color:var(--accent)}

/* ── RESPONSIVE ── */
@media(max-width:1100px){.services-grid{grid-template-columns:1fr 1fr}.services-header{grid-template-columns:1fr;gap:1rem}.services-header-right{justify-content:flex-start}.footer-top{grid-template-columns:1fr 1fr}.project-hero-content{grid-template-columns:1fr;gap:2.5rem;padding-top:calc(var(--nav-h)+3rem)}.project-meta{flex-direction:row;flex-wrap:wrap}.meta-card{flex:1;min-width:180px}}
@media(max-width:900px){.prestation-hero-content{grid-template-columns:1fr;gap:3rem}.masonry{columns:2}.cookie-box{grid-template-columns:1fr;gap:1.5rem}.cookie-btns{flex-direction:row;min-width:unset}.step-grid{grid-template-columns:1fr;gap:2rem}.step-left{position:static}}
@media(max-width:768px){.section{padding:5rem 1.5rem}nav{padding:0 1.5rem}.nav-links,.nav-right{display:none}.burger{display:flex}.hero-content{padding:0 1.8rem 0 5rem;padding-top:var(--nav-h)}.carousel-dots{left:5rem}.carousel-arrow{display:none}.services-grid{grid-template-columns:1fr}.masonry{columns:1}.footer-top{grid-template-columns:1fr}.footer-bottom{flex-direction:column;align-items:flex-start}.form-row{grid-template-columns:1fr}.prestation-hero-content,.project-hero-content{padding-left:1.5rem;padding-right:1.5rem}.trusted-section,.services-section,.projects-section,.contact-section{padding-left:1.5rem;padding-right:1.5rem}}
@media(max-width:480px){.hero-content{padding:0 1.2rem;padding-top:var(--nav-h)}.carousel-dots{left:1.2rem}.cookie-btns{flex-direction:column}.cookie-box{padding:1.5rem}}


.heroA {
  position: relative;
  border-radius: 28px;
  overflow: hidden;
  height: 580px;
  min-height: 480px;
  margin: 100px auto auto auto;
  display: flex;
  align-items: center;
max-width: 1240px;
background: rgba(255,255,255,.12);
border-color: rgba(255,255,255,.18);
box-shadow:
  0 -4px 60px rgba(0,0,0,.3),
  inset 0 1px 0 rgba(255,255,255,.7);
}

.heroA video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

/* shade : assombrissement global + vignette sur tous les bords */
.heroA::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  z-index: 1;
}

.heroA::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,0.55) 100%),
    linear-gradient(to right, rgba(0,0,0,0.5) 0%, transparent 55%);
  z-index: 1;
}

.heroA-content {
  position: relative;
  z-index: 2;
  padding: 0 56px;
  max-width: 560px;
}

.heroA-content h1 {
  font-family: 'Syne', sans-serif;
  font-size: clamp(32px, 4vw, 56px);
  font-weight: 800;
  color: #ffffff;
  line-height: 1.08;
  letter-spacing: -0.025em;
  margin-bottom: 20px;
}

.heroA-content em {
  font-style: normal;
  color: var(--accent-light);
}

.heroA-content p {
  font-size: 16px;
  font-weight: 300;
  color: rgba(255,255,255,0.75);
  line-height: 1.7;
}
.slideService
{
  transition:none;
}

.slideService-overlay 
{
  position: absolute;
  inset: 0;
  background: linear-gradient(to right,rgba(21,30,45,.5) 0%,rgba(21,30,45,.25) 30%,rgba(21,30,45,.1) 100%);
}

#contactConsent
{
    position: fixed;
    inset: 0;

    display: none;

    align-items: center;
    justify-content: center;

    background: rgba(0,0,0,0.72);

    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;

    z-index: 999999;
}

form-message
{
    margin-top: 10px;
    margin-bottom: 14px;

    padding: 12px 16px;

    border-radius: 12px;

    font-size: 0.95rem;
    line-height: 1.4;

    display: none;
}

.form-message.success
{
    display: block;

    background: rgba(40,180,90,0.14);
    border: 1px solid rgba(40,180,90,0.35);

    color: #7dffae;
}

.form-message.error
{
    display: block;

    background: rgba(255,70,70,0.12);
    border: 1px solid rgba(255,70,70,0.3);

    color: #ffb0b0;
}