/* Lexxy — Design system (from presentation 2026) */
:root{
  --primary:#161459;           /* Indigo foncé base */
  --primary-light:#3b3989;     /* Indigo clair pour le dégradé */
  --purple:#5f04ff;            /* Violet CTA */
  --purple-light:#b769ff;
  --pink:#ff2987;              /* Rose vif badges & accents */
  --pink-light:#ff6bcb;
  --orange:#ffb56f;
  --background:#efedff;        /* Lavande clair (sections light) */
  --font-title:"Fjalla One",sans-serif;
  --font-text:"Nunito",sans-serif;
  --radius:16px;
  --gradient-main:linear-gradient(90deg,#5f04ff,#b769ff,#ff2987);
  --gradient-cta:linear-gradient(135deg,#5f04ff,#b769ff);

  --text-on-dark: rgba(255,255,255,.95);
  --muted-on-dark: rgba(255,255,255,.70);
  --stroke-on-dark: rgba(255,255,255,.12);

  --text-on-light: #0a1f6e;
  --muted-on-light: rgba(10,31,110,.58);
  --stroke-on-light: rgba(10,31,110,.10);
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family:var(--font-text);
  color:var(--text-on-light);
  background:#ffffff;
  line-height:1.55;
}

a{color:inherit; text-decoration:none}
a:hover{opacity:.9}

.container{
  width:min(1120px, calc(100% - 40px));
  margin-inline:auto;
}

.skip-link{
  position:absolute;
  left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.skip-link:focus{
  left:16px;top:16px;width:auto;height:auto;
  padding:10px 12px;border-radius:12px;
  background:rgba(255,255,255,.1);
  outline:2px solid rgba(255,255,255,.35);
  z-index:9999;
}

/* ─── Header ─── */
header.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background: linear-gradient(160deg, var(--primary) 0%, var(--primary-light) 100%);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:14px 0;
}
.brand{
  display:flex;align-items:center;gap:12px;min-width:max-content;
}
.brand-mark{
  width:34px;height:34px;
  border-radius:12px;
  background: var(--gradient-main);
  box-shadow: 0 8px 24px rgba(95,4,255,.28);
  position:relative;overflow:hidden;
}
.brand-mark::after{
  content:"";position:absolute;inset:-40%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.35), transparent 45%);
  transform: rotate(18deg);
}
.brand-mark[data-logo="1"]{background:transparent;box-shadow:none;border-radius:0}
.brand-mark[data-logo="1"]::after{content:none}
.brand-name{
  font-family:var(--font-title);
  letter-spacing:.02em;
  text-transform:uppercase;
  font-size:20px;line-height:1;
}
.brand-tag{display:none;font-size:14px;color:var(--muted-on-dark);margin-top:2px}
.brand-stack{display:flex;flex-direction:column}

.nav-links{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:flex-end;
}
.nav-links a{
  font-size:14px;font-weight:500;
  color:var(--muted-on-dark);
  padding:8px 12px;
  border-radius:12px;
  border:1px solid transparent;
  transition: color .15s, background .15s;
}
.nav-links a:hover{color:var(--text-on-dark)}
.nav-links a.btn{padding:7px 18px;border-radius:999px;color:white}
.nav-links a[aria-current="page"]{
  color:var(--text-on-dark);
  border-color: rgba(255,255,255,.14);
  background: rgba(255,255,255,.07);
}

.nav-burger{
  display:none;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:5px;
  width:44px;
  height:44px;
  padding:0;
  border:none;
  border-radius:12px;
  background:rgba(255,255,255,.14);
  cursor:pointer;
  flex-shrink:0;
  z-index:80;
  transition:background .15s;
}
.nav-burger:hover{background:rgba(255,255,255,.22)}
.nav-burger__bar{
  display:block;
  width:22px;
  height:2px;
  border-radius:2px;
  background:#fff;
  transition:transform .22s ease, opacity .22s ease;
}
.nav--open .nav-burger__bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav--open .nav-burger__bar:nth-child(2){opacity:0}
.nav--open .nav-burger__bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:900px){
  .nav-burger{display:flex}
  .nav .nav-links{
    position:fixed;
    top:0;
    right:0;
    width:min(300px, 86vw);
    height:100vh;
    height:100dvh;
    margin:0;
    padding:72px 20px 24px;
    background:#1a1852;
    border-left:1px solid rgba(255,255,255,.1);
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    flex-wrap:nowrap;
    gap:4px;
    transform:translateX(100%);
    transition:transform .28s cubic-bezier(.4,0,.2,1);
    box-shadow:-12px 0 48px rgba(0,0,0,.35);
    z-index:75;
    overflow-y:auto;
  }
  .nav--open .nav-links{transform:translateX(0)}
  .nav-links a{
    padding:14px 16px;
    border-radius:12px;
    font-size:16px;
  }
  .nav-links a.btn{
    margin-top:12px;
    text-align:center;
    justify-content:center;
  }
  body.nav-drawer-open{overflow:hidden;touch-action:none}
}

/* ─── Dropdown nav ─── */
.nav-dropdown{position:relative}
.nav-dropdown-trigger{
  display:flex;align-items:center;gap:6px;
  background:none;border:1px solid transparent;cursor:pointer;
  font-family:var(--font-text);font-size:16px;font-weight:600;
  color:var(--muted-on-dark);
  padding:8px 12px;border-radius:12px;
  transition:color .15s, background .15s;
  white-space:nowrap;
}
.nav-dropdown-trigger:hover,
.nav-dropdown-trigger[aria-expanded="true"]{
  color:var(--text-on-dark);
  background:rgba(255,255,255,.07);
}
.nav-dropdown-arrow{
  font-size:11px;
  display:inline-block;
  transition:transform .2s;
  line-height:1;
}
.nav-dropdown-trigger[aria-expanded="true"] .nav-dropdown-arrow{transform:rotate(180deg)}

.nav-dropdown-menu{
  display:none;
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  min-width:230px;
  background:#1e1b5a;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 16px 48px rgba(0,0,0,.35);
  padding:8px;
  flex-direction:column;
  gap:2px;
  z-index:200;
}
.nav-dropdown-menu.is-open{display:flex}
.nav-dropdown-menu a{
  display:block;
  padding:11px 16px;
  border-radius:10px;
  font-size:15px;font-weight:600;
  color:rgba(255,255,255,.80);
  transition:background .12s, color .12s;
}
.nav-dropdown-menu a:hover{
  background:rgba(255,255,255,.09);
  color:#fff;
}
.nav-dropdown-menu a[aria-current="page"]{
  background:rgba(255,255,255,.08);
  color:#fff;
}

/* ─── Buttons ─── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:10px;padding:10px 26px;
  border-radius:999px;
  font-family:var(--font-text);
  font-weight:400;font-size:17px;
  letter-spacing:.01em;
  border:1px solid transparent;cursor:pointer;
  user-select:none;
  transition: transform .12s ease, box-shadow .18s ease, background .18s ease;
  will-change:transform;
}
.btn:active{transform: translateY(1px)}
.btn--primary{
  color:white;
  background: var(--gradient-cta);
  box-shadow: 0 14px 36px rgba(95,4,255,.28), 0 6px 18px rgba(183,105,255,.18);
}
.btn--primary:hover{box-shadow:0 18px 44px rgba(95,4,255,.36),0 8px 22px rgba(183,105,255,.22)}
.btn--secondary{
  color: var(--purple);
  background: white;
  border: 2px solid var(--purple);
}
.btn--secondary:hover{background:#f4f0ff}
.btn--ghost{
  color: var(--text-on-dark);
  background: rgba(255,255,255,.09);
  border-color: rgba(255,255,255,.14);
}

/* ─── Ligne titre + badge ─── */
.section-title-row{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:20px;
}
.section-title-row .section-title{margin:0}
.badge--light{
  background:rgba(95,4,255,.08);
  border:1px solid rgba(95,4,255,.18);
  color:var(--purple);
  font-size:13px;
  font-weight:700;
  padding:6px 14px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
}

/* ─── Modal offre ─── */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(22,20,89,.55);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  z-index:500;
  padding:max(12px, env(safe-area-inset-top, 0px)) max(14px, env(safe-area-inset-right, 0px)) max(12px, env(safe-area-inset-bottom, 0px)) max(14px, env(safe-area-inset-left, 0px));
  animation:modal-bg-in .2s ease;
}
.modal-overlay[hidden]{display:none}
@keyframes modal-bg-in{from{opacity:0}to{opacity:1}}
.modal{
  background:linear-gradient(160deg, var(--primary) 0%, var(--primary-light) 100%);
  border-radius:24px;
  padding:36px 32px 32px;
  max-width:460px;
  width:100%;
  position:relative;
  border:2px solid #5f04ff;
  box-shadow:0 32px 80px rgba(0,0,0,.40), 0 0 0 1px rgba(95,4,255,.40);
  animation:modal-in .25s cubic-bezier(.34,1.3,.64,1);
  color:var(--text-on-dark);
}
/* Modal 2 colonnes */
.modal--wide{
  max-width:780px;
  padding:0;
  overflow:hidden;
  display:grid;
  grid-template-columns:280px 1fr;
}
.modal--wide .modal__close{
  top:14px;right:14px;
  z-index:2;
}
.modal__img-col{
  position:relative;
  overflow:hidden;
  border-radius:22px 0 0 22px;
}
.modal__img-col img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center top;
  display:block;
  transform:scaleX(-1);
}
.modal__img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(10,4,60,.72) 0%, rgba(10,4,60,.18) 55%, transparent 100%);
  border-radius:22px 0 0 22px;
}
.modal__img-text{
  position:absolute;bottom:24px;left:20px;right:20px;
  display:flex;flex-direction:column;gap:5px;
  color:#fff;
}
.modal__img-text strong{
  font-size:15px;font-weight:700;line-height:1.3;
}
.modal__img-text span{
  font-size:11px;opacity:.80;line-height:1.4;
}
.modal__content-col{
  padding:36px 32px 32px;
  min-width:0;
}
@media(max-width:640px){
  .modal--wide{
    grid-template-columns:1fr;
    max-width:min(460px, calc(100vw - 28px));
    width:100%;
  }
  .modal__img-col{display:none}
  .modal__content-col{padding:32px 18px 26px}
}
@keyframes modal-in{
  from{opacity:0;transform:translateY(20px) scale(.97)}
  to{opacity:1;transform:none}
}
.modal__close{
  position:absolute;top:16px;right:18px;
  background:none;border:none;cursor:pointer;
  font-size:22px;color:rgba(255,255,255,.60);
  line-height:1;padding:4px 8px;border-radius:8px;
  transition:background .15s, color .15s;
}
.modal__close:hover{background:rgba(255,255,255,.10);color:#fff}
.modal__header{text-align:center;margin-bottom:24px}
.modal__plan{
  font-family:var(--font-title);
  font-size:36px;color:#fff;
  margin-bottom:10px;line-height:1.2;
}
.modal__meta{
  display:flex;align-items:center;justify-content:center;
  gap:6px;flex-wrap:wrap;
}
.modal__price{
  font-size:14px;color:rgba(255,255,255,.65);
  white-space:nowrap;
}
.modal__tagline{
  font-size:14px;color:rgba(255,255,255,.65);
  margin:0;
}
.modal__list{
  list-style:none;padding:0;margin:0 0 16px;
  display:flex;flex-direction:column;gap:10px;
}
.modal__list li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:15px;color:rgba(255,255,255,.88);
  line-height:1.45;
}
.modal__list li::before{
  content:"";flex-shrink:0;
  width:8px;height:8px;border-radius:50%;
  background:var(--orange);
  margin-top:5px;
}
.modal__divider{
  height:1px;background:rgba(255,255,255,.10);
  margin:20px 0;
}
.modal__section-label{
  font-size:11px;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;color:rgba(255,255,255,.50);
  margin:0 0 14px;
}
.modal__list--check li::before{
  content:"✓";
  background:none;
  width:auto;height:auto;
  border-radius:0;
  color:#22c55e;
  font-weight:800;
  font-size:15px;
  margin-top:0;
  line-height:1.45;
}
.modal__cta{
  display:flex;width:100%;justify-content:center;
  margin-top:24px;
}

