/* CSS-only carousel for homepage — radio inputs + slides
   Responsive, no JS. Reuses .media-card styles from media.css
*/
.home-carousel {
  max-width: 1100px;
  margin: 28px auto;
  position: relative;
  padding: 12px;
}
.home-carousel .carousel-inner {
  overflow: hidden;
  border-radius: 14px;
  background: linear-gradient(180deg, #fff, #fbf8f4);
  box-shadow: var(--shadow);
  position: relative;
}
.home-carousel .slides {
  display: flex;
  /* total width equals number of pages */
  width: calc(var(--pages, 1) * 100%);
  transition: transform 0.6s cubic-bezier(.4,0,.2,1);
}
.home-carousel input[type="radio"] {
  display: none;
}

/* Each slide takes full width */
.home-carousel .slide {
  /* each slide equals 1 page (100% of the viewport area) */
  flex: 0 0 calc(100% / var(--pages, 1));
  box-sizing: border-box;
  padding: 22px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px; /* espace entre les cartes */
}

/* Navigation dots */
.home-carousel .navigation {
  display: flex;
  justify-content: center;
  gap: 10px;
  padding: 12px 0 6px 0;
}
.home-carousel .navigation label {
  width: 12px;
  height: 12px;
  display: inline-block;
  border-radius: 50%;
  background: #ddd;
  cursor: pointer;
  border: 2px solid #f0f0f0;
  transition: background 0.18s, transform 0.12s;
}
.home-carousel .navigation label:hover { transform: scale(1.12); }

/* Position slides based on checked radio using the pages variable. */
/* Each step shifts by (100% / var(--pages)) of the slides' width so it equals one viewport width. */
#popular1:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 0)); }
#popular2:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 1)); }
#popular3:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 2)); }
#popular4:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 3)); }
#popular5:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 4)); }
#popular6:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 5)); }
#popular7:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 6)); }
#popular8:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 7)); }
#popular9:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 8)); }
#popular10:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 9)); }
#popular11:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 10)); }
#popular12:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 11)); }
#popular13:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 12)); }
#popular14:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 13)); }
#popular15:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 14)); }
#popular16:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 15)); }
#popular17:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 16)); }
#popular18:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 17)); }
#popular19:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 18)); }
#popular20:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 19)); }
#popular21:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 20)); }
#popular22:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 21)); }
#popular23:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 22)); }
#popular24:checked ~ .carousel-inner .slides { transform: translateX(calc(-1 * (100% / var(--pages,1)) * 23)); }

/* Highlight corresponding dot */
/* Highlight corresponding dot (supports up to 24) */
#popular1:checked ~ .navigation label[for="popular1"],
#popular2:checked ~ .navigation label[for="popular2"],
#popular3:checked ~ .navigation label[for="popular3"],
#popular4:checked ~ .navigation label[for="popular4"],
#popular5:checked ~ .navigation label[for="popular5"],
#popular6:checked ~ .navigation label[for="popular6"],
#popular7:checked ~ .navigation label[for="popular7"],
#popular8:checked ~ .navigation label[for="popular8"],
#popular9:checked ~ .navigation label[for="popular9"],
#popular10:checked ~ .navigation label[for="popular10"],
#popular11:checked ~ .navigation label[for="popular11"],
#popular12:checked ~ .navigation label[for="popular12"],
#popular13:checked ~ .navigation label[for="popular13"],
#popular14:checked ~ .navigation label[for="popular14"],
#popular15:checked ~ .navigation label[for="popular15"],
#popular16:checked ~ .navigation label[for="popular16"],
#popular17:checked ~ .navigation label[for="popular17"],
#popular18:checked ~ .navigation label[for="popular18"],
#popular19:checked ~ .navigation label[for="popular19"],
#popular20:checked ~ .navigation label[for="popular20"],
#popular21:checked ~ .navigation label[for="popular21"],
#popular22:checked ~ .navigation label[for="popular22"],
#popular23:checked ~ .navigation label[for="popular23"],
#popular24:checked ~ .navigation label[for="popular24"] {
  background: var(--green);
  border-color: #cfe9d9;
}

