/* =========================================================
   🎬 WPZ LIGHTBOX — PRO (avec miniatures)
   - AU-DESSUS DE TOUT
   - Close visible mobile (safe-area)
   - Thumbs scrollables
   ========================================================= */

:root{
  /* z-index "hard" pour écraser cookies/header/plugins */
  --wpz-z-lightbox: 2147483646;
}

#wpz-lightbox{
  position:fixed;
  inset:0;
  z-index: var(--wpz-z-lightbox);
  display:none;

  /* stacking context propre (évite z-index wars) */
  isolation:isolate;

  /* évite bugs de compositing mobile */
  transform: translateZ(0);
}

#wpz-lightbox.is-open{ display:block; }

.wpz-lightbox-overlay{
  position:absolute;
  inset:0;
  background:var(--overlay-deep);
  z-index: 0;
}

/* UI global */
.wpz-lightbox-ui{
  position:absolute;
  inset:0;
  z-index: 1;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 22px;
  box-sizing:border-box;
}

/* Zone centrale : image + thumbs */
.wpz-lightbox-center{
  width:min(1100px, 94vw);
  max-height:92vh;
  display:flex;
  flex-direction:column;
  gap: 12px;
}

/* Stage image */
.wpz-lightbox-stage{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;

  background: rgba(0,0,0,.30);
  border: 1px solid var(--border-light);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);

  overflow:hidden; /* ✅ on garde hidden pour ne pas “déborder” */
  max-height: calc(92vh - 96px);
}

/* Image */
.wpz-lightbox-stage img{
  width:auto;
  height:auto;
  max-width:100%;
  max-height:100%;
  display:block;
  border-radius: var(--radius); /* arrondi sur l'image */
}

/* Miniatures */
.wpz-lightbox-thumbs{
  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius);
  padding: 10px;
  overflow:hidden;
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
}

.wpz-lightbox-thumbs-track{
  display:flex;
  gap:10px;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding-bottom:2px;
}
.wpz-lightbox-thumbs-track::-webkit-scrollbar{ display:none; }

.wpz-thumb{
  flex:0 0 auto;
  width:86px;
  height:56px;
  border-radius: var(--radius-sm);
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  cursor:pointer;
  position:relative;
  transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.wpz-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  pointer-events:none;
}

.wpz-thumb.is-active{
  border-color: rgba(255,255,255,.35);
  box-shadow: 0 0 0 2px var(--ring-strong);
  transform: translateY(-1px);
}

@media (hover:hover){
  .wpz-thumb:hover{
    border-color: rgba(255,255,255,.28);
    transform: translateY(-1px);
  }
}

/* Controls (prev/next + close global) */
.wpz-lightbox-close,
.wpz-lightbox-prev,
.wpz-lightbox-next{
  position:absolute;
  z-index: 5;
  background: rgba(0,0,0,.55);
  color: var(--text-invert);
  border:1px solid var(--border-light);
  width: var(--btn-round);
  height: var(--btn-round);
  border-radius: var(--radius-pill);
  font-size:22px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition: background var(--transition-fast), transform var(--transition-fast);
}

.wpz-lightbox-close{
  top: calc(14px + env(safe-area-inset-top, 0px));
  right: calc(14px + env(safe-area-inset-right, 0px));
}
.wpz-lightbox-prev{ left:20px; }
.wpz-lightbox-next{ right:20px; }

@media (hover:hover){
  .wpz-lightbox-close:hover,
  .wpz-lightbox-prev:hover,
  .wpz-lightbox-next:hover{
    background: rgba(0,0,0,.78);
    transform: scale(1.04);
  }
}

/* Scroll lock */
html.wpz-lightbox-open,
body.wpz-lightbox-open{
  overflow:hidden !important;
}

/* =========================================================
   ✅ Bouton close "rouge" AU-DESSUS de l’image
   - sans casser overflow:hidden : on le met DANS le stage
   ========================================================= */

.wpz-lightbox-stage-close{
  position:absolute;
  top: 10px;
  right: 10px;
  z-index: 6;

  background: rgba(0,0,0,.45);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;

  color: var(--primary);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;

  padding: 8px 10px;

  transition: transform var(--transition-fast), opacity var(--transition-fast), background var(--transition-fast);
}

@media (hover:hover){
  .wpz-lightbox-stage-close:hover{
    background: rgba(0,0,0,.70);
    transform: scale(1.06);
    opacity: .98;
  }
}

/* Mobile */
@media (max-width:768px){
  .wpz-thumb{ width:76px; height:50px; }
  .wpz-lightbox-ui{ padding: 14px; }
  .wpz-lightbox-prev{ left:10px; }
  .wpz-lightbox-next{ right:10px; }

  /* ✅ close global toujours visible sur mobile */
  .wpz-lightbox-close{
    top: calc(10px + env(safe-area-inset-top, 0px));
    right: calc(10px + env(safe-area-inset-right, 0px));
  }

  /* ✅ grand hit area */
  .wpz-lightbox-stage-close{
    top: 10px;
    right: 10px;
  }
}


@media (max-width:768px){
  .wpz-lightbox-close{ display:none !important; }
  .wpz-lightbox-stage-close{ display:flex !important; }
}
