@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800;900&family=Montserrat:wght@400;500;600;700&family=Inter:wght@300;400;500;600&display=swap');

/* ============================================================
   UNO DIGITAL SN — CSS v5 Final
   Couleur primaire  : #29305a
   Couleur secondaire: #7d89cf
   Fond clair        : #f5f7fb / #ffffff
   ============================================================ */
:root{
  --primary:#29305a; --secondary:#7d89cf; --accent:#7d89cf;
  --accent-dark:#5a67b8; --accent-light:#a8b2e0;
  --bg:#f5f7fb; --bg-card:#ffffff; --bg-alt:#eef1fa;
  --text:#1a1d2e; --text-muted:#4a5568;
  --border:rgba(41,48,90,0.12);
  --shadow-sm:0 2px 12px rgba(41,48,90,0.07);
  --shadow-md:0 8px 32px rgba(41,48,90,0.13);
  --shadow-lg:0 20px 60px rgba(41,48,90,0.18);
  --radius:12px; --radius-lg:20px; --radius-xl:32px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);line-height:1.7;overflow-x:hidden;}
h1,h2,h3,h4{font-family:'Poppins',sans-serif;line-height:1.25;color:var(--primary);}
h1{font-size:clamp(2rem,5vw,3.8rem);font-weight:800;}
h2{font-size:clamp(1.5rem,3.5vw,2.4rem);font-weight:700;}
h3{font-size:clamp(1rem,2vw,1.25rem);font-weight:600;}
p{color:var(--text-muted);font-size:1rem;line-height:1.7;}
a{text-decoration:none;color:inherit;transition:all .3s;}
img{max-width:100%;height:auto;}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:var(--radius);font-family:'Poppins',sans-serif;font-weight:600;font-size:.9rem;cursor:pointer;border:none;transition:all .3s cubic-bezier(.34,1.56,.64,1);text-decoration:none;}
.btn-primary,.btn-accent{background:var(--secondary);color:#fff;box-shadow:0 4px 16px rgba(125,137,207,.35);}
.btn-primary:hover,.btn-accent:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(125,137,207,.45);}
.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary);}
.btn-outline:hover{background:var(--primary);color:#fff;transform:translateY(-2px);}
.btn-outline-sec{background:transparent;color:var(--secondary);border:2px solid var(--secondary);}
.btn-outline-sec:hover{background:var(--secondary);color:#fff;transform:translateY(-2px);}
.btn-white{background:#fff;color:var(--primary);box-shadow:var(--shadow-sm);}
.btn-white:hover{background:var(--secondary);color:#fff;transform:translateY(-2px);}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);}
.btn-ghost:hover{background:rgba(255,255,255,.22);}
.btn-dark{background:var(--primary);color:#fff;}
.btn-dark:hover{background:var(--secondary);transform:translateY(-2px);}

/* ===== HOVER EFFECTS ===== */
.hover-lift{transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s!important;}
.hover-lift:hover{transform:translateY(-7px) scale(1.02)!important;box-shadow:0 20px 50px rgba(41,48,90,.18)!important;}

/* ===== NAVBAR ===== */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 5%;height:74px;display:flex;align-items:center;justify-content:space-between;background:transparent;transition:all .4s ease;}
.navbar.scrolled{background:var(--primary);box-shadow:var(--shadow-md);}
.navbar-brand{display:flex;align-items:center;gap:10px;}
.navbar-logo-img{height:42px;width:auto;object-fit:contain;}
.navbar-nav{display:flex;align-items:center;gap:4px;list-style:none;}
.navbar-nav>li{position:relative;}
.navbar-nav>li>a{color:rgba(255,255,255,.9);font-family:'Montserrat',sans-serif;font-weight:500;font-size:.85rem;padding:8px 12px;border-radius:8px;transition:all .3s;display:flex;align-items:center;gap:4px;}
.navbar-nav>li>a:hover,.navbar-nav>li>a.active{color:#fff;background:rgba(255,255,255,.14);}
.nav-arrow{font-size:.6rem;transition:transform .3s;}
.navbar-nav>li:hover .nav-arrow{transform:rotate(180deg);}
/* DROPDOWN */
.dropdown{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border-radius:14px;box-shadow:0 16px 48px rgba(41,48,90,.18);padding:10px;min-width:255px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s;z-index:200;}
.navbar-nav>li:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.dropdown-item{display:flex;align-items:center;gap:11px;padding:10px 13px;border-radius:10px;color:var(--primary);font-size:.84rem;font-family:'Poppins',sans-serif;font-weight:500;transition:all .25s;}
.dropdown-item:hover{background:rgba(125,137,207,.1);color:var(--secondary);transform:translateX(4px);}
.dropdown-icon{width:32px;height:32px;border-radius:9px;background:rgba(125,137,207,.12);display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0;}
.navbar-cta{background:var(--secondary)!important;color:#fff!important;border-radius:8px!important;padding:10px 18px!important;}
.navbar-cta:hover{background:var(--accent-dark)!important;transform:translateY(-2px)!important;}
/* LANG */
.lang-toggle{display:flex;gap:4px;margin-left:6px;}
.lang-btn{padding:5px 10px;border-radius:6px;font-family:'Poppins',sans-serif;font-size:.73rem;font-weight:700;cursor:pointer;border:1.5px solid rgba(255,255,255,.3);background:transparent;color:rgba(255,255,255,.8);transition:all .3s;}
.lang-btn.active{background:rgba(255,255,255,.18);color:#fff;border-color:rgba(255,255,255,.6);}
.lang-btn:hover{border-color:#fff;color:#fff;}
/* MOBILE */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;}
.hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:all .3s;}
.mobile-menu{display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--primary);z-index:9999;align-items:center;justify-content:center;gap:16px;transform:translateX(-100%);transition:transform .4s ease;padding:24px;}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu a{color:#fff;font-family:'Poppins',sans-serif;font-size:1.2rem;font-weight:600;}
.mobile-menu a:hover{color:var(--accent-light);}
.mobile-close{position:absolute;top:20px;right:20px;background:none;border:none;color:#fff;font-size:1.7rem;cursor:pointer;}
.mobile-sub{display:flex;flex-direction:column;gap:8px;align-items:center;padding:4px 0;}
.mobile-sub a{font-size:.95rem!important;color:rgba(255,255,255,.72)!important;font-weight:500!important;}

/* ===== FLOATING SHAPES ===== */
.floating-shapes{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.shape{position:absolute;border-radius:50%;opacity:.06;animation:float 9s ease-in-out infinite;}
.shape-1{width:500px;height:500px;background:var(--secondary);top:-140px;right:-100px;}
.shape-2{width:300px;height:300px;background:var(--accent-light);bottom:60px;left:-80px;animation-delay:-3s;}
.shape-3{width:200px;height:200px;background:var(--secondary);top:40%;left:28%;animation-delay:-6s;}
@keyframes float{0%,100%{transform:translateY(0) rotate(0);}33%{transform:translateY(-20px) rotate(3deg);}66%{transform:translateY(10px) rotate(-3deg);}}

/* ===== HERO ===== */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;position:relative;overflow:hidden;padding:100px 5% 60px;background:linear-gradient(135deg,#29305a 0%,#1e2347 55%,#2a1a4e 100%);}
.hero-content{position:relative;z-index:2;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(168,178,224,.18);border:1px solid rgba(168,178,224,.35);color:#c8d0f0;padding:8px 18px;border-radius:50px;font-family:'Montserrat',sans-serif;font-size:.76rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:22px;}
.hero h1{color:#fff;margin-bottom:20px;}
.hero h1 span{color:var(--accent-light);}
.hero-desc{color:rgba(255,255,255,.8);font-size:1.04rem;margin-bottom:36px;max-width:520px;}
.hero-buttons{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:50px;}
.hero-stats{display:flex;gap:32px;flex-wrap:wrap;}
.stat-number{font-family:'Poppins',sans-serif;font-size:1.9rem;font-weight:800;color:#fff;display:block;}
.stat-label{font-size:.76rem;color:rgba(255,255,255,.6);font-family:'Montserrat',sans-serif;}
/* Video side */
.hero-img-side{position:relative;display:flex;align-items:center;justify-content:center;}
.hero-video-wrap{position:relative;border-radius:22px;overflow:hidden;box-shadow:0 28px 72px rgba(0,0,0,.5);width:100%;max-width:500px;}
.hero-video-wrap video{width:100%;height:500px;object-fit:cover;display:block;}
.hero-video-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(41,48,90,.15),transparent);}
.hero-img-overlay{position:absolute;bottom:14px;left:14px;right:14px;background:rgba(255,255,255,.18);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.35);border-radius:14px;padding:14px 18px;}
.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.metric-box{text-align:center;}
.metric-val{font-family:'Poppins',sans-serif;font-size:1.3rem;font-weight:800;color:#fff;display:block;text-shadow:0 1px 4px rgba(0,0,0,.3);}
.metric-lbl{font-size:.67rem;color:rgba(255,255,255,.9);font-weight:500;}

/* ===== SECTION ===== */
.section{padding:84px 5%;}
.section-white{background:#fff;}
.section-light{background:var(--bg);}
.section-alt{background:var(--bg-alt);}
.section-header{text-align:center;max-width:620px;margin:0 auto 52px;}
.section-tag{display:inline-block;background:rgba(125,137,207,.12);color:var(--secondary);padding:5px 15px;border-radius:50px;font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:13px;}
.section-header h2{margin-bottom:12px;}

/* ===== SERVICES 3x2 ===== */
.services-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.service-card-img{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative;cursor:pointer;}
.service-card-img:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-lg);}
.service-card-img::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--secondary));transform:scaleX(0);transform-origin:left;transition:transform .4s;z-index:1;}
.service-card-img:hover::before{transform:scaleX(1);}
.service-card-photo{width:100%;height:186px;object-fit:cover;object-position:center 20%;display:block;transition:transform .5s;}
.service-card-img:hover .service-card-photo{transform:scale(1.06);}
.service-card-icon-wrap{position:absolute;top:173px;right:14px;width:38px;height:38px;background:var(--secondary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:0 4px 12px rgba(125,137,207,.45);z-index:2;transition:transform .3s;}
.service-card-img:hover .service-card-icon-wrap{transform:rotate(10deg) scale(1.1);}
.service-card-body{padding:20px 20px 22px;}
.service-card-body h3{font-size:.97rem;margin-bottom:7px;color:var(--primary);}
.service-card-body p{font-size:.82rem;margin-bottom:12px;color:var(--text-muted);}
.service-features{list-style:none;display:flex;flex-direction:column;gap:5px;margin-bottom:14px;}
.service-features li{display:flex;align-items:center;gap:7px;font-size:.79rem;color:var(--text-muted);}
.service-features li::before{content:'✓';width:16px;height:16px;background:rgba(125,137,207,.13);color:var(--secondary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;flex-shrink:0;}
.service-link{color:var(--secondary);font-family:'Poppins',sans-serif;font-weight:600;font-size:.79rem;display:inline-flex;align-items:center;gap:5px;}
.service-link:hover{gap:9px;}

/* ===== TOOLS SCROLL ===== */
.tools-scroll-wrap{overflow:hidden;position:relative;padding:16px 0;}
.tools-scroll-wrap::before,.tools-scroll-wrap::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;}
.tools-scroll-wrap::before{left:0;background:linear-gradient(to right,var(--bg),transparent);}
.tools-scroll-wrap::after{right:0;background:linear-gradient(to left,var(--bg),transparent);}
.tools-track{display:flex;gap:16px;animation:toolsScroll 28s linear infinite;width:max-content;}
.tools-track:hover{animation-play-state:paused;}
.tool-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 16px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);min-width:90px;transition:all .35s cubic-bezier(.34,1.56,.64,1);cursor:default;flex-shrink:0;}
.tool-card:hover{transform:translateY(-5px) scale(1.06);box-shadow:var(--shadow-md);border-color:var(--secondary);}
.tool-icon{font-size:1.6rem;line-height:1;}
.tool-name{font-family:'Poppins',sans-serif;font-weight:600;font-size:.67rem;color:var(--primary);text-align:center;white-space:nowrap;}
@keyframes toolsScroll{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ===== WHY ===== */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.why-list{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:28px;}
.why-list li{display:flex;align-items:flex-start;gap:12px;font-size:.9rem;color:var(--text-muted);}
.why-list li .icon{width:28px;height:28px;background:linear-gradient(135deg,var(--secondary),var(--primary));border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.78rem;flex-shrink:0;margin-top:2px;}
.why-photo{width:100%;border-radius:var(--radius-lg);object-fit:cover;height:400px;transition:transform .5s;}
.why-photo:hover{transform:scale(1.02);}

/* ===== PARTNERS NAMES ONLY ===== */
.partners-strip{background:#fff;padding:48px 5%;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.partners-title{text-align:center;font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin-bottom:28px;}
.partners-names{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;}
.partner-name-item{display:flex;align-items:center;gap:8px;padding:10px 18px;background:var(--bg);border:1px solid var(--border);border-radius:50px;font-family:'Poppins',sans-serif;font-weight:600;font-size:.84rem;color:var(--primary);transition:all .35s cubic-bezier(.34,1.56,.64,1);}
.partner-name-item:hover{background:var(--secondary);color:#fff;border-color:var(--secondary);transform:translateY(-3px);box-shadow:0 8px 24px rgba(125,137,207,.3);}
.partner-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}

/* ===== NOS OFFRES PAGE — Rectangles services ===== */
.offers-services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.offer-service-rect{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden;}
.offer-service-rect::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(125,137,207,.04),transparent);opacity:0;transition:opacity .4s;}
.offer-service-rect:hover::before{opacity:1;}
.offer-service-rect:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);border-color:rgba(125,137,207,.3);}
.offer-svc-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,rgba(125,137,207,.15),rgba(41,48,90,.08));display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:16px;transition:transform .3s;}
.offer-service-rect:hover .offer-svc-icon{transform:scale(1.12) rotate(5deg);}
.offer-service-rect h3{font-size:1rem;margin-bottom:8px;color:var(--primary);}
.offer-service-rect p{font-size:.83rem;margin-bottom:14px;color:var(--text-muted);}
.offer-svc-list{list-style:none;display:flex;flex-direction:column;gap:5px;margin-bottom:18px;}
.offer-svc-list li{display:flex;align-items:center;gap:7px;font-size:.79rem;color:var(--text-muted);}
.offer-svc-list li::before{content:'→';color:var(--secondary);font-weight:700;font-size:.8rem;flex-shrink:0;}

/* ===== PRICING — Style Claude.ai ===== */
.pricing-section-wrap{max-width:1100px;margin:0 auto;}
.pricing-toggle-tabs{display:flex;justify-content:center;margin-bottom:36px;}
.pricing-tabs-inner{background:var(--bg);border-radius:50px;padding:4px;display:inline-flex;gap:2px;}
.ptab{padding:8px 22px;border-radius:50px;font-family:'Poppins',sans-serif;font-weight:600;font-size:.84rem;cursor:pointer;border:none;background:transparent;color:var(--text-muted);transition:all .3s;}
.ptab.active{background:#fff;color:var(--primary);box-shadow:0 2px 8px rgba(41,48,90,.1);}
.annual-save-badge{background:rgba(125,137,207,.15);color:var(--secondary);padding:3px 10px;border-radius:50px;font-size:.72rem;font-weight:700;margin-left:6px;}
.pricing-grid-claude{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.pc-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:28px 24px;position:relative;transition:all .4s cubic-bezier(.34,1.56,.64,1);}
.pc-card:hover:not(.pc-featured){transform:translateY(-6px);box-shadow:var(--shadow-md);}
.pc-card.pc-featured{background:#fff;border:2px solid var(--primary);box-shadow:0 8px 32px rgba(41,48,90,.14);}
.pc-icon{font-size:1.8rem;margin-bottom:14px;display:block;opacity:.7;}
.pc-name{font-family:'Poppins',sans-serif;font-size:1.1rem;font-weight:700;color:var(--primary);margin-bottom:4px;}
.pc-desc{font-size:.82rem;color:var(--text-muted);margin-bottom:16px;}
.pc-price-wrap{margin-bottom:6px;}
.pc-price{font-family:'Poppins',sans-serif;font-size:2.2rem;font-weight:800;color:var(--primary);}
.pc-currency{font-size:.88rem;font-weight:600;vertical-align:super;}
.pc-period{font-size:.78rem;color:var(--text-muted);}
.pc-price-annual{font-size:.76rem;color:var(--secondary);font-weight:600;margin-bottom:16px;display:none;}
.pc-price-annual.show{display:block;}
.pc-btn{width:100%;padding:12px;border-radius:10px;font-family:'Poppins',sans-serif;font-weight:700;font-size:.88rem;cursor:pointer;border:1.5px solid var(--border);background:#fff;color:var(--primary);margin-bottom:18px;transition:all .3s;}
.pc-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);}
.pc-card.pc-featured .pc-btn{background:var(--primary);color:#fff;border-color:var(--primary);}
.pc-card.pc-featured .pc-btn:hover{background:var(--secondary);}
.pc-divider{height:1px;background:var(--border);margin-bottom:16px;}
.pc-intro{font-size:.79rem;font-weight:600;color:var(--text-muted);margin-bottom:10px;}
.pc-features{list-style:none;display:flex;flex-direction:column;gap:8px;}
.pc-features li{display:flex;align-items:flex-start;gap:8px;font-size:.82rem;color:var(--text-muted);}
.pc-check{width:17px;height:17px;border-radius:50%;border:1.5px solid var(--secondary);display:flex;align-items:center;justify-content:center;font-size:.6rem;color:var(--secondary);flex-shrink:0;margin-top:2px;}
.pc-popular{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;padding:5px 16px;border-radius:0 0 10px 10px;font-family:'Poppins',sans-serif;font-size:.7rem;font-weight:700;white-space:nowrap;}

/* ===== SERVICE PAGE HERO ===== */
.service-hero{padding:130px 5% 76px;background:linear-gradient(135deg,var(--primary) 0%,#1e2347 100%);position:relative;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.service-hero-content h1{color:#fff;margin-bottom:14px;}
.service-hero-content p{color:rgba(255,255,255,.78);font-size:1.02rem;margin-bottom:28px;}
.service-hero-img{border-radius:18px;overflow:hidden;box-shadow:0 28px 72px rgba(0,0,0,.4);}
.service-hero-img img{width:100%;height:380px;object-fit:cover;display:block;}

/* ===== OFFER CARDS (nos-offres) ===== */
.offer-big-card{background:#fff;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);margin-bottom:28px;display:grid;grid-template-columns:1fr 1fr;transition:all .4s cubic-bezier(.34,1.56,.64,1);}
.offer-big-card:hover{box-shadow:var(--shadow-lg);border-color:rgba(125,137,207,.25);transform:translateY(-3px);}
.offer-big-card.reverse{direction:rtl;}
.offer-big-card.reverse>*{direction:ltr;}
.offer-card-img{position:relative;overflow:hidden;}
.offer-card-img img{width:100%;height:100%;object-fit:cover;display:block;min-height:280px;transition:transform .5s;}
.offer-big-card:hover .offer-card-img img{transform:scale(1.04);}
.offer-card-img-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(41,48,90,.42),rgba(125,137,207,.12));}
.offer-card-num{position:absolute;top:16px;left:16px;font-family:'Poppins',sans-serif;font-size:2.6rem;font-weight:900;color:rgba(255,255,255,.2);line-height:1;}
.offer-card-content{padding:40px 36px;display:flex;flex-direction:column;justify-content:center;}
.offer-badge{display:inline-block;background:rgba(125,137,207,.12);color:var(--secondary);padding:4px 13px;border-radius:50px;font-size:.7rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:12px;}
.offer-card-content h2{font-size:1.6rem;margin-bottom:10px;}
.offer-card-content p{font-size:.87rem;margin-bottom:16px;}
.offer-list{list-style:none;display:flex;flex-direction:column;gap:7px;margin-bottom:24px;}
.offer-list li{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--text-muted);}
.offer-list li::before{content:'✓';width:18px;height:18px;background:rgba(125,137,207,.12);color:var(--secondary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;flex-shrink:0;}

/* ===== FAQ GRID ===== */
.faq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.faq-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:all .35s cubic-bezier(.34,1.56,.64,1);}
.faq-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(125,137,207,.3);}
.faq-card h3{font-size:.92rem;margin-bottom:8px;color:var(--primary);}
.faq-card p{font-size:.81rem;color:var(--text-muted);}

/* ===== TESTIMONIALS ===== */
.testimonial-section{background:var(--primary);padding:72px 5%;}
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1100px;margin:0 auto;}
.testimonial-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);padding:24px;transition:all .4s cubic-bezier(.34,1.56,.64,1);}
.testimonial-card:hover{transform:translateY(-5px);background:rgba(255,255,255,.1);}
.testimonial-stars{color:var(--accent-light);font-size:.9rem;margin-bottom:12px;letter-spacing:2px;}
.testimonial-text{color:rgba(255,255,255,.86);font-size:.88rem;font-style:italic;margin-bottom:16px;line-height:1.7;}
.testimonial-author{display:flex;align-items:center;gap:10px;}
.author-avatar{width:38px;height:38px;border-radius:50%;background:var(--secondary);display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-weight:700;color:#fff;font-size:.8rem;flex-shrink:0;}
.author-name{font-family:'Poppins',sans-serif;font-weight:600;color:#fff;font-size:.84rem;}
.author-company{font-size:.7rem;color:rgba(255,255,255,.5);}

/* ===== CTA BANNER ===== */
.cta-banner{background:var(--primary);padding:72px 5%;text-align:center;}
.cta-banner h2{color:#fff;margin-bottom:12px;}
.cta-banner p{color:rgba(255,255,255,.8);font-size:1.02rem;margin-bottom:30px;}
.cta-buttons{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;}

/* ===== CTA BLANC ===== */
.cta-white{background:#fff;padding:72px 5%;text-align:center;border-top:1px solid var(--border);}
.cta-white h2{color:var(--primary);margin-bottom:12px;}
.cta-white p{color:var(--text-muted);margin-bottom:30px;}

/* ===== FOOTER — Fond blanc dégradé ===== */
.footer{background:linear-gradient(to bottom,#fff,#f0f3fc);color:var(--primary);padding:64px 5% 28px;border-top:1px solid var(--border);}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px;}
.footer-brand p{color:var(--text-muted);font-size:.85rem;margin:12px 0 20px;max-width:250px;}
.footer-social{display:flex;gap:8px;}
.footer-social a{width:36px;height:36px;background:var(--bg);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--primary);transition:all .35s cubic-bezier(.34,1.56,.64,1);text-decoration:none;font-weight:700;}
.footer-social a:hover{background:var(--secondary);color:#fff;border-color:var(--secondary);transform:translateY(-3px);}
.footer-heading{font-family:'Poppins',sans-serif;font-weight:700;font-size:.79rem;color:var(--primary);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:8px;}
.footer-links a{color:var(--text-muted);font-size:.83rem;transition:color .3s;}
.footer-links a:hover{color:var(--secondary);}
.footer-bottom{border-top:1px solid var(--border);padding-top:20px;display:flex;align-items:center;justify-content:space-between;font-size:.78rem;color:var(--text-muted);}
.footer-bottom-links{display:flex;gap:16px;}
.footer-bottom-links a{color:var(--text-muted);transition:color .3s;}
.footer-bottom-links a:hover{color:var(--secondary);}

/* ===== CHATBOT ===== */
#chatbot-wrapper{position:fixed;bottom:28px;left:28px;z-index:9998;}
#chatbot-bubble{width:54px;height:54px;background:var(--secondary);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 18px rgba(125,137,207,.5);transition:all .35s cubic-bezier(.34,1.56,.64,1);font-size:1.4rem;}
#chatbot-bubble:hover{transform:scale(1.12);}
#chatbot-bubble.pulse{animation:chatPulse 2s ease-in-out infinite;}
@keyframes chatPulse{0%,100%{box-shadow:0 4px 18px rgba(125,137,207,.5);}50%{box-shadow:0 4px 28px rgba(125,137,207,.8),0 0 0 8px rgba(125,137,207,.12);}}
#chatbot-box{position:absolute;bottom:66px;left:0;width:330px;background:#fff;border-radius:18px;box-shadow:0 18px 56px rgba(41,48,90,.2);overflow:hidden;display:none;flex-direction:column;max-height:500px;}
#chatbot-box.open{display:flex;}
#chatbot-header{background:var(--primary);padding:14px 16px;display:flex;align-items:center;gap:10px;}
#chatbot-header .avatar{width:38px;height:38px;border-radius:50%;background:var(--secondary);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;}
#chatbot-header .info .name{font-family:'Poppins',sans-serif;font-weight:700;color:#fff;font-size:.86rem;}
#chatbot-header .info .status{font-size:.69rem;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:4px;}
#chatbot-header .info .status::before{content:'';width:6px;height:6px;background:#25d366;border-radius:50%;display:inline-block;}
#chatbot-close{margin-left:auto;background:none;border:none;color:rgba(255,255,255,.6);font-size:1.1rem;cursor:pointer;padding:4px;}
#chatbot-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:9px;background:#f8f9fe;}
.chat-msg{max-width:85%;padding:9px 13px;border-radius:15px;font-size:.83rem;line-height:1.5;animation:msgIn .3s ease;}
@keyframes msgIn{from{opacity:0;transform:translateY(7px);}to{opacity:1;transform:translateY(0);}}
.chat-msg.bot{background:#fff;border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px;align-self:flex-start;}
.chat-msg.user{background:var(--secondary);color:#fff;border-bottom-right-radius:4px;align-self:flex-end;}
.chat-buttons{display:flex;flex-direction:column;gap:5px;align-self:flex-start;width:100%;}
.chat-btn{padding:7px 13px;border-radius:18px;border:1.5px solid var(--secondary);background:#fff;color:var(--secondary);font-size:.79rem;font-weight:600;cursor:pointer;font-family:'Poppins',sans-serif;transition:all .25s;text-align:left;}
.chat-btn:hover{background:var(--secondary);color:#fff;}
.chat-input-wrap{padding:11px 13px;background:#fff;border-top:1px solid var(--border);display:flex;gap:7px;align-items:center;}
#chat-input{flex:1;padding:8px 12px;border:1.5px solid var(--border);border-radius:18px;font-family:'Inter',sans-serif;font-size:.82rem;outline:none;transition:border-color .3s;}
#chat-input:focus{border-color:var(--secondary);}
#chat-send{width:34px;height:34px;background:var(--secondary);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;color:#fff;transition:all .25s;}
#chat-send:hover{background:var(--accent-dark);}

/* ===== WHATSAPP ===== */
.whatsapp-btn{position:fixed;bottom:28px;right:28px;z-index:999;width:52px;height:52px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.45rem;box-shadow:0 4px 18px rgba(37,211,102,.4);transition:all .35s cubic-bezier(.34,1.56,.64,1);}
.whatsapp-btn:hover{transform:scale(1.12);}

/* ===== PAGE HERO ===== */
.page-hero{background:linear-gradient(135deg,var(--primary) 0%,#1e2347 100%);padding:124px 5% 64px;text-align:center;position:relative;overflow:hidden;}
.page-hero h1{color:#fff;margin-bottom:13px;}
.page-hero p{color:rgba(255,255,255,.78);max-width:580px;margin:0 auto;font-size:1.02rem;}
.breadcrumb{display:flex;align-items:center;justify-content:center;gap:7px;margin-bottom:17px;font-size:.8rem;}
.breadcrumb a{color:rgba(255,255,255,.6);}
.breadcrumb a:hover{color:var(--accent-light);}
.breadcrumb span{color:rgba(255,255,255,.38);}
.breadcrumb .current{color:var(--accent-light);font-weight:600;}

/* ===== AOS ===== */
[data-aos]{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease;}
[data-aos].aos-animate{opacity:1;transform:translateY(0);}
[data-aos="fade-right"]{transform:translateX(-26px);}
[data-aos="fade-right"].aos-animate{transform:translateX(0);}
[data-aos="fade-left"]{transform:translateX(26px);}
[data-aos="fade-left"].aos-animate{transform:translateX(0);}
[data-aos="zoom-in"]{transform:scale(.92);}
[data-aos="zoom-in"].aos-animate{transform:scale(1);}

/* ===== DEVIS FORM ===== */
.devis-modal{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9990;display:none;align-items:center;justify-content:center;padding:20px;}
.devis-modal.open{display:flex;}
.devis-box{background:#fff;border-radius:var(--radius-xl);padding:40px;width:100%;max-width:620px;max-height:90vh;overflow-y:auto;position:relative;}
.devis-box h2{font-size:1.5rem;margin-bottom:6px;}
.devis-box p{font-size:.85rem;margin-bottom:26px;}
.devis-close{position:absolute;top:18px;right:20px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted);}
.form-group{margin-bottom:16px;}
.form-label{display:block;font-family:'Poppins',sans-serif;font-weight:600;font-size:.79rem;color:var(--primary);margin-bottom:6px;}
.form-control{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:'Inter',sans-serif;font-size:.88rem;color:var(--text);background:var(--bg);outline:none;transition:all .3s;}
.form-control:focus{border-color:var(--secondary);background:#fff;box-shadow:0 0 0 3px rgba(125,137,207,.1);}
.form-control::placeholder{color:var(--text-muted);opacity:.65;}
textarea.form-control{resize:vertical;min-height:110px;}
select.form-control{cursor:pointer;}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-success-msg{display:none;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);color:#16a34a;padding:13px;border-radius:var(--radius);text-align:center;font-weight:500;margin-top:12px;}
.form-error-msg{display:none;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:#dc2626;padding:13px;border-radius:var(--radius);text-align:center;font-weight:500;margin-top:12px;}

/* ===== RÉALISATIONS ===== */
.gallery-tabs{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:36px;}
.gtab{padding:8px 18px;border-radius:50px;font-family:'Poppins',sans-serif;font-weight:600;font-size:.8rem;cursor:pointer;border:1.5px solid var(--border);background:#fff;color:var(--text-muted);transition:all .3s;}
.gtab.active,.gtab:hover{border-color:var(--secondary);background:var(--secondary);color:#fff;}
.gallery-concepts{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.concept-card{background:linear-gradient(135deg,rgba(125,137,207,.08),rgba(41,48,90,.04));border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 24px;text-align:center;transition:all .4s cubic-bezier(.34,1.56,.64,1);}
.concept-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);border-color:rgba(125,137,207,.3);}
.concept-icon{font-size:3rem;margin-bottom:16px;display:block;}
.concept-card h3{font-size:1rem;margin-bottom:8px;}
.concept-card p{font-size:.82rem;}
.sites-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.site-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:all .4s cubic-bezier(.34,1.56,.64,1);}
.site-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.site-card-top{height:150px;overflow:hidden;position:relative;}
.site-card-top img{width:100%;height:100%;object-fit:cover;object-position:top;}
.site-card-top .year-badge{position:absolute;top:8px;right:8px;background:rgba(41,48,90,.8);color:#fff;padding:3px 9px;border-radius:50px;font-size:.68rem;font-weight:700;}
.site-card-body{padding:16px 17px;}
.site-card-cat{font-size:.67rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--secondary);margin-bottom:4px;}
.site-card-body h3{font-size:.94rem;margin-bottom:5px;}
.site-card-body p{font-size:.79rem;margin-bottom:11px;}
.site-link-btn{color:var(--secondary);font-size:.77rem;font-weight:600;display:inline-flex;align-items:center;gap:4px;transition:gap .3s;}
.site-link-btn:hover{gap:8px;}
/* Timeline */
.timeline{max-width:780px;margin:0 auto;position:relative;}
.timeline::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:2px;background:var(--border);transform:translateX(-50%);}
.timeline-item{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-bottom:36px;position:relative;}
.timeline-item::after{content:'';position:absolute;left:50%;top:18px;width:12px;height:12px;background:var(--secondary);border-radius:50%;transform:translateX(-50%);border:3px solid #fff;box-shadow:0 0 0 2px var(--secondary);}
.timeline-item:nth-child(even) .tl-content{order:2;}
.timeline-item:nth-child(even) .tl-empty{order:1;}
.tl-content{background:#fff;border-radius:var(--radius);padding:18px;border:1px solid var(--border);transition:all .35s cubic-bezier(.34,1.56,.64,1);}
.tl-content:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.tl-year{font-family:'Poppins',sans-serif;font-size:1.3rem;font-weight:800;color:var(--secondary);margin-bottom:3px;}
.tl-content h3{font-size:.92rem;margin-bottom:5px;}
.tl-content p{font-size:.8rem;}

/* ===== COMMENCER PAGE ===== */
.contact-hero-split{display:grid;grid-template-columns:1fr 1.5fr;min-height:100vh;}
.contact-left{background:linear-gradient(160deg,var(--primary) 0%,#1a2a5e 100%);padding:120px 6% 60px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;}
.contact-left::before{content:'';position:absolute;width:380px;height:380px;background:rgba(125,137,207,.1);border-radius:50%;top:-90px;right:-90px;}
.contact-left h1{color:#fff;font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:13px;position:relative;z-index:1;}
.contact-left>p{color:rgba(255,255,255,.72);margin-bottom:40px;position:relative;z-index:1;}
.contact-info-list{display:flex;flex-direction:column;gap:18px;position:relative;z-index:1;}
.contact-info-item{display:flex;align-items:center;gap:13px;}
.contact-info-icon{width:46px;height:46px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0;}
.contact-info-label{font-family:'Poppins',sans-serif;font-size:.69rem;font-weight:600;color:rgba(255,255,255,.46);text-transform:uppercase;letter-spacing:.5px;margin-bottom:1px;}
.contact-info-val{color:#fff;font-size:.9rem;font-weight:500;}
.contact-info-val a{color:#fff;}
.contact-right{background:#fff;padding:80px 7%;display:flex;flex-direction:column;justify-content:center;}
.step-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:26px;}
.step-badge{display:flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--border);padding:6px 11px;border-radius:50px;font-size:.74rem;font-weight:600;color:var(--primary);font-family:'Poppins',sans-serif;}
.step-badge .num{width:19px;height:19px;background:var(--secondary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.67rem;font-weight:700;}
.contact-social-row{display:flex;gap:9px;margin-top:32px;position:relative;z-index:1;}
.csocial-link{width:40px;height:40px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);font-size:.8rem;font-weight:700;transition:all .3s;}
.csocial-link:hover{background:var(--secondary);border-color:var(--secondary);color:#fff;}

/* ===== RESPONSIVE ===== */
@media(max-width:1100px){
  .hero{grid-template-columns:1fr;padding:100px 5% 50px;}
  .hero-img-side{display:none;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:900px){
  .services-grid-3,.offers-services-grid,.gallery-concepts,.faq-grid,.pricing-grid-claude,.testimonial-grid{grid-template-columns:repeat(2,1fr);}
  .why-grid,.offer-big-card{grid-template-columns:1fr;}
  .offer-big-card.reverse{direction:ltr;}
  .service-hero{grid-template-columns:1fr;padding:100px 5% 56px;}
  .service-hero-img{display:none;}
  .contact-hero-split{grid-template-columns:1fr;}
  .contact-left{padding:100px 5% 40px;}
  .timeline::before{left:16px;}
  .timeline-item{grid-template-columns:1fr;}
  .timeline-item::after{left:16px;}
  .tl-empty{display:none;}
  .sites-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:640px){
  .services-grid-3,.offers-services-grid,.gallery-concepts,.faq-grid,.pricing-grid-claude,.testimonial-grid,.sites-grid{grid-template-columns:1fr;}
  .navbar-nav{display:none;}
  .hamburger{display:flex;}
  .form-row-2{grid-template-columns:1fr;}
  /* Footer mobile 2 colonnes 2 lignes */
  .footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;}
  .footer-grid>div:nth-child(1){grid-column:span 2;}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center;}
  .hero-stats{gap:20px;}
  .section{padding:56px 4%;}
  .hero{padding:84px 4% 44px;}
  /* Padding mobile */
  .service-card-body,.offer-card-content{padding:16px;}
  .pc-card{padding:22px 18px;}
  .partners-names{gap:10px;}
  .partner-name-item{padding:8px 13px;font-size:.78rem;}
  /* No overflow */
  body{overflow-x:hidden;}
  *{max-width:100vw;}
  img,video{max-width:100%;}
}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:var(--secondary);border-radius:3px;}
/* Fix Google Translate bar */
#google_translate_element{display:none!important;}
.goog-te-banner-frame{display:none!important;}
body{top:0!important;}
.skiptranslate{display:none!important;}

/* ============================================================
   PATCH RESPONSIVE & ANIMATIONS v6
   ============================================================ */

/* ===== Fix overflow mobile — CRUCIAL ===== */
html, body { overflow-x: hidden !important; max-width: 100vw; }
* { box-sizing: border-box; }
img, video, iframe, embed { max-width: 100%; height: auto; }
table { max-width: 100%; overflow-x: auto; display: block; }

/* Containers ne débordent jamais */
.section, .section-white, .section-alt, .section-light,
.footer, .page-hero, .hero, .cta-banner, .cta-white,
.testimonial-section, .partners-strip,
.service-hero { padding-left: 4%; padding-right: 4%; }

@media(max-width:480px){
  .section, .section-white, .section-alt { padding: 44px 4%; }
  .hero { padding: 80px 4% 44px; }
  .page-hero { padding: 100px 4% 52px; }
  .footer { padding: 44px 4% 22px; }
  .cta-banner, .cta-white { padding: 52px 4%; }
  
  /* Hero stats sur mobile */
  .hero-stats { gap: 16px; }
  .stat-number { font-size: 1.5rem; }
  
  /* Boutons responsifs */
  .btn { padding: 11px 20px; font-size: .84rem; }
  .hero-buttons { flex-direction: column; gap: 10px; }
  .hero-buttons .btn { width: 100%; justify-content: center; }
  
  /* Grilles 1 colonne sur très petit écran */
  .services-grid-3,
  .offers-services-grid,
  .gallery-grid-icons,
  .faq-grid,
  .pricing-grid-claude,
  .testimonial-grid,
  .sites-grid,
  .gallery-concepts { grid-template-columns: 1fr !important; }
  
  /* Why grid */
  .why-grid { grid-template-columns: 1fr !important; gap: 32px; }
  
  /* Footer 2 colonnes */
  .footer-grid { grid-template-columns: 1fr 1fr !important; gap: 20px; }
  .footer-grid > div:first-child { grid-column: 1 / -1; }
  
  /* Chatbot plus petit */
  #chatbot-box { width: calc(100vw - 32px); left: -8px; }
  
  /* Devis modal */
  .devis-box { padding: 24px 18px; margin: 8px; }
  .form-row-2 { grid-template-columns: 1fr !important; }
  
  /* Navbar */
  .navbar { padding: 0 4%; }
  .navbar-logo-img { height: 36px; }
  
  /* Page hero breadcrumb */
  .breadcrumb { flex-wrap: wrap; }
  
  /* Section header */
  .section-header { margin-bottom: 32px; }
  
  /* Cards */
  .service-card-body, .offer-card-content, .pc-card { padding: 16px 14px; }
  .offer-big-card { grid-template-columns: 1fr !important; }
  .offer-big-card.reverse { direction: ltr !important; }
  
  /* CTA buttons */
  .cta-buttons { flex-direction: column; align-items: center; gap: 10px; }
  .cta-buttons .btn { width: 100%; max-width: 300px; justify-content: center; }
  
  /* Contact page */
  .contact-hero-split { grid-template-columns: 1fr !important; }
  .contact-left { padding: 80px 4% 36px !important; }
  .contact-right { padding: 32px 4% !important; }
  
  /* Partners */
  .partners-names { gap: 8px; }
  .partner-name-item { padding: 7px 12px; font-size: .76rem; }
  
  /* Réalisations */
  .sites-grid { grid-template-columns: 1fr !important; }
  .gallery-grid-icons { grid-template-columns: 1fr !important; }
  .timeline-item { grid-template-columns: 1fr !important; }
  .timeline::before { left: 12px !important; }
  .timeline-item::after { left: 12px !important; }
  
  /* Pricing */
  .pricing-grid-claude { grid-template-columns: 1fr !important; }
  .pc-card.pc-featured { transform: scale(1) !important; }
}

/* ===== DRAPEAUX langue ===== */
.lang-btn { font-size: 1rem !important; padding: 4px 8px !important; border: none !important; background: transparent !important; cursor: pointer; transition: transform .2s !important; line-height: 1; }
.lang-btn:hover { transform: scale(1.2) !important; }
.lang-btn.active { transform: scale(1.15); filter: drop-shadow(0 2px 4px rgba(0,0,0,.2)); }

/* ===== ANIMATIONS supplémentaires ===== */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInLeft {
  from { opacity: 0; transform: translateX(-24px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes fadeInRight {
  from { opacity: 0; transform: translateX(24px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50%       { transform: scale(1.04); }
}
@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}

/* CTA banner shimmer effect */
.cta-banner h2 {
  background: linear-gradient(90deg, #fff 0%, rgba(255,255,255,.7) 50%, #fff 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shimmer 3s linear infinite;
}

/* Hero badge pulse */
.hero-badge { animation: pulse 3s ease-in-out infinite; }

/* Stagger animation pour grilles */
.services-grid-3 .service-card-img:nth-child(1) { animation-delay: .0s; }
.services-grid-3 .service-card-img:nth-child(2) { animation-delay: .1s; }
.services-grid-3 .service-card-img:nth-child(3) { animation-delay: .2s; }
.services-grid-3 .service-card-img:nth-child(4) { animation-delay: .3s; }
.services-grid-3 .service-card-img:nth-child(5) { animation-delay: .4s; }
.services-grid-3 .service-card-img:nth-child(6) { animation-delay: .5s; }

/* Stats counter animation */
.stat-number { animation: fadeInUp .6s ease both; }

/* Galerie réalisations fond blanc + contour bleu */
.concept-icon-card img,
.gallery-item img[src$=".png"] {
  background: #fff;
  padding: 8px;
  border-radius: 8px;
}

/* Force fond blanc pour images PNG dans galerie logos */
.gallery-item.logo-item {
  background: #fff !important;
  border: 2px solid var(--secondary) !important;
  border-radius: var(--radius-lg) !important;
  padding: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* ===== RESPONSIVE MEDIUM ===== */
@media(max-width:768px) and (min-width:481px){
  .services-grid-3 { grid-template-columns: repeat(2,1fr) !important; }
  .sites-grid { grid-template-columns: repeat(2,1fr) !important; }
  .footer-grid { grid-template-columns: 1fr 1fr !important; gap: 24px; }
  .footer-grid > div:first-child { grid-column: 1 / -1; }
  .pricing-grid-claude { grid-template-columns: 1fr !important; }
  .testimonial-grid { grid-template-columns: 1fr !important; }
}

/* ===== Suppression barre Google Translate ===== */
.goog-te-banner-frame.skiptranslate,
.goog-te-gadget,
#goog-gt-votingframe { display: none !important; }
body { top: 0 !important; }
.skiptranslate { display: none !important; }

/* ===== LIGHTBOX ===== */
.lightbox { position: fixed; inset: 0; background: rgba(0,0,0,.92); z-index: 9999; display: none; align-items: center; justify-content: center; padding: 16px; }
.lightbox.open { display: flex; }
.lightbox-inner { position: relative; max-width: min(90vw, 960px); max-height: 90vh; }
.lightbox-inner img, .lightbox-inner video { max-width: 100%; max-height: 85vh; border-radius: 12px; object-fit: contain; }
.lightbox-close { position: fixed; top: 16px; right: 20px; background: rgba(255,255,255,.1); border: none; color: #fff; font-size: 1.6rem; cursor: pointer; z-index: 10000; width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: background .3s; }
.lightbox-close:hover { background: rgba(255,255,255,.25); }
