@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600&display=swap');
  gap: 8px;
  background: #2f2a85;
  border-radius: 12px;
  padding: 8px 14px;
  width: 240px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --indigo:     #2f2a85;
  --indigo-lt:  #6660cd;
  --indigo-pale:#eeedfe;
  --teal:       #0f6e56;
  --teal-pale:  #e1f5ee;
  --gray-50:    #f9fafb;
  --gray-500:   #6b7280;
  --text:       #374151;
  --border:     #e4e8ef;
}

body { font-family: 'DM Sans', sans-serif; color: var(--text); background: #fff; }

.wrap { width: min(1080px, 100%); margin: 0 auto; display: flex; flex-direction: column; padding: 0.5rem 0 2.5rem; gap: 0; }

/* HERO */
.hero { background:var(--indigo); border-radius:18px; padding:44px 48px; position:relative; overflow:hidden; margin-bottom:1.25rem; }
.hero::before, .hero::after { content:''; position:absolute; border-radius:50%; pointer-events:none; }
.hero::before { width:480px; height:480px; right:-120px; top:-200px; border:1.5px solid rgba(255,255,255,0.09); }
.hero::after  { width:700px; height:700px; right:-260px; top:-320px; border:1px solid rgba(255,255,255,0.05); }
.hero-inner { position:relative; display:grid; grid-template-columns:1fr auto; gap:32px; align-items:center; }
.hero-kicker { font-size:0.7rem; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color:rgba(255,255,255,0.5); margin-bottom:12px; display:flex; align-items:center; gap:10px; }
.hero-kicker::before { content:''; display:block; width:24px; height:2px; background:rgba(255,255,255,0.35); border-radius:2px; }
.hero h1 { font-family:'DM Sans',sans-serif; font-size:clamp(2rem,4vw,2.9rem); font-weight:700; color:#fff; line-height:1.15; margin-bottom:16px; letter-spacing:-0.01em; }
.hero p  { font-size:0.93rem; color:rgba(255,255,255,0.78); line-height:1.7; max-width:580px; }
.hero-stats { display:flex; flex-direction:column; gap:12px; flex-shrink:0; }
.stat-pill { background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.16); border-radius:12px; padding:14px 20px; text-align:right; min-width:160px; cursor:default; transition:background .22s,transform .22s,box-shadow .22s,border-color .22s; }
.stat-pill:hover { background:rgba(255,255,255,0.22); border-color:rgba(255,255,255,0.38); transform:translateY(-3px) scale(1.04); box-shadow:0 8px 24px rgba(0,0,0,0.25); }
.stat-pill .val { font-family:'DM Serif Display',serif; font-size:1.55rem; color:#fff; display:block; line-height:1.1; margin-bottom:3px; }
.stat-pill .lbl { font-size:0.73rem; color:rgba(255,255,255,0.55); font-weight:500; text-transform:uppercase; letter-spacing:0.07em; }
.stat-pill:hover .lbl { color:rgba(255,255,255,0.85); }

.section-label { font-size:0.72rem; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--indigo); margin-bottom:14px; }
.section { margin-bottom:1.5rem; }

/* CARROUSEL */
.fab-carousel { border-radius:16px; overflow:hidden; position:relative; background:#111; aspect-ratio:16/7; margin-bottom:1.25rem; }
.fab-track { display:flex; height:100%; transition:transform 0.7s cubic-bezier(0.4,0,0.2,1); will-change:transform; }
.fab-slide { flex:0 0 auto; height:100%; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; background:#1a1660; }
.fab-slide img { width:100%; height:100%; object-fit:cover; display:block; }
.fab-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,0.5) 0%,transparent 55%); pointer-events:none; z-index:2; }
.fab-caption { position:absolute; bottom:18px; left:22px; right:80px; color:rgba(255,255,255,0.88); font-size:0.82rem; font-weight:500; pointer-events:none; z-index:4; display:flex; align-items:center; gap:8px; }
.fab-arrow { position:absolute; top:50%; transform:translateY(-50%); width:40px; height:40px; background:rgba(0,0,0,0.35); border:1px solid rgba(255,255,255,0.2); border-radius:50%; color:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .2s; z-index:5; }
.fab-arrow:hover { background:rgba(0,0,0,0.6); }
.fab-prev { left:14px; }
.fab-next { right:14px; }
.fab-arrow svg { width:16px; height:16px; }
.fab-dots { position:absolute; bottom:14px; right:18px; display:flex; gap:7px; z-index:4; }
.fab-dot { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,0.35); border:none; cursor:pointer; padding:0; transition:background .25s,transform .25s; }
.fab-dot.active { background:#fff; transform:scale(1.25); }

/* LIGHTBOX */
.fab-lightbox { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.9); z-index:10000; align-items:center; justify-content:center; backdrop-filter:blur(8px); }
.fab-lightbox.open { display:flex; }
.fab-lb-inner { position:relative; max-width:92vw; max-height:86vh; border-radius:12px; overflow:hidden; box-shadow:0 32px 80px rgba(0,0,0,0.6); }
.fab-lb-inner img { display:block; max-width:92vw; max-height:86vh; object-fit:contain; }
.fab-lb-close { position:absolute; top:16px; right:16px; width:38px; height:38px; background:rgba(0,0,0,0.5); border:1px solid rgba(255,255,255,0.2); border-radius:50%; color:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:1.2rem; transition:background .2s; z-index:1; }
.fab-lb-close:hover { background:rgba(0,0,0,0.8); }
.fab-lb-counter { position:absolute; bottom:-30px; left:50%; transform:translateX(-50%); color:rgba(255,255,255,0.5); font-size:0.8rem; white-space:nowrap; }

