.elementor-5364 .elementor-element.elementor-element-2ec39cb{padding:0px 0px 0px 0px;}.elementor-5364 .elementor-element.elementor-element-4ab8a81 > .elementor-element-populated{padding:0px 0px 0px 0px;}.elementor-5364 .elementor-element.elementor-element-11f5a54 > .elementor-element-populated{margin:0px 0px 0px 0px;--e-column-margin-right:0px;--e-column-margin-left:0px;padding:0px 0px 0px 0px;}:root{--page-title-display:none;}/* Start custom CSS for html, class: .elementor-element-7116cf5 */.s3 *, .s3 *::before, .s3 *::after { box-sizing: border-box; margin: 0; padding: 0; }

.s3 {
  font-family: Arial, sans-serif;
  --n:  #334A73;
  --n2: #1a2a40;
  --n3: #243558;
  --y:  #FFEE66;
  --yd: rgba(255,238,102,.14);
  --mu: #5a6a84;
  --bd: rgba(51,74,115,.11);
  --bg: #f3f5f9;
  --wh: #ffffff;
  --r:  30px;
  color: var(--n2);
  background: var(--wh);
  overflow-x: hidden;
}

/* ── typo utilitaires ── */
.s3-wrap { max-width: 1060px; margin: 0 auto; padding: 0 22px; }
.s3-tag {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 10px; font-weight: 700; letter-spacing: .2em;
  text-transform: uppercase; color: var(--n);
}
.s3-tag i {
  display: block; width: 22px; height: 2px;
  background: var(--y); border-radius: 2px; flex-shrink: 0;
}
.s3-h2 {
  font-size: clamp(22px, 3vw, 36px); font-weight: 700;
  color: var(--n2); line-height: 1.16; letter-spacing: -.022em;
}
.s3-h2 mark {
  background: none; color: inherit;
  background-image: linear-gradient(transparent 60%, rgba(255,238,102,.55) 60%);
  background-size: 100% 1.2em; background-repeat: no-repeat;
  background-position: 0 .85em; padding-bottom: 2px;
}
.s3-body { font-size: 14.5px; line-height: 1.82; color: var(--mu); }
.s3-body p + p { margin-top: 14px; }

/* ── boutons premium ── */
.s3-btn {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: Arial, sans-serif; font-size: 13.5px; font-weight: 700;
  text-decoration: none; padding: 13px 28px; border-radius: var(--r);
  cursor: pointer; border: none; position: relative; overflow: hidden;
  transition: color .22s;
  letter-spacing: .03em;
  white-space: nowrap;
}
/* Shimmer fill commun */
.s3-btn::before {
  content: '';
  position: absolute; inset: 0;
  background: rgba(255,255,255,0);
  transition: background .22s;
  border-radius: var(--r);
}
.s3-btn:hover::before { background: rgba(255,255,255,.12); }
.s3-btn span { position: relative; z-index: 1; }
.s3-btn svg { position: relative; z-index: 1; flex-shrink: 0; transition: transform .22s; }
.s3-btn:hover svg { transform: translateX(4px); }

/* Jaune */
.s3-btn-y {
  background: var(--y); color: var(--n2);
  box-shadow: 0 4px 20px rgba(255,238,102,.4), 0 1px 4px rgba(0,0,0,.08);
}
.s3-btn-y:hover {
  box-shadow: 0 8px 32px rgba(255,238,102,.55), 0 2px 8px rgba(0,0,0,.1);
  color: var(--n2); text-decoration: none;
}

/* Navy */
.s3-btn-n {
  background: var(--n); color: #fff;
  box-shadow: 0 4px 18px rgba(51,74,115,.28), 0 1px 4px rgba(0,0,0,.08);
}
.s3-btn-n:hover {
  box-shadow: 0 8px 28px rgba(51,74,115,.42);
  color: #fff; text-decoration: none;
}

/* Outline ghost white */
.s3-btn-ow {
  background: transparent; color: #fff;
  border: 2px solid rgba(255,255,255,.38);
}
.s3-btn-ow:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.7);
  color: #fff; text-decoration: none;
}

