#xsHomeFinal{ isolation:isolate; }

/* =========================
   A11Y / petits utilitaires (page)
   ========================= */
#xsHomeFinal .xs-srOnly{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}

/* =========================
   HERO
   - Parallax vidéo via --xs-parallax-y (index.js)
   - Parallax panneau texte via --xs-panel-y / --xs-panel-o (index.js)
   ========================= */
#xsHomeFinal .xs-hero{
  position:relative;
  min-height:calc(100dvh - var(--xs-header-h, 0px));
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  background:var(--xs-ink);
  overflow:hidden;
  isolation:isolate;
}

#xsHomeFinal .xs-heroVideo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  filter:brightness(.88) contrast(1.10) saturate(1.03);
  opacity:1;
  transform:translate3d(0, var(--xs-parallax-y, 0px), 0) scale(1.08);
  will-change:transform;
}

@media (prefers-reduced-motion: reduce){
  #xsHomeFinal .xs-heroVideo{ transform:none !important; }
}

#xsHomeFinal .xs-hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    radial-gradient(1400px 900px at 50% 55%,
      rgba(255,255,255,.06) 0%,
      rgba(11,18,24,.26) 55%,
      rgba(11,18,24,.56) 100%
    ),
    linear-gradient(180deg,
      rgba(11,18,24,.40) 0%,
      rgba(11,18,24,.30) 45%,
      rgba(11,18,24,.58) 100%
    );
}

#xsHomeFinal .xs-hero::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    radial-gradient(900px 520px at 18% 28%, rgba(255,90,60,.10), transparent 70%),
    radial-gradient(900px 620px at 78% 62%, rgba(127,164,184,.10), transparent 70%);
}

#xsHomeFinal .xs-hero .xs-container{
  position:relative;
  z-index:2;
  width:100%;
  max-width:1400px;
  padding:20px var(--xs-pad);
  display:flex;
  justify-content:center;
}

#xsHomeFinal .xs-heroPanel{
  width:min(980px, 100%);
  border-radius:var(--xs-r-lg);
  background:rgba(11,18,24,.34);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 28px 90px rgba(0,0,0,.32);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  padding:40px 28px 26px;
  transform:translate3d(0, var(--xs-panel-y, 0px), 0);
  opacity:var(--xs-panel-o, 1);
  will-change:transform, opacity;
}

@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  #xsHomeFinal .xs-heroPanel{ background:rgba(11,18,24,.44); }
}

@media (prefers-reduced-motion: reduce){
  #xsHomeFinal .xs-heroPanel{
    transform:none !important;
    opacity:1 !important;
  }
}

#xsHomeFinal .xs-heroPanel--centerTitle{ text-align:center; }
#xsHomeFinal .xs-heroPanel--centerTitle .xs-h2,
#xsHomeFinal .xs-heroPanel--centerTitle .xs-lead{
  margin-left:auto;
  margin-right:auto;
}

#xsHomeFinal .xs-kicker{
  margin:0 0 12px;
  color:rgba(255,255,255,.92);
  font-weight:900;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-size:12px;
}

#xsHomeFinal .xs-h1{
  margin:0 0 10px;
  font-weight:900;
  color:#fff;
  font-size:clamp(34px, 4.8vw, 66px);
  line-height:1.02;
  letter-spacing:-0.02em;
  text-shadow:0 16px 46px rgba(0,0,0,.20);
}

#xsHomeFinal .xs-h2{
  margin:0 0 14px;
  font-weight:900;
  color:rgba(255,255,255,.92);
  font-size:clamp(16px, 1.6vw, 22px);
  line-height:1.35;
  letter-spacing:-0.01em;
  max-width:820px;
}

#xsHomeFinal .xs-lead{
  margin:0;
  font-size:16.8px;
  line-height:1.7;
  color:rgba(255,255,255,.90);
  max-width:860px;
}

/* Repères hero */
#xsHomeFinal .xs-heroProof{
  margin-top:18px;
  padding-top:14px;
  position:relative;
}
#xsHomeFinal .xs-heroProof::before{
  content:"";
  position:absolute;
  left:0; right:0;
  top:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
}
#xsHomeFinal .xs-heroFacts{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px 14px;
  text-align:left;
}
#xsHomeFinal .xs-heroFacts li{
  padding:10px 12px;
  border-radius:14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10);
  color:rgba(255,255,255,.88);
  font-size:13.5px;
  line-height:1.45;
}
#xsHomeFinal .xs-heroFacts strong{ color:#fff; font-weight:900; }