/* ─── Accents orange ─── */
.text-orange{color:var(--orange)}
.dot--orange{
  background:var(--orange) !important;
  box-shadow:0 0 0 4px rgba(255,181,111,.30) !important;
}
.card-icon--orange{
  background:linear-gradient(135deg, var(--orange), #ff7043);
}
.chat-sim__result-tag--orange{
  background:rgba(255,181,111,.22);
  color:var(--orange);
}
.btn--orange{
  color:#6b3200;
  background:var(--orange);
  box-shadow:0 8px 24px rgba(255,181,111,.32);
}
.btn--orange:hover{box-shadow:0 12px 32px rgba(255,181,111,.48)}

/* ─── Badge ─── */
.badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  font-size:14px;font-weight:600;
  color: rgba(255,255,255,.86);
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.07);
}
.badge strong{color:white}
.badge .dot{
  width:8px;height:8px;border-radius:999px;
  background: var(--pink);
  box-shadow: 0 0 0 4px rgba(255,41,135,.22);
}

/* ─── Hero : fond sombre + motif de points ─── */
.hero{
  padding:60px 0 80px;
  background:
    radial-gradient(circle, rgba(255,255,255,.22) 1px, transparent 1px) 0 0 / 26px 26px,
    radial-gradient(900px 450px at 85% 5%, rgba(95,4,255,.20), transparent 60%),
    radial-gradient(600px 350px at 10% 88%, rgba(255,41,135,.10), transparent 55%),
    linear-gradient(160deg, var(--primary) 0%, var(--primary-light) 100%);
  color:var(--text-on-dark);
}
.hero-grid{
  display:grid;gap:32px;
  grid-template-columns:2fr 1fr;
  align-items:center;
}
/* Hero centré (sans aside) */
.hero--center{text-align:center}
.hero--center .hero-grid{
  grid-template-columns:1fr;
}
.hero--center .hero-grid > div{
  max-width:760px;
  margin-inline:auto;
}
.hero--center .lead{margin-left:auto;margin-right:auto}
.hero--center .hero-actions{justify-content:center}
.hero--center .badge{display:inline-flex}
.hero h1{
  font-family:var(--font-title);
  font-size: clamp(46px, 5.4vw, 78px);
  line-height:1.1;
  margin:14px 0 16px;
  /* Pas de text-transform uppercase */
}
.lead{
  color: var(--muted-on-dark);
  font-size:20px;max-width:60ch;margin:0 0 18px;
}

/* Highlight = texte en couleur seulement, sans fond */
.highlight{
  color: white;
}

.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}

/* ─── Hero prompt bar ─── */
.hero-prompt{
  display:flex;
  align-items:center;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;
  padding:6px 6px 6px 20px;
  max-width:520px;
  width:100%;
  margin:24px auto 0;
  text-align:left;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.hero-prompt__input{
  flex:1;
  min-width:0;
  background:none;
  border:none;
  outline:none;
  font-family:var(--font-text);
  font-size:16px;
  color:var(--text-on-dark);
}
.hero-prompt__input::placeholder{
  color:rgba(255,255,255,.55);
}
.hero-prompt__btn{
  flex-shrink:0;
  width:44px;height:44px;
  border-radius:999px;
  background:var(--gradient-cta);
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:white;
  box-shadow:0 4px 16px rgba(95,4,255,.32);
  transition:opacity .15s, box-shadow .15s;
}
.hero-prompt__btn:hover{
  opacity:.9;
  box-shadow:0 6px 20px rgba(95,4,255,.44);
}
.hero-aside{
  border-radius:22px;
  border:1px solid rgba(95,4,255,.14);
  background: rgba(95,4,255,.04);
  padding:20px;overflow:hidden;position:relative;
}
.hero-aside::before{
  content:"";position:absolute;inset:-1px;
  background: radial-gradient(500px 200px at 80% 15%, rgba(255,41,135,.10), transparent 55%);
  pointer-events:none;
}
/* Hero-aside dans le hero sombre : réappliquer style original */
.hero .hero-aside{
  border-color:rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
}

/* ─── Chat simulation ─── */
.chat-sim{
  background:linear-gradient(160deg, var(--primary) 0%, var(--primary-light) 100%);
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 24px 64px rgba(28,26,94,.22);
  font-size:14px;
  font-family:var(--font-text);
  width:100%;
  max-width:100%;
  min-width:0;
  margin-inline:auto;
}
.chat-sim__header{
  display:flex;
  align-items:center;
  gap:12px;
  padding:16px 20px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.14);
}
.chat-sim__avatar{
  width:36px;height:36px;
  border-radius:999px;
  background:#1a0a5e;
  border:1.5px solid rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  overflow:hidden;
  padding:6px;
}
.chat-sim__avatar img{
  width:100%;height:100%;
  object-fit:contain;
  display:block;
}
.chat-sim__name{font-weight:700;color:white;font-size:14px;line-height:1.2}
.chat-sim__status{
  font-size:12px;color:rgba(255,255,255,.60);
  display:flex;align-items:center;gap:5px;margin-top:2px;
}
.chat-sim__status .dot{width:6px;height:6px;background:#22c55e;box-shadow:none}
.chat-sim__body{
  padding:18px 16px 32px;
  display:flex;flex-direction:column;gap:48px;
  min-height:220px;
}
.chat-sim__msg{
  max-width:82%;
  padding:11px 15px;
  border-radius:16px;
  font-size:14px;
  line-height:1.55;
}
.chat-sim__msg--ai{
  background:rgba(255,255,255,.10);
  color:rgba(255,255,255,.92);
  border-radius:4px 16px 16px 16px;
  align-self:flex-start;
  max-width:100%;
  width:100%;
  min-width:0;
  box-sizing:border-box;
}
.chat-sim__msg--user{
  background:var(--gradient-cta);
  color:white;
  font-weight:600;
  border-radius:16px 4px 16px 16px;
  align-self:flex-end;
  box-shadow:0 4px 14px rgba(95,4,255,.30);
}
.chat-sim__chips{
  display:flex;flex-wrap:wrap;gap:8px;
  align-self:flex-start;
}
.chat-sim__chip{
  padding:7px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.24);
  color:rgba(255,255,255,.88);
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  background:rgba(255,255,255,.07);
  transition:background .15s, border-color .15s, color .15s;
  user-select:none;
}
.chat-sim__chip:hover{
  background:rgba(255,255,255,.16);
  border-color:rgba(255,255,255,.40);
  color:white;
}
.chat-sim__progress{
  margin-top:10px;
  height:4px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  overflow:hidden;
}
.chat-sim__progress-fill{
  height:100%;
  width:0;
  border-radius:999px;
  background:linear-gradient(90deg,#f97316 0%,#ec4899 100%);
}
@keyframes chat-progress{
  from{width:0}
  to{width:72%}
}

/* ─── Animations scroll du chat ─── */
@keyframes chat-fade-up{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:1;transform:translateY(0)}
}
.chat-sim__header,
.chat-sim__body > *,
.chat-sim__footer{
  opacity:0;
  transform:translateY(14px);
}
.chat-sim--visible .chat-sim__header{
  animation:chat-fade-up .4s ease forwards .10s;
}
.chat-sim--visible .chat-sim__body > *:nth-child(1){
  animation:chat-fade-up .4s ease forwards .35s;
}
.chat-sim--visible .chat-sim__body > *:nth-child(2){
  animation:chat-fade-up .4s ease forwards .80s;
}
.chat-sim--visible .chat-sim__body > *:nth-child(3){
  animation:chat-fade-up .4s ease forwards 1.20s;
}
.chat-sim--visible .chat-sim__body > *:nth-child(4){
  animation:chat-fade-up .4s ease forwards 1.60s;
}
.chat-sim--visible .chat-sim__footer{
  animation:chat-fade-up .4s ease forwards .10s;
}
.chat-sim--visible .chat-sim__progress-fill{
  animation:chat-progress 1.1s ease-out forwards 2.10s;
}
@media(prefers-reduced-motion:reduce){
  .chat-sim__header,
  .chat-sim__body > *,
  .chat-sim__footer{opacity:1;transform:none}
  .chat-sim--visible .chat-sim__progress-fill{animation:none;width:72%}
}
.chat-sim__result-tags{
  display:flex;gap:6px;flex-wrap:wrap;margin-top:10px;
}
.chat-sim__result-tag{
  padding:4px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  color:rgba(255,255,255,.88);
  font-size:12px;font-weight:600;
}
/* Étapes de progression (pastilles Analyse → SMS) */
.chat-sim__result-steps{
  display:flex;
  align-items:center;
  gap:3px 5px;
  flex-wrap:wrap;
  margin-top:10px;
  max-width:100%;
}
.chat-sim__step{
  padding:3px 7px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  color:rgba(255,255,255,.88);
  font-size:9px;font-weight:700;
  letter-spacing:.02em;
  line-height:1.25;
  white-space:nowrap;
}
.chat-sim__step-arrow{
  color:rgba(255,255,255,.40);
  font-size:10px;
  line-height:1;
  flex-shrink:0;
}
.chat-sim__footer{
  display:flex;align-items:center;gap:8px;
  padding:12px 16px;
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.10);
}
.chat-sim__input-fake{
  flex:1;
  background:rgba(255,255,255,.08);
  border-radius:999px;
  padding:10px 16px;
  color:rgba(255,255,255,.38);
  font-size:14px;
  font-family:var(--font-text);
}
.chat-sim__send-btn{
  width:36px;height:36px;
  border-radius:999px;
  background:var(--gradient-cta);
  display:flex;align-items:center;justify-content:center;
  color:white;flex-shrink:0;
  box-shadow:0 4px 12px rgba(95,4,255,.28);
}

/* ─── Sections : bandes pleine largeur ─── */
.section{padding:160px 0}
.section + .section{margin-top:64px}
.section-title{
  font-family:var(--font-title);
  font-size: clamp(36px, 3.6vw, 56px);
  line-height:1.15;margin:0 0 20px;
}
.section-sub{margin:0 0 52px;max-width:78ch;font-size:19px}

/* Section bleu foncé (bande sombre) */
.section--dark{
  background:linear-gradient(160deg, var(--primary) 0%, var(--primary-light) 100%);
  color:var(--text-on-dark);
}
.section--dark .section-title{color:var(--text-on-dark)}
.section--dark .section-sub  {color:var(--muted-on-dark)}
.section--dark .list li      {color:var(--muted-on-dark)}
.section--dark .prose p      {color:var(--muted-on-dark)}

