/* ============================================================
   VARIABLES — Palette Vert Bouteille & Jaune Doré
   ============================================================ */
:root {
  --color-fond:        #F0F2EC;
  --color-fond-alt:    #E3E8DE;
  --color-border:      #C6D1BE;
  --color-primary:     #1E3D2F;
  --color-accent:      #F2C200;
  --color-accent-bg:   rgba(242,194,0,0.12);
  --color-accent-dark: #7A6000;
  --color-text:        #3C5044;
  --color-muted:       #7A9280;
  --font-display: 'Epilogue', sans-serif;
  --font-body:    'Manrope', sans-serif;
  --text-hero: clamp(38px, 4.5vw, 56px);
  --text-h2:   clamp(26px, 3vw, 36px);
  --text-stat: clamp(44px, 5vw, 64px);
  --text-h3: 18px; --text-body: 15px; --text-sm: 13px; --text-ui: 12px; --text-label: 11px;
  --lh-display: 1.05; --lh-heading: 1.15; --lh-body: 1.75;
  --space-xs:8px; --space-sm:16px; --space-md:24px; --space-lg:48px; --space-xl:80px;
  --container-max:1280px; --container-pad:clamp(20px,5vw,80px);
  --radius:12px; --radius-md:16px; --radius-lg:24px;
  --transition:0.25s ease;
  --shadow-sm: 0 2px 8px rgba(30,61,47,.06);
  --shadow-md: 0 4px 20px rgba(30,61,47,.10);
  --shadow-lg: 0 8px 40px rgba(30,61,47,.14);
}

/* ============================================================
   RESET & BASE STYLES
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--color-fond);color:var(--color-text);font-family:var(--font-body);font-size:var(--text-body);line-height:var(--lh-body);-webkit-font-smoothing:antialiased}
img,svg{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--transition)}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:var(--font-body)}
h1,h2,h3{font-family:var(--font-display);font-weight:800;line-height:var(--lh-heading);color:var(--color-primary);text-transform:uppercase;letter-spacing:.02em}
h1{font-size:var(--text-hero);font-weight:900;line-height:var(--lh-display);letter-spacing:.01em}
h2{font-size:var(--text-h2);font-weight:800}
h3{font-size:var(--text-h3);font-weight:700;letter-spacing:.03em}
p{color:var(--color-text);font-size:var(--text-body);line-height:var(--lh-body)}

/* ============================================================
   LAYOUT
   ============================================================ */
.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 var(--container-pad)}
.section{padding:var(--space-xl) 0}
.section--dark{background:var(--color-primary)}
.section--dark h1,.section--dark h2,.section--dark h3{color:var(--color-fond)}
.section--dark p{color:rgba(240,237,230,.7)}
.section--alt{background:var(--color-fond-alt)}
.section-header{margin-bottom:var(--space-lg)}
.section-header--center{text-align:center}
.section-label{display:block;font-family:var(--font-body);font-size:var(--text-ui);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);margin-bottom:var(--space-sm)}

/* ============================================================
   COMPONENTS: TAGS & BUTTONS
   ============================================================ */
