/**
 * Hero Slider - Splide.js
 * Styles pour #heroSplide (images, textes, boutons depuis l'admin)
 */

/* ========== Variables ========== */
#heroSplide.hero-slider-modern,
.splide.hero-slider-modern {
  --hero-font-title: inherit;
  --hero-font-text: inherit;
  --hero-font-btn: inherit;
  --hero-size-title: clamp(1.75rem, 4vw, 3.5rem);
  --hero-size-title-mobile: clamp(1.5rem, 6vw, 2.5rem);
  --hero-size-subtitle: clamp(0.95rem, 1.5vw, 1.15rem);
  --hero-size-btn: clamp(0.875rem, 1.2vw, 1rem);
  --hero-color-title: #fff;
  --hero-color-text: rgba(255, 255, 255, 0.95);
  --hero-color-btn: #fff;
  --hero-bg-btn: rgba(0, 0, 0, 0.5);
  --hero-bg-btn-hover: #5B246D;
  --hero-overlay: linear-gradient(to bottom, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0.5) 100%);
  --hero-text-shadow: 0 2px 12px rgba(0,0,0,0.4);
  --hero-text-shadow-strong: 0 2px 20px rgba(0,0,0,0.6);
}

/* ========== Conteneur : pleine largeur (sort du container si besoin), image à sa place ========== */
#heroSplide.hero-splide-fullwidth,
.hero-splide-fullwidth {
  width: 100vw !important;
  max-width: 100vw !important;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw !important;
  margin-right: -50vw !important;
  box-sizing: border-box;
  background: #0a0a0a !important; /* bandes latérales noires avec object-fit: contain */
}

#heroSplide.hero-slider-modern,
.splide.hero-slider-modern {
  width: 100% !important;
  max-width: 100% !important;
  overflow: hidden;
  background: #0a0a0a !important;
  box-sizing: border-box;
}

.splide.hero-slider-modern .splide__track {
  width: 100% !important;
  overflow: hidden;
}

.splide.hero-slider-modern .splide__list {
  width: 100% !important;
}

.splide.hero-slider-modern .splide__slide {
  position: relative;
  width: 100% !important;
  min-width: 100% !important;
  box-sizing: border-box;
  background: #0a0a0a !important;
}

.splide.hero-slider-modern .slide-link {
  display: block;
  width: 100% !important;
  min-width: 100%;
  overflow: hidden;
  color: inherit;
  text-decoration: none;
  box-sizing: border-box;
}

.splide.hero-slider-modern .hero-slide-figure,
.splide.hero-slider-modern .hero-slide-img {
  width: 100% !important;
  max-width: 100% !important;
}

/* ========== Figure + image ========== */
.splide.hero-slider-modern .hero-slide-figure {
  position: relative;
  margin: 0;
  overflow: hidden;
  background: #0a0a0a;
  padding-top: 56.25%;
  height: 0;
}

/* Desktop (PC) : ratio 3:1 (1920×640) pour afficher l’image en entier sans recadrage */
@media (min-width: 1025px) {
  .splide.hero-slider-modern .hero-slide-figure {
    padding-top: 49.10%; /* 33.333% × 1.15 (agrandi 15%) */
    height: 0;
  }
}

.splide.hero-slider-modern .hero-slide-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.splide.hero-slider-modern .hero-slide-figure::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--hero-overlay);
  pointer-events: none;
}

/* ========== Responsive hauteur ========== */
@media (max-width: 1024px) {
  .splide.hero-slider-modern .hero-slide-figure {
    padding-top: 0;
    height: 75vh;   /* 65vh +15% */
    min-height: 322px;  /* 280px +15% */
    max-height: 100vh;
  }
}

/* Mobile (< 768px) : hauteur fixe +15% (575px), image cover centrée, texte centré */
@media (max-width: 767px) {
  .splide.hero-slider-modern .hero-slide-figure {
    height: 575px !important;   /* 500px +15% */
    min-height: 575px !important;
    max-height: 575px !important;
    padding-top: 0 !important;
  }

  .splide.hero-slider-modern .hero-slide-img {
    object-fit: cover !important;
    object-position: center !important;
  }

  /* Texte centré verticalement et horizontalement */
  .splide.hero-slider-modern .hero-caption {
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 16px 12px;
  }

  .splide.hero-slider-modern .caption-inner {
    text-align: center;
    max-width: 100%;
  }

  /* Tailles de police réduites pour ne pas masquer l'image */
  .splide.hero-slider-modern .hero-caption .slide_title-two,
  .splide.hero-slider-modern .hero-caption h1,
  .splide.hero-slider-modern .hero-caption h2 {
    font-size: clamp(1.1rem, 4.5vw, 1.5rem) !important;
    margin-bottom: 0.25em;
  }

  .splide.hero-slider-modern .hero-caption p,
  .splide.hero-slider-modern .hero-caption .description,
  .splide.hero-slider-modern .hero-caption .slide_subtitle {
    font-size: clamp(0.8rem, 2.5vw, 0.95rem) !important;
    margin-bottom: 0.5em;
  }

  .splide.hero-slider-modern .hero-caption .btn-box .btn,
  .splide.hero-slider-modern .hero-caption a.btn {
    font-size: 0.8rem !important;
    padding: 0.45em 1em;
  }
}