/* Section fond blanc */
.section--demo-cta{padding-bottom:80px}
.section--blog-feed{padding-top:80px}
.section--white{
  background:#ffffff;
  color:var(--text-on-light);
}
.section--white .section-title{color:var(--text-on-light)}
.section--white .section-sub  {color:var(--muted-on-light)}
.section--white .list li      {color:var(--muted-on-light)}
.section--white .list li::before{
  background:var(--orange);box-shadow:0 0 0 4px rgba(255,181,111,.28);
}
.section--white .prose p{color:var(--muted-on-light)}

.section--lavender{
  background:#f3efff;
  color:var(--text-on-light);
}
.section--lavender .section-title{color:var(--text-on-light)}
.section--lavender .section-sub  {color:var(--muted-on-light)}
.section--lavender .card{background:white}

/* Section violet clair (bande claire) */
.section--purple{
  background:var(--background);
  color:var(--text-on-light);
}
.section--purple .section-title{color:var(--text-on-light)}
.section--purple .section-sub  {color:var(--muted-on-light)}
.section--purple .list li      {color:var(--muted-on-light)}
.section--purple .list li::before{
  background:var(--pink);box-shadow:0 0 0 4px rgba(255,41,135,.18);
}
.section--purple .prose p{color:var(--muted-on-light)}

/* Section accent : bande bleu foncé simple, sans cadre */
.section--accent{
  background:linear-gradient(160deg, var(--primary) 0%, var(--primary-light) 100%);
  color:var(--text-on-dark);
}
.section--accent .section-title{color:var(--text-on-dark)}
.section--accent .section-sub  {color:var(--muted-on-dark)}
.section--accent p              {color:var(--muted-on-dark)}

/* ─── Grids ─── */
.grid{display:grid;gap:28px}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}

/* ─── Cartes — blanches par défaut ─── */
.card{
  border-radius:var(--radius);
  padding:24px;
  background:#ffffff;
  color: var(--text-on-light);
  border:1px solid rgba(28,26,94,.08);
  box-shadow:0 6px 24px rgba(28,26,94,.09);
  transition: box-shadow .2s, transform .15s;
}
.card:hover{
  box-shadow:0 12px 40px rgba(95,4,255,.14);
  transform:translateY(-2px);
}
.card h3{
  font-family:var(--font-text);
  font-weight:800;
  margin:0 0 8px;
  font-size:22px;
  color: var(--text-on-light);
}
.card p{margin:0;color:var(--muted-on-light)}
.card-icon{
  width:44px;height:44px;border-radius:50%;
  background: var(--gradient-cta);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;font-size:22px;
}

/* Carte avec image en tête */
.card--with-img{padding-top:0;overflow:hidden}
.card-img{
  margin:0 -24px 20px;
  height:180px;
  overflow:hidden;
}
.card-img img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 15%;
  display:block;
  transition:transform .4s ease;
}
.card--with-img:hover .card-img img{transform:scale(1.04)}
.card-img--duo{
  display:flex;
  gap:3px;
}
.card-img--duo .card-img__item{
  width:50%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  flex-shrink:0;
}

/* Variante mauve (fond lavande, texte foncé) */
.card--mauve{
  background:var(--background);
  border-color:rgba(95,4,255,.12);
  box-shadow:0 6px 24px rgba(95,4,255,.08);
  padding-top:48px;
  padding-bottom:48px;
}
.card--mauve h3{color:var(--text-on-light)}
.card--mauve p{color:var(--muted-on-light)}
.card--mauve:hover{box-shadow:0 12px 36px rgba(95,4,255,.16)}

/* Variante sombre (pour sections claires qui veulent contraste) */
.card--dark{
  background: rgba(255,255,255,.06);
  color: var(--text-on-dark);
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 8px 28px rgba(0,0,0,.20);
}
.card--dark h3{color:var(--text-on-dark)}
.card--dark p{color:var(--muted-on-dark)}
.card--dark:hover{box-shadow:0 14px 40px rgba(0,0,0,.28)}

/* .card--light alias gardé pour compatibilité */
.card--light{
  background:white;color:var(--text-on-light);
  border-color:rgba(23,23,42,.10);
  box-shadow:0 12px 40px rgba(0,0,0,.10);
}
.card--light h3{color:var(--text-on-light)}
.card--light p{color:var(--muted-on-light)}

/* ─── Listes ─── */
.list{margin:14px 0 0;padding:0;list-style:none;display:grid;gap:10px}
.list li{display:flex;gap:10px;align-items:flex-start;color:var(--muted-on-light)}
.list li::before{
  content:"";width:10px;height:10px;border-radius:999px;
  margin-top:7px;
  background: var(--pink);
  box-shadow:0 0 0 4px rgba(255,41,135,.20);
  flex:0 0 auto;
}
/* Dans les cartes blanches, les listes utilisent texte sombre */
.card .list li{color: var(--muted-on-light)}
.card--dark .list li{color: var(--muted-on-dark)}
.list--on-dark li{color:#fff}

/* ─── Split ─── */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:20px;align-items:start}

/* ─── Article Meta (date + reading time) ─── */
.article-meta{
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
  padding:28px 0 20px;
  border-bottom:1px solid rgba(10,31,110,.08);
  margin-bottom:32px;
}
.article-meta__item{
  display:flex;
  align-items:center;
  gap:7px;
  font-size:14px;
  color:#888;
}
.article-meta__item svg{
  flex-shrink:0;
  color:var(--orange);
}

/* ─── Article TOC ─── */
.article-toc{
  background:#f6f6fb;
  border:1px solid rgba(10,31,110,.09);
  border-radius:14px;
  padding:20px 24px;
  margin-bottom:36px;
}
.article-toc__title{
  display:block;
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.07em;
  color:var(--primary);
  margin-bottom:12px;
}
.article-toc__list{
  margin:0;
  padding-left:18px;
  list-style:decimal;
}
.article-toc__list li{
  margin:5px 0 !important;
  font-size:14.5px !important;
  color:var(--dark) !important;
  line-height:1.45 !important;
}
.article-toc__list a,
.prose .article-toc__list a{
  color:var(--primary) !important;
  text-decoration:none !important;
  font-weight:700;
  transition:opacity .18s;
  opacity:.85;
}
.article-toc__list a:hover,
.prose .article-toc__list a:hover{opacity:1;}

/* liens dans le corps des articles */
.prose a{
  color:var(--orange);
  text-decoration:underline;
  text-underline-offset:3px;
  transition:opacity .18s;
}
.prose a:hover{opacity:.75}

/* ─── Bouton remonter en haut ─── */
#scroll-top{
  position:fixed;
  bottom:28px;
  right:28px;
  z-index:999;
  width:44px;
  height:44px;
  border-radius:50%;
  border:none;
  background:var(--orange);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 4px 16px rgba(255,127,40,.35);
  opacity:0;
  transform:translateY(12px);
  pointer-events:none;
  transition:opacity .22s, transform .22s, background .15s;
}
#scroll-top.visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
#scroll-top:hover{ background:#e06000; box-shadow:0 6px 20px rgba(255,127,40,.5); }
#scroll-top:active{ transform:translateY(2px); }
@media(max-width:540px){
  #scroll-top{ bottom:16px; right:16px; width:40px; height:40px; }
}

/* ─── Lien texte orange ─── */
.link-orange{
  color:var(--orange);
  font-weight:700;
  font-size:15px;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:4px;
  transition:opacity .15s;
}
.link-orange:hover{ opacity:.75; text-decoration:underline; }

/* ─── Article Nav (précédent / suivant) ─── */
.article-nav{
  display:flex;
  gap:14px;
  justify-content:space-between;
  align-items:stretch;
  margin:28px 0;
  max-width:calc(100% - 280px - 48px);
}
.article-nav__prev,
.article-nav__next{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:4px;
  padding:20px 22px;
  text-decoration:none;
  color:#fff;
  flex:1;
  max-width:48%;
  min-height:110px;
  border-radius:16px;
  overflow:hidden;
  background-color:#161459;
  background-size:cover;
  background-position:center;
  transition:transform .2s, box-shadow .2s;
  box-shadow:0 4px 18px rgba(10,4,60,.18);
}
.article-nav__prev::before,
.article-nav__next::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(10,4,60,.82) 0%, rgba(10,4,60,.45) 55%, rgba(10,4,60,.18) 100%);
  border-radius:inherit;
}
.article-nav__prev:hover,
.article-nav__next:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 32px rgba(10,4,60,.28);
}
.article-nav__prev{ align-items:flex-start; }
.article-nav__next{ align-items:flex-end; text-align:right; }
.article-nav__label{
  position:relative;
  font-size:10px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.07em;
  color:var(--orange);
  z-index:1;
}
.article-nav__title{
  position:relative;
  font-size:13px;
  font-weight:700;
  color:#fff;
  line-height:1.35;
  z-index:1;
  text-shadow:0 1px 4px rgba(0,0,0,.4);
}
.article-nav__spacer{ flex:1; max-width:48%; }

/* Nav dans la sidebar : colonnes empilées pleine largeur */
.article-sidebar .article-nav{
  flex-direction:column;
  max-width:100%;
  margin:0 0 20px;
  gap:10px;
}
.article-sidebar .article-nav__prev,
.article-sidebar .article-nav__next{
  max-width:100%;
  min-height:90px;
  align-items:flex-start;
  text-align:left;
}
.article-sidebar .article-nav__spacer{ display:none; }

@media(max-width:760px){
  .article-nav{ max-width:100%; }
}
@media(max-width:540px){
  .article-nav{ flex-direction:column; }
  .article-nav__prev,
  .article-nav__next{ max-width:100%; align-items:flex-start; text-align:left; min-height:90px; }
}

