:root{
  --bg:#0b0f14;
  --bg2:#0f1720;
  --soft:#f5f6f8;
  --paper:#ffffff;
  --ink:#0e141b;
  --muted:#5e6a78;
  --muted2:#9aa6b4;
  --line:rgba(14,20,27,.14);
  --line2:rgba(255,255,255,.14);
  --gold:#c8a24a;
  --gold2:#e2c06b;
  --radius:18px;
  --shadow: 0 18px 50px rgba(0,0,0,.22);
  --shadow2: 0 10px 24px rgba(0,0,0,.18);
  --max: 1140px;
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--paper)}
a{color:inherit}
.wrap{max-width:var(--max);margin:0 auto;padding:0 18px}

/* Top */
.top{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.top__inner{ display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:6px 0;   /* 🔽 réduit la hauteur du header */}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo__mark{
  width:40px;height:40px;border-radius:14px;
  background: radial-gradient(120% 120% at 20% 10%, rgba(226,192,107,.55), transparent 60%),
              linear-gradient(135deg, #111827, #0b0f14);
  box-shadow: var(--shadow2);
  border:1px solid rgba(255,255,255,.08);
}
.logo__text{display:flex;flex-direction:column;line-height:1}
.logo__name{font-weight:900;letter-spacing:.10em}
.logo__sub{margin-top:3px;font-weight:700;letter-spacing:.28em;color:var(--muted);font-size:12px}
.logo__img{
  height:32px;          /* <-- baisse la hauteur */
  width:auto;
  max-width:160px;      /* <-- empêche les logos trop larges */
  display:block;
  object-fit:contain;
}

/* Nav */
.nav{display:flex;align-items:center;gap:18px}
.nav a{text-decoration:none;color:var(--muted);font-size:14px}
.nav a:hover{color:var(--ink)}
.nav__cta{color:var(--ink);font-weight:800}

.burger{
  display:none;
  width:46px;height:42px;border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
}
.burger span{display:block;height:2px;background:var(--ink);margin:6px 10px;border-radius:2px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 16px;border-radius:14px;
  font-weight:800;font-size:14px;
  text-decoration:none;border:1px solid transparent;
  cursor:pointer;
}
.btn--gold{
  background:linear-gradient(135deg,var(--gold2),var(--gold));
  color:#16130b;
  box-shadow: var(--shadow2);
}
.btn--gold:hover{filter:brightness(1.03)}
.btn--ghost{
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.22);
}
.btn--ghost:hover{border-color:rgba(255,255,255,.36)}

/* Hero */
.hero{position:relative;min-height:78vh;display:grid;place-items:center;overflow:hidden}
.hero__bg{
  position:absolute;inset:-2px;
  background:
    radial-gradient(800px 600px at 20% 20%, rgba(200,162,74,.22), transparent 60%),
    radial-gradient(900px 700px at 80% 20%, rgba(140,170,220,.18), transparent 60%),
    linear-gradient(180deg, #0a0f14 0%, #0f1720 60%, #0b0f14 100%);
}
.hero__bg::after{
  content:"";
  position:absolute;inset:0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px) 0 0 / 80px 80px,
    linear-gradient(0deg, rgba(255,255,255,.04) 1px, transparent 1px) 0 0 / 80px 80px;
  opacity:.35;
  mask-image: radial-gradient(closest-side, rgba(0,0,0,.75), transparent 70%);
  pointer-events:none;
}
.hero__inner{position:relative;color:#fff;padding:74px 0 44px}
.eyebrow{
  display:inline-block;
  border:1px solid rgba(255,255,255,.18);
  padding:7px 10px;border-radius:999px;
  font-weight:800;font-size:12px;letter-spacing:.10em;
  color:rgba(255,255,255,.88);
  background:rgba(0,0,0,.16);
}
.hero h1{
  margin:14px 0 10px;
  font-size:54px;line-height:1.02;
  letter-spacing:-.02em;
}
.hero__lead{max-width:70ch;color:rgba(255,255,255,.78);font-size:17px;margin:0 0 18px}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0 26px}
.hero__facts{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.fact{
  padding:14px;border-radius:18px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
}
.fact__k{display:block;color:rgba(255,255,255,.60);font-size:12px;margin-bottom:6px}
.fact__v{font-weight:800}

/* Sections */
.section{padding:62px 0}
.section--soft{background:var(--soft)}
.section--dark{background:linear-gradient(180deg, #0f1720, #0b0f14);color:#fff}
h2{margin:0 0 10px;font-size:30px;letter-spacing:-.01em}
h3{margin:0 0 10px;font-size:18px}
.muted{color:var(--muted)}
.muted--dark{color:rgba(255,255,255,.74)}
.fine{font-size:12px;color:var(--muted);margin-top:10px}
.fine--dark{color:rgba(255,255,255,.62)}

/* Split */
.split{display:grid;grid-template-columns:1.25fr .75fr;gap:18px;align-items:start}
.panel{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;box-shadow:var(--shadow2);
}
.dl{margin:12px 0 0}
.dl div{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px dashed rgba(14,20,27,.18)}
.dl div:last-child{border-bottom:none}
.dl dt{color:var(--muted);font-size:13px}
.dl dd{margin:0;font-weight:800;font-size:13px;text-align:right}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.chip{
  border:1px solid rgba(14,20,27,.14);
  background:#fff;
  padding:7px 10px;border-radius:999px;
  font-weight:800;font-size:12px;color:#111827;
}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);
  padding:16px;
  box-shadow: var(--shadow2);
}
.card__media{
  height:150px;border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  margin-bottom:14px;
  background:
    radial-gradient(700px 220px at 30% 0%, rgba(226,192,107,.28), transparent 60%),
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.card__media--b{background:
  radial-gradient(700px 220px at 60% 0%, rgba(140,170,220,.22), transparent 60%),
  linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));}
.card__media--c{background:
  radial-gradient(700px 220px at 40% 0%, rgba(200,162,74,.22), transparent 60%),
  linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));}