@media (max-width:900px){
  #xsHomeFinal .xs-heroFacts{ grid-template-columns:1fr; }
}

#xsHomeFinal .xs-heroFade{
  position:absolute;
  left:0; right:0;
  bottom:-1px;
  height:150px;
  background:linear-gradient(180deg, transparent, var(--xs-white) 92%);
  z-index:2;
  pointer-events:none;
}

@media (max-width:900px){
  #xsHomeFinal .xs-hero{
    min-height:auto;
    padding:100px 0 70px;
  }
  #xsHomeFinal .xs-heroPanel{
    padding:32px 20px 22px;
    border-radius:20px;
    margin:0 10px;
  }
}

/* =========================
   TOKENS (page)
   ========================= */
#xsHomeFinal{
  --xh-card-r:18px;
  --xh-border:rgba(31,42,50,.14);
  --xh-shadow:0 18px 45px rgba(9,15,22,.10);
  --xh-shadowHover:0 26px 70px rgba(9,15,22,.14);
  --xh-blur:12px;

  --xh-glass-a:rgba(255,255,255,.88);
  --xh-glass-b:rgba(255,255,255,.72);
  --xh-glass-c:rgba(255,255,255,.64);

  --xh-accent:#ff5a3c;
  --xh-accentGlow:rgba(255,90,60,.28);
}

/* =========================
   Sections (base)
   ========================= */
#xsHomeFinal .xs-sec{
  padding:74px 0;
  background:var(--xs-white);
  position:relative;
}

#xsHomeFinal .xs-sec + .xs-sec::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(31,42,50,.10), transparent);
}

#xsHomeFinal .xs-secTitle{
  margin:0 0 10px;
  color:var(--xs-deep);
  font-size:28px;
  line-height:1.2;
  font-weight:900;
  letter-spacing:-0.01em;
  position:relative;
  padding-left:14px;
}

#xsHomeFinal .xs-secTitle::before{
  content:"";
  position:absolute;
  left:0;
  top:.26em;
  width:4px;
  height:1.05em;
  border-radius:3px;
  background:rgba(255,90,60,.85);
}

#xsHomeFinal .xs-secLead{
  margin:0 0 26px;
  color:rgba(31,42,50,.84);
  font-size:16.5px;
  line-height:1.75;
  max-width:980px;
}

/* =========================
   GRILLES
   ========================= */
#xsHomeFinal .xs-grid3{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:18px;
  align-items:stretch;
}
#xsHomeFinal .xs-grid3 > *{ height:100%; }

#xsHomeFinal .xs-grid6{
  display:grid;
  grid-template-columns:repeat(3, minmax(280px, 1fr));
  gap:18px;
  align-items:stretch;
}
#xsHomeFinal .xs-grid6 > *{ height:100%; }

@media (max-width:1100px){
  #xsHomeFinal .xs-grid6{ grid-template-columns:repeat(2, minmax(260px, 1fr)); }
}
@media (max-width:740px){
  #xsHomeFinal .xs-grid6{ grid-template-columns:1fr; }
}

/* =========================
   CARTES (base)
   ========================= */
#xsHomeFinal .xs-card{
  position:relative;
  overflow:hidden;
  border-radius:var(--xh-card-r);
  height:100%;
  display:flex;
  flex-direction:column;
  min-height:300px;

  background:linear-gradient(180deg, var(--xh-glass-a) 0%, var(--xh-glass-b) 55%, var(--xh-glass-c) 100%);
  border:1px solid var(--xh-border);

  box-shadow:
    var(--xh-shadow),
    inset 0 1px 0 rgba(255,255,255,.70),
    inset 0 -1px 0 rgba(31,42,50,.06);

  backdrop-filter:blur(var(--xh-blur));
  -webkit-backdrop-filter:blur(var(--xh-blur));

  transition:transform .22s ease, box-shadow .22s ease, filter .22s ease;
}

@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  #xsHomeFinal .xs-card{ background:rgba(255,255,255,.94); }
}

#xsHomeFinal .xs-card::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(720px 280px at 18% 10%, rgba(255,255,255,.62), transparent 60%),
    radial-gradient(760px 360px at 82% 88%, rgba(127,164,184,.14), transparent 65%);
  opacity:.95;
}