/* ─── Article Author ─── */
.article-author{
  display:flex;
  align-items:flex-start;
  gap:18px;
  background:#f8f8fb;
  border:1px solid rgba(0,0,0,.07);
  border-radius:16px;
  padding:24px 28px;
  margin-top:28px;
  max-width:calc(100% - 280px - 48px);
}
.article-author__photo{
  width:68px;
  height:68px;
  border-radius:50%;
  object-fit:cover;
  object-position:top center;
  flex-shrink:0;
  border:2px solid rgba(0,0,0,.08);
}
.article-author__info{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.article-author__name{
  font-size:17px;
  font-weight:700;
  color:var(--dark);
  font-family:var(--font-title);
  letter-spacing:-.01em;
}
.article-author__role{
  font-size:14px;
  color:#e91e8c;
  font-weight:500;
}
.article-author__bio{
  margin:8px 0 0;
  font-size:15px;
  line-height:1.6;
  color:#555;
}
@media(max-width:760px){
  .article-author{max-width:100%}
}
@media(max-width:540px){
  .article-author{flex-direction:column;align-items:center;text-align:center}
}

/* ─── CTA Band ─── */
.cta-band{
  border-radius:22px;
  background:
    radial-gradient(circle, rgba(140,80,255,.18) 1px, transparent 1px),
    linear-gradient(135deg, rgba(10,4,60,.97) 0%, rgba(22,8,80,.95) 100%);
  background-size:22px 22px, 100% 100%;
  border:1px solid rgba(95,4,255,.28);
  padding:48px 52px;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  gap:32px;
}
.cta-band .section-title{color:#fff}
.cta-band p{margin:10px 0 0;color:rgba(255,255,255,.65);font-size:16px}
.cta-band .btn--primary{
  background:#fff;
  color:var(--dark);
  border-color:#fff;
}
.cta-band .btn--primary:hover{
  background:rgba(255,255,255,.88);
  box-shadow:0 8px 24px rgba(255,255,255,.18);
}
.cta-band > div:last-child{
  display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end;
}
@media(max-width:760px){
  .cta-band{
    grid-template-columns:1fr;
    padding:36px 28px;
  }
  .cta-band > div:last-child{
    justify-content:flex-start;
  }
}
.section--white .section-title{color:var(--text-on-light)}

/* ─── Vision Lexxy ─── */
.vision-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:24px;
}
.vision-tagline{
  font-size:clamp(16px,1.8vw,20px);
  text-align:center;
  color:var(--muted-on-light);
  margin:0 auto 56px;
  max-width:860px;
  line-height:1.65;
  font-weight:400;
}
.vision-highlight--purple{color:inherit;font-weight:400}
.vision-highlight--pink{color:inherit;font-weight:400}
.vision-steps{
  display:flex;
  align-items:center;
  gap:0;
}
.vision-step{
  flex:1;
  position:relative;
  background:white;
  border-radius:16px;
  border:1.5px solid #ede8ff;
  border-top:3px solid #ede8ff;
  padding:28px 20px 24px;
  text-align:center;
  box-shadow:0 2px 16px rgba(95,4,255,.06);
}
.vision-step--blue  {border-top-color:var(--orange)}
.vision-step--purple{border-top-color:#b48fff}
.vision-step--pink  {border-top-color:var(--pink)}
.vision-step--green {border-top-color:#4ade80}
.vision-step__num{
  display:flex;align-items:center;justify-content:center;
  width:52px;height:52px;border-radius:50%;
  font-size:36px;font-weight:800;
  font-family:var(--font-title);
  line-height:1;
  margin:0 auto 16px;
}
.vision-step--blue   .vision-step__num{color:var(--orange)}
.vision-step--purple .vision-step__num{color:#5f04ff}
.vision-step--pink   .vision-step__num{color:var(--pink)}
.vision-step--green  .vision-step__num{color:#22c55e}
.vision-step__icon{display:none}
.vision-step h3{
  font-family:var(--font-text);
  font-size:22px;font-weight:800;
  color:var(--text-on-light);
  margin:0 0 6px;
  letter-spacing:0;
  line-height:1.15;
}
.vision-step p{
  font-size:16px;color:var(--muted-on-light);
  margin:0;line-height:1.5;
}
.vision-step__connector{
  flex:0 0 24px;
  height:3px;
  background:repeating-linear-gradient(90deg,#7c5cbf 0,#7c5cbf 6px,transparent 6px,transparent 12px);
  margin-bottom:16px;
}
.section--dark .vision-header .section-title{color:white}
@media(max-width:760px){
  .vision-steps{flex-direction:column;align-items:stretch;gap:12px}
  .vision-step__connector{width:1px;height:24px;flex:none;margin:0 auto;background:repeating-linear-gradient(180deg,rgba(255,255,255,.25) 0,rgba(255,255,255,.25) 4px,transparent 4px,transparent 10px)}
}

/* ─── Omni Visual (orbital channels) ─── */
.omni-visual{
  position:relative;
  width:100%;
  max-width:400px;
  margin:0 auto;
}
.omni-visual__svg{
  display:block;
  width:100%;
  height:auto;
}
.omni-bubble{
  position:absolute;
  background:#fff;
  border-radius:50%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:0;
  box-shadow:0 4px 18px rgba(95,4,255,.15);
  text-align:center;
}
.omni-bubble--lg{width:140px;height:140px}
.omni-bubble--md{width:124px;height:124px}
.omni-bubble--sm{width:104px;height:104px}

@keyframes omni-float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}
.omni-float-1{animation:omni-float 3.4s ease-in-out infinite 0s}
.omni-float-2{animation:omni-float 3.4s ease-in-out infinite .55s}
.omni-float-3{animation:omni-float 3.4s ease-in-out infinite 1.1s}
.omni-float-4{animation:omni-float 3.4s ease-in-out infinite 1.65s}
.omni-float-5{animation:omni-float 3.4s ease-in-out infinite 2.2s}
.omni-float-6{animation:omni-float 3.4s ease-in-out infinite 2.75s}

/* ─── Omni Tabs ─── */
.omni-tabs{
  display:flex;
  gap:0;
  border:1px solid rgba(95,4,255,.14);
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 4px 32px rgba(95,4,255,.07);
}
.omni-tabs__nav{
  display:flex;
  flex-direction:column;
  flex:0 0 220px;
  background:#f8f6ff;
  border-right:1px solid rgba(95,4,255,.10);
  padding:12px 8px;
  gap:4px;
}
.omni-tab-btn{
  display:flex;align-items:center;gap:10px;
  background:none;border:none;cursor:pointer;
  text-align:left;
  font-family:var(--font-text);font-size:15px;
  color:var(--muted-on-light);
  padding:12px 14px;
  border-radius:12px;
  transition:background .15s, color .15s;
  font-weight:500;
  white-space:nowrap;
}
.omni-tab-btn:hover{
  background:rgba(95,4,255,.07);
  color:var(--purple);
}
.omni-tab-btn--active{
  background:white;
  color:var(--purple);
  font-weight:600;
  box-shadow:0 2px 10px rgba(95,4,255,.10);
}
.omni-tab-btn__icon{
  flex-shrink:0;
  width:24px;height:24px;
  display:flex;align-items:center;justify-content:center;
  color:var(--purple);
}
.omni-tab-btn__label{
  flex:1;
  min-width:0;
}
.omni-tab-btn--active .omni-tab-btn__icon{
  color:var(--purple);
}
.omni-tab-btn--discover{
  margin-top:auto;
  border-top:1px solid rgba(95,4,255,.12);
  padding-top:16px;
  margin-top:8px;
  text-decoration:none;
  white-space:normal;
  line-height:1.3;
}
.omni-tabs__panels{
  flex:1 1 0;
  min-width:0;
}
.omni-tab-panel{
  display:none;
}
.omni-tab-panel--active{
  display:flex;
  flex-direction:row;
  align-items:stretch;
  gap:0;
  height:560px;
  border-radius:20px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 4px 32px rgba(10,4,60,.07);
}
.omni-tab-panel__body{
  flex:1;
  padding:44px 48px;
  min-width:0;
  order:1;
  display:flex;
  flex-direction:column;
  justify-content:center;
  overflow:hidden;
}
.omni-tab-panel__img{
  flex:0 0 44%;
  max-width:44%;
  order:2;
  overflow:hidden;
  background:#f3efff;
  position:relative;
  cursor:zoom-in;
}
.omni-tab-panel__img img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
}
@media(max-width:860px){
  .omni-tab-panel--active{flex-direction:column;min-height:auto}
  .omni-tab-panel__img{flex:none;max-width:100%;height:220px}
}
.omni-tab-panel__body h3{
  font-size:22px;font-weight:700;
  color:var(--text-on-light);
  margin:0 0 12px;
}
.omni-tab-panel__body p{
  font-size:15px;line-height:1.7;
  color:var(--muted-on-light);
  margin:0 0 20px;
}
.omni-tab-panel__list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:8px;
}
.omni-tab-panel__list li{
  font-size:14px;color:var(--text-on-light);
  padding-left:20px;position:relative;
}
.omni-tab-panel__list li::before{
  content:'';position:absolute;left:0;top:7px;
  width:7px;height:7px;border-radius:50%;
  background:var(--orange);
}
@media(max-width:860px){
  .omni-tabs{flex-direction:column}
  .omni-tabs__nav{flex-direction:row;flex-wrap:wrap;flex:none;border-right:none;border-bottom:1px solid rgba(95,4,255,.10)}
  .omni-tab-btn{font-size:13px;padding:8px 12px;white-space:nowrap}
}

/* ─── Multi-marques section ─── */
.section--multimarque{
  position:relative;
}
.multimarque-card{
  position:relative;
  border-radius:24px;
  overflow:hidden;
  padding:64px 40px;
  background-image:url("/Images/Accueil/fond-geometrique-violet-lexxy.webp");
  background-size:cover;
  background-position:center;
}
.multimarque-card::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(10,4,60,.88) 0%, rgba(22,8,80,.82) 100%);
  z-index:0;
}
.multimarque-card > *{
  position:relative;z-index:1;
}
.section--multimarque .section-title{
  color:white;
}
.section--multimarque .section-sub{
  color:rgba(255,255,255,.70);
}
.card--glass{
  background:rgba(255,255,255,.08);
  border:2px solid #5f04ff;
  box-shadow:0 0 0 1px rgba(95,4,255,.40);
  backdrop-filter:blur(12px);
  border-radius:16px;
  padding:28px;
  color:white;
}
.card--glass h3{
  color:white;margin-bottom:10px;
}
.card--glass p{
  color:rgba(255,255,255,.72);
  font-size:15px;line-height:1.6;
  margin:0;
}

/* ─── CTA Offer Card ─── */
.cta-offer-card{
  max-width:780px;
  margin:0 auto;
  border-radius:24px;
  border:1px solid rgba(95,4,255,.18);
  box-shadow:0 8px 48px rgba(95,4,255,.10);
  overflow:hidden;
}
.cta-offer-card__header{
  background:linear-gradient(135deg,#1a0a4a,#2d1060);
  color:white;
  text-align:center;
  padding:0;
  overflow:hidden;
  height:320px;
}
.cta-offer-card__img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 35%;
  display:block;
}
.cta-offer-card__plan{
  display:inline-block;
  font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(255,255,255,.12);
  border-radius:999px;padding:4px 14px;
  margin-bottom:16px;
  color:rgba(255,255,255,.85);
}
.cta-offer-card__price{
  font-size:64px;font-weight:700;line-height:1;
  color:white;
}
.cta-offer-card__price span{font-size:32px;vertical-align:super;margin-left:2px}
.cta-offer-card__tagline{
  margin:10px 0 0;
  font-size:14px;color:rgba(255,255,255,.6);
}
.cta-offer-card__body{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  background:white;
}
.cta-offer-card__body > div{
  padding:32px 36px;
}
.cta-offer-card__body > div:first-child{
  border-right:1px solid rgba(0,0,0,.06);
}
.cta-offer-card__label{
  font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(0,0,0,.35);
  margin:0 0 16px;
}
.cta-offer-card__list{
  list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;
}
.cta-offer-card__list li{
  font-size:15px;color:var(--text-on-light);
  padding-left:22px;position:relative;
}
.cta-offer-card__list li::before{
  content:'';position:absolute;left:0;top:6px;
  width:8px;height:8px;border-radius:50%;
  background:var(--purple);
}
.cta-offer-card__list--check li::before{
  content:'✓';
  background:none;
  color:#22c55e;
  font-weight:700;font-size:13px;
  top:1px;width:auto;height:auto;border-radius:0;
}
.cta-offer-card__footer{
  background:white;
  text-align:center;
  padding:32px 48px 40px;
  border-top:1px solid rgba(0,0,0,.06);
}
@media(max-width:640px){
  .cta-offer-card__body{grid-template-columns:1fr}
  .cta-offer-card__body > div:first-child{border-right:none;border-bottom:1px solid rgba(0,0,0,.06)}
  .cta-offer-card__header{padding:32px 24px 24px}
  .cta-offer-card__footer{padding:24px}
}

/* ─── Footer ─── */
footer.site-footer{
  padding:72px 0 0;
  background:linear-gradient(160deg, var(--primary) 0%, var(--primary-light) 100%);
  color:var(--muted-on-dark);
}
.footer-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr;
  gap:40px;
  padding-bottom:52px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.footer-brand .brand{display:inline-flex;margin-bottom:4px}
.footer-tagline{
  font-size:15px;color:var(--muted-on-dark);
  margin:14px 0 10px;max-width:30ch;line-height:1.5;
}
.footer-rubeez-card{
  display:inline-flex;flex-direction:column;gap:8px;
  margin-top:14px;padding:12px 16px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
}
.footer-rubeez-intro{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.45);font-weight:700}
.footer-rubeez-card a{display:inline-block;text-decoration:none;opacity:.7;transition:opacity .15s}
.footer-rubeez-card a:hover{opacity:1}
.footer-rubeez-logo{display:block;height:20px;width:auto}
.footer-linkedin-link{display:inline-flex;align-items:center;text-decoration:none;opacity:.65;transition:opacity .15s}
.footer-linkedin-link:hover{opacity:1}
.footer-linkedin-link img{display:block;height:18px;width:auto}
.footer-nav-title{
  font-family:var(--font-text);font-weight:800;
  font-size:12px;text-transform:uppercase;letter-spacing:.08em;
  color:rgba(255,255,255,.45);margin:0 0 18px;
}
.footer-nav-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px}
.footer-nav-col ul li a{font-size:15px;color:var(--muted-on-dark);transition:color .15s}
.footer-nav-col ul li a:hover{color:#fff}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 0;font-size:13px;color:rgba(255,255,255,.40);
}
.footer-bottom-links{display:flex;gap:22px}
.footer-bottom-links a{color:rgba(255,255,255,.40);transition:color .15s}
.footer-bottom-links a:hover{color:rgba(255,255,255,.70)}