.tag{display:inline-flex;align-items:center;font-family:var(--font-body);font-size:var(--text-label);font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:4px 12px;border-radius:100px;background:var(--color-accent-bg);color:var(--color-accent-dark)}
.btn{display:inline-flex;align-items:center;gap:var(--space-xs);font-family:var(--font-body);font-size:var(--text-label);font-weight:600;text-transform:uppercase;letter-spacing:.09em;padding:14px 28px;border-radius:6px;transition:all var(--transition);white-space:nowrap;cursor:pointer}
.btn--primary{background:var(--color-primary);color:var(--color-fond);border:2px solid var(--color-primary)}
.btn--primary:hover{background:#1a1a1a;border-color:#1a1a1a}
.btn--outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}
.btn--outline:hover{background:var(--color-primary);color:var(--color-fond)}
.btn--accent{background:var(--color-accent);color:var(--color-primary);border:2px solid var(--color-accent)}
.btn--accent:hover{background:#d4960f;border-color:#d4960f}

/* ============================================================
   ANIMATIONS
   ============================================================ */
[data-animate]{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease}
[data-animate].is-visible{opacity:1;transform:translateY(0)}
[data-animate-delay="1"]{transition-delay:.1s}[data-animate-delay="2"]{transition-delay:.2s}
[data-animate-delay="3"]{transition-delay:.3s}[data-animate-delay="4"]{transition-delay:.4s}
[data-animate-delay="5"]{transition-delay:.5s}[data-animate-delay="6"]{transition-delay:.6s}
[data-animate-delay="7"]{transition-delay:.7s}[data-animate-delay="8"]{transition-delay:.8s}[data-animate-delay="9"]{transition-delay:.9s}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--color-fond);border-bottom:1px solid transparent;transition:border-color var(--transition),box-shadow var(--transition);height:72px;display:flex;align-items:center}
.site-header.is-scrolled{border-color:var(--color-border);box-shadow:var(--shadow-sm);background:rgba(240,242,236,.96);backdrop-filter:blur(8px)}
.site-header__inner{display:flex;align-items:center;gap:var(--space-lg);height:100%}
.site-header__logo{flex-shrink:0;display:flex;align-items:center;gap:10px}
.logo-mark{width:28px;height:auto;flex-shrink:0}
.logo-text{font-family:var(--font-display);font-size:17px;font-weight:900;color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em}
.site-nav{flex:1}
.site-nav__list{display:flex;align-items:center;gap:var(--space-lg)}
.site-nav__link{font-family:var(--font-body);font-size:var(--text-ui);font-weight:500;text-transform:uppercase;letter-spacing:.07em;color:var(--color-primary);position:relative;padding-bottom:2px}
.site-nav__link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--color-accent);transition:width var(--transition)}
.site-nav__link:hover::after,.site-nav__link.is-active::after{width:100%}
.site-header__actions{display:flex;align-items:center;gap:var(--space-md);flex-shrink:0}
.site-header__cta{padding:10px 22px}
.lang-switcher{display:flex;align-items:center;gap:4px}
.lang-switcher a,.lang-switcher span{font-family:var(--font-body);font-size:var(--text-ui);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted);padding:4px 6px;border-radius:4px;transition:color var(--transition),background var(--transition)}
.lang-switcher a:hover{color:var(--color-primary);background:var(--color-fond-alt)}
.lang-active{color:var(--color-primary)!important;font-weight:700!important}
.burger{display:none;flex-direction:column;justify-content:space-between;width:28px;height:18px;padding:0;flex-shrink:0}
.burger__line{display:block;width:100%;height:2px;background:var(--color-primary);border-radius:2px;transition:transform var(--transition),opacity var(--transition);transform-origin:center}
.burger.is-open .burger__line:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.is-open .burger__line:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.is-open .burger__line:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* Logo swap au scroll */
.logo-swap {
  position: relative;
  display: flex;
  align-items: center;
  height: 22px;
}
.logo-wa {
  display: block;
  height: 20px;
  width: auto;
  color: #1E3D2F;
  transition: opacity 0.4s ease, transform 0.4s ease;
  transform-origin: left center;
}
.logo-w {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%) scale(0.75);
  height: 26px;
  width: auto;
  color: #1E3D2F;
  opacity: 0;
  transition: opacity 0.4s ease, transform 0.4s ease;
  transform-origin: left center;
}
.site-header.is-scrolled .logo-wa {
  opacity: 0;
  transform: scale(0.8);
}
.site-header.is-scrolled .logo-w {
  opacity: 1;
  transform: translateY(-50%) scale(1);
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.section-hero{position:relative;min-height:100vh;display:flex;align-items:center;padding-top:calc(72px + var(--space-xl));padding-bottom:var(--space-xl);background:var(--color-fond);overflow:hidden}
.section-hero__inner{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:var(--space-xl);position:relative;z-index:1}
.section-hero__tag{margin-bottom:var(--space-md)}
.section-hero__title{margin-top:var(--space-sm);margin-bottom:var(--space-md);max-width:18ch}
.section-hero__subtitle{font-size:19px;color:var(--color-text);max-width:52ch;margin-bottom:var(--space-lg);line-height:1.75}
.section-hero__ctas{display:flex;flex-wrap:wrap;gap:var(--space-sm)}
.section-hero__media{position:relative}
.section-hero__image-wrap{position:relative;z-index:1;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.section-hero__img-placeholder{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#e8dfd0 0%,#d5c9b8 40%,#c8bca9 100%);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg)}
.section-hero__img-placeholder svg{opacity:.25}
.section-hero__blob{position:absolute;pointer-events:none;z-index:0}
.section-hero__blob:first-child{top:-5%;right:-5%;width:55%;opacity:1}
.section-hero__blob--2{bottom:10%;left:-2%;width:20%}
.section-hero__scroll{position:absolute;bottom:var(--space-md);left:50%;transform:translateX(-50%);color:var(--color-muted);animation:bounce 2s ease-in-out infinite}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* Hero Editorial */
.section-hero {
  background: linear-gradient(135deg, #d5dfd0 0%, #eff1eb 44%, #f8f4df 100%);
}
.hero-shapes {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.hero-shape {
  position: absolute;
  border-radius: 50%;
}
.hero-shape--1 {
  width: clamp(300px, 38vw, 540px);
  height: clamp(300px, 38vw, 540px);
  background: rgba(30,61,47,0.045);
  top: -20%;
  right: -12%;
  animation: hsDrift1 28s ease-in-out infinite;
}
.hero-shape--2 {
  width: clamp(220px, 28vw, 400px);
  height: clamp(220px, 28vw, 400px);
  background: transparent;
  border: 1.5px solid rgba(30,61,47,0.07);
  bottom: -14%;
  left: -10%;
  animation: hsDrift2 34s ease-in-out infinite;
}
.hero-shape--3 {
  width: clamp(140px, 18vw, 260px);
  height: clamp(140px, 18vw, 260px);
  background: rgba(242,194,0,0.055);
  bottom: -8%;
  right: -4%;
  animation: hsDrift3 22s ease-in-out infinite;
}
.hero-shape--4 {
  width: clamp(100px, 12vw, 180px);
  height: clamp(100px, 12vw, 180px);
  background: transparent;
  border: 1px solid rgba(242,194,0,0.09);
  top: -6%;
  left: -4%;
  animation: hsDrift2 40s ease-in-out 6s infinite;
}
@keyframes hsDrift1 {
  0%, 100% { transform: translate(0px, 0px) scale(1); }
  30%       { transform: translate(-22px, 28px) scale(1.03); }
  65%       { transform: translate(16px, -18px) scale(0.97); }
}
@keyframes hsDrift2 {
  0%, 100% { transform: translate(0px, 0px) scale(1); }
  40%       { transform: translate(26px, -20px) scale(1.05); }
  75%       { transform: translate(-14px, 24px) scale(0.96); }
}
@keyframes hsDrift3 {
  0%, 100% { transform: translate(0px, 0px); }
  50%       { transform: translate(20px, -16px); }
}
.hero-watermark {
  position: absolute;
  right: -4%;
  bottom: -6%;
  width: clamp(320px, 44vw, 620px);
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  animation:
    heroWReveal 1.8s cubic-bezier(0.16, 1, 0.3, 1) 0.4s forwards,
    heroWFloat  16s ease-in-out 2.4s infinite,
    heroWColor  8s ease-in-out 2s infinite;
}
@keyframes heroWReveal {
  from { opacity: 0; transform: scale(0.92); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes heroWFloat {
  0%   { transform: translateY(0) rotate(0deg); }
  30%  { transform: translateY(-14px) rotate(0.5deg); }
  65%  { transform: translateY(8px) rotate(-0.3deg); }
  100% { transform: translateY(0) rotate(0deg); }
}
@keyframes heroWColor {
  0%, 100% { color: var(--color-accent); filter: drop-shadow(0 0 32px rgba(242,194,0,0.25)); }
  40%      { color: rgba(255,255,255,0.55); filter: drop-shadow(0 0 40px rgba(255,255,255,0.15)); }
  70%      { color: var(--color-accent); filter: drop-shadow(0 0 32px rgba(242,194,0,0.2)); }
}
.hero-editorial {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: var(--space-lg);
  padding-top: 96px;
  padding-bottom: 48px;
  /* left/right comes from .container: clamp(20px,5vw,80px) */
  text-align: center;
  position: relative;
  z-index: 1;
}
.hero-editorial .section-hero__title {
  font-size: clamp(32px, 4.2vw, 58px) !important;
  line-height: 1.06 !important;
  letter-spacing: -0.01em !important;
  max-width: none !important;
  color: var(--color-primary);
  text-align: center;
  margin: 0;
}
.hero-title-accent {
  color: var(--color-accent);
}
.hero-bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-lg);
  text-align: center;
}
.section-hero__subtitle {
  font-size: 19px;
  color: var(--color-text);
  line-height: 1.8;
  margin: 0;
  max-width: 72ch;
}
.hero-bottom-ctas {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: var(--space-sm);
}
.section-hero__scroll { color: var(--color-muted); z-index: 3; position: absolute; }
.hero-logos {
  padding: clamp(48px, 7vh, 80px) 0 clamp(40px, 6vh, 72px);
  background: var(--color-fond);
}
.hero-logos--dark {
  background: var(--color-primary);
  padding: clamp(32px, 5vh, 56px) 0;
}
.hero-logos--dark .logos-track__item img {
  filter: grayscale(1) opacity(0.45) invert(1) !important;
}
.hero-logos--dark .logos-track__item img:hover {
  filter: grayscale(0) opacity(0.9) invert(1) !important;
}
.logos-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: clamp(20px, 4vw, 56px) clamp(32px, 5vw, 72px);
}
.hero-logos__title {
  text-align: center;
  font-family: var(--font-display);
  font-size: clamp(22px, 2vw, 26px);
  font-weight: 800;
  color: var(--color-primary);
  margin-bottom: var(--space-lg);
}
.site-header{background:transparent;border-bottom-color:rgba(30,61,47,0.08)}
.site-header__inner{align-items:center!important}
.site-header__actions{align-items:center!important;gap:var(--space-sm)!important}
.site-nav__list{justify-content:center;align-items:center}
.lang-switcher{display:flex;align-items:center;line-height:1}
.site-header .logo-wa,.site-header .logo-w{color:#1E3D2F}
.site-header .site-nav__link{color:#1E3D2F}.site-header .site-nav__link::after{background:#E8C93C}
.site-header .lang-switcher span{color:#1E3D2F!important;font-weight:700!important}.site-header .lang-switcher a{color:#7A9280}
.site-header .burger__line{background:#1E3D2F}
.site-header .site-header__cta{background:#1E3D2F;color:#F0F2EC;border-color:#1E3D2F}
.site-header .site-header__cta:hover{background:#142a1f;border-color:#142a1f}
.site-header.is-scrolled{background:rgba(240,242,236,0.97)!important;border-color:#C6D1BE!important}
.site-header.is-scrolled .logo-wa,.site-header.is-scrolled .logo-w{color:#1E3D2F}.site-header.is-scrolled .site-nav__link{color:#1E3D2F}.site-header.is-scrolled .site-nav__link::after{background:#E8C93C}
.site-header.is-scrolled .lang-switcher span{color:#1E3D2F!important}.site-header.is-scrolled .lang-switcher a{color:#7A9280}
.site-header.is-scrolled .burger__line{background:#1E3D2F}.site-header.is-scrolled .site-header__cta{background:#1E3D2F;color:#F0F2EC;border-color:#1E3D2F}

/* ============================================================
   PHOTO STRIP
   ============================================================ */
.photo-strip {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  height: clamp(220px, 28vw, 380px);
  overflow: hidden;
}
.photo-strip__item {
  position: relative;
  overflow: hidden;
}
.photo-strip__item img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.6s ease;
}
.photo-strip__item:hover img {
  transform: scale(1.04);
}
.photo-strip__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: rgba(255,255,255,0.5);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-align: center;
  padding: 16px;
}
.photo-strip__placeholder svg { opacity: 0.4; }
@media(max-width: 600px) {
  .photo-strip { grid-template-columns: 1fr 1fr; height: 200px; }
  .photo-strip__item:last-child { display: none; }
}

/* ============================================================
   TEXT + MEDIA SECTION
   ============================================================ */
.section-texte-media__inner{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:var(--space-xl)}
.section-texte-media__tag{margin-bottom:var(--space-md);display:inline-block}
.section-texte-media__title{margin-top:var(--space-sm);margin-bottom:var(--space-md);max-width:22ch}
.section-texte-media__body p{margin-bottom:var(--space-sm);color:var(--color-text)}
.section-texte-media__body p:last-child{margin-bottom:0}
.section-texte-media__cta{margin-top:var(--space-lg)}
.section-texte-media__image-wrap{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);position:relative;z-index:1}
.img-placeholder{width:100%;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);background:linear-gradient(135deg,#e0d7cc 0%,#ccc1b2 60%,#bfb3a2 100%)}
.img-placeholder--media{aspect-ratio:4/3}
.img-placeholder--card{aspect-ratio:16/9;min-height:280px}
.img-placeholder--team{aspect-ratio:3/4}
.img-placeholder svg{opacity:.2}
.media-wrap-relative{position:relative}
.blob-deco{position:absolute;bottom:-24px;left:-24px;width:100px;height:100px;background:var(--color-accent);border-radius:50%;opacity:.15;z-index:0}

/* ============================================================
   LOGOS MARQUEE
   ============================================================ */
.section-logos{padding:var(--space-lg) 0}
.section-logos__title{font-size:clamp(13px,2vw,16px);font-weight:700;color:var(--color-primary);margin-bottom:var(--space-lg);text-align:center;letter-spacing:.04em;font-family:var(--font-display)}
.logos-marquee-wrap{
  overflow:hidden;
  mask-image:linear-gradient(90deg,transparent 0%,black 4%,black 96%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,black 4%,black 96%,transparent 100%);
}
.logos-track{
  display:flex;
  align-items:center;
  gap:0;
  animation:logos-scroll 42s linear infinite;
  will-change:transform;
}
.logos-marquee-wrap:hover .logos-track{animation-play-state:paused}
@keyframes logos-scroll{
  0%  {transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.logos-track__item{
  flex-shrink:0;
  width:210px;
  height:80px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 28px;
}
.logos-track__item img{
  max-height:52px;
  max-width:154px;
  width:auto;
  height:auto;
  filter:grayscale(1) opacity(.5);
  transition:filter .35s ease;
  display:block;
}
.logos-track__item img:hover{filter:grayscale(0) opacity(1)}
.section-logos__list{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--space-md) var(--space-xl)}
.section-logos__item{opacity:.5;transition:opacity var(--transition)}
.section-logos__item:hover{opacity:1}
.logo-pill{font-family:var(--font-display);font-size:var(--text-sm);font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary);padding:8px 20px;border:1.5px solid var(--color-border);border-radius:6px;filter:grayscale(1);transition:filter var(--transition)}
.section-logos__item:hover .logo-pill{filter:grayscale(0)}

/* ============================================================
   STATS
   ============================================================ */
.section-stats{background:var(--color-fond);position:relative;overflow:hidden}
.section-stats::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 60%,rgba(230,168,23,.06) 100%);pointer-events:none}
.section-stats{background:#1E3D2F}.section-stats::before{background:radial-gradient(ellipse 55% 55% at 50% 50%,rgba(232,201,60,.09) 0%,transparent 70%)}
.section-stats__list{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);position:relative;z-index:1}
.section-stats__item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-lg) var(--space-md);border-right:1px solid var(--color-border)}
.section-stats__item:last-child{border-right:none}
.section-stats__value{font-family:var(--font-display);font-size:var(--text-stat);font-weight:900;line-height:var(--lh-display);color:var(--color-accent);margin-bottom:var(--space-xs)}
.section-stats__value{color:#E8C93C}.section-stats__label{color:rgba(240,242,236,0.50)}.section-stats__item{border-color:rgba(240,242,236,0.10)}
.section-stats__label{font-family:var(--font-body);font-size:var(--text-sm);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);max-width:20ch;text-align:center}

/* ============================================================
   CARDS & GRID
   ============================================================ */
.section-grille-cards__title{max-width:28ch;margin:0 auto}
.section-grille-cards__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-bottom:var(--space-lg)}
.card-enjeu{background:var(--color-fond);border-radius:var(--radius);padding:var(--space-lg) var(--space-md);border:1px solid var(--color-border);transition:box-shadow var(--transition),transform var(--transition)}
.card-enjeu:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.card-enjeu{transition:box-shadow .3s ease,transform .3s ease,border-color .3s ease}
.card-enjeu:hover{box-shadow:0 12px 48px rgba(232,201,60,0.20),0 4px 16px rgba(30,61,47,0.08);border-color:rgba(232,201,60,0.42);transform:translateY(-7px)}
.card-enjeu__icon{width:48px;height:48px;background:var(--color-accent-bg);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-md)}
.card-enjeu__title{color:var(--color-primary);margin-bottom:var(--space-xs);font-size:var(--text-h3)}
.card-enjeu__text{font-size:var(--text-sm);color:var(--color-text);line-height:1.65}
.card-enjeu__text { font-size: 15px; line-height: 1.6; }
.cta-banner{background:var(--color-primary);border-radius:var(--radius);padding:var(--space-lg) var(--space-xl);display:flex;align-items:center;justify-content:center;text-align:center}
.cta-banner { justify-content: space-between !important; gap: clamp(24px, 4vw, 60px); text-align: left !important; }
.cta-banner__text {
  font-family: var(--font-display);
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: #F0F2EC;
  line-height: 1.4;
  margin: 0;
}
.cta-banner__text span {
  font-weight: 400;
  color: rgba(240,242,236,0.65);
  font-size: .9em;
}
@media(max-width: 640px){
  .cta-banner { flex-direction: column; text-align: center !important; padding: var(--space-lg) var(--space-md); }
  .cta-banner__text { text-align: center; font-size: 20px; line-height: 1.35; }
  .cta-banner__text span { font-size: 16px; }
  .cta-banner .btn { font-size: 14px; padding: 16px 36px; width: 100%; justify-content: center; }
}

/* ============================================================
   CAROUSEL
   ============================================================ */
.section-carousel__header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:var(--space-lg);gap:var(--space-md)}
.section-carousel__controls{display:flex;gap:var(--space-xs);flex-shrink:0}
.carousel-btn{width:44px;height:44px;border-radius:50%;border:2px solid var(--color-border);background:var(--color-fond);color:var(--color-primary);display:flex;align-items:center;justify-content:center;transition:all var(--transition);cursor:pointer}
.carousel-btn:hover{border-color:var(--color-primary);background:var(--color-primary);color:var(--color-fond)}
.section-carousel__track-wrap{overflow:hidden;border-radius:var(--radius-lg)}
.section-carousel__track{display:flex;transition:transform .45s cubic-bezier(.4,0,.2,1)}
.carousel-slide{min-width:100%;display:grid;grid-template-columns:1fr 1.6fr;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;background:var(--color-fond)}
.carousel-slide__info{padding:var(--space-xl) var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}
.carousel-slide__client-name{font-family:var(--font-display);font-size:var(--text-h3);font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--color-primary)}
.carousel-slide__tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}
.carousel-slide__desc{font-size:var(--text-sm);color:var(--color-text);line-height:1.7;flex:1}
.carousel-slide__cta{align-self:flex-start}
.carousel-slide__media{overflow:hidden;background:var(--color-fond-alt)}
.carousel-slide__media .img-placeholder{min-height:340px;border-radius:0}
.section-carousel__dots{display:flex;justify-content:center;gap:var(--space-xs);margin-top:var(--space-md)}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border);border:none;cursor:pointer;transition:all var(--transition);padding:0}
.carousel-dot.is-active,.carousel-dot:hover{background:var(--color-accent);transform:scale(1.3)}

/* ============================================================
   REALIZATIONS / PROJECTS
   ============================================================ */
.real-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0 20px;
}
.real-tab {
  padding: 10px 22px;
  border-radius: 100px;
  border: 1.5px solid var(--color-border);
  background: transparent;
  font-family: var(--font-display);
  font-size: clamp(12px, 1.1vw, 14px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  cursor: pointer;
  color: var(--color-muted);
  transition: background .2s, border-color .2s, color .2s;
}
.real-tab:hover { border-color: var(--color-primary); color: var(--color-primary); }
.real-tab.is-active { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-fond); }
/* ─── Réalisations slider ─────────────────────────────── */
.real-panels-viewport {
  overflow: hidden;
  width: 100%;
}
.real-panels-track {
  display: flex;
  width: 100%;
  transition: transform 0.46s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}