#xsHomeFinal .xs-card::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:inherit;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.28),
    inset 0 12px 22px rgba(255,255,255,.10),
    inset 0 -18px 26px rgba(0,0,0,.05);
  opacity:.95;
}

@media (hover:hover) and (pointer:fine){
  #xsHomeFinal .xs-card:hover{
    transform:translateY(-4px);
    box-shadow:
      var(--xh-shadowHover),
      inset 0 1px 0 rgba(255,255,255,.76),
      inset 0 -1px 0 rgba(31,42,50,.08);
    filter:brightness(1.02);
  }
}

#xsHomeFinal .xs-cardBody{
  position:relative;
  padding:16px 16px 16px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

#xsHomeFinal .xs-cardMeta{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:900;
  font-size:12px;
  color:rgba(31,42,50,.70);
  letter-spacing:.02em;
}

#xsHomeFinal .xs-pill{
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(31,42,50,.12);
  box-shadow:0 10px 22px rgba(9,15,22,.06);
}

#xsHomeFinal .xs-dot{ opacity:.55; }
#xsHomeFinal .xs-mini{ opacity:.85; }

#xsHomeFinal .xs-card h3{
  margin:0;
  font-size:16px;
  font-weight:900;
  color:var(--xs-deep);
}

#xsHomeFinal .xs-card p{
  margin:0;
  color:rgba(31,42,50,.82);
  font-size:15.5px;
  line-height:1.7;
}

/* clamp sur grid6 (homogénéité) */
#xsHomeFinal .xs-grid6 .xs-card p{
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:4;
  overflow:hidden;
}

/* cartes liens */
#xsHomeFinal a.xs-card{
  text-decoration:none;
  color:inherit;
}
#xsHomeFinal a.xs-card:focus-visible{
  outline:2px solid var(--xs-focus);
  outline-offset:3px;
}

/* =========================
   ACCENT ORANGE (base)
   ========================= */
#xsHomeFinal .route-card.route-card--main,
#xsHomeFinal .xs-card--accent{
  background:linear-gradient(180deg, rgba(255,105,78,.98) 0%, rgba(255,90,60,.96) 55%, rgba(240,74,48,.96) 100%);
  border:1px solid rgba(255,90,60,.98);
  color:#fff;
  box-shadow:
    0 26px 70px var(--xh-accentGlow),
    inset 0 1px 0 rgba(255,255,255,.35),
    inset 0 -1px 0 rgba(0,0,0,.10);
}

#xsHomeFinal .route-card.route-card--main::before,
#xsHomeFinal .xs-card--accent::before{ opacity:.25; }

#xsHomeFinal .route-card.route-card--main h3,
#xsHomeFinal .route-card.route-card--main p,
#xsHomeFinal .xs-card--accent h3,
#xsHomeFinal .xs-card--accent p{ color:#fff; }

#xsHomeFinal .route-card.route-card--main .xs-cardMeta,
#xsHomeFinal .xs-card--accent .xs-cardMeta{ color:rgba(255,255,255,.86); }

#xsHomeFinal .route-card.route-card--main .xs-pill,
#xsHomeFinal .xs-card--accent .xs-pill{
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  box-shadow:none;
}

/* Empilement colonne 3 (desktop) */
#xsHomeFinal .xs-grid6 .xs-accentTop{ grid-column:3; grid-row:1; }
#xsHomeFinal .xs-grid6 .xs-accentBottom{ grid-column:3; grid-row:2; }
@media (max-width:1100px){
  #xsHomeFinal .xs-grid6 .xs-accentTop,
  #xsHomeFinal .xs-grid6 .xs-accentBottom{ grid-column:auto; grid-row:auto; }
}

/* =========================================================
   SECTION 6 CARTES (juste après le HERO) — VERSION CORRIGÉE
   Objectif :
   - Fond AION plus visible (overlay moins sombre + contraste)
   - Cartes plus transparentes (vrai glass), sans voile gris
   - Lisibilité texte parfaite
   ========================================================= */
#xsHomeFinal .xs-hero + .xs-sec{
  /* on laisse respirer l'image : overlay plus léger */
  background:
    linear-gradient(180deg, rgba(7,10,14,.42) 0%, rgba(7,10,14,.26) 55%, rgba(7,10,14,.38) 100%),
    url("/medias/aion.png");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  position:relative;
  overflow:hidden;
}

