/* Top-of-page hero carousel — dependency-free, sibling to gallery.css.
   Progressive enhancement: the bare markup is a static banner; hero-slider.js adds
   `.is-enhanced` to a MULTI-slide [data-hero-slider] to turn on the carousel.
   The legacy single-photo hero (style.css `section.hero`) is untouched — this only
   styles `.hero--slider`. Image heights mirror the old `.hero .image` so migrated
   pages look identical. No Owl/Lightcase classes are reintroduced. */

.hero--slider .container { position: relative; }

/* Controls are useless without JS, so stay hidden until enhanced (and on
   single-slide sliders, which are never enhanced). */
.hero--slider .hero__nav,
.hero--slider .hero__toggle,
.hero--slider .hero__dots { display: none; }

/* Slide image — same responsive heights as the legacy `.hero .image`. */
.hero--slider .hero__slide { margin: 0; }
.hero--slider .hero__slide img {
  display: block;
  width: 100%;
  height: 160px;
  object-fit: cover;
  border-radius: 2px;
}
@media (min-width: 568px)  { .hero--slider .hero__slide img { height: 250px; } }
@media (min-width: 1024px) { .hero--slider .hero__slide img { height: 400px; } }

/* Caption below the image — matches `section.hero .caption`. */
.hero--slider .hero__cap {
  margin-top: 14px;
  text-align: center;
  font-family: "Lora", Georgia, serif;
  color: #252525;
  font-size: 14px;
  line-height: 24px;
}

/* --- Enhanced (multi-slide) mode -------------------------------------------- */
/* Stack every slide in a single grid cell: the viewport is as tall as the tallest
   slide, so swapping slides never shifts the layout. Active slide fades in. */
.hero--slider.is-enhanced .hero__viewport { display: grid; }
.hero--slider.is-enhanced .hero__slide {
  grid-area: 1 / 1;
  opacity: 0;
  visibility: hidden;
  transition: opacity .5s ease;
}
.hero--slider.is-enhanced .hero__slide.is-active {
  opacity: 1;
  visibility: visible;
}
@media (prefers-reduced-motion: reduce) {
  .hero--slider.is-enhanced .hero__slide { transition: none; }
  /* No autoplay under reduced motion, so the pause/play toggle has nothing to do. */
  .hero--slider.is-enhanced .hero__toggle { display: none; }
}

/* Reveal controls once enhanced. */
.hero--slider.is-enhanced .hero__nav,
.hero--slider.is-enhanced .hero__toggle { display: block; }
.hero--slider.is-enhanced .hero__dots { display: flex; }

/* Arrows + toggle, overlaid on the image area. */
.hero--slider .hero__nav,
.hero--slider .hero__toggle {
  position: absolute;
  background: rgba(0, 0, 0, .45);
  border: 0;
  color: #fff;
  cursor: pointer;
  line-height: 1;
  user-select: none;
  border-radius: 3px;
}
.hero--slider .hero__nav {
  top: 80px;                 /* centre on the base 160px image */
  transform: translateY(-50%);
  font-size: 2.4rem;
  padding: .05em .3em;
}
@media (min-width: 568px)  { .hero--slider .hero__nav { top: 125px; } }
@media (min-width: 1024px) { .hero--slider .hero__nav { top: 200px; } }
.hero--slider .hero__prev { left: 8px; }
.hero--slider .hero__next { right: 8px; }

.hero--slider .hero__toggle {
  top: 8px;
  right: 8px;
  font-size: 1rem;
  padding: .35em .55em;
}

.hero--slider .hero__nav:hover,
.hero--slider .hero__toggle:hover { color: #701b45; }

.hero--slider .hero__nav:focus-visible,
.hero--slider .hero__toggle:focus-visible,
.hero--slider .hero__dot:focus-visible {
  outline: 2px solid #701b45;
  outline-offset: 2px;
}

/* Dots, centred below the caption. */
.hero--slider .hero__dots {
  justify-content: center;
  gap: 10px;
  margin-top: 14px;
}
.hero--slider .hero__dot {
  width: 11px;
  height: 11px;
  padding: 0;
  border: 1px solid #701b45;
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
}
.hero--slider .hero__dot.is-active { background: #701b45; }