.real-panel {
  /* flex: 0 0 100% = chaque panneau occupe exactement la largeur du viewport */
  flex: 0 0 100%;
  width: 100%;
  box-sizing: border-box;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: clamp(20px, 2.5vw, 36px);
  align-items: stretch;
  min-height: clamp(480px, 68vh, 720px);
}
.real-panel__info {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: clamp(24px, 3vw, 36px);
  background: #fff;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  height: 100%;
}
.real-panel__info__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--color-border);
  flex-shrink: 0;
  min-height: clamp(60px, 9vh, 100px);
}
.real-panel__info .carousel-slide__tags { display: flex; flex-wrap: wrap; gap: 6px; }
.real-panel__info .carousel-slide__desc { font-size: 16px; color: var(--color-text); line-height: 1.7; margin: 0; flex: 1; }
.real-panel__info a { margin-top: auto; font-size: 14px; }
.real-bento {
  display: grid;
  grid-template-columns: 2fr 1fr;
  grid-template-rows: clamp(160px, 24vh, 260px) auto;
  gap: 12px;
}
.real-bento__visuel-main {
  grid-column: 1; grid-row: 1;
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
}
.real-bento__visuel-side {
  grid-column: 2; grid-row: 1;
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 20px;
  text-align: center;
}
.real-bento__stat-val {
  font-family: var(--font-display);
  font-size: clamp(32px, 3.5vw, 52px);
  font-weight: 900;
  color: #ffffff;
  line-height: 1;
}
.real-bento__stat-lbl {
  font-size: 13px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .06em;
  color: rgba(255,255,255,0.85); line-height: 1.4;
}
.real-bento__bottom {
  grid-column: 1 / -1; grid-row: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

/* ─── Browser mockup frame ──────────────────────────────── */
.browser-frame {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: #e9eaec;
  box-shadow: 0 2px 12px rgba(30,61,47,.10);
  display: flex;
  flex-direction: column;
}
.browser-frame__chrome {
  background: #e9eaec;
  border-bottom: 1px solid #d0d2d6;
  padding: 7px 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.browser-frame__dots {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}
.browser-frame__dots span {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  display: block;
}
.browser-frame__dots span:nth-child(1){background:#FF5F57}
.browser-frame__dots span:nth-child(2){background:#FEBC2E}
.browser-frame__dots span:nth-child(3){background:#28C840}
.browser-frame__url {
  flex: 1;
  background: rgba(255,255,255,.75);
  border: 1px solid #c8cacd;
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 10px;
  color: #555;
  text-align: center;
  font-family: var(--font-body);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.6;
}
/* Screenshot à l'intérieur du browser frame : image bord-à-bord, hauteur naturelle */
.browser-frame .real-bento__screenshot {
  border-radius: 0;
  width: 100%;
  padding: 0;
  aspect-ratio: unset;
  background: transparent;
}
.browser-frame .real-bento__screenshot img {
  width: 100%;
  height: auto;
  display: block;
  flex-shrink: unset;
}
.real-bento__screenshot {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: #F0EDE6;
  padding: 10px;
  aspect-ratio: 714/906;
  display: flex;
  justify-content: center;
  align-items: stretch;
}
#slide-cegid .real-bento__screenshot,
#slide-rollon .real-bento__screenshot,
#slide-simago .real-bento__screenshot,
#slide-merieux .real-bento__screenshot {
  padding: 0;
}
#slide-cegid .real-bento__screenshot img,
#slide-rollon .real-bento__screenshot img,
#slide-simago .real-bento__screenshot img,
#slide-merieux .real-bento__screenshot img {
  border-radius: 0;
}
#slide-cegid   .real-bento__screenshot { background: #E8F0FA; }
#slide-rollon  .real-bento__screenshot { background: #EBEBEB; }
#slide-simago  .real-bento__screenshot { background: #E7F3EC; }
#slide-merieux .real-bento__screenshot { background: #EDE8F5; }
/* Rollon — bottom fusionné en une seule card paysage */
#slide-rollon .real-bento__bottom {
  grid-template-columns: 1fr;
}
#slide-rollon .real-bento__bottom .real-bento__screenshot {
  aspect-ratio: unset;
}
#slide-rollon .real-bento__bottom .real-bento__screenshot img {
  width: 100%;
  height: auto;
  display: block;
}
/* Desktop : pas de zoom/lightbox sur les images bento */
@media(min-width: 769px) {
  .real-bento__screenshot img,
  .real-bento__visuel-main img {
    pointer-events: none;
    cursor: default;
  }
}
@media(max-width: 900px) {
  .real-panel { grid-template-columns: 1fr; min-height: unset; }
  .real-panel__info { height: auto; }
  .real-bento { grid-template-rows: 140px clamp(220px, 35vh, 320px); height: auto; }
}
@media(max-width: 768px) {
  /* Réalisations : marges égales gauche / droite */
  .real-panel { padding: 0; }
  .real-bento { margin: 0; }
  .real-bento__bottom { grid-template-columns: 1fr 1fr; }
  /* Screenshot : curseur zoom-in visible */
  .real-bento__screenshot img,
  .real-bento__visuel-main img { cursor: zoom-in; }
  /* Légère réduction pour la transition réalisations → qui-sommes-nous */
  #realisations.section { padding-bottom: 20px; }
  .section-equipe-story.section { padding-top: 20px; }
}

