/* =========================
   BASE
========================= */
:root{
  --bg: #0b0b0b;   /* ✅ le noir de référence (site + cards + bandes) */
  --fg: #f2f2f2;
}

* { box-sizing: border-box; }
html, body { height: 100%; }

body{
  margin:0;
  background: var(--bg);
  color: var(--fg);

  /* IMPORTANT : on utilise la Typekit (sinon tout change de taille/largeur) */
  font-family: neue-haas-grotesk-text, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}

img { display:block; max-width:100%; }

/* =========================
   TOPBAR
========================= */
.topbar{
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--bg);
}

.topbarInner{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;

  /* ✅ Base desktop */
  padding:48px 180px 18px;

  gap:24px;

  max-width:1920px;
  margin:0 auto;
}

.idBlock{
  text-decoration:none;
  color:inherit;
  display:inline-block;
}

.idName{
  font-family: neue-haas-grotesk-display, neue-haas-grotesk-text, system-ui, sans-serif;
  font-weight:700;
  letter-spacing:0.02em;
  font-size:32px;
  line-height:1;
}

.idRole{
  margin-top:6px;
  font-size:11px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  opacity:0.9;
  font-weight:400;
}

/* =========================
   NAV
========================= */
.nav{
  display:flex;
  gap:18px;
  align-items:center;
  margin-top:24px;
}

.nav a{
  color: var(--fg);
  text-decoration:none;
  font-size:11px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  opacity:0.85;
  padding:4px 0;
}

.nav a[aria-current="page"]{ opacity:1; }

.nav a:hover{
  opacity:1;
  text-decoration: line-through;
}

/* =========================
   WRAP / SEPARATOR HR (sep)
========================= */
.wrap{
  /* ✅ Base desktop */
  padding:0 180px 64px;

  max-width:1920px;
  margin:0 auto;
}

/* ✅ GAIN ~4cm PAR CÔTÉ SUR TRÈS GRAND ÉCRAN (4K) */
@media (min-width: 1800px){
  .topbarInner{ padding:48px 30px 18px; }
  .wrap{ padding:0 30px 64px; }
}

.sep{
  border:0;
  height:1px;
  background: rgba(255,255,255,0.15);
  margin: 18px 0 28px;
}

/* =========================
   ROW
========================= */
.row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:24px;
  align-items:start;
  margin: 0 0 22px;
}

.rowTitle{
  font-family: neue-haas-grotesk-display, neue-haas-grotesk-text, system-ui, sans-serif;
  font-size:12px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  font-weight:600;
}

.rowMeta{
  text-align:right;
  font-size:10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  opacity:0.75;
  line-height:1.7;
}

/* =========================
   GRID 16/9
========================= */
.grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:32px;
  margin-bottom: 28px;
}

/* ✅ CADRE : noir, mais discret (plus de double/triple trait) */
.card{
  display:block;
  overflow:hidden;
  aspect-ratio: 16 / 9;

  background: var(--bg);
  border-radius:2px;

  border: 1px solid rgba(0,0,0,0.35); /* ✅ cadre noir doux */
  box-shadow: none;                   /* ✅ enlève l’inset */
}

/* ✅ IMAGE : plus de recadrage, et bandes EXACTEMENT même noir que le site */
.card img{
  width:100%;
  height:100%;
  object-fit: contain;
  object-position: center;
  background: var(--bg);

  transform: scale(1);
  transition: transform 220ms ease;

  outline: none;   /* ✅ enlève le 2e cadre */
}

.card:hover img{ transform: scale(1.00); }

/* =========================
   FOOTER
========================= */
.footer{
  display:flex;
  justify-content:space-between;
  margin-top:48px;
  font-size:12px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  opacity:0.7;
}

/* =========================
   LIGHTBOX
========================= */
.lightbox{
  position: fixed;
  inset: 0;
  display: none;
  place-items: center;
  background: rgba(0,0,0,0.85);
  z-index: 100;
  padding: 24px;
}

.lightbox.open{
  display: grid;
}

#lightboxImg{
  max-width: min(1200px, 96vw);
  max-height: 92vh;
  width: auto;
  height: auto;
  border: 1px solid rgba(255,255,255,0.18);
}

/* --- Zoom léger au clic (ne touche pas la mise en page) --- */
.lightbox{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,0.6);
  z-index:9999;
  padding:24px;
}
.lightbox.open{ display:flex; }

.lightboxInner{
  width:min(980px, 92vw);
  max-height:72vh;
  border-radius:12px;
  overflow:hidden;
}

.lightboxInner img{
  width:100%;
  max-height:72vh;
  display:block;
  object-fit:contain;
}

body.noScroll{ overflow:hidden; }

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 900px){
  .topbarInner{
    padding:28px 22px 12px;
    max-width:none;
    margin:0;
  }

  .wrap{
    padding:0 22px 42px;
    max-width:none;
    margin:0;
  }

  .nav{ display:none; }

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

  .row{ grid-template-columns: 1fr 1fr; gap:16px; }
  .rowMeta{ text-align:right; }
}

/* MOBILE: afficher la nav */
@media (max-width: 780px){
  .nav{
    display:flex !important;
    flex-wrap:wrap;
    gap:14px;
    font-size:10px;
    line-height:1.2;
  }
}

/* =========================
   VIMEO / YOUTUBE PLAYER
   (centré, même logique que ALLIANZ)
========================= */
.vimeoWrap{
  width: 100%;
  margin: 0 auto 28px;
}

.vimeoCine{
  position: relative;
  width: min(1200px, 100%);
  margin: 0 auto;
  aspect-ratio: 16 / 9;
}

.vimeoCine iframe{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}