body.lightbox-open {
  position: fixed;
  inset: 0;
  width: 100%;
  overflow: hidden;
}

.is-lightboxable {
  cursor: zoom-in;
}

.is-lightboxable:focus-visible {
  outline: 2px solid rgba(97, 166, 151, .34);
  outline-offset: 4px;
}

.svh-lightbox {
  position: fixed;
  inset: 0;
  z-index: 1100;
  display: grid;
  place-items: center;
  padding: clamp(12px, 3vw, 32px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .22s ease;
}

.svh-lightbox[hidden] {
  display: none;
}

.svh-lightbox.is-open {
  opacity: 1;
  pointer-events: auto;
}

.svh-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 8%, rgba(112, 170, 154, .2), transparent 26%),
    radial-gradient(circle at 82% 88%, rgba(186, 143, 96, .16), transparent 30%),
    rgba(5, 9, 9, .86);
  -webkit-backdrop-filter: blur(12px) saturate(118%);
  backdrop-filter: blur(12px) saturate(118%);
}

.svh-lightbox__dialog {
  position: relative;
  z-index: 1;
  width: min(1220px, 100%);
  max-height: 100%;
  overflow: auto;
  overscroll-behavior: contain;
}

.svh-lightbox__dialog::-webkit-scrollbar {
  width: 0;
}

.svh-lightbox__panel {
  display: grid;
  gap: 14px;
  margin: 0;
  opacity: 0;
  transform: translateY(14px) scale(.986);
  transition: transform .28s cubic-bezier(.2, .8, .2, 1), opacity .22s ease;
}

.svh-lightbox.is-open .svh-lightbox__panel {
  opacity: 1;
  transform: none;
}

.svh-lightbox__stage {
  position: relative;
  display: grid;
  place-items: center;
  min-height: min(72svh, 780px);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(103, 161, 148, .16), transparent 30%),
    linear-gradient(180deg, rgba(18, 27, 25, .94), rgba(8, 13, 12, .94));
  box-shadow:
    0 34px 90px rgba(0, 0, 0, .42),
    inset 0 1px 0 rgba(255, 255, 255, .08);
}

.svh-lightbox__img {
  width: 100%;
  max-height: min(76svh, 880px);
  object-fit: contain;
  padding: clamp(12px, 2vw, 18px) clamp(72px, 7vw, 96px);
  border-radius: 22px;
  transition: opacity .22s ease, transform .24s ease;
}

.svh-lightbox.is-loading .svh-lightbox__img {
  opacity: .32;
  transform: scale(.992);
}

.svh-lightbox__counter,
.svh-lightbox__close,
.svh-lightbox__nav {
  position: absolute;
  z-index: 2;
}

.svh-lightbox__counter {
  top: clamp(12px, 2vw, 18px);
  left: clamp(12px, 2vw, 18px);
  margin: 0;
  padding: 7px 12px;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 999px;
  background: rgba(11, 18, 17, .68);
  color: rgba(246, 250, 248, .9);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
}

.svh-lightbox__counter:empty {
  display: none;
}

.svh-lightbox__close,
.svh-lightbox__nav {
  width: 52px;
  height: 52px;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 18px;
  background: rgba(18, 29, 27, .72);
  -webkit-backdrop-filter: blur(10px) saturate(120%);
  backdrop-filter: blur(10px) saturate(120%);
  box-shadow: 0 16px 34px rgba(0, 0, 0, .24);
  color: rgba(248, 252, 250, .96);
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}

.svh-lightbox__close {
  top: clamp(12px, 2vw, 18px);
  right: clamp(12px, 2vw, 18px);
}

.svh-lightbox__nav--prev {
  left: clamp(12px, 2vw, 18px);
}

.svh-lightbox__nav--next {
  right: clamp(12px, 2vw, 18px);
}

.svh-lightbox__nav {
  top: 50%;
  transform: translateY(-50%);
}

.svh-lightbox__close:hover,
.svh-lightbox__nav:hover,
.svh-lightbox__close:focus-visible,
.svh-lightbox__nav:focus-visible {
  background: rgba(35, 52, 48, .82);
  border-color: rgba(137, 201, 185, .34);
}

.svh-lightbox__close:active {
  transform: scale(.98);
}

.svh-lightbox__nav:active {
  transform: translateY(-50%) scale(.98);
}

.svh-lightbox__close svg,
.svh-lightbox__nav svg {
  width: 24px;
  height: 24px;
}

.svh-lightbox__close path,
.svh-lightbox__nav path {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.svh-lightbox.is-single .svh-lightbox__nav {
  display: none;
}

.svh-lightbox__caption {
  display: grid;
  gap: 7px;
  max-width: min(76ch, 100%);
  padding: 0 4px;
  color: rgba(246, 251, 248, .92);
}

.svh-lightbox__title,
.svh-lightbox__text,
.svh-lightbox__description {
  margin: 0;
}

.svh-lightbox__title {
  font-size: 1rem;
}

.svh-lightbox__text {
  color: rgba(255, 255, 255, .78);
}

.svh-lightbox__description {
  color: rgba(255, 255, 255, .62);
  font-size: .94rem;
}

@media (max-width: 720px) {
  .svh-lightbox {
    padding: 10px;
  }

  .svh-lightbox__stage {
    min-height: min(68svh, 620px);
    border-radius: 22px;
  }

  .svh-lightbox__img {
    max-height: min(68svh, 620px);
    padding: 64px 10px 76px;
  }

  .svh-lightbox__close,
  .svh-lightbox__nav {
    width: 44px;
    height: 44px;
    border-radius: 16px;
  }

  .svh-lightbox__nav {
    top: auto;
    bottom: 14px;
    transform: none;
  }

  .svh-lightbox__nav--prev {
    left: calc(50% - 52px);
  }

  .svh-lightbox__nav--next {
    right: calc(50% - 52px);
  }

  .svh-lightbox__nav:active {
    transform: scale(.98);
  }
}