/* ── Lightbox ────────────────────────────────────────────── */
.lb-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(10,10,10,0.94);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .22s ease;
  cursor: zoom-out;
}
.lb-overlay.lb-open { opacity: 1; }
.lb-overlay img {
  max-width: 94vw; max-height: 90vh;
  object-fit: contain; border-radius: 8px;
  transform: scale(.94); transition: transform .22s ease;
  pointer-events: none; display: block;
}
.lb-overlay.lb-open img { transform: scale(1); }
.lb-close {
  position: absolute; top: 14px; right: 18px;
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,.12); border: none;
  color: #fff; font-size: 20px; line-height: 1;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .18s;
}
.lb-close:hover { background: rgba(255,255,255,.25); }
.form-input:focus,.form-textarea:focus{border-color:#E8C93C;box-shadow:0 0 0 3px rgba(232,201,60,0.15)}

/* ============================================================
   TEAM
   ============================================================ */
.section-team__title{margin-bottom:var(--space-sm)}
.section-team__intro{max-width:60ch;margin:0 auto var(--space-lg);text-align:center;color:var(--color-text)}
.section-team__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}
.card-member{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-sm)}
.card-member__photo-wrap{width:110px;height:130px;border-radius:var(--radius);overflow:hidden;background:var(--color-fond);border:2px solid var(--color-border)}
.card-member__photo-wrap .img-placeholder{height:100%;border-radius:0}
.card-member__name{font-family:var(--font-display);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--color-primary)}
.card-member__role{font-size:var(--text-sm);color:var(--color-muted)}
.team-quote{background:var(--color-primary);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;position:relative;overflow:hidden}
.team-quote::before{content:'"';position:absolute;top:-20px;left:var(--space-lg);font-family:var(--font-display);font-size:160px;font-weight:900;color:var(--color-accent);opacity:.12;line-height:1;pointer-events:none}
.team-quote__text{font-family:var(--font-display);font-size:clamp(16px,2.5vw,24px);font-weight:700;text-transform:uppercase;letter-spacing:.02em;line-height:1.3;color:var(--color-fond);max-width:70ch;margin:0 auto var(--space-md)}
.team-quote__author{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--color-accent)}
.team-quote__role{font-size:var(--text-sm);color:var(--color-muted);display:block;margin-top:4px}