/* ─── KPI ─── */
.kpi{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:20px}
.kpi .card{padding:18px}
.kpi strong{
  font-family:var(--font-text);
  font-weight:900;
  font-size:22px;
  color: var(--primary);
  /* Pas de uppercase */
}
.kpi span{display:block;color:var(--muted-on-light);font-size:15px;margin-top:4px}

/* ─── Formulaires ─── */
.form{display:grid;gap:12px}
.field label{display:block;font-weight:700;font-size:15px;margin-bottom:6px}
.field input,.field textarea,.field select{
  width:100%;padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:var(--text-on-dark);
  font-family:var(--font-text);
  outline:none;font-size:17px;
}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{
  border-color:rgba(95,4,255,.70);
  box-shadow:0 0 0 4px rgba(95,4,255,.16);
}

/* ─── Prose (blog) ─── */
.prose{max-width:78ch}
.prose h1,.prose h2{
  font-family:var(--font-title);
  line-height:1.2;
  color:var(--dark);
}
.prose h3{
  font-family:var(--font-text);
  font-weight:800;
  line-height:1.2;
  color:var(--dark);
}
.prose h1{font-size:clamp(34px,4vw,54px);margin:0 0 12px}
.prose h2{font-size:clamp(28px,2.6vw,42px);margin:36px 0 12px}
.prose h2.section-title{font-size:clamp(36px,3.6vw,56px);margin:0 0 10px}
.prose h3{font-size:clamp(20px,1.6vw,26px);margin:28px 0 10px}
.prose p{color:var(--muted-on-light);font-size:clamp(16px,1.25vw,18px);line-height:1.8}
.prose ul,.prose ol{padding-left:24px}
.prose li{margin:8px 0;color:var(--muted-on-light);font-size:clamp(16px,1.25vw,18px);line-height:1.75}

.article-hero{
  position:relative;
  aspect-ratio:16/7.65;
  border-radius:24px;
  overflow:hidden;
  border:1px solid rgba(10,31,110,.10);
}
.article-hero__img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.article-hero__dot{
  display:block;
  width:10px;
  height:10px;
  border-radius:999px;
  background:var(--orange);
  box-shadow:0 0 0 4px rgba(255,181,111,.35);
  margin-bottom:14px;
}
.article-hero__overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(10,31,110,.18) 0%,rgba(10,31,110,.42) 38%,rgba(10,31,110,.78) 100%);
}
.article-hero__content{
  position:absolute;
  inset:auto 0 0 0;
  padding:40px 36px;
  z-index:1;
}
.article-hero__content h1{
  margin:0;
  color:#fff;
  max-width:760px;
  font-size:clamp(34px,4.5vw,58px);
  line-height:1.08;
}
.blog-index-card{
  overflow:hidden;
  padding:0;
}
.blog-index-card__media{
  aspect-ratio:16/9;
  overflow:hidden;
  border-bottom:1px solid rgba(10,31,110,.08);
}
.blog-index-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.blog-index-card h3,
.blog-index-card p{
  padding-left:28px;
  padding-right:28px;
}
.blog-index-card h3{
  margin-top:24px;
}
.blog-index-card p{
  padding-bottom:28px;
}
@media(max-width:700px){
  .article-hero{aspect-ratio:16/7.65}
  .article-hero__content{
    padding:28px 24px;
  }
}

/* ─── Tableau ─── */
.table{
  width:100%;border-collapse:separate;border-spacing:0;
  overflow:hidden;border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
}
.table th,.table td{text-align:left;padding:14px;border-bottom:1px solid rgba(255,255,255,.08)}
.table th{
  font-size:14px;font-weight:800;
  color:rgba(255,255,255,.78);
  letter-spacing:.06em;text-transform:uppercase;
}
.table tr:last-child td{border-bottom:0}

.ill{width:100%;height:auto;display:block}

/* ─── Card image zoom (lightbox) ─── */
.card-img--zoomable{
  position:relative;
  cursor:zoom-in;
}
.card-img__zoom-btn{
  position:absolute;
  bottom:10px;right:10px;
  width:34px;height:34px;
  background:rgba(255,255,255,.9);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#5f04ff;
  opacity:0;
  transform:scale(.8);
  transition:opacity .2s ease,transform .2s ease;
  pointer-events:none;
  box-shadow:0 2px 12px rgba(10,4,60,.2);
}
.card-img--zoomable:hover .card-img__zoom-btn{
  opacity:1;
  transform:scale(1);
}
.card-img--zoomable:hover img{
  transform:scale(1.04);
  transition:transform .35s ease;
}

/* ─── Brand Hub Carousel ─── */
.brand-carousel{
  position:relative;
  display:flex;
  align-items:center;
  gap:0;
  padding:48px 0 56px;
}
.brand-carousel__viewport{
  flex:1;
  overflow:hidden;
  /* espace vertical pour que le scale ne soit pas coupé */
  padding:32px 0;
  margin:-32px 0;
}
.brand-carousel__track{
  display:flex;
  align-items:center;
  gap:24px;
  /* le JS gère le translateX, pas de justify-content */
  will-change:transform;
}
.brand-carousel__item{
  flex:0 0 520px;
  width:520px;
  height:240px;
  display:flex;
  flex-direction:row;
  background:linear-gradient(135deg,#2d0a8e 0%,#4a0fbe 100%);
  border-radius:20px;
  border:1.5px solid rgba(180,140,255,.35);
  box-shadow:0 2px 10px rgba(10,4,60,.08);
  overflow:hidden;
  cursor:pointer;
  will-change:transform,opacity;
  transform-origin:center center;
}
.brand-carousel__item--active{
  box-shadow:0 6px 24px rgba(95,4,255,.14);
}
.brand-carousel__img{
  flex:0 0 270px;
  width:270px;
  overflow:hidden;
  background:rgba(255,255,255,.08);
  position:relative;
}
.brand-carousel__img img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  transform:scale(1.15);
  transition:transform .45s ease;
}
.brand-carousel__body{
  flex:0 0 250px;
  width:250px;
  padding:24px 24px 26px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  overflow:hidden;
}
.brand-carousel__body h3{
  font-size:1.05rem;
  font-weight:700;
  color:#ffffff;
  margin:0 0 8px;
  line-height:1.2;
}
.brand-carousel__body p{
  font-size:.875rem;
  color:rgba(255,255,255,.72);
  margin:0;
  line-height:1.5;
}
.brand-carousel__btn{
  flex:0 0 auto;
  width:44px;height:44px;
  border-radius:50%;
  border:2px solid rgba(95,4,255,.2);
  background:#fff;
  color:#5f04ff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:background .2s,border-color .2s,transform .2s;
  z-index:20;
  position:relative;
  box-shadow:0 2px 12px rgba(10,4,60,.08);
}
.brand-carousel__btn:hover{
  background:#5f04ff;
  border-color:#5f04ff;
  color:#fff;
  transform:scale(1.08);
}
.brand-carousel__btn--prev{ margin-right:12px; }
.brand-carousel__btn--next{ margin-left:12px; }

/* ─── Canal feature list (2 colonnes titre / desc) ─── */
.canal-feat-list{
  margin:0;padding:0;
  border-top:1px solid rgba(10,4,60,.08);
}
.canal-feat-row{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:24px;
  align-items:baseline;
  padding:18px 0;
  border-bottom:1px solid rgba(10,4,60,.08);
}
.canal-feat-row dt{
  font-size:18px;
  font-weight:800;
  color:#1a0a5e;
  line-height:1.4;
}
.canal-feat-row dd{
  margin:0;
  font-size:15px;
  color:rgba(10,4,60,.55);
  line-height:1.6;
}

/* ─── Canal sticky stack ─── */
.canal-stack{
  display:flex;
  flex-direction:column;
}
.canal-sticky-wrap{
  position:sticky;
  top:80px;
}
.canal-card-inner{
  background:#f3efff;
  border-radius:0;
  box-shadow:none;
  padding:72px 0;
  transform-origin:top center;
  will-change:transform,filter;
}