@media (max-width: 575px) {
  .splide.hero-slider-modern .hero-slide-figure {
    height: 575px !important;   /* 500px +15% */
    min-height: 575px !important;
    max-height: 575px !important;
  }
}

/* Mobile : on donne de la hauteur pour que le texte ait de la place */
@media (max-width: 767px) {
  .splide.hero-slider-modern .hero-slide-figure {
    height: 500px !important;
  }
  .splide.hero-slider-modern .hero-slide-figure .hero-slide-img {
    height: 100%;
    width: 100%;
    object-fit: cover;
    object-position: center;
  }
}

/* ========== Caption (texte depuis l'admin) ========== */
.splide.hero-slider-modern .hero-caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: clamp(20px, 4vw, 48px);
  pointer-events: none;
}

.splide.hero-slider-modern .hero-caption * {
  pointer-events: auto;
}

.splide.hero-slider-modern .hero-caption-only {
  min-height: 200px;
  background: #1a1a1a;
}

.splide.hero-slider-modern .caption-inner {
  max-width: 42em;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  justify-content: center;
  align-items: flex-start;
}

/* Classes à ajouter dans l’admin (HTML de la description) : position + taille mobile */
/* Position horizontale : envelopper le contenu dans un div avec une des classes */
.splide.hero-slider-modern .caption-inner .hero-pos-left {
  align-self: flex-start;
  text-align: left;
}
.splide.hero-slider-modern .caption-inner .hero-pos-center {
  align-self: center;
  text-align: center;
}
.splide.hero-slider-modern .caption-inner .hero-pos-right {
  align-self: flex-end;
  text-align: right;
}
/* Position verticale */
.splide.hero-slider-modern .caption-inner .hero-pos-top {
  align-self: flex-start;
  margin-top: 0;
  margin-bottom: auto;
}
.splide.hero-slider-modern .caption-inner .hero-pos-middle {
  align-self: center;
}
.splide.hero-slider-modern .caption-inner .hero-pos-bottom {
  align-self: flex-end;
  margin-top: auto;
  margin-bottom: 0;
}

/* Taille de police sur mobile (< 768px) : ajouter une classe au bloc */
@media (max-width: 767px) {
  .splide.hero-slider-modern .caption-inner .hero-mobile-sm *,
  .splide.hero-slider-modern .caption-inner .hero-mobile-sm {
    font-size: 0.85em !important;
  }
  .splide.hero-slider-modern .caption-inner .hero-mobile-sm .slide_title-two,
  .splide.hero-slider-modern .caption-inner .hero-mobile-sm h1,
  .splide.hero-slider-modern .caption-inner .hero-mobile-sm h2 {
    font-size: clamp(0.95rem, 4vw, 1.2rem) !important;
  }
  .splide.hero-slider-modern .caption-inner .hero-mobile-sm .btn,
  .splide.hero-slider-modern .caption-inner .hero-mobile-sm a.btn {
    font-size: 0.75rem !important;
  }

  .splide.hero-slider-modern .caption-inner .hero-mobile-md {
    /* taille par défaut mobile, déjà dans le CSS */
  }

  .splide.hero-slider-modern .caption-inner .hero-mobile-lg *,
  .splide.hero-slider-modern .caption-inner .hero-mobile-lg {
    font-size: 1.1em !important;
  }
  .splide.hero-slider-modern .caption-inner .hero-mobile-lg .slide_title-two,
  .splide.hero-slider-modern .caption-inner .hero-mobile-lg h1,
  .splide.hero-slider-modern .caption-inner .hero-mobile-lg h2 {
    font-size: clamp(1.25rem, 5vw, 1.65rem) !important;
  }
  .splide.hero-slider-modern .caption-inner .hero-mobile-lg .btn,
  .splide.hero-slider-modern .caption-inner .hero-mobile-lg a.btn {
    font-size: 0.9rem !important;
  }
}