/* Outline navy */
.s3-btn-on {
  background: transparent; color: var(--n);
  border: 2px solid var(--bd);
}
.s3-btn-on:hover {
  background: var(--yd);
  border-color: var(--n);
  color: var(--n); text-decoration: none;
}

/* ════════════════════════════════
   HERO V4 — gradient bleu, texte gauche, image droite
════════════════════════════════ */
.s3-hero {
  
  background: linear-gradient(135deg, #091628 0%, #162844 40%, #1e3a6e 75%, #243a70 100%);
  display: flex; align-items: center;
  position: relative; overflow: hidden;
}
/* Cercles lumineux décoratifs CSS */
.s3-hero::before {
  content: ''; position: absolute;
  width: 700px; height: 700px; border-radius: 50%;
  background: radial-gradient(circle, rgba(51,74,115,.55) 0%, transparent 70%);
  top: -200px; left: -150px; pointer-events: none;
}
.s3-hero::after {
  content: ''; position: absolute;
  width: 400px; height: 400px; border-radius: 50%;
  background: radial-gradient(circle, rgba(255,238,102,.06) 0%, transparent 70%);
  bottom: -80px; left: 40%; pointer-events: none;
}

.s3-hero-inner {
  position: relative; z-index: 2; width: 100%;
  padding: 80px 22px;
  max-width: 1060px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center;
}
.s3-hero-pill {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,238,102,.12); border: 1px solid rgba(255,238,102,.32);
  border-radius: var(--r); padding: 5px 16px; margin-bottom: 22px;
}
.s3-hero-pill-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--y); flex-shrink: 0; }
.s3-hero-pill span { font-size: 10px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--y); }
.s3-hero h1 {
  font-size: clamp(30px, 4.5vw, 54px); font-weight: 700; color: #fff;
  line-height: 1.08; letter-spacing: -.025em; margin-bottom: 20px;
}
.s3-hero h1 em { font-style: normal; color: var(--y); }
.s3-hero-desc { font-size: 15px; line-height: 1.74; color: rgba(255,255,255,.68); margin-bottom: 32px; }
.s3-hero-btns { display: flex; gap: 12px; flex-wrap: wrap; }

/* Image droite avec cadre */
.s3-hero-imgbox {
  position: relative; border-radius: 20px; overflow: visible;
}
.s3-hero-imgbox img {
  width: 100%; aspect-ratio: 4/5; object-fit: cover;
  border-radius: 20px; display: block;
  box-shadow: 0 32px 80px rgba(0,0,0,.5);
}
/* Stats flottantes sur l'image */
.s3-hero-badge-tl {
  position: absolute; top: -14px; left: -14px;
  background: var(--y); border-radius: 14px; padding: 14px 18px;
  box-shadow: 0 8px 28px rgba(0,0,0,.25); text-align: center; z-index: 3;
}
.s3-hero-badge-tl strong { font-size: 22px; font-weight: 700; color: var(--n2); display: block; line-height: 1; }
.s3-hero-badge-tl span   { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: rgba(26,42,64,.6); margin-top: 3px; display: block; }
.s3-hero-badge-br {
  position: absolute; bottom: -14px; right: -14px;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-radius: 14px; padding: 14px 18px; z-index: 3;
}
.s3-hero-badge-br-row { display: flex; align-items: center; gap: 10px; }
.s3-hero-badge-br-row + .s3-hero-badge-br-row { margin-top: 10px; padding-top: 10px; border-top: 1px solid rgba(255,255,255,.12); }
.s3-hero-badge-br strong { font-size: 18px; font-weight: 700; color: #fff; line-height: 1; }
.s3-hero-badge-br span   { font-size: 11px; color: rgba(255,255,255,.5); line-height: 1.3; }

/* Langues sous les boutons */
.s3-langs { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 20px; }
.s3-lp {
  font-size: 12px; font-weight: 700; padding: 5px 13px; border-radius: var(--r);
  color: rgba(255,255,255,.8); background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14);
}
/* Suppression ancienne carte glass */
.s3-glass { display: none; }
.s3-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 18px; }
.s3-stat-n { font-size: 28px; font-weight: 700; color: #fff; line-height: 1; }
.s3-stat-l { font-size: 11px; color: rgba(255,255,255,.46); margin-top: 3px; line-height: 1.35; }
.s3-glass-lbl { display: none; }
/* Badge stamp supprimé */
.s3-hero-stamp { display: none; }

/* ════════════════════════════════
   SECTION AGENCE — 2 colonnes image + texte
════════════════════════════════ */
.s3-agence { background: var(--wh); padding: 90px 22px; }
.s3-agence-grid { max-width: 1060px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }

.s3-pic { position: relative; border-radius: 20px; overflow: visible; }
.s3-pic img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: 20px; display: block; }
/* Carte chiffre flottante */
.s3-pic-float {
  position: absolute; bottom: -20px; right: -20px;
  background: var(--y); border-radius: 16px; padding: 16px 22px;
  box-shadow: 0 12px 36px rgba(0,0,0,.18); text-align: center;
}
.s3-pic-float strong { font-size: 24px; font-weight: 700; color: var(--n2); display: block; line-height: 1; }
.s3-pic-float span   { font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: rgba(26,42,64,.6); margin-top: 3px; display: block; }