/* Equipe Story Layout */
.equipe-layout {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: start;
}
.equipe-story {
  position: sticky;
  top: calc(72px + var(--space-lg));
}
.equipe-story__title {
  margin-top: 0;
  margin-bottom: var(--space-lg);
  font-size: var(--text-h2);
  line-height: 1.15;
}
.equipe-story__text p {
  color: var(--color-text);
  font-size: clamp(16px, 1.5vw, 19px);
  line-height: 1.8;
  margin-bottom: var(--space-md);
}
.equipe-story__intro {
  font-size: clamp(18px, 1.8vw, 23px) !important;
  font-weight: 600 !important;
  color: var(--color-primary) !important;
  line-height: 1.6 !important;
  padding-bottom: var(--space-sm);
  border-bottom: 2px solid var(--color-accent);
  margin-bottom: var(--space-md) !important;
}
.equipe-story__text p:last-child {
  font-weight: 700;
  color: var(--color-primary);
  font-size: clamp(17px, 1.6vw, 20px);
}
.equipe-story__cta { margin-top: var(--space-sm); }
.equipe-stat {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  margin: var(--space-lg) 0 var(--space-md);
  padding: 14px 20px;
  background: var(--color-accent-bg);
  border-left: 3px solid var(--color-accent);
  border-radius: 0 8px 8px 0;
}
.equipe-stat__val {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 38px);
  font-weight: 900;
  color: var(--color-primary);
  line-height: 1;
}
.equipe-stat__lbl {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-muted);
  max-width: 18ch;
  line-height: 1.4;
}
.equipe-members {
  padding-top: clamp(100px, 14vw, 200px);
}
.equipe-members__title {
  font-family: var(--font-display);
  font-size: clamp(13px, 1.1vw, 15px);
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: var(--space-lg);
}
.equipe-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(10px, 1.5vw, 16px);
  align-items: start;
}
.equipe-grid .card-member {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.equipe-grid .card-member__photo-wrap {
  width: 100%; height: 0;
  padding-bottom: 160%;
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: 0;
}
.equipe-grid .card-member__photo-wrap img,
.equipe-grid .card-member__photo-wrap .img-placeholder {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: 50% 15%;
}
.equipe-grid .card-member__photo-wrap img {
  filter: grayscale(1) contrast(1.05);
  transition: filter 0.5s ease, transform 0.5s ease;
}
.equipe-grid .card-member:hover .card-member__photo-wrap img {
  filter: grayscale(0) contrast(1);
  transform: scale(1.04);
}
.equipe-grid .card-member:not(.card-member--stat) > div:not(.card-member__photo-wrap) {
  padding: 3px 0 12px;
  text-align: left;
  width: 100%;
}
.equipe-grid .card-member__name {
  font-size: 13px; font-weight: 700;
  color: var(--color-primary) !important;
  text-align: left !important;
  display: block;
}
.equipe-grid .card-member__role {
  font-size: 12px; line-height: 1.4;
  color: var(--color-text) !important;
  opacity: 0.7;
  text-align: left !important;
  display: block;
}
.equipe-grid .card-member:not(.card-member--stat) a {
  display: block;
  text-align: left;
}
.equipe-grid .card-member a svg { color: var(--color-muted); }
.equipe-grid .card-member a:hover svg { color: var(--color-accent); }
.equipe-grid .card-member:nth-child(even):not([data-animate]) { transform: translateY(36px); }
.equipe-grid .card-member:nth-child(even)[data-animate]:not(.is-visible) { transform: translateY(calc(36px + 24px)); }
.equipe-grid .card-member:nth-child(even)[data-animate].is-visible { transform: translateY(36px); }
.equipe-grid .card-member--stat { order: 99; }
.card-member--stat .card-member__photo-wrap {
  height: 0 !important;
  padding-bottom: 160% !important;
  background: var(--color-accent);
  display: block !important;
  position: relative !important;
  border-radius: var(--radius-md);
  margin-bottom: 0;
}
.card-member--stat .card-member__photo-wrap > div {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 16px;
}
.card-member--stat .card-stat__val {
  font-family: var(--font-display);
  font-size: clamp(26px, 3.5vw, 38px);
  font-weight: 900;
  color: var(--color-primary);
  line-height: 1;
}
.card-member--stat .card-stat__lbl {
  font-size: 13px; font-weight: 600;
  text-align: center; line-height: 1.4;
  color: rgba(30,61,47,0.85);
  text-transform: uppercase; letter-spacing: .05em;
  max-width: 12ch;
}
.equipe-partners-wrap { margin-top: calc(var(--space-xl) + 36px); }
.equipe-partners__title {
  font-size: clamp(16px, 1.8vw, 22px);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.4;
  max-width: none;
  margin-bottom: var(--space-lg);
  text-transform: none;
  letter-spacing: 0;
  text-align: center;
}
.equipe-partners__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-sm);
}
.equipe-partner-card {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0;
  padding: clamp(18px, 1.8vw, 26px);
  background: rgba(255,255,255,0.18);
  border: 1px solid rgba(198,209,190,0.28);
  border-radius: var(--radius-lg);
  transition: background 0.25s, box-shadow 0.25s;
  box-shadow: none;
  text-decoration: none;
  color: inherit;
}
.equipe-partner-card:hover {
  background: rgba(255,255,255,0.42);
  box-shadow: var(--shadow-sm);
}
.equipe-partner-card__logo-wrap {
  flex: 0 0 28%;
  width: 28%;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding-right: clamp(16px, 1.5vw, 22px);
  border-right: 1px solid rgba(198,209,190,0.45);
}
.equipe-partner-card__logo-wrap img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 38px;
  object-fit: contain;
  object-position: center;
}
.equipe-partner-card__expertise {
  flex: 1;
  padding-left: clamp(16px, 1.5vw, 22px);
  font-size: clamp(14px, 1.3vw, 16px);
  font-weight: 500;
  color: var(--color-primary);
  line-height: 1.6;
}
.partner-logo--text {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 900;
  color: var(--color-primary);
  letter-spacing: .02em;
  height: 36px;
  display: flex;
  align-items: center;
}
@media(max-width:768px) {
  .equipe-partners__grid { grid-template-columns: repeat(2,1fr); gap:12px; }
  /* Titre partenaires plus grand */
  .equipe-partners__title { font-size: 20px; margin-bottom: var(--space-md); }
  /* Cards : logo plus visible, texte plus lisible */
  .equipe-partner-card {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 18px 16px;
  }
  .equipe-partner-card__logo-wrap {
    flex: none;
    width: 100%;
    justify-content: flex-start;
    min-height: 36px;
    padding-right: 0;
    border-right: none;
    border-bottom: 1px solid rgba(198,209,190,0.45);
    padding-bottom: 12px;
  }
  .equipe-partner-card__logo-wrap img {
    max-height: 28px;
    width: auto;
    max-width: 100%;
  }
  .equipe-partner-card__expertise {
    padding-left: 0;
    font-size: 13px;
    line-height: 1.5;
  }
}
.equipe-quote-wrap { margin-top: calc(var(--space-xl) + 36px); }
.services-quote-wrap { margin-top: var(--space-xl); }
.services-team-quote .team-quote__author { color: var(--color-fond) !important; }
.services-team-quote .team-quote__text { color: rgba(240,242,236,0.9) !important; }
.team-quote {
  display: grid !important;
  grid-template-columns: 180px 1fr !important;
  gap: clamp(28px, 4vw, 60px) !important;
  align-items: center !important;
  text-align: left !important;
  padding: clamp(32px, 4vw, 52px) clamp(28px, 4vw, 52px) !important;
}
.team-quote::before { display: none !important; }
.team-quote__author-block {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-right: clamp(20px, 3vw, 40px);
  border-right: 1px solid rgba(240,242,236,0.18);
}
.team-quote__author {
  font-size: 13px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  line-height: 1.2 !important;
}
.team-quote__role {
  color: rgba(240,242,236,0.5) !important;
  margin-top: 0 !important;
}
.team-quote__text {
  max-width: none !important;
  margin: 0 !important;
  font-size: clamp(17px, 2.2vw, 24px) !important;
}
@media(max-width: 600px) {
  .team-quote { grid-template-columns: 1fr !important; }
  .team-quote__author-block { border-right: none; border-bottom: 1px solid rgba(240,242,236,0.18); padding-right: 0; padding-bottom: 16px; }
}
@media(max-width:1024px){
  .equipe-layout { grid-template-columns: 1fr; }
  .equipe-story { position: relative; top: auto; }
  .equipe-members { padding-top: var(--space-xl); }
  .equipe-grid { grid-template-columns: repeat(4, 1fr); }
  .equipe-grid .card-member { transform: none !important; }
}
@media(max-width:640px){
  .equipe-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================================
   MANIFESTE & QUOTE SECTIONS
   ============================================================ */
.section-manifeste-simple {
  background-color: #1E3D2F;
  background-image:
    radial-gradient(ellipse 55% 65% at 92% 20%, rgba(232,201,60,0.07) 0%, transparent 60%),
    radial-gradient(ellipse 40% 50% at 5% 85%, rgba(232,201,60,0.05) 0%, transparent 55%),
    radial-gradient(circle, rgba(255,240,160,0.04) 1px, transparent 1px);
  background-size: auto, auto, 28px 28px;
  position: relative; overflow: hidden;
  padding-bottom: clamp(80px, 10vw, 140px);
}
.manifeste-simple {
  max-width: 740px;
  margin: 0 auto;
  text-align: left;
  position: relative;
  z-index: 1;
}
.manifeste-simple__tag {
  margin-bottom: var(--space-md);
  display: inline-block;
  background: rgba(232,201,60,0.18) !important;
  color: #EDD355 !important;
}
.manifeste-simple__title { color: #F0F2EC !important; }
.manifeste-simple__cta { color: rgba(240,242,236,0.8) !important; border-color: rgba(240,242,236,0.3) !important; }
.manifeste-simple__cta:hover { background: rgba(240,242,236,0.1) !important; }
.manifeste-simple__title {
  font-size: clamp(24px, 2.6vw, 34px) !important;
  line-height: 1.12 !important;
  margin-top: var(--space-sm);
  margin-bottom: var(--space-lg);
  max-width: 100%;
}
.manifeste-simple__body p {
  font-size: 19px;
  line-height: 1.82;
  color: rgba(240,242,236,0.72);
  margin-bottom: var(--space-md);
}
.manifeste-simple__body p:last-child {
  margin-bottom: 0;
  font-weight: 600;
  color: rgba(240,242,236,0.92);
}
.section-quote-bridge {
  background: var(--color-fond);
  padding: clamp(40px, 6vw, 72px) 0;
}
.quote-bridge__inner {
  width: min(100% - 40px, 1200px);
  margin: 0 auto;
  background: #E8EBE1;
  border-radius: var(--radius-lg);
  padding: clamp(36px, 4vw, 56px) clamp(32px, 4vw, 56px);
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: clamp(32px, 4vw, 64px);
  align-items: start;
}
.quote-bridge__author {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-right: clamp(20px, 3vw, 40px);
  border-right: 1px solid rgba(30,61,47,0.18);
  padding-top: 8px;
}
.quote-bridge__name {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--color-primary);
  line-height: 1.3;
}
.quote-bridge__role {
  font-size: 13px;
  color: var(--color-muted);
  line-height: 1.5;
  margin-top: 2px;
}
.quote-bridge__company {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  color: #1E3D2F;
  letter-spacing: .01em;
  margin-top: 10px;
  display: inline-block;
  border-top: 2px solid #1E3D2F;
  padding-top: 8px;
}
.quote-bridge__text {
  font-family: var(--font-display);
  font-size: clamp(16px, 1.65vw, 20px);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.55;
  margin: 0;
  font-style: normal;
  position: relative;
  padding-top: 0;
  z-index: 1;
}
.quote-bridge__text::before {
  content: "\201C";
  font-family: var(--font-display);
  font-size: 180px;
  font-weight: 900;
  font-style: normal;
  color: var(--color-accent);
  line-height: 1;
  position: absolute;
  top: -56px;
  left: -16px;
  opacity: 0.10;
  pointer-events: none;
  z-index: 0;
}
@media(max-width: 600px) {
  .quote-bridge__inner { grid-template-columns: 1fr; }
  .quote-bridge__author { border-right: none; border-bottom: 1px solid rgba(30,61,47,0.15); padding-right: 0; padding-bottom: 16px; }
}
.stab {
  font-weight: 800;
  font-style: italic;
  color: var(--color-accent);
}

/* ============================================================
   SPLASH SCREEN
   ============================================================ */
#splash-screen {
  position: fixed;
  inset: 0;
  z-index: 10001;
  background: var(--color-primary);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(16px, 2.5vw, 28px);
  animation: splashOverlayOut 0.8s cubic-bezier(0.4, 0, 0.2, 1) 5.4s forwards;
}
#splash-screen.splash--gone {
  display: none;
}
.splash-halo {
  position: absolute;
  width: clamp(280px, 40vw, 540px);
  height: clamp(280px, 40vw, 540px);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(232,201,60,0.18) 0%, rgba(232,201,60,0.04) 55%, transparent 75%);
  animation: splashHaloIn 1.4s ease-out 0.15s both;
}
.splash-w {
  position: relative;
  width: clamp(80px, 14vw, 160px);
  color: var(--color-accent);
  filter: drop-shadow(0 0 28px rgba(232,201,60,0.35));
  animation:
    splashWIn    1.1s cubic-bezier(0.16, 1, 0.3, 1) 0.2s both,
    splashWPulse 1.0s ease-in-out 1.6s 1,
    splashFadeOut 0.6s ease-in 4.8s forwards;
}
.splash-tagline {
  font-family: var(--font-body);
  font-size: clamp(11px, 1.3vw, 14px);
  font-weight: 700;
  letter-spacing: 0.26em;
  color: rgba(240,242,236,0.45);
  animation: splashTagIn 0.7s ease-out 0.9s both, splashFadeOut 0.6s ease-in 4.8s forwards;
}
.splash-phrase {
  font-family: var(--font-display);
  font-size: clamp(16px, 2.2vw, 26px);
  font-weight: 800;
  line-height: 1.25;
  text-align: center;
  color: #F0F2EC;
  max-width: min(88vw, 640px);
  opacity: 0;
  animation: splashPhraseIn 1.0s cubic-bezier(0.16, 1, 0.3, 1) 1.8s forwards, splashFadeOut 0.6s ease-in 4.8s forwards;
}
.splash-phrase em {
  color: var(--color-accent);
  font-style: normal;
}
.splash-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  background: var(--color-accent);
  animation: splashBarGrow 5.0s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.1s forwards;
  opacity: 0.65;
}
@media(max-width:768px){
  .splash-w{
    width:clamp(140px,38vw,200px);
  }
  .splash-tagline{
    font-size:13px;
    letter-spacing:0.22em;
  }
  .splash-phrase{
    font-size:clamp(22px,5.5vw,28px);
    max-width:100%;
    padding:0 var(--container-pad);
    box-sizing:border-box;
  }
  .splash-halo{
    width:clamp(320px,70vw,420px);
    height:clamp(320px,70vw,420px);
  }
}
@keyframes splashHaloIn {
  from { opacity: 0; transform: scale(0.4); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes splashWIn {
  from { opacity: 0; transform: scale(0.4) rotate(-12deg); }
  60%  { transform: scale(1.05) rotate(1deg); }
  to   { opacity: 1; transform: scale(1) rotate(0deg); }
}
@keyframes splashWPulse {
  0%   { transform: scale(1); filter: drop-shadow(0 0 28px rgba(232,201,60,0.35)); }
  50%  { transform: scale(1.06); filter: drop-shadow(0 0 48px rgba(232,201,60,0.6)); }
  100% { transform: scale(1); filter: drop-shadow(0 0 28px rgba(232,201,60,0.35)); }
}
@keyframes splashFadeOut {
  from { opacity: 1; }
  to   { opacity: 0; }
}
@keyframes splashTagIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes splashPhraseIn {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes splashBarGrow {
  from { width: 0%; }
  to   { width: 100%; }
}
@keyframes splashOverlayOut {
  from { opacity: 1; }
  to   { opacity: 0; pointer-events: none; }
}

/* ============================================================
   TÉMOIGNAGE / TESTIMONIALS
   ============================================================ */
.section-temoignage { background: var(--color-fond); }
.temoignage-card {
  background: #1E3D2F;
  border-radius: var(--radius-lg);
  padding: clamp(28px, 4vw, 48px) clamp(28px, 4vw, 52px);
  display: grid;
  grid-template-columns: 1fr 4fr;
  gap: clamp(24px, 3vw, 48px);
  align-items: center;
  position: relative;
  overflow: hidden;
}
.temoignage-card::before {
  content: '\201C\201C';
  position: absolute;
  top: -20px;
  left: 24px;
  font-family: var(--font-display);
  font-size: 160px;
  font-weight: 900;
  line-height: 1;
  color: rgba(240,242,236,0.06);
  pointer-events: none;
  letter-spacing: -0.1em;
}
.temoignage-author {
  display: flex;
  flex-direction: column;
  gap: 4px;
  border-right: 1px solid rgba(240,242,236,0.12);
  padding-right: clamp(20px, 2.5vw, 40px);
}
.temoignage-author__name {
  font-family: var(--font-display);
  font-size: clamp(13px, 1.2vw, 15px);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--color-accent);
}
.temoignage-author__role {
  font-size: 12px;
  color: rgba(240,242,236,0.5);
  line-height: 1.5;
}
.temoignage-text {
  font-family: var(--font-display);
  font-size: clamp(15px, 1.6vw, 20px);
  font-weight: 700;
  line-height: 1.5;
  color: rgba(240,242,236,0.92);
  margin: 0;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: .01em;
}
.temoignage-card--cream {
  background: var(--color-fond);
  margin-top: clamp(32px, 5vw, 56px);
}
.temoignage-card--cream::before {
  color: rgba(30,61,47,0.05);
}
.temoignage-card--cream .temoignage-author {
  border-right-color: var(--color-border);
}
.temoignage-card--cream .temoignage-author__name {
  color: var(--color-primary);
}
.temoignage-card--cream .temoignage-author__role {
  color: var(--color-muted);
}
.temoignage-card--cream .temoignage-text {
  color: var(--color-primary);
}

/* ============================================================
   COLONNES / SERVICES
   ============================================================ */
.section-colonnes__title{color:var(--color-fond);max-width:32ch;margin:0 auto}
.section-colonnes__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(240,237,230,.12);border-radius:var(--radius);overflow:hidden;margin-top:var(--space-xl)}
.col-service{padding:var(--space-xl) var(--space-lg);background:var(--color-primary);transition:background var(--transition)}
.col-service:hover{background:rgba(240,237,230,.04)}
.col-service__number{display:block;font-family:var(--font-display);font-size:var(--text-ui);font-weight:700;letter-spacing:.08em;color:var(--color-accent);margin-bottom:var(--space-md)}
.col-service__name{font-family:var(--font-display);font-size:var(--text-h3);font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-fond);margin-bottom:var(--space-md)}
.col-service__list{display:flex;flex-direction:column;gap:var(--space-xs)}
.col-service__item{display:flex;align-items:flex-start;gap:var(--space-xs);font-size:var(--text-sm);color:rgba(240,237,230,.65);line-height:1.55}
.col-service__item svg{flex-shrink:0;margin-top:2px}

