.hachi-slider-placeholder {
  padding: 28px;
  border: 1px dashed rgba(160, 124, 79, 0.45);
  background: rgba(242, 217, 204, 0.35);
  color: var(--soft-cocoa, #5a4838);
  text-align: center;
}

.hachi-slider-visual-only .hero-visual {
  min-height: clamp(420px, 62vw, 760px);
}

.hero-slide picture,
.hachi-slide-video {
  display: block;
  width: 100%;
  height: 100%;
}

.hachi-slide-video {
  object-fit: cover;
}

.hero-slide-caption p {
  margin: 12px 0 0;
  color: rgba(251, 245, 240, 0.82);
  line-height: 1.55;
}

.hero-slide-caption .button {
  margin-top: 18px;
}

.hachi-slider-arrows {
  position: absolute;
  inset: 50% clamp(18px, 4vw, 42px) auto;
  z-index: 4;
  display: flex;
  justify-content: space-between;
  pointer-events: none;
  transform: translateY(-50%);
}

.hachi-slider-arrows button {
  display: grid;
  width: 44px;
  height: 44px;
  place-items: center;
  border: 1px solid rgba(251, 245, 240, 0.62);
  background: rgba(90, 72, 56, 0.28);
  color: var(--rose-ivory, #fbf5f0);
  cursor: pointer;
  font-size: 28px;
  line-height: 1;
  pointer-events: auto;
  transition: background 220ms ease, border-color 220ms ease, transform 220ms ease;
}

.hachi-slider-arrows button:hover {
  border-color: var(--honey-gold, #dca748);
  background: rgba(90, 72, 56, 0.54);
  transform: translateY(-1px);
}