/* vignette + punch du fond (sans l’éteindre) */
#xsHomeFinal .xs-hero + .xs-sec::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(1100px 640px at 50% 30%, rgba(255,255,255,.14), transparent 62%),
    radial-gradient(900px 700px at 76% 72%, rgba(255,90,60,.10), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.22));
}

/* grain ultra léger (option premium) */
#xsHomeFinal .xs-hero + .xs-sec::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
  background-image:radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:4px 4px;
  opacity:.12;
}

#xsHomeFinal .xs-hero + .xs-sec .xs-container{
  position:relative;
  z-index:1;
}

/* titres en clair */
#xsHomeFinal .xs-hero + .xs-sec .xs-secTitle{ color:#fff; }
#xsHomeFinal .xs-hero + .xs-sec .xs-secTitle::before{ background:rgba(255,90,60,.92); }
#xsHomeFinal .xs-hero + .xs-sec .xs-secLead{ color:rgba(255,255,255,.86); }

/* ---- CARTES : vrai glass (plus transparent + blur), sans voile gris ---- */
#xsHomeFinal .xs-hero + .xs-sec .xs-card{
  background:rgba(255,255,255,.08);                /* plus transparent */
  border:1px solid rgba(255,255,255,.20);
  box-shadow:
    0 18px 55px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.10);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}

/* IMPORTANT : on coupe les reflets/voiles internes qui ternissent tout */
#xsHomeFinal .xs-hero + .xs-sec .xs-card::before,
#xsHomeFinal .xs-hero + .xs-sec .xs-card::after{
  opacity:0 !important;
}

/* typo sur fond sombre */
#xsHomeFinal .xs-hero + .xs-sec .xs-card h3{ color:#fff; }
#xsHomeFinal .xs-hero + .xs-sec .xs-card p{ color:rgba(255,255,255,.84); }
#xsHomeFinal .xs-hero + .xs-sec .xs-cardMeta{ color:rgba(255,255,255,.70); }
#xsHomeFinal .xs-hero + .xs-sec .xs-pill{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.88);
  box-shadow:none;
}

/* hover : plus “premium”, sans assombrir */
@media (hover:hover) and (pointer:fine){
  #xsHomeFinal .xs-hero + .xs-sec .xs-card:hover{
    transform:translateY(-4px);
    box-shadow:
      0 26px 78px rgba(0,0,0,.34),
      inset 0 1px 0 rgba(255,255,255,.12);
    filter:brightness(1.04);
  }
}

/* Orange : garder le signal, mais en glass coloré (pas bloc opaque) */
#xsHomeFinal .xs-hero + .xs-sec .route-card.route-card--main,
#xsHomeFinal .xs-hero + .xs-sec .xs-card--accent{
  background:rgba(255,90,60,.16);
  border:1px solid rgba(255,90,60,.55);
  box-shadow:
    0 24px 70px rgba(255,90,60,.18),
    inset 0 1px 0 rgba(255,255,255,.10);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}

#xsHomeFinal .xs-hero + .xs-sec .route-card.route-card--main::before,
#xsHomeFinal .xs-hero + .xs-sec .route-card.route-card--main::after,
#xsHomeFinal .xs-hero + .xs-sec .xs-card--accent::before,
#xsHomeFinal .xs-hero + .xs-sec .xs-card--accent::after{
  opacity:0 !important;
}

/* =========================================================
   DUO (Captain/Sarah)
   ========================================================= */
#xsHomeFinal .xs-duoGrid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:28px;
  margin-top:24px;
  align-items:stretch;
}
@media (max-width:900px){
  #xsHomeFinal .xs-duoGrid{ grid-template-columns:1fr; }
}

#xsHomeFinal .xs-duoCard{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  height:100%;
  padding:16px 18px 18px;
  border-radius:24px;
  background:#fff;
  border:1px solid rgba(31,42,50,.14);
  box-shadow:0 18px 45px rgba(0,0,0,.08);
  transition:transform .22s ease, box-shadow .22s ease;
}
@media (hover:hover) and (pointer:fine){
  #xsHomeFinal .xs-duoCard:hover{
    transform:translateY(-3px);
    box-shadow:0 22px 60px rgba(0,0,0,.12);
  }
}