/* Services Editorial */
.section-colonnes__grid--editorial {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin-top: 40px;
  border-top: 1px solid rgba(255,255,255,0.12);
}
#services.section { padding: clamp(36px, 4vw, 52px) 0; }
.col-service--editorial {
  padding: 48px 40px 48px 0;
  border-right: 1px solid rgba(255,255,255,0.12);
  padding-left: 40px;
}
.col-service--editorial:first-child { padding-left: 0; }
.col-service--editorial:last-child { border-right: none; }
.col-service__num-big {
  font-size: 72px;
  font-weight: 800;
  color: rgba(255,255,255,0.07);
  line-height: 1;
  margin-bottom: 20px;
  font-family: var(--font-heading);
  letter-spacing: -0.02em;
}
.col-service__name--editorial {
  font-size: clamp(20px, 1.8vw, 26px);
  font-weight: 700;
  color: #fff;
  margin-bottom: 16px;
  letter-spacing: -0.01em;
  line-height: 1.2;
}
.col-service--editorial .col-service__item {
  font-size: clamp(14px, 1.25vw, 16px);
  color: rgba(255,255,255,0.65);
}
.col-service--editorial .col-service__list {
  gap: 10px;
}
.col-service__promise {
  font-size: clamp(14px, 1.25vw, 16px);
  color: #fff !important;
  font-weight: 800;
  line-height: 1.75;
  margin: 0;
}
@media (max-width: 768px) {
  .section-colonnes__grid--editorial { grid-template-columns: 1fr; }
  .col-service--editorial { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.12); padding: 36px 0; }
  .col-service--editorial:last-child { border-bottom: none; }
  /* Textes de contenu plus lisibles sur mobile */
  .col-service__promise { font-size: 17px; }
  .col-service--editorial .col-service__item { font-size: 16px; }
  .col-service--editorial .col-service__list { gap: 14px; }
  /* Cédric : annuler le double-marge dû au .container parent */
  .services-quote-wrap .quote-bridge__inner {
    width: 100%;
    padding: clamp(24px,4vw,36px) clamp(20px,4vw,28px);
  }
}

/* ============================================================
   STACK TECH
   ============================================================ */
.section-stack{background:var(--color-fond-alt)}
.section-stack__title{max-width:28ch;margin:0 auto}
.section-stack__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-xs);margin-top:var(--space-md)}
.card-stack{background:var(--color-fond);border-radius:var(--radius);padding:clamp(16px,1.8vw,24px);border:1px solid var(--color-border)}
.card-stack--full{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);align-items:center}
.card-stack__label{font-family:var(--font-body);font-size:var(--text-ui);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent-dark);background:var(--color-accent-bg);padding:3px 10px;border-radius:4px;display:inline-block;margin-bottom:var(--space-sm)}
.card-stack__title{font-family:var(--font-display);font-size:clamp(17px,1.5vw,20px);font-weight:800;text-transform:uppercase;letter-spacing:.03em;color:var(--color-primary);margin-bottom:var(--space-xs)}
.card-stack__text{font-size:clamp(14px,1.3vw,16px);color:var(--color-text);line-height:1.7}
.card-stack__items{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}
.stack-pill{font-family:var(--font-body);font-size:var(--text-ui);font-weight:600;color:var(--color-muted);border:1px solid var(--color-border);border-radius:4px;padding:3px 10px}