/* ─── Responsive ─── */
@media(max-width:980px){
  .hero-grid,.split{grid-template-columns:1fr}
  .section-home-prompt.split > .prose{order:1}
  .section-home-prompt.split > div:first-child{order:2;max-width:100% !important;margin:0 !important}
  .grid-3{grid-template-columns:1fr}
  .canal-block{grid-template-columns:1fr !important}
  .canal-block--reverse .canal-block__img{order:-1}
  .canal-card-inner .container{grid-template-columns:1fr !important}
  .canal-card-inner{padding:40px 0 !important}
  .grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-brand{grid-column:1/-1}
  .footer-links{justify-content:flex-start}
  .cta-band{flex-direction:column;align-items:flex-start}
  .footer-bottom{flex-direction:column;gap:12px;align-items:flex-start}
}
@media(max-width:600px){
  .section{padding:100px 0}
  .section + .section{margin-top:40px}
  .footer-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .kpi{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(prefers-reduced-motion:reduce){.btn{transition:none}.card{transition:none}}

/* ─── Brand Hub Carousel ─── */
.brand-carousel{
  position:relative;
  margin-top:48px;
}
.brand-carousel__slide{
  display:none;
  grid-template-columns:1.1fr .9fr;
  gap:0;
  border-radius:20px;
  overflow:hidden;
  border:1px solid rgba(95,4,255,.12);
  box-shadow:0 4px 32px rgba(95,4,255,.08);
  min-height:420px;
  animation:carousel-fade .5s ease;
}
.brand-carousel__slide--active{display:grid}
@keyframes carousel-fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.brand-carousel__img{
  overflow:hidden;
  background:#f3efff;
  display:flex;align-items:center;justify-content:center;
}
.brand-carousel__img img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.brand-carousel__img--placeholder{
  background:linear-gradient(135deg,#f0ecff,#e8e0ff);
}
.brand-carousel__content{
  padding:48px 44px;
  background:white;
  display:flex;flex-direction:column;justify-content:center;
}
.brand-carousel__num{
  font-size:12px;font-weight:700;letter-spacing:.1em;
  color:var(--orange);text-transform:uppercase;
  margin-bottom:16px;display:block;
}
.brand-carousel__content h3{
  font-family:var(--font-text);
  font-size:28px;font-weight:800;
  color:var(--text-on-light);
  margin:0 0 16px;
}
.brand-carousel__content p{
  font-size:16px;line-height:1.7;
  color:var(--muted-on-light);
  margin:0;
}
.brand-carousel__controls{
  display:flex;align-items:center;gap:16px;margin-top:24px;
}
.brand-carousel__arrow{
  flex-shrink:0;
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(95,4,255,.18);
  background:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:rgba(95,4,255,.5);
  transition:background .15s,color .15s,border-color .15s;
}
.brand-carousel__arrow:hover{
  background:rgba(95,4,255,.07);
  color:var(--purple);
  border-color:var(--purple);
}
.brand-carousel__progress-bar{
  flex:1;height:4px;border-radius:99px;
  background:rgba(95,4,255,.12);overflow:hidden;
}
.brand-carousel__progress-fill{
  height:100%;border-radius:99px;
  background:var(--purple);
  width:calc(100% / 5);
  transition:width .4s ease;
}
@media(max-width:768px){
  .brand-carousel__slide{grid-template-columns:1fr}
  .brand-carousel__item{flex-direction:column;flex:0 0 280px;width:280px}
  .brand-carousel__img{flex:none;width:100%;height:180px}
  .brand-carousel__content{padding:32px 24px}
}

/* ─── Brand Carousel controls (arrows + progress bar) ─── */
.brand-carousel__controls{
  display:flex;align-items:center;gap:16px;margin-top:24px;
}
.brand-carousel__arrow{
  flex-shrink:0;
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(95,4,255,.18);
  background:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:rgba(95,4,255,.5);
  transition:background .15s,color .15s,border-color .15s;
}
.brand-carousel__arrow:hover{
  background:rgba(95,4,255,.07);
  color:var(--purple);
  border-color:var(--purple);
}
.brand-carousel__progress-bar{
  flex:1;height:4px;border-radius:99px;
  background:rgba(95,4,255,.12);overflow:hidden;
}
.brand-carousel__progress-fill{
  height:100%;border-radius:99px;
  background:var(--purple);
  width:calc(100% / 5);
  transition:width .4s ease;
}

/* ─── Blog feed (homepage) ─── */
.blog-feed-grid{
  grid-template-columns:repeat(3,1fr);
}
.blog-card{
  display:flex;flex-direction:column;gap:12px;
  padding:32px;border-radius:16px;
  border:1px solid rgba(95,4,255,.10);
  background:#fff;
  text-decoration:none;color:inherit;
  transition:box-shadow .2s, transform .2s, border-color .2s;
}
.blog-card__media{
  margin:-32px -32px 8px;
  aspect-ratio:16/9;
  overflow:hidden;
  border-radius:16px 16px 0 0;
  background:#ede9ff;
}
.blog-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .25s ease;
}
.blog-card:hover{
  box-shadow:0 8px 32px rgba(95,4,255,.10);
  transform:translateY(-3px);
  border-color:rgba(95,4,255,.22);
}
.blog-card:hover .blog-card__media img{
  transform:scale(1.03);
}
.blog-card__cat{
  font-size:11px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--purple);
  opacity:.7;
}
.blog-card__title{
  font-size:clamp(16px,1.4vw,19px);font-weight:700;
  line-height:1.35;color:var(--dark);margin:0;
}
.blog-card__excerpt{
  font-size:14px;color:var(--muted-on-light);
  line-height:1.6;margin:0;flex:1;
}
.blog-card__link{
  font-size:13px;font-weight:700;color:var(--orange,#f47c20);
  margin-top:4px;
}
.blog-card:hover .blog-card__link{
  text-decoration:underline;
}
@media(max-width:860px){
  .blog-feed-grid{ grid-template-columns:1fr; }
}
@media(min-width:640px) and (max-width:860px){
  .blog-feed-grid{ grid-template-columns:repeat(2,1fr); }
}

/* ─── Section CTA démo (remplace cta-offer-card) ─── */
.demo-cta-block{
  display:flex;align-items:center;justify-content:space-between;
  gap:40px;flex-wrap:wrap;
  background:linear-gradient(135deg,rgba(95,4,255,.06) 0%,rgba(95,4,255,.02) 100%);
  border:1px solid rgba(95,4,255,.12);
  border-radius:20px;padding:56px 64px;
}
.demo-cta-block__text{ flex:1;min-width:260px; }
.demo-cta-block__action{ display:flex;flex-direction:column;align-items:center;text-align:center; }
@media(max-width:700px){
  .demo-cta-block{ padding:40px 28px;flex-direction:column;text-align:center; }
}

/* ─── Modal démo ─── */
.modal--demo{ grid-template-columns:260px minmax(0,1fr);max-width:820px; }
.modal--demo .modal__content-col,
.modal--demo .modal__form,
.modal--demo .modal__fields{
  min-width:0;
  max-width:100%;
}
.modal--demo .modal__fields > .field,
.modal--demo .modal__fields > .field--dark{
  min-width:0;
  max-width:100%;
}
.modal__form{ display:flex;flex-direction:column;gap:0; }
.modal__fields{ display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px; }
.field--dark label{
  display:block;font-size:12px;font-weight:600;
  color:rgba(255,255,255,.55);margin-bottom:6px;letter-spacing:.04em;
}
.field--dark input,.field--dark textarea{
  width:100%;max-width:100%;min-width:0;
  background:rgba(255,255,255,.07);
  border:none;border-radius:8px;
  color:#fff;font-size:14px;padding:10px 14px;
  transition:background .15s;box-sizing:border-box;
}
.field--dark input::placeholder{ color:rgba(255,255,255,.3); }
.field--dark input:focus{
  outline:none;
  background:rgba(255,255,255,.12);
}
@media(max-width:640px){
  .modal--demo{ grid-template-columns:1fr;max-width:min(460px, calc(100vw - 28px)); }
  .modal__fields{ grid-template-columns:1fr; }
  .modal--demo .modal__content-col{
    padding:28px 16px 22px;
  }
  .modal--demo .modal__plan{
    font-size:clamp(1.35rem, 5.4vw, 1.85rem);
    line-height:1.15;
    padding-right:2.5rem;
    overflow-wrap:anywhere;
    word-break:break-word;
  }
  .modal--demo .modal__close{
    top:10px;
    right:10px;
  }
  .modal--demo .modal__cta.btn,
  .modal--demo .modal__form button.modal__cta{
    width:100%;
    max-width:100%;
    box-sizing:border-box;
    white-space:normal;
    text-align:center;
    padding-left:14px;
    padding-right:14px;
    line-height:1.35;
  }
}

/* ─── Btn large ─── */
.btn--lg{ font-size:17px;padding:11px 36px; }

/* ─── Champs formulaire démo ─── */
.field__req{ color:#f47c20;margin-left:2px; }
.field--dark select{
  width:100%;max-width:100%;min-width:0;
  background:rgba(255,255,255,.07);
  border:none;border-radius:8px;
  color:#fff;font-size:14px;padding:10px 14px;
  transition:background .15s;box-sizing:border-box;
  appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,.5)' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
}
.field--dark select option{ background:#1a0a4a;color:#fff; }
.field--dark select:focus{
  outline:none;
  background-color:rgba(255,255,255,.12);
}

/* ─── Article layout avec sidebar sticky ─── */
.article-layout{
  display:grid;
  grid-template-columns:1fr 280px;
  gap:48px;
  align-items:start;
}
.article-sidebar{
  position:sticky;
  top:96px;
}
.article-sidebar__card{
  background:
    radial-gradient(circle at 20% 80%, rgba(255,255,255,.022) 1px, transparent 1px),
    radial-gradient(circle at 80% 20%, rgba(255,255,255,.022) 1px, transparent 1px),
    linear-gradient(135deg, rgba(10,4,60,.97) 0%, rgba(22,8,80,.95) 100%);
  background-size:24px 24px, 24px 24px, 100% 100%;
  border:1px solid rgba(95,4,255,.28);
  border-radius:20px;
  padding:32px 28px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.article-sidebar__eyebrow{
  font-size:11px;font-weight:700;letter-spacing:.07em;
  text-transform:uppercase;
  color:var(--orange,#f47c20);
  margin:0;
}
.article-sidebar__title{
  font-family:var(--font-title);
  font-size:clamp(24px,2vw,30px);line-height:1.15;
  color:#fff;margin:0;
}
.article-sidebar__body{
  font-size:14px;line-height:1.6;
  color:rgba(255,255,255,.62);
  margin:0;
}
.article-sidebar .btn--primary{
  font-size:13px;padding:12px 18px;
}
.article-sidebar__note{
  font-size:12px;color:rgba(255,255,255,.35);
  text-align:center;margin:0;
}
@media(max-width:960px){
  .article-layout{
    grid-template-columns:1fr;
  }
  .article-sidebar{
    position:static;
  }
  .article-sidebar__card{
    display:none;
  }
}

/* ─── Section démo inline (homepage) ─── */
.inline-demo-block{
  display:flex;
  flex-direction:column;
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 12px 60px rgba(95,4,255,.10);
  border:1px solid rgba(10,31,110,.08);
  max-width:860px;
  margin:0 auto;
}
.inline-demo-block__hero{
  position:relative;
  overflow:hidden;
  height:300px;
}
.inline-demo-block__hero img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 20%;
  display:block;
}
.inline-demo-block__img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,4,60,.78) 0%,rgba(10,4,60,.30) 55%,rgba(10,4,60,.12) 100%);
}
.inline-demo-block__hero-content{
  position:absolute;
  inset:auto 0 0 0;
  padding:32px 40px;
  text-align:center;
}
.inline-demo-block__form-col{
  padding:40px 80px 48px;
  background:#fff;
}
.inline-demo-form__fields{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.inline-demo-form__fields .field label{
  display:block;font-size:12px;font-weight:700;
  color:rgba(10,31,110,.55);margin-bottom:6px;letter-spacing:.04em;
}
.inline-demo-form__fields .field input,
.inline-demo-form__fields .field select{
  width:100%;background:#f6f5ff;
  border:none;border-radius:8px;
  color:var(--dark);font-size:14px;padding:10px 14px;
  transition:border-color .15s;box-sizing:border-box;
}
.inline-demo-form__fields .field input::placeholder{ color:rgba(10,31,110,.3); }
.inline-demo-form__fields .field input:focus,
.inline-demo-form__fields .field select:focus{
  outline:none;border-color:var(--purple);
  background:#fff;
}
.inline-demo-form__fields .field select{
  appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(95,4,255,.5)' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
  background-size:12px;
}
@media(max-width:620px){
  .inline-demo-block__hero{ height:220px; }
  .inline-demo-block__hero-content{ padding:24px; }
  .inline-demo-block__form-col{ padding:28px 24px 36px; }
  .inline-demo-form__fields{ grid-template-columns:1fr; }
}

/* ─── Article hero centré (page blog index) ─── */
.article-hero__content--center{
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:60px 36px;
}
.article-hero__content--center h1{
  max-width:800px;
  font-size:clamp(36px,5vw,64px);
}

/* ─── Cartes blog avec image + titre overlay ─── */
.blog-card-hero{
  display:flex;
  flex-direction:column;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(10,31,110,.08);
  text-decoration:none;
  color:inherit;
  background:#fff;
  transition:box-shadow .2s, transform .2s;
}
.blog-card-hero:hover{
  box-shadow:0 10px 40px rgba(95,4,255,.12);
  transform:translateY(-3px);
}
.blog-card-hero__media{
  position:relative;
  aspect-ratio:16/9;
  overflow:hidden;
}
.blog-card-hero__media img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform .4s ease;
}
.blog-card-hero:hover .blog-card-hero__media img{
  transform:scale(1.04);
}
.blog-card-hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(10,4,60,.92) 0%, rgba(10,4,60,.55) 50%, rgba(10,4,60,.25) 100%);
}
.blog-card-hero__title{
  position:absolute;
  inset:0 0 auto 0;
  padding:20px 22px;
}
.blog-card-hero__title h3{
  margin:0;
  color:#fff;
  font-size:clamp(22px,3vw,32px);
  line-height:1.2;
  font-family:var(--font-title);
}
.blog-card-hero__desc{
  font-size:16px;
  color:var(--muted-on-light);
  padding:16px 22px 6px;
  margin:0;
  line-height:1.7;
}
.blog-card-hero__footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:10px 22px 20px;
}
.blog-card-hero__link{
  font-size:13px;
  font-weight:700;
  color:var(--orange);
  white-space:nowrap;
}
.blog-card-hero__meta{
  font-size:12px;
  color:rgba(10,31,110,.5);
  margin:0;
  letter-spacing:.02em;
}
.blog-card-hero:hover .blog-card-hero__link{
  text-decoration:underline;
}