/* Carte tag feature inline */
.s3-feature-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 22px; }
.s3-ft {
  display: flex; align-items: center; gap: 7px;
  font-size: 12px; font-weight: 700; color: var(--n);
  background: var(--yd); border: 1px solid rgba(51,74,115,.14);
  padding: 6px 14px; border-radius: var(--r);
}
.s3-ft svg { width: 13px; height: 13px; stroke: var(--n); fill: none; stroke-width: 2.2; flex-shrink: 0; }

/* ════════════════════════════════
   FORMATS — icônes SVG, ZÉRO image
   Layout: 2×2 dense, bordures internes
════════════════════════════════ */
.s3-formats { background: var(--n2); padding: 90px 22px; }
.s3-formats-head { max-width: 1060px; margin: 0 auto 50px; display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.s3-formats-head .s3-tag { color: rgba(255,238,102,.8); }
.s3-formats-head .s3-tag i { background: var(--y); }
.s3-formats-head .s3-h2 { color: #fff; max-width: 560px; }
.s3-formats-head .s3-h2 mark { background-image: linear-gradient(transparent 60%, rgba(255,238,102,.3) 60%); }

/* Grille 2×2 avec séparateurs internes */
.s3-fgrid {
  max-width: 1060px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr;
  border: 1px solid rgba(255,255,255,.1); border-radius: 20px; overflow: hidden;
}
.s3-fc {
  padding: 40px 36px;
  border-right: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
  position: relative; overflow: hidden;
  transition: background .25s;
}
.s3-fc:nth-child(2n) { border-right: none; }
.s3-fc:nth-child(3), .s3-fc:nth-child(4) { border-bottom: none; }
.s3-fc:hover { background: rgba(255,255,255,.04); }

/* Numéro décoratif grand */
.s3-fc-num {
  position: absolute; top: 24px; right: 28px;
  font-size: 72px; font-weight: 700; color: rgba(255,255,255,.04);
  line-height: 1; pointer-events: none; user-select: none;
}
/* Icône grande */
.s3-fc-icon {
  width: 52px; height: 52px; border-radius: 14px;
  background: rgba(255,238,102,.14); border: 1px solid rgba(255,238,102,.25);
  display: flex; align-items: center; justify-content: center; margin-bottom: 20px;
  transition: background .22s, transform .22s;
}
.s3-fc:hover .s3-fc-icon { background: rgba(255,238,102,.22); transform: scale(1.06); }
.s3-fc-icon svg { width: 26px; height: 26px; stroke: var(--y); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.s3-fc h3 { font-size: 16px; font-weight: 700; color: #fff; margin-bottom: 12px; line-height: 1.25; }
.s3-fc p  { font-size: 13.5px; line-height: 1.76; color: rgba(255,255,255,.56); }

/* Tag tech bottom */
.s3-fc-tags { display: flex; gap: 7px; flex-wrap: wrap; margin-top: 20px; }
.s3-fc-tag {
  font-size: 11px; font-weight: 700; padding: 4px 12px; border-radius: var(--r);
  color: rgba(255,238,102,.8); background: rgba(255,238,102,.08);
  border: 1px solid rgba(255,238,102,.18); letter-spacing: .04em;
}

/* ════════════════════════════════
   SEO — texte + carte dark (sans block keywords)
════════════════════════════════ */
.s3-seo { background: var(--bg); padding: 90px 22px; }
.s3-seo-grid { max-width: 1060px; margin: 0 auto; display: grid; grid-template-columns: 1fr 340px; gap: 56px; align-items: start; }
.s3-seo-items { display: flex; flex-direction: column; }
.s3-seo-row { display: grid; grid-template-columns: 10px 1fr; gap: 22px; padding: 28px 0; border-bottom: 1px solid var(--bd); }
.s3-seo-row:first-child { border-top: 1px solid var(--bd); }
.s3-seo-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--y); border: 2px solid var(--n); margin-top: 5px; flex-shrink: 0; }
.s3-seo-row h3 { font-size: 14px; font-weight: 700; color: var(--n); margin-bottom: 8px; }
.s3-seo-row p  { font-size: 13.5px; line-height: 1.74; color: var(--mu); }

/* Card geo coverage */
.s3-geo-card {
  background: linear-gradient(148deg, #0d1b2f, #334A73);
  border-radius: 20px; padding: 28px 24px;
  position: sticky; top: 24px;
}
.s3-geo-lbl { font-size: 10px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--y); margin-bottom: 18px; }
.s3-geo-zones { display: flex; flex-direction: column; gap: 10px; margin-bottom: 22px; }
.s3-geo-zone {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; border-radius: 12px;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
}
.s3-geo-zone-name { font-size: 13px; font-weight: 700; color: #fff; }
.s3-geo-zone-sub  { font-size: 11px; color: rgba(255,255,255,.42); margin-top: 1px; }
.s3-geo-zone-flag { font-size: 18px; line-height: 1; }
.s3-geo-sep { border: none; border-top: 1px solid rgba(255,255,255,.1); margin: 4px 0; }
.s3-geo-tech { display: flex; flex-wrap: wrap; gap: 7px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,.1); }
.s3-geo-pill {
  font-size: 11px; font-weight: 700; padding: 5px 13px; border-radius: var(--r);
  color: rgba(255,255,255,.7); background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
}
.s3-geo-pill-y { color: var(--y); background: rgba(255,238,102,.1); border-color: rgba(255,238,102,.25); }

/* ════════════════════════════════
   STACK TECHNIQUE V4 — gradient bleu, 3 cartes horizontales pleine largeur
════════════════════════════════ */
.s3-stack {
  background: linear-gradient(148deg, #091628 0%, #162844 45%, #1e3a6e 100%);
  padding: 90px 22px; position: relative; overflow: hidden;
}
.s3-stack::before {
  content: ''; position: absolute;
  width: 600px; height: 600px; border-radius: 50%;
  background: radial-gradient(circle, rgba(255,238,102,.04) 0%, transparent 70%);
  top: -200px; right: -100px; pointer-events: none;
}
.s3-stack .s3-tag { color: rgba(255,238,102,.75); }
.s3-stack .s3-tag i { background: var(--y); }
.s3-stack .s3-h2 { color: #fff; }
.s3-stack .s3-h2 mark { background-image: linear-gradient(transparent 60%, rgba(255,238,102,.28) 60%); }

/* 3 cartes horizontales full-width empilées */
.s3-stack-cards {
  max-width: 1060px; margin: 0 auto;
  display: flex; flex-direction: column; gap: 16px;
}
.s3-scard {
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
  border-radius: 18px; padding: 0;
  transition: background .22s, border-color .22s;
  overflow: hidden;
}
.s3-scard:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.2); }
.s3-scard-inner {
  display: grid; grid-template-columns: 80px 1fr auto; gap: 0; align-items: stretch;
}
/* Bande numéro gauche */
.s3-scard-num {
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,238,102,.1); border-right: 1px solid rgba(255,255,255,.08);
  padding: 28px 0;
}
.s3-scard-num span {
  font-size: 28px; font-weight: 700; color: var(--y);
  opacity: .7; line-height: 1;
}
/* Corps texte */
.s3-scard-body { padding: 26px 28px; }
.s3-scard-body h3 { font-size: 15px; font-weight: 700; color: #fff; margin-bottom: 8px; line-height: 1.3; }
.s3-scard-body p  { font-size: 13.5px; line-height: 1.74; color: rgba(255,255,255,.55); }
/* Icône droite */
.s3-scard-icon {
  display: flex; align-items: center; justify-content: center;
  padding: 0 28px; border-left: 1px solid rgba(255,255,255,.08);
}
.s3-scard-icon svg {
  width: 36px; height: 36px; stroke: rgba(255,238,102,.45); fill: none;
  stroke-width: 1.4; stroke-linecap: round; stroke-linejoin: round;
  flex-shrink: 0;
}
/* Suppression ancienne col image */
.s3-stack-col { display: flex; flex-direction: column; gap: 20px; }
.s3-stack-img { display: none; }

/* CTA bande jaune */
.s3-band { background: var(--y); padding: 44px 22px; }
.s3-band-in {
  max-width: 1060px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap;
}
.s3-band-lbl { font-size: 10px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: rgba(26,42,64,.5); margin-bottom: 6px; }
.s3-band h3  { font-size: 20px; font-weight: 700; color: var(--n2); line-height: 1.25; }
.s3-band p   { font-size: 13px; color: rgba(26,42,64,.58); margin-top: 4px; }

/* ════════════════════════════════
   PROCESS — 2 colonnes image + checklist
════════════════════════════════ */
.s3-process { background: var(--bg); padding: 90px 22px; }
.s3-process-grid { max-width: 1060px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.s3-process-pic { position: relative; border-radius: 20px; overflow: hidden; }
.s3-process-pic img { width: 100%; aspect-ratio: 3/4; object-fit: cover; display: block; border-radius: 20px; }
.s3-process-overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(to top, rgba(10,18,38,.88) 0%, transparent 65%);
  padding: 28px 26px; border-radius: 0 0 20px 20px;
}
.s3-process-quote { font-size: 15px; font-weight: 700; color: #fff; line-height: 1.4; }
.s3-process-quote em { color: var(--y); font-style: normal; }

.s3-checks { display: flex; flex-direction: column; gap: 14px; }
.s3-check {
  display: flex; gap: 14px; align-items: flex-start;
  padding: 18px 18px; border-radius: 14px;
  background: var(--wh); border: 1px solid var(--bd);
  transition: border-color .2s, box-shadow .2s;
}
.s3-check:hover { border-color: var(--n); box-shadow: 0 6px 20px rgba(51,74,115,.09); }
.s3-check-ic {
  width: 26px; height: 26px; border-radius: 8px; background: var(--y);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.s3-check-ic svg { width: 13px; height: 13px; stroke: var(--n2); fill: none; stroke-width: 2.5; }
.s3-check h4 { font-size: 13.5px; font-weight: 700; color: var(--n2); margin-bottom: 4px; line-height: 1.3; }
.s3-check p  { font-size: 13px; line-height: 1.66; color: var(--mu); }

/* Timeline compacte */
.s3-tl {
  background: linear-gradient(148deg, #0d1b2f, #334A73);
  border-radius: 18px; padding: 26px 22px; margin-top: 18px;
}
.s3-tl-lbl { font-size: 10px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--y); margin-bottom: 18px; }
.s3-tl-list { display: flex; flex-direction: column; }
.s3-tl-step {
  display: grid; grid-template-columns: 28px 1fr; gap: 13px;
  padding-bottom: 16px; position: relative;
}
.s3-tl-step:not(:last-child)::before {
  content: ''; position: absolute;
  left: 13px; top: 28px; bottom: 0; width: 2px;
  background: rgba(255,255,255,.09);
}
.s3-tl-dot {
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(255,238,102,.13); border: 2px solid rgba(255,238,102,.38);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; color: var(--y);
  position: relative; z-index: 1; flex-shrink: 0;
}
.s3-tl-t { font-size: 12.5px; font-weight: 700; color: #fff; margin-bottom: 2px; }
.s3-tl-d { font-size: 12px; color: rgba(255,255,255,.43); line-height: 1.45; }

/* ════════════════════════════════
   DIFFÉRENTIEL — dark cards, pas d'image en bg
════════════════════════════════ */
.s3-diff { background: var(--n2); padding: 90px 22px; }
.s3-diff-head { max-width: 1060px; margin: 0 auto 48px; display: flex; align-items: flex-end; gap: 32px; flex-wrap: wrap; justify-content: space-between; }
.s3-diff-head .s3-tag { color: var(--y); }
.s3-diff-head .s3-tag i { background: var(--y); }
.s3-diff-head .s3-h2 { color: #fff; }
.s3-diff-grid { max-width: 1060px; margin: 0 auto; display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.s3-dcard {
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.09);
  border-radius: 18px; padding: 28px 24px;
  transition: background .22s, border-color .22s, transform .22s;
  position: relative; overflow: hidden;
}
/* Ligne jaune en haut au hover */
.s3-dcard::after {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 3px;
  background: var(--y); border-radius: 18px 18px 0 0;
  transform: scaleX(0); transform-origin: left;
  transition: transform .25s ease;
}
.s3-dcard:hover { background: rgba(255,255,255,.09); border-color: rgba(255,255,255,.16); }
.s3-dcard:hover::after { transform: scaleX(1); }
.s3-dcard-ic {
  width: 42px; height: 42px; border-radius: 12px;
  background: rgba(255,238,102,.13); border: 1px solid rgba(255,238,102,.22);
  display: flex; align-items: center; justify-content: center; margin-bottom: 16px;
}
.s3-dcard-ic svg { width: 20px; height: 20px; stroke: var(--y); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.s3-dcard h3 { font-size: 14px; font-weight: 700; color: #fff; margin-bottom: 10px; line-height: 1.3; }
.s3-dcard p  { font-size: 13px; line-height: 1.72; color: rgba(255,255,255,.54); }

/* ════════════════════════════════
   STUDIO CRÉATIF
════════════════════════════════ */
.s3-studio { background: var(--wh); padding: 90px 22px; }
.s3-studio-grid { max-width: 1060px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.s3-studio-rows { display: flex; flex-direction: column; }
.s3-studio-row { padding: 26px 0; border-bottom: 1px solid var(--bd); }
.s3-studio-row:first-child { border-top: 1px solid var(--bd); }
.s3-studio-row h3 { font-size: 14px; font-weight: 700; color: var(--n); margin-bottom: 8px; }
.s3-studio-row p  { font-size: 13.5px; line-height: 1.74; color: var(--mu); }
.s3-studio-row p + p { margin-top: 11px; }
/* Image 1er sur mobile */
.s3-studio-text { order: 2; }
.s3-studio-img  { order: 1; }

/* ════════════════════════════════
   ÉCONOMIE LOCALE
════════════════════════════════ */
.s3-eco { background: var(--bg); padding: 90px 22px; }
.s3-eco-inner { max-width: 1060px; margin: 0 auto; }

/* Banner image large */
.s3-eco-banner { position: relative; border-radius: 20px; overflow: hidden; height: 300px; margin-bottom: 40px; }
.s3-eco-banner img { width: 100%; height: 100%; object-fit: cover; display: block; }
.s3-eco-banner::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(10,18,38,.8) 0%, rgba(10,18,38,.15) 65%);
}
.s3-eco-banner-txt {
  position: absolute; left: 36px; top: 50%; transform: translateY(-50%); z-index: 2;
}
.s3-eco-banner-txt h3 { font-size: clamp(18px,2.5vw,28px); font-weight: 700; color: #fff; line-height: 1.2; }
.s3-eco-banner-txt p  { font-size: 13px; color: rgba(255,255,255,.6); margin-top: 6px; }

.s3-eco-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.s3-ecard {
  background: var(--wh); border-radius: 18px; overflow: hidden;
  border: 1px solid var(--bd);
  transition: box-shadow .22s, border-color .22s;
}
.s3-ecard:hover { box-shadow: 0 10px 36px rgba(51,74,115,.11); border-color: var(--n); }
.s3-ecard-img { width: 100%; height: 156px; object-fit: cover; display: block; }
.s3-ecard-body { padding: 20px 20px 24px; }
.s3-ecard h3 {
  font-size: 13.5px; font-weight: 700; color: var(--n);
  margin-bottom: 12px; padding-bottom: 10px;
  border-bottom: 2px solid var(--y); line-height: 1.3;
}
.s3-ecard p { font-size: 13px; line-height: 1.72; color: var(--mu); }
.s3-ecard p + p { margin-top: 10px; }

/* Bloc avantage transfrontalier */
.s3-trans {
  margin-top: 24px;
  background: linear-gradient(138deg, #0d1b2f 0%, #334A73 100%);
  border-radius: 20px; padding: 40px 36px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 36px; align-items: center;
}
.s3-trans-lbl { font-size: 10px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--y); margin-bottom: 12px; }
.s3-trans h3 { font-size: 20px; font-weight: 700; color: #fff; line-height: 1.25; margin-bottom: 14px; }
.s3-trans p  { font-size: 13.5px; line-height: 1.74; color: rgba(255,255,255,.58); }
.s3-trans-list { display: flex; flex-direction: column; gap: 11px; }
.s3-trans-item {
  display: flex; gap: 12px; align-items: flex-start;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
  border-radius: 12px; padding: 13px 16px;
  transition: background .18s;
}
.s3-trans-item:hover { background: rgba(255,255,255,.1); }
.s3-trans-y { color: var(--y); font-size: 15px; flex-shrink: 0; line-height: 1.4; }
.s3-trans-item span { font-size: 13px; color: rgba(255,255,255,.74); line-height: 1.45; }

/* ════════════════════════════════
   FAQ
════════════════════════════════ */
.s3-faq { background: var(--wh); padding: 90px 22px; }
.s3-faq-head { text-align: center; margin-bottom: 48px; }
.s3-faq-head .s3-tag { justify-content: center; }
.s3-faq-head .s3-tag i { display: none; }
.s3-faq-head .s3-h2 { margin-top: 10px; max-width: 600px; margin-left: auto; margin-right: auto; text-align: center; }
.s3-faq-list { max-width: 720px; margin: 0 auto; }
.s3-faq-item { border-bottom: 1px solid var(--bd); }
.s3-faq-item:first-child { border-top: 1px solid var(--bd); }
.s3-faq-q {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  font-size: 15px; font-weight: 700; color: var(--n2); padding: 22px 0;
  cursor: pointer; line-height: 1.35;
}
.s3-faq-plus {
  width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
  background: var(--yd); color: var(--n); font-size: 20px; font-weight: 300;
  display: flex; align-items: center; justify-content: center;
  transition: transform .22s, background .18s;
}
.s3-faq-item.open .s3-faq-plus { transform: rotate(45deg); background: var(--y); }
.s3-faq-a { font-size: 14px; line-height: 1.78; color: var(--mu); padding-bottom: 22px; display: none; }
.s3-faq-item.open .s3-faq-a { display: block; }

/* ════════════════════════════════
   CTA FINAL — gradient navy, ZÉRO image en bg
════════════════════════════════ */
.s3-cta {
  background: linear-gradient(148deg, #091628 0%, #1a2e55 55%, #0d2040 100%);
  padding: 110px 22px; position: relative; overflow: hidden;
}
/* Cercles décoratifs géométriques — pas d'image */
.s3-cta::before, .s3-cta::after {
  content: ''; position: absolute; border-radius: 50%; pointer-events: none;
}
.s3-cta::before {
  width: 500px; height: 500px; top: -180px; right: -100px;
  background: radial-gradient(circle, rgba(255,238,102,.07) 0%, transparent 70%);
}
.s3-cta::after {
  width: 320px; height: 320px; bottom: -100px; left: -60px;
  background: radial-gradient(circle, rgba(51,74,115,.6) 0%, transparent 70%);
}
.s3-cta-in {
  position: relative; z-index: 1; text-align: center; max-width: 680px; margin: 0 auto;
}
.s3-cta-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,238,102,.12); border: 1px solid rgba(255,238,102,.28);
  border-radius: var(--r); padding: 5px 18px; margin-bottom: 26px;
}
.s3-cta-badge-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--y); }
.s3-cta-badge span { font-size: 10px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--y); }
.s3-cta h2 {
  font-size: clamp(24px, 4vw, 44px); font-weight: 700; color: #fff;
  line-height: 1.13; letter-spacing: -.02em; margin-bottom: 16px;
}
.s3-cta h2 span { color: var(--y); }
.s3-cta p { font-size: 15px; line-height: 1.72; color: rgba(255,255,255,.62); margin-bottom: 38px; }
.s3-cta-btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.s3-cta-note { margin-top: 20px; font-size: 11px; color: rgba(255,255,255,.28); letter-spacing: .06em; }

/* ════════════════════════════════
   RESPONSIVE — MOBILE sans vibration
════════════════════════════════ */
@media (max-width: 860px) {
  .s3-hero-inner   { grid-template-columns: 1fr; padding: 60px 10px 56px; gap: 36px; }
  .s3-hero-imgbox  { order: -1; }
  .s3-hero-imgbox img { aspect-ratio: 16/9; }
  .s3-hero-badge-tl { top: -10px; left: 10px; }
  .s3-hero-badge-br { bottom: -10px; right: 10px; }

  .s3-agence-grid,
  .s3-seo-grid { grid-template-columns: 1fr; gap: 36px; }

  /* Studio : grille → flex pour activer order */
  .s3-studio-grid  { display: flex; flex-direction: column; gap: 28px; }
  .s3-studio-text  { order: 2; }
  .s3-studio-img   { order: 1; }

  .s3-fgrid        { grid-template-columns: 1fr; }
  .s3-fc           { border-right: none; }
  .s3-fc:nth-child(3) { border-bottom: 1px solid rgba(255,255,255,.08); }

  .s3-scard-inner  { grid-template-columns: 56px 1fr; }
  .s3-scard-icon   { display: none; }

  .s3-diff-grid    { grid-template-columns: 1fr; }
  .s3-eco-cards    { grid-template-columns: 1fr; }
  .s3-trans        { grid-template-columns: 1fr; gap: 24px; }

  .s3-geo-card     { position: static; }
  .s3-band-in      { flex-direction: column; align-items: flex-start; }
  .s3-eco-banner   { height: 220px; }
  .s3-eco-banner-txt { left: 20px; }
  .s3-pic-float    { right: 0; bottom: -10px; }

  /* Timeline process → vertical sur mobile */
  .s3-process .s3-tl > div[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  .s3-process div[style*="flex-direction:column;align-items:center"] > div[style*="position:absolute"] {
    display: none;
  }
  /* Process checklist 3col → 1col */
  .s3-process div[style*="grid-template-columns:repeat(3"] {
    grid-template-columns: 1fr !important;
  }

  .s3-agence, .s3-formats, .s3-seo, .s3-stack,
  .s3-process, .s3-diff, .s3-studio, .s3-eco,
  .s3-faq, .s3-cta { padding: 60px 18px; }
}

@media (min-width: 580px) and (max-width: 860px) {
  .s3-diff-grid  { grid-template-columns: repeat(2,1fr); }
  .s3-eco-cards  { grid-template-columns: repeat(2,1fr); }
  .s3-fgrid      { grid-template-columns: repeat(2,1fr); }
}

/* Zéro transform sur mobile → zéro vibration */
@media (max-width: 860px) {
  .s3-fc:hover .s3-fc-icon,
  .s3-btn:hover svg             { transform: none; }
  .s3-dcard                     { transition: background .22s, border-color .22s; }
  .s3-dcard:hover               { transform: none; }
}

@media (prefers-reduced-motion: reduce) {
  .s3 *, .s3 *::before, .s3 *::after { transition: none !important; animation: none !important; }
}/* End custom CSS */