/* Logo chips & tech stack extras */
.logo-chips { display:flex; flex-wrap:wrap; gap:6px; margin-top:10px; }
.logo-chip {
  display:flex; align-items:center;
}
.logo-chip__icon {
  width:36px; height:36px; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:800; color:#fff;
  flex-shrink:0;
}
.logo-chip__label {
  font-size:12px; font-weight:600; color:var(--color-muted);
  line-height:1.2; letter-spacing:0.01em;
}
.wp-logo-big {
  width:96px; height:96px; border-radius:var(--radius-lg); background:#21759B;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.card-stack__icon {
  width: 40px; height: 40px;
  background: rgba(30,61,47,0.07);
  border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
  flex-shrink: 0;
}
.card-stack--valentin {
  background: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  padding: clamp(24px, 2.5vw, 36px) !important;
  margin-top: clamp(16px, 2vw, 28px) !important;
}
.valentin-quote__inner {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: clamp(24px, 3vw, 48px);
  align-items: center;
}
.valentin-quote__left {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  padding-right: clamp(20px, 2vw, 32px);
  border-right: 1px solid rgba(240,242,236,0.18);
}
.valentin-quote__author {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 3px;
  width: 100%;
}
.valentin-quote__name {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #fff;
  line-height: 1.3;
  text-align: left;
}
.valentin-quote__role {
  font-size: 13px;
  color: rgba(240,242,236,0.55);
  line-height: 1.5;
  margin-top: 2px;
  text-align: left;
}
.valentin-quote__company {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  color: #fff;
  text-align: left;
  margin-top: 10px;
  padding-top: 8px;
  border-top: 2px solid rgba(240,242,236,0.35);
  width: 100%;
}
.valentin-quote__text {
  font-family: var(--font-display);
  font-size: clamp(16px, 1.65vw, 20px);
  font-weight: 700;
  color: rgba(240,242,236,0.92);
  line-height: 1.6;
  margin: 0;
  font-style: normal;
  position: relative;
  z-index: 1;
}
.valentin-quote__text::before {
  content: "\201C";
  font-family: var(--font-display);
  font-size: 180px;
  font-weight: 900;
  font-style: normal;
  color: var(--color-accent);
  line-height: 1;
  position: absolute;
  top: -56px;
  left: -16px;
  opacity: 0.18;
  pointer-events: none;
  z-index: 0;
}
@media(max-width:600px) {
  .valentin-quote__inner { grid-template-columns: 1fr; }
  .valentin-quote__left { flex-direction: row; border-right: none; padding-right: 0; border-bottom: 1px solid rgba(240,242,236,0.18); padding-bottom: 16px; align-items: center; justify-content: flex-start; }
}
.card-stack__aside-label {
  font-size:13px; font-weight:600; color:var(--color-muted);
  text-align:center; line-height:1.3; max-width:110px;
}
.card-stack__aside-badges { display:flex; flex-direction:column; gap:6px; align-items:center; }
.aside-badge {
  font-size:12px; font-weight:700; color:#21759B;
  background:rgba(33,117,155,.1); border:1px solid rgba(33,117,155,.2);
  border-radius:100px; padding:3px 10px; white-space:nowrap;
}
.logo-chips--grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:10px;
}
.card-stack--ai .card-stack__icon {
  width: 80px;
  height: 72px;
  background: transparent;
  border-radius: 0;
  overflow: visible;
  margin-bottom: 18px;
}
.ai-icon-svg { overflow: visible; display: block; }
@keyframes ai-ring-pulse {
  0%   { transform: scale(0.88); opacity: 0.35; }
  50%  { transform: scale(1.04); opacity: 0.1; }
  100% { transform: scale(0.88); opacity: 0.35; }
}
@keyframes ai-ring-pulse-2 {
  0%   { transform: scale(1.04); opacity: 0.12; }
  50%  { transform: scale(0.9);  opacity: 0.3; }
  100% { transform: scale(1.04); opacity: 0.12; }
}
@keyframes ai-dot-blink {
  0%, 100% { opacity: 0.45; }
  50%       { opacity: 1; }
}
@keyframes ai-dash-flow {
  0%   { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: -24; }
}
@keyframes ai-w-glow {
  0%, 100% { opacity: 0.92; }
  50%       { opacity: 1; filter: drop-shadow(0 0 3px rgba(232,201,60,0.35)); }
}
.ai-ring-1 { transform-origin: 40px 36px; animation: ai-ring-pulse   3.2s ease-in-out infinite; }
.ai-ring-2 { transform-origin: 40px 36px; animation: ai-ring-pulse-2 3.2s ease-in-out infinite 0.8s; }
.ai-tm-ring-1 { transform-origin: 100px 150px; animation: ai-ring-pulse   3.2s ease-in-out infinite; }
.ai-tm-ring-2 { transform-origin: 100px 150px; animation: ai-ring-pulse-2 3.2s ease-in-out infinite 0.8s; }
.ai-dot-1  { animation: ai-dot-blink 2.4s ease-in-out infinite 0s; }
.ai-dot-2  { animation: ai-dot-blink 2.4s ease-in-out infinite 0.4s; }
.ai-dot-3  { animation: ai-dot-blink 2.4s ease-in-out infinite 0.8s; }
.ai-dot-4  { animation: ai-dot-blink 2.4s ease-in-out infinite 1.2s; }
.ai-dot-5  { animation: ai-dot-blink 2.4s ease-in-out infinite 1.6s; }
.ai-dot-6  { animation: ai-dot-blink 2.4s ease-in-out infinite 0.3s; }
.ai-dot-7  { animation: ai-dot-blink 2.4s ease-in-out infinite 0.9s; }
.ai-dot-8  { animation: ai-dot-blink 2.4s ease-in-out infinite 1.5s; }
.ai-line   { animation: ai-dash-flow 2s linear infinite; }
.ai-line-2 { animation: ai-dash-flow 2s linear infinite 0.5s; }
.ai-line-3 { animation: ai-dash-flow 2s linear infinite 1s; }
.ai-line-4 { animation: ai-dash-flow 2s linear infinite 1.5s; }
.ai-line-d1 { animation: ai-dash-flow 1.8s linear infinite 0.2s; }
.ai-line-d2 { animation: ai-dash-flow 1.8s linear infinite 0.7s; }
.ai-line-d3 { animation: ai-dash-flow 1.8s linear infinite 1.2s; }
.ai-line-d4 { animation: ai-dash-flow 1.8s linear infinite 1.7s; }
.ai-w-shape { animation: ai-w-glow 4s ease-in-out infinite; }

/* ============================================================
   FORMULAIRE / FORM
   ============================================================ */