.list{margin:10px 0 0;padding-left:18px;color:rgba(255,255,255,.70)}
.list li{margin:8px 0}

/* Note */
.note{
  margin-top:16px;padding:14px;border-radius:16px;
  border:1px solid rgba(14,20,27,.14);
  background:#fff;color:#2b3440;
}
.note--dark{
  border-color:rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.82);
}

/* Tiles (references) */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.tile{
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
  background:#fff;
  box-shadow: var(--shadow2);
}
.tile__img{height:170px;background:
  radial-gradient(800px 240px at 30% 10%, rgba(200,162,74,.25), transparent 60%),
  linear-gradient(135deg, #0f1720, #111827);}
.tile__img--2{background:
  radial-gradient(800px 240px at 70% 10%, rgba(140,170,220,.22), transparent 60%),
  linear-gradient(135deg, #0f1720, #111827);}
.tile__img--3{background:
  radial-gradient(800px 240px at 50% 10%, rgba(226,192,107,.20), transparent 60%),
  linear-gradient(135deg, #0f1720, #111827);}
.tile__body{padding:14px}
.tile__title{font-weight:900}
.tile__sub{margin-top:4px;color:var(--muted);font-size:13px}

/* Partner logos */
.logos{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:18px}
.logoBox{
  height:80px;border-radius:16px;
  display:grid;place-items:center;
  background:#fff;border:1px dashed rgba(14,20,27,.24);
  color:var(--muted);font-weight:900;
}

/* Contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start;margin-top:10px}
.contact__box{
  margin-top:14px;
  padding:14px;border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.86);
}
.spacer{height:10px}

.form label{display:block;font-weight:900;font-size:13px;margin-bottom:10px;color:rgba(255,255,255,.86)}
.form input,.form textarea{
  width:100%;
  margin-top:6px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:14px;
  padding:12px;
  font:inherit;
  color:#fff;
  background:rgba(0,0,0,.18);
  outline:none;
}
.form input:focus,.form textarea:focus{border-color:rgba(226,192,107,.55); box-shadow:0 0 0 4px rgba(226,192,107,.14)}

/* Footer */
.footer{background:#0b0f14;color:rgba(255,255,255,.70);padding:18px 0;border-top:1px solid rgba(255,255,255,.10)}
.footer__inner{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}
.footer__links a{text-decoration:none;color:rgba(255,255,255,.70)}
.footer__links a:hover{color:#fff}

/* Mobile */
@media (max-width: 980px){
  .hero h1{font-size:40px}
  .hero__facts{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .tiles{grid-template-columns:1fr}
  .logos{grid-template-columns:1fr 1fr}
  .contact{grid-template-columns:1fr}
  .burger{display:inline-block}
  .nav{
    position:fixed; left:18px; right:18px; top:74px;
    display:none; flex-direction:column; gap:10px;
    background:rgba(255,255,255,.96);
    border:1px solid var(--line);
    border-radius:18px;
    padding:14px;
    box-shadow: var(--shadow2);
  }
  .nav--open{display:flex}
}
/* Sécurité: empêche toute image de déborder et casser la page */
img{
  max-width: 100%;
  height: auto;
}

/* Limite STRICTE du logo */
.logo__img{
  height: 148px !important;
  max-height: 148px !important;
  width: auto !important;
  max-width: 200px !important;
}
/* ===== Cartes Activités : image + texte séparés ===== */

.cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}

.card{
  background:#0b0f14;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 12px 30px rgba(0,0,0,.35);
}

.card__media{
  height:180px;
  overflow:hidden;
}

.card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.card__content{
  padding:18px;
  background:#0f1720;
}

.card__content h3{
  margin:0 0 8px;
  color:#fff;
}

.card__content p{
  margin:0 0 12px;
  color:rgba(255,255,255,.8);
  font-size:14px;
}

.card__content ul{
  margin:0;
  padding-left:18px;
  color:rgba(255,255,255,.75);
  font-size:13px;
}

.card__content li{
  margin-bottom:6px;
}

/* Mobile */
@media (max-width: 980px){
  .cards{
    grid-template-columns:1fr;
  }
}