.home-visual-banner {
  position: relative;
  width: 100%;
  aspect-ratio: 4719 / 1844;
  min-height: 300px;
  max-height: 1000px;
  background: #0b1218;
  overflow: hidden;
}
.home-visual-banner__sr-title {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.visual-carousel {
  position: absolute;
  inset: 0;
}

.visual-carousel__viewport {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.visual-carousel__track {
  display: flex;
  height: 100%;
  transform: translate3d(0, 0, 0);
  transition: transform 680ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}

.visual-carousel__slide {
  position: relative;
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
}

.visual-carousel__slide-link {
  display: block;
  width: 100%;
  height: 100%;
  text-decoration: none;
}

.visual-carousel__slide-link:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.9);
  outline-offset: -2px;
}

.visual-carousel__slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  filter: contrast(1.04) saturate(1.05);
}

.visual-carousel__slide::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(
      900px 520px at 25% 20%,
      rgba(0, 180, 140, 0.1),
      transparent 60%
    ),
    radial-gradient(
      1000px 600px at 85% 15%,
      rgba(20, 90, 160, 0.16),
      transparent 62%
    ),
    linear-gradient(180deg, rgba(0, 0, 0, 0.22), rgba(0, 0, 0, 0.1));
  pointer-events: none;
}

.visual-carousel__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(10, 16, 22, 0.42);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition:
    background 160ms ease,
    border-color 160ms ease,
    transform 160ms ease;
}

.visual-carousel__nav:hover,
.visual-carousel__nav:focus-visible {
  background: rgba(10, 16, 22, 0.62);
  border-color: rgba(255, 255, 255, 0.34);
}

.visual-carousel__nav:active {
  transform: translateY(-50%) scale(0.98);
}

.visual-carousel__nav--prev {
  left: clamp(12px, 2vw, 26px);
}

.visual-carousel__nav--next {
  right: clamp(12px, 2vw, 26px);
}

.visual-carousel__nav svg {
  width: 20px;
  height: 20px;
}

.visual-carousel__dots {
  position: absolute;
  left: 50%;
  bottom: clamp(14px, 3vh, 28px);
  transform: translateX(-50%);
  display: inline-flex;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(10, 16, 22, 0.42);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.visual-carousel__dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  border: none;
  padding: 0;
  background: rgba(255, 255, 255, 0.38);
  cursor: pointer;
  transition:
    width 160ms ease,
    background 160ms ease;
}

.visual-carousel__dot[aria-selected='true'] {
  width: 24px;
  background: rgba(255, 255, 255, 0.92);
}

.visual-carousel__dot:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.9);
  outline-offset: 3px;
}

@media (max-width: 768px) {
  .home-visual-banner {
    min-height: 240px;
    max-height: 520px;
  }

  .visual-carousel__nav {
    width: 42px;
    height: 42px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .visual-carousel__track {
    transition: none;
  }

  .visual-carousel__nav,
  .visual-carousel__dot {
    transition: none;
  }
}