.section-formulaire__inner{display:grid;grid-template-columns:1fr 1.55fr;gap:clamp(40px,5vw,80px);align-items:center}
.section-formulaire__tag{display:inline-block;margin-bottom:var(--space-md)}
.section-formulaire__title{margin-bottom:var(--space-md);max-width:20ch}
.section-formulaire__subtitle{color:var(--color-text);margin-bottom:var(--space-lg);font-size:clamp(15px,1.4vw,17px);line-height:1.8;max-width:38ch}
.contact-info{display:flex;flex-direction:column;gap:12px;margin-bottom:var(--space-lg)}
.contact-info li{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-body);color:var(--color-text)}
.contact-info a:hover{color:var(--color-accent)}
.contact-also{padding-top:var(--space-md);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-md)}
.contact-also__intro{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--color-muted);margin-bottom:4px}
.contact-also__item{display:flex;align-items:flex-start;gap:12px}
.contact-also__icon{font-size:20px;line-height:1;flex-shrink:0;margin-top:2px}
.contact-also__label{font-size:13px;font-weight:800;color:var(--color-primary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.contact-also__text{font-size:13px;color:var(--color-text);line-height:1.65}
.contact-reassurance__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted)}
.form-wrap{background:var(--color-fond-alt);border-radius:var(--radius-lg);padding:clamp(28px,3vw,40px);border:1px solid var(--color-border)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm) var(--space-md)}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field--full{grid-column:1/-1}
.form-label{font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--color-primary)}
.form-input,.form-textarea{width:100%;font-family:var(--font-body);font-size:var(--text-body);color:var(--color-primary);background:var(--color-fond);border:1.5px solid var(--color-border);border-radius:var(--radius);padding:10px 14px;transition:border-color var(--transition),box-shadow var(--transition);outline:none}
.form-input::placeholder,.form-textarea::placeholder{color:var(--color-muted);font-size:14px}
.form-input:focus,.form-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(242,194,0,.15)}
.form-textarea{min-height:100px;resize:vertical}
.form-rgpd{display:flex;align-items:flex-start;gap:var(--space-xs)}
.form-rgpd input{width:16px;height:16px;accent-color:var(--color-accent);margin-top:2px;flex-shrink:0}
.form-rgpd label{font-size:var(--text-sm);color:var(--color-text);line-height:1.5}
.form-rgpd a{color:var(--color-accent-dark);text-decoration:underline}
.form-submit{margin-top:var(--space-md);width:100%;justify-content:center;padding:16px}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:#1C2D21;position:relative;overflow:hidden}
.footer-watermark-wrap{position:absolute;right:-4%;bottom:-10%;width:clamp(280px,38vw,560px);pointer-events:none;user-select:none;opacity:1}
.footer-watermark-svg{width:100%;height:auto;display:block}
.footer-body__inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(20px,2.5vw,52px);align-items:start;padding:clamp(44px,5.5vw,80px) 0 clamp(24px,2.5vw,36px);position:relative;z-index:1}
.site-footer__logo{display:flex;align-items:center;gap:10px;margin-bottom:var(--space-md);text-decoration:none}
.site-footer__logo-svg{height:20px;width:auto;display:block}
.footer-brand__tagline{font-size:clamp(13px,1.25vw,15px);color:rgba(240,237,230,.78);line-height:1.75;max-width:38ch;margin-bottom:clamp(18px,2vw,26px)}
.footer-brand__socials{display:flex;flex-direction:column;gap:10px;margin-bottom:clamp(18px,2vw,26px)}
.footer-contact-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:rgba(240,237,230,.7);transition:color var(--transition);text-decoration:none}
.footer-contact-link:hover{color:var(--color-accent)}
.footer-contact-link svg{flex-shrink:0}
.footer-nav-col__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:rgba(240,237,230,.42);margin-bottom:clamp(16px,1.8vw,22px)}
.footer-nav-col ul{display:flex;flex-direction:column;gap:clamp(10px,1vw,14px);list-style:none}
.footer-nav-col a{font-size:15px;font-weight:500;color:rgba(240,237,230,.82);transition:color var(--transition);text-decoration:none}
.footer-nav-col a:hover{color:#F0EDE6}
.footer-location__text{font-size:15px;color:rgba(240,237,230,.68);line-height:1.8}
.footer-lang{display:flex;gap:6px;margin-top:clamp(16px,1.8vw,24px)}
.footer-lang a,.footer-lang span{font-family:var(--font-body);font-size:var(--text-ui);font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:5px 10px;border-radius:5px;transition:color var(--transition),background var(--transition),border-color var(--transition);text-decoration:none;border:1px solid transparent}
.footer-lang a{color:rgba(240,237,230,.75);border-color:rgba(240,237,230,.2)}
.footer-lang a:hover{color:#F0EDE6;background:rgba(240,237,230,.1);border-color:rgba(240,237,230,.35)}
.footer-lang .lang-active{color:#1E3D2F;background:#E8C93C;border-color:#E8C93C}
.site-footer__legal{border-top:1px solid rgba(240,237,230,.1);position:relative;z-index:1}
.site-footer__legal-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:16px 0}
.site-footer__copyright{font-size:14px;color:rgba(240,237,230,.65)}
.footer-made{font-size:14px;color:rgba(240,237,230,.5);font-style:italic}
.legal-links{display:flex;gap:var(--space-md);list-style:none}
.legal-links a{font-size:14px;font-weight:600;color:rgba(240,237,230,.75);transition:color var(--transition);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(240,237,230,.35)}
.legal-links a:hover{color:#F0EDE6;text-decoration-color:rgba(240,237,230,.8)}

/* Back to top button */
#back-to-top {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 999;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--color-primary, #1E3D2F);
  color: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
}
#back-to-top.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
#back-to-top:hover {
  background: #2a5440;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .section-hero__inner,.section-texte-media__inner,.section-formulaire__inner{grid-template-columns:1fr}
  .section-hero__media{display:none}
  .section-hero__blob{display:none}
  .section-hero__title,.section-hero__subtitle{max-width:100%}
  .section-hero__ctas{justify-content:center}
  .section-hero__inner{text-align:center}
  .section-texte-media__media{order:-1}
  .section-grille-cards__grid{grid-template-columns:repeat(2,1fr)}
  .carousel-slide{grid-template-columns:1fr}
  .carousel-slide__media{display:none}
  .section-colonnes__grid{grid-template-columns:1fr}
  .section-stack__grid{grid-template-columns:1fr}
  .card-stack--full{grid-column:1;grid-template-columns:1fr}
  .footer-body__inner{grid-template-columns:1fr 1fr}.footer-cta__inner{flex-direction:column;align-items:flex-start}
}
@media(max-width:1024px){
  /* Réduit --space-xl pour compresser uniformément tous les paddings de section */
  :root{ --space-xl:36px }
}
@media(max-width:768px){
  /* Empêche tout scroll horizontal parasite (sliders à marge négative) */
  body{overflow-x:hidden}
  /* Réduction supplémentaire sur téléphone */
  :root{ --space-xl:28px }
  .site-header__inner{justify-content:space-between}
  .site-nav,.site-header__actions{display:none}
  /* Clip overflow — le grid 1fr peut dépasser le container si un enfant déborde */
  .section-equipe-story{overflow-x:hidden}
  .equipe-layout{overflow:hidden}
  /* min-width:0 empêche les cellules grid de gonfler au-delà de 1fr */
  .equipe-story,.equipe-members{min-width:0;max-width:100%}
  .equipe-story__text p,.equipe-story__intro,.equipe-story__text p:last-child{
    overflow-wrap:break-word;
    white-space:normal;
    max-width:100%;
    word-break:normal;
  }
  /* Réduit le padding-top équipe + l'espacement vers les partenaires */
  .equipe-members{padding-top:var(--space-lg)}
  .equipe-partners-wrap{margin-top:var(--space-lg) !important}
  /* Titre "Our team" plus lisible sur mobile */
  .equipe-members__title{font-size:22px;letter-spacing:.08em}
  /* Équipe : slider horizontal 2,5 cards visibles */
  .equipe-grid{
    display:flex !important;
    overflow-x:auto !important;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    gap:12px;
    padding:4px 20px 20px 0;
    margin:0 -20px 0 0;
    scrollbar-width:none;
    align-items:flex-start;
    grid-template-columns:unset !important;
  }
  .equipe-grid::-webkit-scrollbar{display:none}
  .equipe-grid .card-member{
    flex-shrink:0 !important;
    width:38vw !important;
    transform:none !important;
    scroll-snap-align:start;
  }
  .site-nav.is-open{display:flex;flex-direction:column;position:fixed;top:72px;left:0;right:0;bottom:0;background:var(--color-fond);padding:var(--space-xl) var(--space-lg) 140px;z-index:1001;overflow-y:auto}
  .site-nav.is-open .site-nav__list{flex-direction:column;align-items:flex-start;gap:var(--space-md)}
  .site-nav.is-open .site-nav__link{font-size:18px}
  .site-nav.is-open + .site-header__actions{display:flex;flex-direction:column;gap:12px;position:fixed;bottom:0;left:0;right:0;z-index:1001;background:var(--color-fond);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border)}
  .site-nav.is-open + .site-header__actions .site-header__cta{width:100%;justify-content:center;font-size:13px}
  .site-nav.is-open + .site-header__actions .lang-switcher{display:flex;gap:16px;justify-content:center}
  .burger{display:flex}
  .section-stats__list{grid-template-columns:1fr;gap:0}
  .section-stats__item{border-right:none;border-bottom:1px solid var(--color-border)}
  .section-stats__item:last-child{border-bottom:none}
  .section-grille-cards__grid{grid-template-columns:1fr}
  .section-team__grid{grid-template-columns:repeat(2,1fr)}
  /* Libère le footer du overflow:hidden qui coupe la barre légale */
  .site-footer{overflow-x:hidden;overflow-y:visible}
  .site-footer__legal-inner{flex-direction:column;text-align:center;padding:20px 24px;gap:10px}
  .footer-body__inner{grid-template-columns:1fr 1fr;padding-left:24px;padding-right:24px;gap:28px 20px}
  /* Brand et contact sur toute la largeur, les deux nav en 2 colonnes */
  .footer-brand{grid-column:1/-1}
  .footer-body__inner>div.footer-nav-col{grid-column:1/-1}
  .footer-brand__tagline{font-size:16px;max-width:100%;line-height:1.7}
  .footer-nav-col a,.footer-contact-link{font-size:17px}
  .footer-nav-col__title{font-size:13px;margin-bottom:14px}
  .footer-nav-col ul{gap:14px}
  .footer-made{display:block;font-size:14px}
  .site-footer__copyright,.legal-links a{font-size:14px}
  .form-grid{grid-template-columns:1fr}
  .form-label{font-size:15px}
  /* Logos clients : grille 2 colonnes avec respiration verticale */
  .hero-logos{padding:40px 0 36px}
  .hero-logos .container{padding-left:clamp(44px,8vw,80px);padding-right:clamp(44px,8vw,80px)}
  .hero-logos__title{margin-bottom:28px}
  .logos-grid{
    display:grid !important;
    grid-template-columns:repeat(2,1fr);
    gap:16px 16px;
  }
  /* !important pour écraser les height:auto en inline style sur certains <li> */
  .logos-grid .logos-track__item{
    flex-shrink:1;
    width:100% !important;
    height:96px !important;
    padding:0 20px;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    box-sizing:border-box;
  }
  .logos-grid .logos-track__item img{
    max-height:52px !important;
    max-width:100%;
    width:auto;
    height:auto !important;
    object-fit:contain;
  }
  .site-nav.is-open{background:#1E3D2F}
  .site-nav.is-open .site-nav__link{color:rgba(240,242,236,0.82)}
  .site-nav.is-open .site-nav__link:hover{color:#E8C93C}
  .site-nav.is-open+.site-header__actions{background:#152B20;border-top-color:rgba(240,242,236,0.1)}
  .site-nav.is-open+.site-header__actions .site-header__cta{background:var(--color-accent);color:var(--color-primary);border-color:var(--color-accent)}
  .site-nav.is-open+.site-header__actions .lang-switcher span{color:rgba(240,242,236,0.9) !important;font-weight:700 !important}
  .site-nav.is-open+.site-header__actions .lang-switcher a{color:rgba(240,242,236,0.45) !important}
}
@media(max-width:480px){
  :root{ --space-xl:22px }
  .section-hero{padding-top:calc(72px + var(--space-lg));min-height:auto}
  .hero-editorial{align-items:flex-start;text-align:left}
  .hero-editorial .section-hero__title{text-align:left;font-size:clamp(26px,7vw,36px) !important}
  .section-hero__subtitle{text-align:left}
  .hero-bottom{align-items:flex-start;text-align:left}
  .section-hero__ctas{flex-direction:column;align-items:stretch}
  .section-hero__ctas .btn{justify-content:center}
  .team-quote{padding:var(--space-lg) var(--space-md)}
  .form-wrap{padding:var(--space-lg) var(--space-md)}
  /* Enjeux : slider horizontal avec scroll-snap */
  /* overflow-x:hidden sur la section pour ne pas déborder sur la page */
  .section-grille-cards{overflow-x:hidden}
  /* margin-right négatif = le second enjeu dépasse à droite */
  /* pas de margin-left négatif = premier enjeu calé sur le padding du container */
  .section-grille-cards__grid{
    display:flex;
    flex-direction:row;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    gap:12px;
    padding:4px 20px 20px 0;
    margin:0 -20px 0 0;
    scrollbar-width:none;
  }
  .section-grille-cards__grid::-webkit-scrollbar{display:none}
  .card-enjeu{
    flex-shrink:0;
    width:70vw;
    scroll-snap-align:start;
  }
}

/* ── PAGE TRANSITIONS ─────────────────────────────── */
@keyframes pageIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
body { animation: pageIn .5s cubic-bezier(0.16, 1, 0.3, 1) both; }
body.page-out {
  transition: opacity .35s ease, transform .35s ease;
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
}

