:root {
  --parvus-transition-duration: 300ms;
  --parvus-transition-timing-function: cubic-bezier(0.62, 0.16, 0.13, 1.01);
  --parvus-overlay-color: var(--light_box);
  --parvus-overlay-text: var(--txt);
  --parvus-button-color: var(--box);
  --parvus-button-text: var(--txt);
  --parvus-button-hover-color: hsl(229, 24%, 33%);
  --parvus-button-hover-text: hsl(0, 0%, 100%);
  --parvus-caption-background-color: transparent;
  --parvus-caption-color: hsl(228, 24%, 23%);
  --parvus-error-loading-error-background-color: hsl(0, 0%, 100%);
  --parvus-image-loading-error-color: hsl(228, 24%, 23%);
  --parvus-loader-background-color: hsl(23, 40%, 96%);
  --parvus-loader-color: hsl(228, 24%, 23%);

}

.parvus-is-open {
  touch-action: none;
}

/**
 * Parvus trigger
 *
 */
.parvus-zoom {
  display: block;
  position: relative;
}
.parvus-zoom__indicator {
  align-items: center;
  background-color: var(--parvus-button-color);
  color: var(--parvus-button-text);
  display: none;
  justify-content: center;
  padding: 0.5rem;
  position: absolute;
  inset-inline-end: 0.5rem;
  inset-block-start: 0.5rem;
}
.parvus-zoom img {
  display: block;
}

/**
 * Parvus
 *
 */
.parvus {
  box-sizing: border-box;
  contain: strict;
  inset: 0;
  overflow: hidden;
  overscroll-behavior: contain;
  position: fixed;
  z-index: 1337;
}
.parvus *, .parvus *::before, .parvus *::after {
  box-sizing: border-box;
}
.parvus[aria-hidden=true] {
  display: none;
}
.parvus__overlay {
  background-color: var(--parvus-overlay-color);
  inset: 0;
  position: absolute;
}
.parvus__slider {
  inset: 0;
  position: absolute;
}
.parvus__slider[aria-hidden=true] {
  display: none;
}
@media screen and (prefers-reduced-motion: no-preference) {
  .parvus__slider--animate:not(.parvus__slider--is-dragging) {
    transition: transform var(--parvus-transition-duration) var(--parvus-transition-timing-function);
    will-change: transform;
  }
}
.parvus__slider--is-draggable {
  cursor: grab;
}
.parvus__slider--is-dragging {
  cursor: grabbing;
}
.parvus__slide {
  display: grid;
  block-size: 100%;
  justify-content: center;
  padding-block-end: 1rem;
  padding-block-start: 3.75rem;
  padding-inline-end: 1rem;
  padding-inline-start: 1rem;
  place-items: center;
  inline-size: 100%;
}
.parvus__slide img {
  display: block;
  block-size: auto;
  margin-inline-start: auto;
  margin-inline-end: auto;
  transform-origin: left top;
  inline-size: auto;
}
.parvus__content--error {
  background-color: var(--parvus-error-loading-error-background-color);
  color: var(--parvus-error-loading-error-color);
  padding-block: 0.5rem;
  padding-inline: 1rem;
}
.parvus__caption {
  background-color: var(--parvus-caption-background-color);
  color: var(--parvus-caption-color);
  padding-block-start: 0.5rem;
  text-align: start;
}
.parvus__loader {
  display: inline-block;
  block-size: 6.25rem;
  inset-inline-start: 50%;
  position: absolute;
  inset-block-start: 50%;
  transform: translate(-50%, -50%);
  inline-size: 6.25rem;
}
.parvus__loader::before {
  animation: spin 1s infinite;
  border-radius: 100%;
  border: 0.25rem solid var(--parvus-loader-background-color);
  border-top-color: var(--parvus-loader-color);
  content: "";
  inset: 0;
  position: absolute;
  z-index: 1;
}
.parvus__toolbar {
  align-items: center;
  display: flex;
  justify-content: space-between;
  inset-inline-start: 1rem;
  position: absolute;
  inset-inline-end: 1rem;
  inset-block-start: 1rem;
}
.parvus__controls {
  display: flex;
  gap: 0.5rem;
}
.parvus__btn {
  appearance: none;
  background-color: var(--parvus-button-color);
  background-image: none;
  border-radius: 0;
  border: 0.0625rem solid transparent;
  color: var(--parvus-button-text);
  cursor: pointer;
  display: flex;
  font: inherit;
  padding: 0.3125rem;
  position: relative;
  touch-action: manipulation;
  will-change: transform, opacity;
  z-index: 7;
}
.parvus__btn:hover {
  background-color: var(--parvus-button-hover-color);
  color: var(--parvus-button-hover-text);
}
.parvus__btn--previous {
  inset-inline-start: 0;
  position: absolute;
  inset-block-start: calc(50vh - 1rem);
  transform: translateY(-50%);
}
.parvus__btn--next {
  position: absolute;
  inset-inline-end: 0;
  inset-block-start: calc(50vh - 1rem);
  transform: translateY(-50%);
}
.parvus__btn svg {
  pointer-events: none;
}
.parvus__btn[aria-hidden=true] {
  display: none;
}
.parvus__counter {
  position: relative;
  z-index: 7;
}
.parvus__counter[aria-hidden=true] {
  display: none;
}
@media screen and (prefers-reduced-motion: no-preference) {
  .parvus__overlay, .parvus__counter, .parvus__btn--close, .parvus__btn--previous, .parvus__btn--next, .parvus__caption {
    transition: transform var(--parvus-transition-duration) var(--parvus-transition-timing-function), opacity var(--parvus-transition-duration) var(--parvus-transition-timing-function);
    will-change: transform, opacity;
  }
  .parvus--is-opening .parvus__overlay, .parvus--is-opening .parvus__counter, .parvus--is-opening .parvus__btn--close, .parvus--is-opening .parvus__btn--previous, .parvus--is-opening .parvus__btn--next, .parvus--is-opening .parvus__caption, .parvus--is-closing .parvus__overlay, .parvus--is-closing .parvus__counter, .parvus--is-closing .parvus__btn--close, .parvus--is-closing .parvus__btn--previous, .parvus--is-closing .parvus__btn--next, .parvus--is-closing .parvus__caption {
    opacity: 0;
  }
  .parvus--is-vertical-closing .parvus__counter, .parvus--is-vertical-closing .parvus__btn--close {
    transform: translateY(-100%);
    opacity: 0;
  }
  .parvus--is-vertical-closing .parvus__btn--previous {
    transform: translate(-100%, -50%);
    opacity: 0;
  }
  .parvus--is-vertical-closing .parvus__btn--next {
    transform: translate(100%, -50%);
    opacity: 0;
  }
  .parvus--is-vertical-closing .parvus__caption {
    transform: translateY(100%);
    opacity: 0;
  }
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}