/* Typographie */
.splide.hero-slider-modern .slide_title-two,
.splide.hero-slider-modern .hero-caption .slide_title-two {
  font-family: var(--hero-font-title);
  font-size: var(--hero-size-title);
  font-weight: 700;
  line-height: 1.2;
  color: var(--hero-color-title);
  text-shadow: var(--hero-text-shadow-strong);
  margin: 0 0 0.35em;
}

.splide.hero-slider-modern .hero-caption p,
.splide.hero-slider-modern .hero-caption .description {
  font-family: var(--hero-font-text);
  font-size: var(--hero-size-subtitle);
  line-height: 1.5;
  color: var(--hero-color-text);
  text-shadow: var(--hero-text-shadow);
  margin: 0 0 0.75em;
}

.splide.hero-slider-modern .hero-caption p:last-child {
  margin-bottom: 0;
}

/* Bouton CTA (hover #5B246D) */
.splide.hero-slider-modern .btn-box {
  margin-top: 1.25em;
  margin-bottom: 0;
}

.splide.hero-slider-modern .btn-box .btn {
  font-family: var(--hero-font-btn);
  font-size: var(--hero-size-btn);
  font-weight: 600;
  color: var(--hero-color-btn);
  background: var(--hero-bg-btn);
  border: 2px solid rgba(255, 255, 255, 0.6);
  padding: 0.6em 1.4em;
  border-radius: 4px;
  text-shadow: var(--hero-text-shadow);
  transition: background 0.25s ease, border-color 0.25s ease, transform 0.2s ease;
}

.splide.hero-slider-modern .btn-box .btn:hover {
  background: var(--hero-bg-btn-hover);
  border-color: rgba(255, 255, 255, 0.9);
  color: #fff;
  transform: translateY(-2px);
}

/* Tailles directes pour titre et description (à mettre dans le HTML en admin) */
/* Titre : ajouter la classe sur le <p> ou <h2> du titre */
.splide.hero-slider-modern .hero-caption .hero-title-xs { font-size: 1rem !important; }
.splide.hero-slider-modern .hero-caption .hero-title-sm { font-size: 1.35rem !important; }
.splide.hero-slider-modern .hero-caption .hero-title-md { font-size: 1.75rem !important; }
.splide.hero-slider-modern .hero-caption .hero-title-lg { font-size: 2.25rem !important; }
.splide.hero-slider-modern .hero-caption .hero-title-xl { font-size: 2.75rem !important; }
/* Description / sous-titre : ajouter la classe sur le <p> */
.splide.hero-slider-modern .hero-caption .hero-desc-xs { font-size: 0.75rem !important; }
.splide.hero-slider-modern .hero-caption .hero-desc-sm { font-size: 0.875rem !important; }
.splide.hero-slider-modern .hero-caption .hero-desc-md { font-size: 1rem !important; }
.splide.hero-slider-modern .hero-caption .hero-desc-lg { font-size: 1.15rem !important; }
.splide.hero-slider-modern .hero-caption .hero-desc-xl { font-size: 1.35rem !important; }

@media (max-width: 991px) {
  .splide.hero-slider-modern .slide_title-two {
    font-size: var(--hero-size-title-mobile);
  }
  .splide.hero-slider-modern .hero-caption {
    padding: 24px 20px;
  }
  .splide.hero-slider-modern .btn-box .btn {
    padding: 0.55em 1.2em;
    min-height: 44px;
  }
}

@media (max-width: 575px) {
  .splide.hero-slider-modern .hero-caption {
    padding: 20px 16px;
  }
}

/* ========== Flèches Splide ========== */
.splide.hero-slider-modern .splide__arrows .splide__arrow {
  width: 50px;
  height: 50px;
  background: rgba(0, 0, 0, 0.4);
  border-radius: 4px;
  opacity: 0.9;
  border: none;
}

.splide.hero-slider-modern .splide__arrows .splide__arrow:hover {
  background: rgba(0, 0, 0, 0.7);
  opacity: 1;
}

.splide.hero-slider-modern .splide__arrows .splide__arrow--prev {
  left: 15px;
}

.splide.hero-slider-modern .splide__arrows .splide__arrow--next {
  right: 15px;
}

/* ========== Pagination Splide ========== */
.splide.hero-slider-modern .splide__pagination {
  bottom: 15px;
}

.splide.hero-slider-modern .splide__pagination__page {
  width: 12px;
  height: 12px;
  background: rgba(255, 255, 255, 0.5);
}

.splide.hero-slider-modern .splide__pagination__page.is-active {
  background: #fff;
}
