/* ─────────────────────────────────────────
   PIZZABOX PROJECT — style.css
   ───────────────────────────────────────── */

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

html, body {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
}

body {
  background-image: url('bg-texture.jpeg');
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  height: 100vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  font-family: 'Bebas Neue', sans-serif;
  color: red;
}

/* ── Header ── */
header {
  flex: 0 0 auto;
  text-align: center;
  padding: 16px 0 8px;
}

h1 {
  font-size: clamp(1.6rem, 7vw, 8rem);
  line-height: 1;
  margin: 0;
  padding: 0;
  white-space: nowrap;
  user-select: none;
}

/* ── Zone slider + boutons ── */
main {
  flex: 1 1 0;
  min-height: 0;
  position: relative;
  display: flex;
  align-items: center;
}

/* ── Swiper container ── */
.swiper {
  width: 100%;
  height: 100%;
  overflow: visible !important;
}

.swiper-wrapper {
  align-items: center;
}

/* ── Slides ──
   Les photos sont au ratio 4/5 (portrait).
   On fixe la hauteur de l'image en vh via --img-h.
   La largeur de la slide = --img-h × 4/5 (ratio exact).
   Ainsi l'image remplit toujours toute la hauteur disponible.

   --overlap-ratio : fraction de la slide cachée derrière la voisine.
   Swiper lit cette valeur via JS (spaceBetween ne peut pas être CSS).   */
:root {
  --img-h: 78vh;
  /* largeur slide = hauteur × ratio 4/5,
     mais plafonnée à 55vw pour ne jamais déborder sur écran étroit.
     ⚠️  Ces valeurs sont dupliquées dans script.js (IMG_H_VH, SLIDE_RATIO, SLIDE_MAX_VW)
         car getComputedStyle ne résout pas les calc() imbriqués.
         Si tu modifies ces valeurs, mets à jour les constantes JS aussi. */
  --slide-w: min(calc(var(--img-h) * 4 / 5), 55vw);
  /* chevauchement : 0.84 = 84% de la slide est derrière la voisine
     ✅  Cette valeur est lue directement par le JS via getComputedStyle. */
  --overlap-ratio: 0.84;
}

.swiper-slide {
  width: var(--slide-w) !important;
  /* hauteur = image + caption + marge */
  height: calc(var(--img-h) + 48px);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
}

/* L'article est le "card" visuel qui se transforme */
article {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  transform-origin: center center;
  transition: transform 0.4s ease, opacity 0.4s ease, filter 0.4s ease;
  position: relative;
}

article img {
  display: block;
  width: 100%;
  /* remplit la largeur de la slide (= ratio 4/5) */
  height: var(--img-h);
  /* hauteur fixée en vh */
  object-fit: cover;
  /* couvre sans déformer */
  user-select: none;
  pointer-events: none;
}

/* ── Caption ── */
.caption {
  display: none;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  margin: 8px 0 0;
  text-align: center;
  line-height: 1.1;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 20px;
  color: black;
}

.swiper-slide-active .caption {
  display: flex;
}

/* ── Classes de profondeur ── */

/* Slide active — gérée nativement par Swiper */
.swiper-slide-active {
  z-index: 5;
}

.swiper-slide-active article {
  transform: scale(1);
  opacity: 1;
  filter: none;
}

/* ±1 — swiper-slide-prev / swiper-slide-next (natif Swiper) */
.swiper-slide-prev,
.swiper-slide-next {
  z-index: 4;
}

.swiper-slide-prev article,
.swiper-slide-next article {
  transform: scale(0.92);
  opacity: 1;
  filter: brightness(0.65) blur(1px);
}

/* ±2 — classe custom pos-2 */
.swiper-slide.pos-2 {
  z-index: 3;
}

.swiper-slide.pos-2 article {
  transform: scale(0.84);
  opacity: 1;
  filter: brightness(0.35) blur(3px);
}

/* Slides hors de ±2 : invisibles mais toujours dans le DOM pour Swiper */
.swiper-slide.pos-hidden {
  visibility: hidden;
  pointer-events: none;
}

/* ── Boutons de navigation ── */
#btn-prev,
#btn-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  user-select: none;
  /* couleur normale : rouge semi-transparent */
  color: rgba(180, 0, 0, 0.75);
  transition: color 0.2s;
  /* taille fluide */
  width: clamp(36px, 5vw, 54px);
  height: clamp(36px, 5vw, 54px);
  display: flex;
  align-items: center;
  justify-content: center;
}

#btn-prev {
  left: 12px;
}

#btn-next {
  right: 12px;
}

#btn-prev:hover,
#btn-next:hover {
  color: rgba(255, 30, 30, 1);
}

/* Le SVG hérite de currentColor via fill */
#btn-prev svg,
#btn-next svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
  display: block;
}

/* ── Mobile (≤ 480px) — caption plus petite ── */
@media (max-width: 480px) {
  .caption {
    font-size: 16px;
  }
}