#xsHomeFinal .xs-duoPhoto{
  width:100%;
  border-radius:20px;
  overflow:hidden;
  margin:0 0 14px;
  background:#0b1218;
  aspect-ratio:9 / 11;
  height:auto;
  display:block;
}
#xsHomeFinal .xs-duoPhoto img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:50% 35%;
  display:block;
  transition:transform .35s ease;
  transform:translateZ(0);
}
@media (hover:hover) and (pointer:fine){
  #xsHomeFinal .xs-duoCard:hover .xs-duoPhoto img{ transform:scale(1.04); }
}

#xsHomeFinal .xs-duoCard > p{
  margin:0 0 14px;
  color:rgba(31,42,50,.84);
  line-height:1.75;
}
#xsHomeFinal .xs-duoUnderBtn{
  margin:0;
  color:rgba(31,42,50,.78);
  font-size:14.5px;
  line-height:1.6;
}

/* =========================
   TEAM
   ========================= */
#xsHomeFinal .xs-teamGrid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(210px, 1fr));
  gap:18px;
  margin-top:22px;
  align-items:stretch;
}

#xsHomeFinal .xs-member{
  text-decoration:none;
  color:inherit;
  display:block;
}

#xsHomeFinal .xs-member:focus-visible .xs-memberCard{
  outline:2px solid var(--xs-focus);
  outline-offset:3px;
}

#xsHomeFinal .xs-memberCard{
  border-radius:16px;
  overflow:hidden;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(31,42,50,.14);
  box-shadow:var(--xs-shadow2);
  transition:transform .25s ease, box-shadow .25s ease, filter .25s ease;
  max-width:320px;
  margin:0 auto;
}

@media (hover:hover) and (pointer:fine){
  #xsHomeFinal .xs-memberCard:hover{
    transform:translateY(-2px);
    box-shadow:0 22px 55px rgba(0,0,0,.12);
    filter:brightness(1.01);
  }
}

#xsHomeFinal .xs-memberPhoto{
  position:relative;
  padding-top:88%;
  background:var(--xs-white);
  overflow:hidden;
}

#xsHomeFinal .xs-memberPhoto img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.01);
  transition:transform .3s ease;
}

@media (hover:hover) and (pointer:fine){
  #xsHomeFinal .xs-memberCard:hover .xs-memberPhoto img{ transform:scale(1.05); }
}

#xsHomeFinal .xs-memberBody{ padding:12px 12px 14px; }

#xsHomeFinal .xs-memberName{
  margin:0 0 6px;
  font-size:18px;
  font-weight:900;
  letter-spacing:-0.01em;
  color:var(--xs-deep);
}

#xsHomeFinal .xs-memberRole{
  margin:0;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(31,42,50,.62);
  font-weight:900;
}

/* =========================
   SPLIT (ARION)
   ========================= */
#xsHomeFinal .xs-split{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:18px;
  align-items:stretch;
}
@media (max-width:900px){
  #xsHomeFinal .xs-split{ grid-template-columns:1fr; }
}

#xsHomeFinal .xs-visual{
  border-radius:var(--xs-r-lg);
  min-height:420px;
  border:1px solid rgba(31,42,50,.14);
  overflow:hidden;
  position:relative;
  box-shadow:var(--xs-shadow);
  transition:transform .28s ease, box-shadow .28s ease;
}
@media (hover:hover) and (pointer:fine){
  #xsHomeFinal .xs-visual:hover{
    transform:translateY(-2px);
    box-shadow:0 22px 60px rgba(0,0,0,.12);
  }
}

#xsHomeFinal .xs-visual::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:var(--bg);
  background-size:cover;
  background-position:center;
  transform:scale(1.02);
  filter:saturate(.98) contrast(1.02);
  transition:transform .3s ease;
}
@media (hover:hover) and (pointer:fine){
  #xsHomeFinal .xs-visual:hover::before{ transform:scale(1.05); }
}

#xsHomeFinal .xs-visual::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 520px at 50% 80%, rgba(255,255,255,.06), rgba(11,18,24,.18) 60%, rgba(11,18,24,.30) 100%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(11,18,24,.18));
}

#xsHomeFinal .xs-side{
  border-radius:var(--xs-r-lg);
  background:rgba(255,255,255,.94);
  border:1px solid rgba(31,42,50,.14);
  box-shadow:var(--xs-shadow);
  padding:22px 22px 18px;
}

