/* #region PAGE NOS MOYENS */
.means-page-main { padding-top: 0; }
.means-hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  padding: 132px 0 96px;
  margin-top: 0;
  background:
    linear-gradient(90deg, rgba(8, 13, 20, .78) 0%, rgba(8, 13, 20, .56) 42%, rgba(8, 13, 20, .16) 78%),
    linear-gradient(180deg, rgba(8, 13, 20, .18) 0%, rgba(8, 13, 20, .08) 46%, rgba(8, 13, 20, .64) 100%),
    url("../Assets/Photos/Background-Nos-Moyens.jpg") center center / cover no-repeat;
  isolation: isolate;
  overflow: hidden;
}
.means-hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 28%;
  z-index: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0), #ffffff 86%);
  pointer-events: none;
}
.means-hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(90deg, rgba(117,184,234,.2), transparent 34%);
  opacity: .28;
  pointer-events: none;
}
.means-hero .container { width: min(calc(100% - 88px), 1520px); max-width: none; margin: 0 auto; }
.means-hero-content {
  position: relative;
  z-index: 1;
  width: min(760px, 100%);
  color: #fff;
  padding-top: 34px;
}
.means-hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 22px;
  font-family: "Sora", sans-serif;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.92);
  text-shadow: 0 10px 28px rgba(0,0,0,.35);
  animation: meansHeroIn .75s var(--ease-out-soft) both;
}
.means-hero-kicker::before {
  content: "";
  width: 42px;
  height: 2px;
  border-radius: 999px;
  background: var(--blue);
  box-shadow: 0 0 18px rgba(117,184,234,.52);
}
.means-hero-content h1 {
  font-family: "Sora", sans-serif;
  font-size: clamp(3.8rem, 5.8vw, 6.2rem);
  font-weight: 800;
  line-height: .96;
  letter-spacing: 0;
  max-width: 760px;
  margin-bottom: 24px;
  text-wrap: balance;
  text-shadow: 0 20px 52px rgba(0,0,0,.42);
  animation: meansHeroIn .95s .06s var(--ease-out-soft) both;
}
.means-hero-lines { width: min(650px, 100%); margin-top: 0; }
.means-hero-lines p {
  font-family: "Sora", sans-serif;
  font-size: clamp(1.08rem, 1.35vw, 1.38rem);
  font-weight: 650;
  line-height: 1.45;
  color: rgba(255,255,255,.92);
  max-width: 620px;
  margin: 0;
  text-wrap: balance;
  text-shadow: 0 14px 34px rgba(0,0,0,.36);
  animation: meansHeroIn .95s .16s var(--ease-out-soft) both;
}
.means-hero-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 34px;
  animation: meansHeroIn .95s .24s var(--ease-out-soft) both;
}
.means-hero-stats span {
  position: relative;
  overflow: hidden;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 10px 15px;
  border-radius: 12px;
  background:
    linear-gradient(180deg, rgba(117,184,234,.18), rgba(255,255,255,.12));
  border: 1px solid rgba(117,184,234,.48);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.2),
    0 12px 28px rgba(0,0,0,.16),
    0 0 0 1px rgba(117,184,234,.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: #fff;
  font-size: .88rem;
  font-weight: 700;
  line-height: 1.15;
}
.means-hero-stats span::before {
  content: "";
  position: absolute;
  left: 10px;
  right: 10px;
  top: 0;
  height: 2px;
  border-radius: 0 0 999px 999px;
  background: rgba(117,184,234,.9);
  box-shadow: 0 0 14px rgba(117,184,234,.55);
}
.means-hero-stats strong {
  font-family: "Sora", sans-serif;
  font-size: 1.05rem;
  color: #bfe5ff;
}
@keyframes meansHeroIn { from { opacity: 0; transform: translate3d(0, 34px, 0); } to { opacity: 1; transform: translate3d(0, 0, 0); } }
.title-break-mobile, .subtitle-break-mobile { display: none; }
.means-intro { padding: 120px 0 110px; }
.means-intro .container { max-width: 980px; }
.means-intro-text { max-width: 920px; margin: 0 auto; text-align: center; }
.means-intro-text p { font-size: clamp(1.08rem, 1.3vw, 1.28rem); line-height: 1.95; color: #25303a; }
.means-intro-text span { color: var(--blue-strong); font-weight: 500; }
.means-section { padding: 132px 0; }
.means-section .container { position: relative; }
.means-title { position: relative; font-family: "Sora", sans-serif; font-size: clamp(1.8rem, 2.6vw, 2.7rem); font-weight: 800; line-height: 1.08; margin-bottom: 16px; letter-spacing: 0; color: #11151b; text-wrap: balance; }
.means-title::after { content: ""; display: block; width: 68px; height: 3px; margin-top: 14px; border-radius: 999px; background: linear-gradient(90deg, var(--blue), var(--blue-strong)); box-shadow: 0 8px 18px rgba(74,151,223,.18); }
.means-title span { color: var(--blue-strong); }
.means-subtitle { font-family: "Sora", sans-serif; font-size: clamp(1.2rem, 1.85vw, 1.75rem); font-weight: 700; line-height: 1.2; color: #11151b; margin-bottom: 22px; }
.means-lead { max-width: 900px; font-size: 1.08rem; line-height: 1.85; color: #33404b; }
.means-lead.narrow { max-width: 780px; }
.means-block { display: grid; gap: 48px; }
.means-block-split { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr); gap: 84px; align-items: center; margin-bottom: 62px; }
.means-text-col h3 { font-family: "Sora", sans-serif; font-size: clamp(1.2rem, 1.75vw, 1.75rem); font-weight: 700; line-height: 1.22; color: #11151b; margin-bottom: 18px; }
.means-text-col p { font-size: 1.03rem; line-height: 1.88; color: #2d3741; max-width: 700px; }
.means-image-col { display: flex; justify-content: flex-end; }
.means-image-col img { width: 100%; max-width: 520px; height: 360px; object-fit: cover; border-radius: 28px; box-shadow: 0 18px 40px rgba(0,0,0,.14); transition: transform .5s var(--ease-smooth), box-shadow .35s ease, filter .35s ease; }
.means-image-col:hover img { transform: translateY(-5px) scale(1.015); filter: saturate(1.04); box-shadow: 0 26px 54px rgba(16,24,32,.18); }
.means-section .means-text-col, .means-section .means-image-col { justify-self: stretch; }
.reverse-mobile { grid-template-columns: minmax(360px, .92fr) minmax(0, 1.08fr); }
.means-icons-grid { display: grid; gap: 26px; margin-top: 18px; }
.means-icons-grid.four-cols { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.means-icon-card { position: relative; overflow: hidden; text-align: center; padding: 34px 22px 28px; border-radius: 24px; background: rgba(255,255,255,.72); border: 1px solid rgba(216,229,238,.9); box-shadow: 0 10px 26px rgba(0,0,0,.04); transition: transform .28s var(--ease-smooth), box-shadow .28s ease, border-color .25s ease, background-color .25s ease; }
.means-icon-card::before { content: ""; position: absolute; inset-inline: 0; top: 0; height: 3px; background: linear-gradient(90deg, var(--blue), var(--blue-strong)); transform: scaleX(.22); transform-origin: center; transition: transform .32s var(--ease-out-soft); }
.means-icon-card:hover { transform: translateY(-6px); box-shadow: 0 18px 38px rgba(16,24,32,.09), 0 8px 18px rgba(74,151,223,.07); border-color: rgba(117,184,234,.48); background: rgba(255,255,255,.9); }
.means-icon-card:hover::before { transform: scaleX(1); }
.means-icon { width: 78px; height: 78px; margin: 0 auto 18px; border-radius: 50%; background: linear-gradient(180deg, #f5fafe 0%, #e9f3f9 100%); border: 1px solid #d7e6ef; display: flex; align-items: center; justify-content: center; font-size: 2rem; }
.means-icon-card h4 { font-family: "Sora", sans-serif; font-size: 1.03rem; font-weight: 700; line-height: 1.3; margin-bottom: 10px; color: #162033; }
.means-icon-card p { font-size: .94rem; line-height: 1.65; color: #4a5764; }
.means-suppliers-section { overflow: hidden; }
.means-suppliers-marquee { position: relative; overflow: hidden; width: 100%; margin-top: 42px; padding: 10px 0 6px; }
.means-suppliers-marquee::before, .means-suppliers-marquee::after { content: ""; position: absolute; top: 0; bottom: 0; width: 96px; z-index: 2; pointer-events: none; }
.means-suppliers-marquee::before { left: 0; background: linear-gradient(to right, #f5f5f5 0%, rgba(245,245,245,0) 100%); }
.means-suppliers-marquee::after { right: 0; background: linear-gradient(to left, #f5f5f5 0%, rgba(245,245,245,0) 100%); }
.means-suppliers-track { display: flex; align-items: center; gap: 0; width: max-content; animation: meansSuppliersMarquee 42s linear infinite; will-change: transform; }
.means-suppliers-marquee:hover .means-suppliers-track { animation-play-state: running; }
@keyframes meansSuppliersMarquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.means-supplier { flex: 0 0 280px; width: 280px; display: flex; align-items: center; justify-content: center; padding: 0 26px; }
.means-supplier-logo { width: 190px; height: 96px; display: flex; align-items: center; justify-content: center; overflow: visible; }
.means-supplier-logo img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; opacity: .94; transition: transform .28s ease, opacity .28s ease, filter .28s ease; transform-origin: center; }
.means-supplier-logo img:hover { opacity: 1; filter: saturate(1.04); }
.means-supplier-logo.ms-boost-sm img { transform: scale(1.02); }
.means-supplier-logo.ms-boost-md img { transform: scale(1.12); }
.means-supplier-logo.ms-boost-lg img { transform: scale(1.22); }
.means-supplier-logo.ms-boost-sm img:hover { transform: scale(1.08); }
.means-supplier-logo.ms-boost-md img:hover { transform: scale(1.18); }
.means-supplier-logo.ms-boost-lg img:hover { transform: scale(1.28); }
.means-list-grid { display: grid; gap: 20px; margin-top: 42px; max-width: 840px; }
.means-list-item { display: flex; align-items: flex-start; gap: 20px; padding: 24px 0; border-bottom: 1px solid #e2ebf1; }
.means-list-item:first-child { border-top: 1px solid #e2ebf1; }
.means-list-icon { width: 58px; min-width: 58px; height: 58px; border-radius: 18px; background: linear-gradient(180deg, #f4fafe 0%, #e9f3f9 100%); border: 1px solid #d8e5ee; display: flex; align-items: center; justify-content: center; font-size: 1.45rem; }
.means-list-item h4 { font-family: "Sora", sans-serif; font-size: 1.02rem; font-weight: 700; margin-bottom: 8px; color: #162033; }
.means-list-item p { font-size: .98rem; line-height: 1.72; color: #465360; }
.means-infra .means-block-split { justify-items: start; align-items: center; }
.means-infra .means-image-col { justify-content: flex-start; }
.means-infra .means-text-col { text-align: left; }
.process-line { position: relative; display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 22px; margin-top: 50px; padding-top: 24px; }
.process-line::before { content: ""; position: absolute; top: 61px; left: 8%; right: 8%; height: 2px; background: #1f2430; opacity: .18; }
.process-step { position: relative; text-align: center; z-index: 1; transition: transform .28s var(--ease-smooth); }
.process-step:hover { transform: translateY(-4px); }
.process-icon { width: 80px; height: 80px; margin: 0 auto 20px; border-radius: 50%; background: linear-gradient(180deg, #f4fafe 0%, #e9f3f9 100%); border: 1px solid #d8e5ee; display: flex; align-items: center; justify-content: center; font-size: 1.8rem; position: relative; transition: transform .28s var(--ease-smooth), border-color .25s ease, box-shadow .25s ease; }
.process-step:hover .process-icon { transform: scale(1.06); border-color: rgba(117,184,234,.58); box-shadow: 0 14px 30px rgba(74,151,223,.13); }
.process-icon::after { content: ""; position: absolute; bottom: -20px; left: 50%; width: 2px; height: 20px; background: rgba(31,36,48,.18); transform: translateX(-50%); }
.process-box { min-height: 132px; padding: 18px 16px; border-radius: 18px; background: #f5fafc; border: 1px solid #dbe7ee; box-shadow: 0 8px 20px rgba(0,0,0,.04); transition: box-shadow .28s ease, border-color .25s ease; }
.process-step:hover .process-box { border-color: rgba(117,184,234,.42); box-shadow: 0 16px 32px rgba(16,24,32,.08); }
.process-box strong { display: block; font-size: .95rem; line-height: 1.4; margin-bottom: 10px; color: #162033; }
.process-box p { font-size: .87rem; line-height: 1.55; color: #4a5663; }
.means-check-grid { display: flex; flex-direction: column; gap: 16px; margin-top: 34px; max-width: 560px; }
.means-check-item { display: flex; align-items: center; gap: 14px; min-height: 64px; padding: 16px 20px; border-radius: 18px; background: rgba(255,255,255,.8); border: 1px solid #dbe7ef; box-shadow: 0 6px 18px rgba(0,0,0,.04); transition: all .25s ease; }
.means-check-item:hover { transform: translateX(6px); box-shadow: 0 12px 22px rgba(0,0,0,.08); }
.means-check-item span:first-child { width: 26px; height: 26px; border-radius: 50%; background: rgba(117,184,234,.2); color: var(--blue-strong); display: flex; align-items: center; justify-content: center; font-weight: 700; }
.means-cta { display: flex; justify-content: center; margin-top: 54px; }
.means-cta .pill-btn { min-width: 210px; min-height: 54px; border-radius: 14px; }
.means-hero { overflow-x: clip; }
/* #endregion */
