@media only screen and (max-width: 600px) {
  .souvenir-modal-wrapper {
    min-width: calc(90vw - 2em);
  }
}

@media only screen and (min-width: 601px) {
    .souvenir-modal-wrapper {
      min-width: 400px;
    }
}

.souvenir-modal-wrapper {
    padding: 0.75em 1em;
    margin: 1em auto;
    max-width: 24em;
    width: 80%;
    display: flex;
    filter: drop-shadow(0 0.2rem 0.3rem #000000a8);
    font-weight: bold;
    p {
        padding: 0 1em;
        line-height: 32px;
        margin: 0;
    }
}

.souvenir-wrapper {
  margin: 0.25em 0.5em;
  display: inline-block;
  position: relative;
  p {
    display: none;
  }
}

.souvenir-wrapper::after {
  content: "";
  position: absolute;
  bottom: calc(5%);
  left: calc(25% - 4px);
  width: calc(50% + 8px);
  height: calc(25% + 8px);
  z-index: 90;
  background: rgba(var(--primary-color), 0.05);
  border: 2px solid rgba(var(--primary-color), 0.1);
  border-radius: 50%;
  box-sizing: border-box;
  pointer-events: none;
}

.souvenir-wrapper:hover::after {
  border: 2px solid var(--highlight);
}

img.souvenir {
  margin: 0.5em;
  display: block;
  filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.6)) drop-shadow(0 -0.1rem 0.5rem rgba(var(--primary-color), 0.4));
  z-index: 100;
  position: relative;
  cursor: pointer;
}

.souvenir-modal-wrapper {
  z-index: 10000;
  width: 40%;
  min-height: 400px;
  margin: auto;
  display: flex;
  justify-content: flex-end;
  background-color: var(--background-secondary);
  padding: 1em;
  border-radius: 0.5em;

  .souvenir-modal-preview {
    width: 30%;
    max-width: 400px;
    min-width: 150px;
    padding: 2em;
    display: flex;
  }
}

.souvenir-modal-gallery-wrapper {
  margin: auto;
  display: flex;
}

.souvenir-modal-gallery {
  position: relative;
  margin: auto;
  img {
    cursor: pointer;
    border: 2px solid transparent;
    transition: border 0.2s;
    position: absolute;
    image-rendering: pixelated;
    filter: drop-shadow(0px 1px 0.05rem rgba(0, 0, 0, 0.6));
  }

    img.active-souvenir {
        filter: drop-shadow(0 2px 0.3rem var(--highlight));
        image-rendering: pixelated;
    }
}

.souvenir-preview {
  width: 80%;
  margin: 2em auto;
  margin-top: auto;
  display: block;
  image-rendering: pixelated;
}

.souvenir-page {
  font-size: 0.8em;
  text-align: center;
  width: 100%;
  padding: 1em;
  background: var(--background);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
}