/* Media-card inside slide should be centered and not too wide */
.home-carousel .media-card {
  /* each card takes roughly 1/3 of the slide minus gaps; flex-based so it's responsive */
  flex: 0 0 calc((100% - 36px) / 3);
  max-width: 360px;
  margin: 0;
}

/* Controls (flèches) */
.home-carousel > label.carousel-arrow {
  display: none;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(0,0,0,0.6);
  color: #fff;
  font-size: 24px;
  line-height: 48px;
  text-align: center;
  cursor: pointer;
  box-shadow: 0 8px 22px rgba(0,0,0,0.32);
  transition: background 0.14s ease, transform 0.12s ease, opacity 0.12s;
  pointer-events: auto;
  z-index: 40;
  opacity: 0.95;
}
.home-carousel > label.carousel-arrow.prev { left: 8px; }
.home-carousel > label.carousel-arrow.next { right: 8px; }
.home-carousel > label.carousel-arrow:hover,
.home-carousel > label.carousel-arrow:focus { transform: translateY(-50%) scale(1.04); background: rgba(0,0,0,0.75); outline: none; }

/* Show adjacent labels when the radio is checked: input + label.prev + label.next */
.home-carousel input[type="radio"] + label.carousel-arrow.prev { display: none; }
.home-carousel input[type="radio"] + label.carousel-arrow.prev + label.carousel-arrow.next { display: none; }
.home-carousel input[type="radio"]:checked + label.carousel-arrow.prev { display: block; }
.home-carousel input[type="radio"]:checked + label.carousel-arrow.prev + label.carousel-arrow.next { display: block; }

/* Keyboard focus style */
.home-carousel label.carousel-arrow:focus {
  box-shadow: 0 0 0 4px rgba(78,124,90,0.18), 0 8px 22px rgba(0,0,0,0.32);
}

@media (max-width: 900px) {
  /* On medium screens, show 2 cards per slide sizing */
  .home-carousel .media-card { flex: 0 0 calc((100% - 18px) / 2); max-width: 320px; }
}
@media (max-width: 640px) {
  /* On small screens cards stack / occupy viewport width */
  .home-carousel .media-card { flex: 0 0 90vw; max-width: 90vw; }
  .home-carousel .navigation { gap: 8px; }
}

/* Helper to visually highlight active dot */
.home-carousel .navigation label.active { background: var(--green); border-color: #cfe9d9; }

/* End of file */

/* =========================
   NovaKult title & home content
   ========================= */
.novakult-title {
  text-align: center;
  padding: 22px 12px 6px;
  background: linear-gradient(180deg, rgba(250,250,250,0.6), rgba(248,248,246,0.4));
}
.novakult-title .container { max-width: 1100px; margin: 0 auto; }
.novakult-title h2 {
  font-family: 'Segoe UI', Roboto, Arial, sans-serif;
  font-size: 36px;
  margin: 0 0 8px;
  color: var(--dark, #24312b);
  letter-spacing: 0.6px;
}
.novakult-subtitle {
  color: #5b6b60;
  margin: 0;
  font-size: 15px;
}

.home-content { padding: 34px 12px 40px; background: #fff; }

/* Espace sous le bloc d'accueil (titre + paragraphe) */
.acceuil {
  max-width: 1100px;
  margin: 20px auto 40px; /* top, horizontal center, bottom spacing */
  padding: 0 12px;
}

@media (min-width: 900px) {
  .acceuil { margin-bottom: 64px; }
}
.home-content .container { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: center; }
.home-content .about h3 { margin-top: 0; font-size: 22px; color: var(--dark,#24312b); }
.home-content .about p { color: #44534a; line-height: 1.5; }
.features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.feature-card { background: linear-gradient(180deg,#ffffff,#fbfbfb); border-radius: 10px; padding: 18px; box-shadow: 0 6px 18px rgba(28,40,32,0.06); border: 1px solid #eef5ef; }
.feature-card h4 { margin: 0 0 8px; font-size: 16px; color: var(--green,#4e7c5a); }
.feature-card p { margin: 0; color: #596a60; font-size: 14px; }

@media (max-width: 900px) {
  .home-content .container { grid-template-columns: 1fr; align-items: start; }
  .features { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .features { grid-template-columns: 1fr; }
}
