*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:#fff;color:#1a1a1a;font-family:'Montserrat',sans-serif;font-weight:400;display:flex;flex-direction:column;min-height:100vh}

/* ── HEADER ── */
header{
  position:relative;
  text-align:center;
  padding:3rem 2rem 0;
  border-left:3px solid #1a1a1a;
  border-right:3px solid #1a1a1a;
  border-top:3px solid #1a1a1a;
}
.reserve-top{
  position:absolute;
  top:0; left:0;
  background:#1a1a1a;
  color:#fff;
  padding:.55rem 1.1rem;
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  text-decoration:none;
  transition:background .2s;
}
.reserve-top:hover{background:#333}
.site-name{
  font-size:clamp(1.8rem,4vw,3rem);
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#1a1a1a;
  line-height:1;
  margin-top:.5rem;
}
.site-tagline{
  font-size:clamp(.72rem,1.3vw,.9rem);
  font-weight:500;
  color:#888;
  letter-spacing:.04em;
  margin-top:.6rem;
  padding-bottom:2rem;
}

/* ── NAV ── */
.nav-wrap{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  border-left:3px solid #1a1a1a;
  border-right:3px solid #1a1a1a;
  border-top:1px solid #e0e0e0;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
@media(min-width:901px){
  .nav-wrap{justify-content:center}
}
.nav-wrap::before,.nav-wrap::after{
  content:'';
  display:block;
  width:50px;
  height:3px;
  background:#ccc;
  flex-shrink:0;
}
.nav-item{position:relative}
.nav-link{
  display:block;
  padding:.85rem 1.3rem;
  font-size:clamp(.72rem,1.4vw,1rem);
  font-weight:700;
  letter-spacing:.03em;
  text-transform:uppercase;
  color:#1a1a1a;
  text-decoration:none;
  white-space:nowrap;
  cursor:pointer;
  transition:color .2s;
}
.nav-link:hover{color:#555}
.nav-link.active{color:#555;border-bottom:2px solid #1a1a1a}
.nav-item:hover .dropdown{display:block}
.dropdown{
  display:none;
  position:absolute;
  top:calc(100% + 1px);
  left:50%;
  transform:translateX(-50%);
  background:#fff;
  border:2px solid #1a1a1a;
  min-width:260px;
  z-index:200;
}
.dropdown a{
  display:block;
  padding:.65rem 1.1rem;
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.04em;
  color:#1a1a1a;
  text-decoration:none;
  border-bottom:1px solid #eee;
  cursor:pointer;
  transition:background .15s;
}
.dropdown a:last-child{border-bottom:none}
.dropdown a:hover{background:#f5f5f5}

/* ── SLIDER ── */
.slider-zone{
  display:flex;
  align-items:center;
  justify-content:center;
  /*border-left:3px solid #1a1a1a;*/
  /*border-right:3px solid #1a1a1a;*/
  padding:0.5rem 1rem;
  gap:1rem;
  height:clamp(220px,43vw,500px);
}
.slider-side{
  flex-shrink:0;
  width:clamp(36px,5vw,60px);
  background:#d0d0d0;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  border:none;
  outline:none;
  transition:background .2s;
}
.slider-side:hover{background:#bbb}
.slider-side svg{
  width:20px;height:20px;
  stroke:#fff;stroke-width:2.5;
  fill:none;stroke-linecap:round;stroke-linejoin:round;
}
.slider-main{flex:1;position:relative;height:100%;max-width:100%}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease}
.slide.active{opacity:1}
.slide-bg{position:absolute;inset:0;background-size:contain;background-position:center;background-repeat:no-repeat}
/* Chaque slide : dimensions fixes, overflow caché */
.slide-bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Fond flouté : même image étirée pour remplir */
.slide-bg-blur {
  position: absolute;
  inset: -20px; /* déborde pour éviter les bords du filtre blur */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: blur(18px) brightness(0.75) saturate(1.2);
  transform: scale(1.05); /* compense le halo du blur */
}

/* Image nette au centre, contenue sans crop */
.slide-bg-sharp {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

/* Attribution des images aux deux couches */
.slide:nth-child(1)  .slide-bg-blur,
.slide:nth-child(1)  .slide-bg-sharp  { background-image: url('slides/slide-bb-scene.jpg'); }

.slide:nth-child(2)  .slide-bg-blur,
.slide:nth-child(2)  .slide-bg-sharp  { background-image: url('slides/slide-vi-orsay.jpg'); }

.slide:nth-child(3)  .slide-bg-blur,
.slide:nth-child(3)  .slide-bg-sharp  { background-image: url('slides/slide-bb-danse.jpg'); }

.slide:nth-child(4)  .slide-bg-blur,
.slide:nth-child(4)  .slide-bg-sharp  { background-image: url('slides/slide-vi-moreau.jpg'); }

.slide:nth-child(5)  .slide-bg-blur,
.slide:nth-child(5)  .slide-bg-sharp  { background-image: url('slides/slide-bb-mains.jpg'); }

.slide:nth-child(6)  .slide-bg-blur,
.slide:nth-child(6)  .slide-bg-sharp  { background-image: url('slides/slide-vi-pompidou.jpg'); }

.slide:nth-child(7)  .slide-bg-blur,
.slide:nth-child(7)  .slide-bg-sharp  { background-image: url('slides/slide-bb-tel.jpg'); }

.slide:nth-child(8)  .slide-bg-blur,
.slide:nth-child(8)  .slide-bg-sharp  { background-image: url('slides/slide-bb-visage.jpg'); }

.slide:nth-child(9)  .slide-bg-blur,
.slide:nth-child(9)  .slide-bg-sharp  { background-image: url('slides/slide-vi-zadkine.jpg'); }

.slide:nth-child(10) .slide-bg-blur,
.slide:nth-child(10) .slide-bg-sharp  { background-image: url('slides/slider1.png'); }

.slide:nth-child(11) .slide-bg-blur,
.slide:nth-child(11) .slide-bg-sharp  { background-image: url('slides/slider3.jpg'); }

.slide:nth-child(12) .slide-bg-blur,
.slide:nth-child(12) .slide-bg-sharp  { background-image: url('slides/slider6.jpg'); }

.slide:nth-child(13) .slide-bg-blur,
.slide:nth-child(13) .slide-bg-sharp  { background-image: url('slides/slider7.jpg'); }

/*.slide:nth-child(11) .slide-bg-blur,
.slide:nth-child(11) .slide-bg-sharp  { background-image: url('slides/slider1.jpg'); }

.slide:nth-child(12) .slide-bg-blur,
.slide:nth-child(12) .slide-bg-sharp  { background-image: url('slides/slider2.jpg'); }

.slide:nth-child(13) .slide-bg-blur,
.slide:nth-child(13) .slide-bg-sharp  { background-image: url('slides/slider3.jpg'); }

.slide:nth-child(14) .slide-bg-blur,
.slide:nth-child(14) .slide-bg-sharp  { background-image: url('slides/slider4.jpg'); }

.slide:nth-child(15) .slide-bg-blur,
.slide:nth-child(15) .slide-bg-sharp  { background-image: url('slides/slider5.jpg'); }

.slide:nth-child(16) .slide-bg-blur,
.slide:nth-child(16) .slide-bg-sharp  { background-image: url('slides/slider6.jpg'); }

.slide:nth-child(17) .slide-bg-blur,
.slide:nth-child(17) .slide-bg-sharp  { background-image: url('slides/slider7.jpg'); }*/
.slide-label{
  display: none;
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);
  font-size:clamp(.85rem,1.8vw,1.2rem);
  font-weight:700;font-style:italic;
  color:#fff;
  background:#CCCCCC;
  padding:5px;
  letter-spacing:.04em;z-index:2;
  white-space:nowrap; /* évite le retour à la ligne sur les titres longs */
}
.slider-dots{position:absolute;bottom:.4rem;left:50%;transform:translateX(-50%);display:flex;gap:.4rem;z-index:10}
.dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.35);border:none;cursor:pointer;padding:0;transition:background .3s}
.dot.active{background:#fff}

/* ── SECTIONS ── */
.sections-wrap{flex:1}
.sections-wrap:has(.content-section.open){
  border-left:3px solid #1a1a1a;
  border-right:3px solid #1a1a1a;
  border-bottom:3px solid #1a1a1a;
}
.content-section{
  display:none;
  padding:3.5rem 4rem 4rem;
  max-width:1100px;
  margin:0 auto;
  animation:rise .35s ease;
}
.content-section.open{display:block}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.s-kicker{
  font-size:.6rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:#aaa;margin-bottom:.8rem;
}
.s-title{
  font-size:clamp(1.6rem,3vw,2.5rem);
  font-weight:800;text-transform:uppercase;
  letter-spacing:.04em;
  line-height:1.05;
  padding-bottom:1rem;
  border-bottom:3px solid #1a1a1a;
  margin-bottom:2.2rem;
}

/* spectacles */
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.sc{border:2px solid #e8e8e8;padding:2.2rem 2rem;display:flex;flex-direction:column}
.sc h3{font-size:1.3rem;font-weight:800;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.3rem;line-height:1.1}
.sc .by{font-size:.78rem;font-weight:500;color:#888;margin-bottom:1.2rem}
.sc-synopsis-row{display:flex;gap:1.2rem;align-items:flex-start;margin-bottom:1.2rem}
.sc-synopsis{font-size:.8rem;color:#555;line-height:1.85;font-weight:400;flex:1}
.sc-affiche{width:100px;flex-shrink:0;height:auto;display:block;border:1px solid #e8e8e8}
.sc .date{font-size:.8rem;font-weight:600;color:#555;line-height:2;flex:1;margin-bottom:1.5rem}
.sc-tag{display:inline-block;background:#f0f0f0;color:#888;font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:.3rem .8rem;margin-bottom:1.2rem;align-self:flex-start}
.sc-venues{display:flex;flex-direction:column;gap:1.1rem;margin-bottom:1.5rem}
.sc-venue-item{padding:.9rem 1rem;background:#f9f9f9;border-left:3px solid #1a1a1a;display:flex;flex-direction:column;gap:.8rem}
.sc-venue-img{width:100%;max-width:280px;height:auto;display:block}
.sc-venue-name{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#1a1a1a}
.sc-venue-date{font-size:.72rem;font-weight:500;color:#888}
.sc-fiche{margin-bottom:1rem}
.sc-fiche summary{font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#aaa;cursor:pointer;padding:.4rem 0;list-style:none}
.sc-fiche summary::-webkit-details-marker{display:none}
.sc-fiche summary::after{content:' +';color:#ccc}
details[open] .sc-fiche summary::after,
.sc-fiche[open] summary::after{content:' −';color:#ccc}
.sc-fiche ul{margin-top:.7rem;padding-left:0;list-style:none}
.sc-fiche li{font-size:.72rem;color:#888;line-height:1.9;padding-left:.8rem;position:relative}
.sc-fiche li::before{content:'–';position:absolute;left:0;color:#ddd}
.sc-actions{display:flex;align-items:center;gap:1.5rem;margin-top:auto}
.btn-black{
  display:inline-block;
  background:#1a1a1a;color:#fff;
  padding:.55rem 1.4rem;
  font-size:.68rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  text-decoration:none;
  transition:background .2s;
}
.btn-black:hover{background:#333}
.btn-ghost{
  font-size:.65rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:#aaa;text-decoration:none;
  border-bottom:1px solid #ddd;
  padding-bottom:1px;cursor:pointer;
  transition:color .2s,border-color .2s;
}
.btn-ghost:hover{color:#1a1a1a;border-color:#1a1a1a}

/* visite imaginaire */
.vi-tagline{font-size:clamp(1.2rem,2.2vw,1.7rem);font-weight:700;color:#1a1a1a;margin-bottom:1rem;line-height:1.2;text-transform:uppercase;letter-spacing:.03em}
.vi-desc{font-size:.82rem;color:#666;line-height:1.95;max-width:640px;margin-bottom:2.5rem;font-weight:400}
.vi-desc p{margin-bottom:.9rem}
.vi-desc p:last-child{margin-bottom:0}
.vi-list{list-style:none;padding:0;margin:.7rem 0 1.1rem}
.vi-list li{font-size:.82rem;color:#666;line-height:1.85;padding-left:1.4rem;position:relative;margin-bottom:.6rem;font-weight:400}
.vi-list li::before{content:'▶';position:absolute;left:0;font-size:.5rem;color:#1a1a1a;top:.35em}
.vi-modes{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:#e8e8e8;margin-bottom:2.5rem}
.vi-mode{background:#fff;display:flex;flex-direction:column}
.vi-mode-img{width:100%;height:auto;max-height:260px;object-fit:cover;display:block}
.vi-mode-verb{font-size:.85rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.7rem;color:#1a1a1a;padding:1.4rem 1.5rem 0}
.vi-mode p:last-child{font-size:.78rem;color:#888;line-height:1.75;font-weight:400;padding:0 1.5rem 1.8rem}
.vi-musees{margin-bottom:2.5rem}
.vi-musees-label{font-size:.58rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#ccc;margin-bottom:.9rem}
.vi-tags{display:flex;flex-wrap:wrap;gap:.45rem}
.vi-tags span{font-size:.68rem;color:#888;border:1px solid #e0e0e0;padding:.28rem .75rem;font-weight:500}
.vi-cta{
  display:inline-block;
  font-size:.65rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:#1a1a1a;text-decoration:none;
  border-bottom:2px solid #1a1a1a;
  padding-bottom:2px;
  transition:opacity .2s;
}
.vi-cta:hover{opacity:.45}
.vi-cta--top{
  display:inline-block;
  font-size:.95rem;font-weight:700;
  letter-spacing:.06em;
  color:#1a1a1a;text-decoration:none;
  border-bottom:3px solid #1a1a1a;
  padding-bottom:3px;
  margin-bottom:2rem;
  transition:opacity .2s;
}
.vi-cta--top:hover{opacity:.45}

/* coaching */
.coaching-intro{margin-bottom:2rem}
.coaching-what-label{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#aaa;margin-bottom:.8rem}
.coaching-quote{
  font-size:.95rem;font-weight:500;font-style:italic;
  color:#555;line-height:1.7;
  border-left:3px solid #1a1a1a;
  padding-left:1.2rem;
}
.coaching-quote-author{display:block;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#aaa;margin-top:.6rem;font-style:normal}
.coaching-methode{margin-bottom:2rem}
.coaching-methode-label{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#aaa;margin-bottom:.8rem}
.coaching-methode-list{list-style:none;padding:0}
.coaching-methode-list li{font-size:.8rem;color:#666;line-height:2;padding-left:1.1rem;position:relative;font-weight:400}
.coaching-methode-list li::before{content:'—';position:absolute;left:0;color:#ccc}
.coaching-lead{font-size:.82rem;color:#666;line-height:1.95;max-width:580px;margin-bottom:2.5rem;font-weight:400}
.coaching-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-bottom:2.5rem}
.cc{padding-top:1.2rem;border-top:3px solid #1a1a1a;display:flex;flex-direction:column}
.cc h4{font-size:.82rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.55rem}
.cc p{font-size:.76rem;color:#888;line-height:1.75;font-weight:400}
.cc-visual{width:100%;max-width:260px;height:auto;display:block;margin:1rem 0}
.brochure-link{
  display:inline-block;margin-top:auto;padding-top:1.2rem;
  align-self:flex-start;
  font-size:.6rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:#1a1a1a;text-decoration:none;
  border-bottom:1px solid #1a1a1a;
  padding-bottom:1px;
  transition:opacity .2s;
}
.brochure-link:hover{opacity:.45}
.coaching-clients{padding-top:2rem;border-top:2px solid #e8e8e8}
.coaching-clients-label{font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#ccc;margin-bottom:1.2rem}
.confiance-img{max-width:620px;width:100%;height:auto;display:block;margin:0 auto;filter:grayscale(20%);opacity:.85}

/* presse */
.press-section-title{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#aaa;margin-bottom:1.2rem}
.press-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:#fff}
.press-card{background:#fff;padding:1.8rem 1.6rem;display:flex;flex-direction:column;gap:.9rem;text-decoration:none;color:inherit;transition:background .2s}
.press-card:hover{background:#f8f8f8}
.press-card--big:hover{background:#f8f8f8}
.press-quote{font-size:1rem;font-weight:600;color:#1a1a1a;line-height:1.5;font-style:italic}
.press-source{font-size:.58rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#bbb}
.press-arrow{font-size:.58rem;color:#ccc;letter-spacing:.08em;margin-top:auto;font-weight:600}

/* equipe */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;margin-bottom:2.5rem}
.member-photo{
  width:120px;height:120px;
  border-radius:50%;
  overflow:hidden;
  margin-bottom:1.2rem;
  border:3px solid #1a1a1a;
}
.member-photo img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:top center;
  display:block;
}
.mb h3{font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.2rem}
.mb .role{font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#bbb;margin-bottom:.8rem;line-height:1.6}
.mb p{font-size:.8rem;color:#666;line-height:1.85;font-weight:400}
.contact-row{padding-top:2rem;border-top:2px solid #e8e8e8;display:flex;gap:3rem;flex-wrap:wrap}
.contact-row a{font-size:.75rem;font-weight:600;color:#888;text-decoration:none;letter-spacing:.04em;transition:color .2s}
.contact-row a:hover{color:#1a1a1a}

/* accessibilité / SEO */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* footer */
footer{border-top:1px solid #eee;text-align:center;padding:1.4rem;font-size:.58rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#ccc}

/* responsive */
@media(max-width:900px){
  .nav-wrap::before,.nav-wrap::after{display:none}
  .nav-link{padding:.75rem .7rem;font-size:.72rem;white-space:nowrap}
  .slider-side{width:36px}
  .content-section{padding:2.5rem 1.5rem 3rem}
  .spec-grid,.vi-modes,.coaching-cols,.press-grid,.team-grid{grid-template-columns:1fr}
  .contact-row{flex-direction:column;gap:1rem}
}

/* ── SLIDER : photos entières, gris sur les côtés ── */

/* Supprime le padding latéral */
.slider-zone {
  padding-left: 0;
  padding-right: 0;
  max-width: calc(1100px + 2 * clamp(36px, 5vw, 60px) + 2rem);
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

/* Photos non rognées, gris sur les bandes vides */
.slide-bg {
  background-size: contain;          /* ← pas de crop */
  background-position: center center;
  background-repeat: no-repeat;
  /* le background-color par slide reste géré via nth-child */
}

.slider-main {
  position: relative; /* déjà là normalement */
}

.slider-main::before,
.slider-main::after {
  content: '';
  position: absolute;
  top: 5%;           /* décalage vers le bas */
  bottom:5%;
  width: clamp(80px, 12vw, 220px);
  background: #ddd;
  z-index: 0;
  float: none;       /* annule l'ancien float */
  height: auto;      /* laisse top/bottom gérer */
  margin: 0;
}


.slider-main::after {
  right: -5%; 
}

.slider-main::before {
  left: -5%;  
}


/* Et assure-toi que les slides passent par-dessus */
.slide {
  z-index: 1;
}