#xsHomeFinal .xs-side h3{
  margin:0 0 10px;
  font-size:18px;
  font-weight:900;
  color:var(--xs-deep);
  position:relative;
  padding-left:12px;
}
#xsHomeFinal .xs-side h3::before{
  content:"";
  position:absolute;
  left:0;
  top:.28em;
  width:3px;
  height:1.05em;
  border-radius:3px;
  background:rgba(127,164,184,.78);
}

/* =========================
   DOC (Splide)
   ========================= */
#xsHomeFinal .xs-docSplide{
  max-width:1040px;
  margin:0 auto 32px;
}

#xsHomeFinal .xs-docSlide{
  display:block;
  position:relative;
  overflow:hidden;
  border-radius:18px;
  background:#000;
  aspect-ratio:3/4;
  box-shadow:0 18px 45px rgba(0,0,0,.22);
  transform:translateY(0);
  transition:transform .25s ease, box-shadow .25s ease;
}

#xsHomeFinal .xs-docSlide img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .35s ease;
}

#xsHomeFinal .splide__slide{ height:auto; }
#xsHomeFinal .splide__slide > .xs-docSlide{ height:100%; }

@media (hover:hover) and (pointer:fine){
  #xsHomeFinal .xs-docSlide:hover{
    transform:translateY(-4px);
    box-shadow:0 24px 60px rgba(0,0,0,.30);
  }
  #xsHomeFinal .xs-docSlide:hover img{ transform:scale(1.04); }
}

#xsHomeFinal .xs-docSplide .splide__arrow{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(31,42,50,.14);
  box-shadow:var(--xs-shadow2);
  opacity:1;
}

#xsHomeFinal .xs-docSplide .splide__pagination__page{
  background:rgba(31,42,50,.24);
}
#xsHomeFinal .xs-docSplide .splide__pagination__page.is-active{
  background:rgba(255,90,60,.95);
}

/* =========================
   ROUTE (split + card clean)
   ========================= */
#xsHomeFinal .xs-routeSplit{
  display:grid;
  grid-template-columns:1fr 380px;
  gap:18px;
  align-items:stretch;
}
@media (max-width:980px){
  #xsHomeFinal .xs-routeSplit{ grid-template-columns:1fr; }
}

#xsHomeFinal .xs-routeCopy{ min-width:0; }

#xsHomeFinal .xs-impasseCard{
  text-decoration:none;
  color:inherit;
  display:block;
  border-radius:var(--xs-r-lg);
  overflow:hidden;
  border:1px solid rgba(31,42,50,.14);
  box-shadow:var(--xs-shadow);
  background:#000;
}

#xsHomeFinal .xs-impasseCard:focus-visible{
  outline:2px solid var(--xs-focus);
  outline-offset:3px;
}

#xsHomeFinal .xs-impasseCard--clean .xs-impasseMedia{ min-height:320px; }

#xsHomeFinal .xs-impasseMedia{
  position:relative;
  min-height:320px;
  background:#000;
}

#xsHomeFinal .xs-impasseMedia::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:var(--img);
  background-size:cover;
  background-position:center;
  transform:scale(1.02);
  filter:saturate(.98) contrast(1.02);
  transition:transform .35s ease;
}

#xsHomeFinal .xs-impasseMedia::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 520px at 50% 75%, rgba(255,255,255,.06), rgba(11,18,24,.20) 60%, rgba(11,18,24,.42) 100%),
    linear-gradient(180deg, rgba(11,18,24,.10), rgba(11,18,24,.55));
}

@media (hover:hover) and (pointer:fine){
  #xsHomeFinal .xs-impasseCard:hover .xs-impasseMedia::before{ transform:scale(1.06); }
}

/* =========================
   PARTENAIRES (band)
   ========================= */
#xsHomeFinal .xs-band{
  border-radius:var(--xs-r-lg);
  background:rgba(255,255,255,.94);
  border:1px solid rgba(31,42,50,.14);
  box-shadow:var(--xs-shadow);
  padding:26px;
}

#xsHomeFinal .xs-bandGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  align-items:start;
}
@media (max-width:900px){
  #xsHomeFinal .xs-bandGrid{ grid-template-columns:1fr; }
}