/* DOC CARD */
.doc-card { background:#fff; border:1px solid var(--border); border-radius:14px; padding:22px 26px; display:flex; flex-direction:row; align-items:center; gap:20px; width:100%; transition:box-shadow .2s,transform .2s; }
.doc-card:hover { box-shadow:0 8px 28px rgba(47,42,133,0.10); transform:translateY(-2px); }
.doc-card-icon { width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0; background:var(--indigo-pale); }
.doc-card-icon svg { width:22px; height:22px; }
.doc-card-content { flex:1; min-width:0; }
.doc-card h3 { font-size:0.97rem; font-weight:600; color:#1f1d4d; line-height:1.3; margin-bottom:4px; }
.doc-card p  { font-size:0.84rem; color:var(--gray-500); line-height:1.55; margin:0; }
.btn-download { display:inline-flex; align-items:center; gap:8px; padding:9px 18px; background:var(--indigo); color:#fff; font-family:'DM Sans',sans-serif; font-size:0.82rem; font-weight:500; border-radius:20px; border:none; cursor:pointer; text-decoration:none; transition:background .2s,box-shadow .2s; white-space:nowrap; flex-shrink:0; }
.btn-download:hover { background:var(--indigo-lt); box-shadow:0 3px 14px rgba(102,96,205,0.35); }
.btn-download svg { width:14px; height:14px; }

/* INFO BLOCK */
.info-block { background:var(--gray-50); border:1px solid var(--border); border-radius:16px; padding:32px 36px; }
.info-block h2 { font-size:1.2rem; font-weight:700; color:#1f1d4d; margin-bottom:16px; line-height:1.3; }
.info-block > p { font-size:0.88rem; color:var(--gray-500); line-height:1.75; margin-bottom:12px; }
.feature-row { display:flex; gap:14px; flex-wrap:wrap; margin:20px 0 8px; }
.f-pill { background:var(--indigo); border-radius:12px; padding:16px 22px; display:flex; flex-direction:column; gap:3px; flex:1; min-width:140px; cursor:default; transition:background .22s,transform .22s,box-shadow .22s; }
.f-pill:hover { background:var(--indigo-lt); transform:translateY(-3px) scale(1.02); box-shadow:0 8px 24px rgba(47,42,133,0.30); }
.f-pill .f-val { font-family:'DM Serif Display',serif; font-size:1.6rem; color:#fff; line-height:1; }
.f-pill .f-lbl { font-size:0.72rem; color:rgba(255,255,255,0.6); font-weight:500; text-transform:uppercase; letter-spacing:0.07em; transition:color .22s; }
.f-pill:hover .f-lbl { color:rgba(255,255,255,0.85); }

/* CONF CARD */
.conf-card { background:var(--teal-pale); border:1px solid #b2e3d0; border-left:4px solid var(--teal); border-radius:14px; padding:24px 28px; display:flex; gap:20px; align-items:flex-start; }
.conf-icon { width:44px; height:44px; background:var(--teal); border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.conf-icon svg { width:22px; height:22px; }
.conf-card h3 { font-size:0.97rem; font-weight:600; color:#0a4035; margin-bottom:6px; line-height:1.3; }
.conf-card p  { font-size:0.86rem; color:#246b55; line-height:1.7; }
.btn-voir-plus { display:inline-flex; align-items:center; gap:8px; padding:9px 20px; background:var(--teal); color:#fff; font-family:'DM Sans',sans-serif; font-size:0.82rem; font-weight:600; border-radius:20px; border:none; cursor:pointer; text-decoration:none; transition:background .2s,box-shadow .2s,transform .2s; margin-top:12px; width:fit-content; }
.btn-voir-plus:hover { background:#0a4035; box-shadow:0 4px 16px rgba(15,110,86,0.35); transform:translateY(-1px); }
.btn-voir-plus svg { width:14px; height:14px; }

/* CONTACT */
.contact-card { background:#f5f4ff; border:1px solid #dddaf7; border-radius:16px; padding:28px 40px; display:flex; align-items:center; gap:28px; }
.contact-icon { width:52px; height:52px; background:var(--indigo); border-radius:14px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.contact-icon svg { width:24px; height:24px; }
.contact-text h2 { font-size:1rem; font-weight:600; color:#1f1d4d; margin-bottom:6px; }
.contact-text p  { font-size:0.88rem; color:var(--gray-500); line-height:1.65; }
.contact-text a  { color:var(--indigo); font-weight:600; text-decoration:none; border-bottom:1px solid #c9c5f5; transition:color .2s,border-color .2s; }
.contact-text a:hover { color:var(--indigo-lt); border-color:var(--indigo-lt); }

@media (max-width:620px) {
  .hero { padding:28px 22px; }
  .hero-inner { grid-template-columns:1fr; }
  .hero-stats { flex-direction:row; flex-wrap:wrap; }
  .stat-pill { text-align:left; min-width:130px; }
  .contact-card { flex-direction:column; align-items:flex-start; padding:24px 20px; }
  .info-block { padding:24px 20px; }
  .conf-card { padding:18px; }
  .doc-card { flex-direction:column; }
  .btn-download { width:100%; justify-content:center; }
}