/* ── Bandeau contrôle avant IA ── */
.section--control-banner{
  padding:120px 0;
  background:linear-gradient(135deg,#0a043c 0%,#160850 100%);
  text-align:left;
}
.section--control-banner::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(10,4,60,.82) 0%,rgba(22,8,80,.76) 100%);
  z-index:0;
}
.section--control-banner .container{
  position:relative;z-index:1;
}
.control-banner__text{
  font-family:var(--font-title);
  font-size:clamp(28px,4.5vw,58px);
  line-height:1.25;
  color:#fff;
  margin:0;
  letter-spacing:-.01em;
}
.control-banner__text em{
  font-style:normal;
  color:#fff;
  -webkit-text-fill-color:#fff;
}
.control-banner__item{
  color:#fff;
  font-style:normal;
  -webkit-text-fill-color:#fff;
}
.control-banner__item:last-child{
  color:#fff;
  -webkit-text-fill-color:#fff;
  background:none;
}
.control-banner__sep{
  color:rgba(255,255,255,.25);
  margin:0 12px;
  font-size:.7em;
  vertical-align:middle;
}

/* ── Du temps gagné (section standalone home) ── */
.tg-wrap{
  overflow-x:auto;
  border-radius:20px;
  box-shadow:0 8px 40px rgba(95,4,255,.08);
}
.tg-table{
  width:100%;
  border-collapse:collapse;
  font-size:15.5px;
  min-width:560px;
}
.tg-table thead tr{
  background:var(--primary);
  color:#fff;
}
.tg-table th{
  padding:16px 20px;
  font-size:13px;
  font-weight:700;
  text-align:center;
  line-height:1.4;
  white-space:nowrap;
}
.tg-table__th-action{text-align:left;border-radius:20px 0 0 0}
.tg-table__th-gain{background:var(--purple);border-radius:0 20px 0 0}
.tg-table tbody tr{
  border-bottom:1.5px solid #f1f5f9;
  background:#fff;
  transition:background .15s;
}
.tg-table tbody tr:hover{background:#faf8ff}
.tg-table td{
  padding:16px 20px;
  text-align:center;
  vertical-align:middle;
}
.tg-table__action{
  text-align:left;
  font-weight:700;
  color:var(--dark);
  font-size:15px;
  white-space:nowrap;
}
.tg-table__action span{margin-right:8px}
.tg-table__sans{
  color:#94a3b8;
  text-decoration:line-through;
  font-size:14px;
}
.tg-table__avec{
  color:#16a34a;
  font-weight:800;
  font-size:15px;
}
.tg-table__eco{
  font-size:14px;
  color:#475569;
}
.gain-bar-cell{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:5px;
  min-width:72px;
}
.gain-bar-cell--sm{min-width:60px}
.gain-bar-cell__num{
  font-weight:900;
  font-size:14px;
  background:linear-gradient(90deg,var(--purple),#b48fff);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  white-space:nowrap;
  line-height:1;
}
.gain-bar-cell__num--big{
  font-size:20px;
}
.gain-bar-cell--sm .gain-bar-cell__num{font-size:12px}
.gain-bar-cell__track{
  width:100%;
  height:7px;
  background:#ede8ff;
  border-radius:99px;
  overflow:hidden;
}
.gain-bar-cell--sm .gain-bar-cell__track{height:5px}
.gain-bar-cell__fill{
  height:100%;
  border-radius:99px;
  background:linear-gradient(90deg,var(--purple),#b48fff);
  transition:width .4s ease;
}
.tg-table tfoot tr{
  background:linear-gradient(90deg,#f3efff,#ede8ff);
  border-top:2px solid #ede8ff;
}
.tg-table tfoot td{
  font-weight:700;
  padding:18px 20px;
}
.tg-table__foot-label{
  text-align:left;
  color:var(--dark);
  font-size:14px;
  font-weight:700;
}

/* ── DISC / Réassurance ── */
:root{
  --disc-d:#dc2626;
  --disc-i:#d97706;
  --disc-s:#16a34a;
  --disc-c:#2563eb;
}

.disc-tabs{
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
  margin-top:4px;
}
.disc-tab{
  display:flex;
  align-items:center;
  gap:8px;
  padding:9px 20px;
  border-radius:50px;
  border:2px solid #e5e7eb;
  background:#f8fafc;
  cursor:pointer;
  font-family:var(--font-text);
  font-size:14px;
  font-weight:700;
  color:#64748b;
  transition:all .2s;
}
.disc-tab:hover{
  border-color:#cbd5e1;
  background:#fff;
  color:var(--dark);
}
.disc-tab__letter{
  width:28px;
  height:28px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:13px;
  color:#fff;
  flex-shrink:0;
}
.disc-tab--d .disc-tab__letter{background:var(--disc-d)}
.disc-tab--i .disc-tab__letter{background:var(--disc-i)}
.disc-tab--s .disc-tab__letter{background:var(--disc-s)}
.disc-tab--c .disc-tab__letter{background:var(--disc-c)}

.disc-tab--d.is-active{border-color:var(--disc-d);background:#fff;color:var(--disc-d);box-shadow:0 4px 16px rgba(220,38,38,.12)}
.disc-tab--i.is-active{border-color:var(--disc-i);background:#fff;color:var(--disc-i);box-shadow:0 4px 16px rgba(217,119,6,.12)}
.disc-tab--s.is-active{border-color:var(--disc-s);background:#fff;color:var(--disc-s);box-shadow:0 4px 16px rgba(22,163,74,.12)}
.disc-tab--c.is-active{border-color:var(--disc-c);background:#fff;color:var(--disc-c);box-shadow:0 4px 16px rgba(37,99,235,.12)}

.disc-tagline-wrap{
  min-height:72px;
  text-align:center;
  margin-bottom:40px;
}
.disc-tagline-item{
  animation:discIn .25s ease;
}
.disc-tagline-item__quote{
  font-size:17px;
  font-style:italic;
  color:var(--dark);
  margin:0 0 6px;
  font-weight:600;
}
.disc-tagline-item__sub{
  font-size:15px;
  color:#64748b;
  margin:0;
}
@keyframes discIn{
  from{opacity:0;transform:translateY(6px)}
  to{opacity:1;transform:translateY(0)}
}

.reassurance-blocks{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  align-items:start;
}
.reassurance-block{
  background:#fff;
  border-radius:20px;
  border:2px solid #ede8ff;
  padding:28px 24px 24px;
  box-shadow:0 4px 20px rgba(95,4,255,.05);
  position:relative;
  transition:border-color .3s,box-shadow .3s,transform .3s;
  overflow:hidden;
}
.reassurance-block__badge{
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:#ede8ff;
  border-radius:20px 20px 0 0;
  transition:background .3s;
}
.reassurance-block.is-featured{
  border-color:transparent;
  box-shadow:0 8px 40px rgba(95,4,255,.14);
  transform:translateY(-4px);
  z-index:1;
}
.reassurance-block.is-featured-d .reassurance-block__badge{background:var(--disc-d)}
.reassurance-block.is-featured-i .reassurance-block__badge{background:var(--disc-i)}
.reassurance-block.is-featured-s .reassurance-block__badge{background:var(--disc-s)}
.reassurance-block.is-featured-c .reassurance-block__badge{background:var(--disc-c)}
.reassurance-block.is-featured-d{border-color:var(--disc-d);box-shadow:0 8px 40px rgba(220,38,38,.12)}
.reassurance-block.is-featured-i{border-color:var(--disc-i);box-shadow:0 8px 40px rgba(217,119,6,.12)}
.reassurance-block.is-featured-s{border-color:var(--disc-s);box-shadow:0 8px 40px rgba(22,163,74,.12)}
.reassurance-block.is-featured-c{border-color:var(--disc-c);box-shadow:0 8px 40px rgba(37,99,235,.12)}

.reassurance-block__header{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:20px;
}
.reassurance-block__icon{
  width:40px;height:40px;
  border-radius:12px;
  background:#f3efff;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  color:var(--purple);
  transition:background .3s,color .3s;
}
.reassurance-block.is-featured .reassurance-block__icon{
  background:var(--purple);
  color:#fff;
}
.reassurance-block__title{
  font-size:15px;
  font-weight:800;
  color:var(--dark);
  margin:0;
  line-height:1.35;
}

/* Time table */
.time-table-wrap{overflow-x:auto}
.time-table{
  width:100%;
  border-collapse:collapse;
  font-size:13px;
}
.time-table th{
  background:var(--primary);
  color:#fff;
  padding:8px 10px;
  text-align:center;
  font-size:12px;
  font-weight:700;
  white-space:nowrap;
}
.time-table th:first-child{text-align:left;border-radius:8px 0 0 8px}
.time-table th:last-child{border-radius:0 8px 8px 0}
.time-table .time-table__th-gain{background:var(--purple)}
.time-table td{
  padding:8px 10px;
  border-bottom:1px solid #f1f5f9;
  text-align:center;
  vertical-align:middle;
}
.time-table td:first-child{text-align:left;font-weight:700;white-space:nowrap}
.time-table tr:last-child td{border-bottom:none}
.time-table__icon{margin-right:5px}
.time-table__sans{color:#94a3b8;text-decoration:line-through}
.time-table__avec{color:#16a34a;font-weight:700}
/* .time-table__gain remplacé par .gain-bar-cell */

/* Avant / Après / Impact */
.transition-cols{
  display:grid;
  grid-template-columns:1fr auto 1fr auto 1fr;
  gap:8px;
  align-items:start;
}
.transition-arrow{
  color:#cbd5e1;
  font-size:20px;
  padding-top:36px;
  align-self:start;
}
.transition-col__label{
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  color:#fff;
  background:var(--primary);
  border-radius:8px;
  padding:5px 8px;
  margin-bottom:10px;
  text-align:center;
}
.transition-col--apres .transition-col__label{background:var(--purple)}
.transition-col--impact .transition-col__label{
  background:linear-gradient(135deg,var(--purple),var(--pink));
}
.transition-col ul{
  margin:0;
  padding:0 0 0 14px;
  font-size:13px;
  color:#475569;
  line-height:1.7;
}

/* 3 étapes transition */
.transition-steps{
  display:grid;
  grid-template-columns:1fr auto 1fr auto 1fr;
  gap:8px;
  align-items:start;
}
.transition-step__connector{
  color:#cbd5e1;
  font-size:20px;
  padding-top:16px;
}
.transition-step__num{
  display:inline-block;
  background:var(--pink);
  color:#fff;
  font-size:11px;
  font-weight:900;
  border-radius:20px;
  padding:3px 10px;
  margin-bottom:8px;
}
.transition-step__title{
  font-size:14px;
  font-weight:800;
  color:var(--dark);
  margin:0 0 8px;
}
.transition-step ul{
  margin:0;
  padding:0 0 0 14px;
  font-size:12.5px;
  color:#475569;
  line-height:1.7;
}
.transition-step__tagline{
  margin-top:10px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.06em;
  color:#94a3b8;
}

@media(max-width:900px){
  .reassurance-blocks{grid-template-columns:1fr}
  .reassurance-block.is-featured{transform:none}
  .transition-cols,.transition-steps{grid-template-columns:1fr;gap:4px}
  .transition-arrow,.transition-step__connector{display:none}
}

/* ── Transition sans risque (section standalone) ── */
.transition-steps-full{
  display:grid;
  grid-template-columns:1fr auto 1fr auto 1fr;
  gap:0 24px;
  align-items:center;
  max-width:900px;
  margin:0 auto;
}
.tsf-connector{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.tsf-step{
  background:#fff;
  border-radius:20px;
  border:2px solid #ede8ff;
  padding:32px 28px;
  box-shadow:0 4px 20px rgba(95,4,255,.06);
  display:flex;
  flex-direction:column;
  gap:16px;
  height:100%;
}
.tsf-step--highlight{
  border-color:var(--purple);
  box-shadow:0 8px 36px rgba(95,4,255,.13);
  transform:translateY(-4px);
}
.tsf-step__num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;height:40px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--purple),var(--pink));
  color:#fff;
  font-size:14px;
  font-weight:900;
  flex-shrink:0;
}
.tsf-step--highlight .tsf-step__num{
  background:linear-gradient(135deg,var(--pink),var(--purple));
}
.tsf-step__title{
  font-size:20px;
  font-weight:800;
  color:var(--dark);
  margin:0;
}
.tsf-step__body ul{
  margin:0;
  padding:0 0 0 18px;
  color:#475569;
  font-size:15px;
  line-height:1.8;
}
.tsf-step__tagline{
  font-size:11px;
  font-weight:900;
  letter-spacing:.1em;
  color:var(--purple);
  margin-top:auto;
}
.tsf-step--highlight .tsf-step__tagline{color:var(--pink)}

@media(max-width:860px){
  .transition-steps-full{
    grid-template-columns:1fr;
    max-width:480px;
  }
  .tsf-connector{transform:rotate(90deg);margin:8px auto}
  .tsf-step--highlight{transform:none}
}

/* ── Marketing manuel → autonome (section standalone) ── */
.mma-grid{
  display:grid;
  grid-template-columns:1fr auto 1fr auto 1fr;
  gap:0 28px;
  align-items:center;
  max-width:1000px;
  margin:0 auto;
}
.mma-arrows{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  opacity:.7;
}
.mma-col{
  background:#fff;
  border-radius:20px;
  padding:32px 28px;
  border:2px solid #ede8ff;
  box-shadow:0 4px 20px rgba(95,4,255,.05);
  height:100%;
}
.mma-col__label{
  display:inline-flex;
  align-items:center;
  gap:7px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.1em;
  border-radius:8px;
  padding:5px 12px;
  margin-bottom:20px;
}
.mma-col--avant .mma-col__label{
  background:#fee2e2;
  color:#dc2626;
}
.mma-col--apres .mma-col__label{
  background:#ede8ff;
  color:var(--purple);
}
.mma-col--apres{
  border-color:var(--purple);
  box-shadow:0 8px 36px rgba(95,4,255,.12);
  transform:translateY(-4px);
}
.mma-col--impact .mma-col__label{
  background:linear-gradient(135deg,#5f04ff,#b48fff);
  color:#fff;
}
.mma-col--impact{
  border-color:#b48fff;
  box-shadow:0 8px 36px rgba(140,80,255,.15);
}
.mma-col__list{
  margin:0;
  padding:0 0 0 18px;
  font-size:15px;
  color:#475569;
  line-height:1.9;
}
.mma-col__list li::marker{color:var(--purple)}
.mma-col--avant .mma-col__list li::marker{color:#dc2626}
.mma-col--impact .mma-col__list li::marker{color:#7c3aed}

@media(max-width:860px){
  .mma-grid{
    grid-template-columns:1fr;
    max-width:480px;
    margin:0 auto;
    gap:8px;
  }
  .mma-arrows{transform:rotate(90deg);margin:4px auto}
  .mma-col--apres{transform:none}
}

/* ── FAQ ── */
.faq-list{
  display:flex;
  flex-direction:column;
  gap:0;
}
.faq-item{
  border-bottom:1.5px solid #ede8ff;
}
.faq-item:first-child{
  border-top:1.5px solid #ede8ff;
}
.faq-item__question{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:20px 4px;
  font-size:17px;
  font-weight:700;
  color:var(--dark);
  cursor:pointer;
  list-style:none;
  user-select:none;
}
.faq-item__question::-webkit-details-marker{display:none}
.faq-item__icon{
  flex-shrink:0;
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--purple);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .2s,transform .3s;
}
.faq-item__icon::before{
  content:'';
  display:block;
  width:12px;
  height:2px;
  background:#fff;
  border-radius:2px;
  position:relative;
}
.faq-item__icon::after{
  content:'';
  display:block;
  width:2px;
  height:12px;
  background:#fff;
  border-radius:2px;
  position:absolute;
  transition:transform .3s,opacity .3s;
}
.faq-item[open] .faq-item__icon{
  background:var(--orange);
  transform:rotate(45deg);
}
.faq-item__answer{
  padding:0 4px 22px;
  color:#4a5568;
  font-size:15.5px;
  line-height:1.7;
  animation:faqIn .22s ease;
}
.faq-item__answer p{margin:0}
@keyframes faqIn{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:translateY(0)}
}

/* ─── Responsive : accueil, contact, fonctionnalités (mobile) ─── */
.hero-home-grid > *{
  min-width:0;
}
.split > div:has(.chat-sim){
  min-width:0;
}

@media(max-width:900px){
  .hero-home-grid{
    grid-template-columns:1fr !important;
    gap:32px !important;
    padding-top:48px !important;
    padding-bottom:56px !important;
  }
  .home-omni-split{
    grid-template-columns:1fr !important;
    gap:32px !important;
  }
  .home-omni-split .omni-row--shift{
    margin-left:0 !important;
    margin-right:0 !important;
  }
  .home-secteurs-grid{
    grid-template-columns:repeat(2,1fr) !important;
    gap:14px !important;
  }
  .contact-split-layout{
    grid-template-columns:1fr !important;
    gap:40px !important;
  }
  .contact-brands-grid{
    grid-template-columns:1fr !important;
    gap:20px !important;
  }
  .fonc-omni-message-grid{
    grid-template-columns:1fr !important;
  }
  .fonc-omni-message-grid > div:first-child{
    display:none !important;
  }
  .fonc-omni-message-grid > div:last-child{
    padding:40px 24px !important;
  }
  #profils-grid{
    grid-template-columns:repeat(2,1fr) !important;
    gap:12px !important;
  }
}

@media(max-width:900px){
  .omni-tabs__nav .omni-tabs__cta-demo{display:none !important}
  .omni-tabs__nav{
    flex-direction:row !important;
    flex-wrap:nowrap !important;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    gap:6px !important;
    padding:10px 8px !important;
    border-right:none !important;
    border-bottom:1px solid rgba(95,4,255,.12);
    flex:0 0 auto !important;
    max-width:100%;
  }
  .omni-tab-btn{
    flex:0 0 auto;
    justify-content:center;
    padding:10px 12px !important;
    min-width:48px;
  }
  .omni-tab-btn__label{
    position:absolute;
    width:1px;
    height:1px;
    padding:0;
    margin:-1px;
    overflow:hidden;
    clip:rect(0,0,0,0);
    white-space:nowrap;
    border:0;
  }
  .omni-tab-btn{position:relative}
  .omni-tabs{flex-direction:column}
  .omni-tab-panel--active{
    flex-direction:column !important;
    height:auto !important;
    min-height:0 !important;
  }
  .omni-tab-panel__img{
    order:0 !important;
    flex:none !important;
    max-width:100% !important;
    height:200px !important;
  }
  .omni-tab-panel__body{
    order:1 !important;
    padding:24px 20px 32px !important;
  }
}

@media(max-width:767px){
  #brandCarousel .brand-carousel__btn{display:none !important}
  #brandCarousel .brand-carousel{
    padding-left:0;
    padding-right:0;
    gap:0;
  }
  #brandCarousel .brand-carousel__viewport{
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scroll-padding-inline:16px;
    padding-top:16px;
    padding-bottom:16px;
    margin:0;
  }
  #brandCarousel .brand-carousel__track{
    transform:none !important;
    transition:none !important;
    gap:16px;
    padding:0 16px 12px;
    align-items:stretch;
  }
  #brandCarousel .brand-carousel__item{
    flex:0 0 min(88vw,380px) !important;
    width:min(88vw,380px) !important;
    height:auto !important;
    min-height:0 !important;
    flex-direction:column !important;
    transform:none !important;
    opacity:1 !important;
    scroll-snap-align:center;
    cursor:default;
  }
  #brandCarousel .brand-carousel__img{
    flex:none !important;
    width:100% !important;
    height:200px !important;
  }
  #brandCarousel .brand-carousel__body{
    flex:1 1 auto !important;
    width:100% !important;
    max-width:none !important;
  }
}
