:host {
  position: relative;
  display: inline-flex;
  max-height: 100%;
  pointer-events: none;
}

  :host * {
    box-sizing: border-box;
  }

.file-viewer-image {
  display: inline-flex;
  margin: 0;
  justify-content: center;
}

.file-viewer-image--show-watermark .file-viewer-image__watermark {
    display: inline-flex;
  }

.file-viewer-image__container {
  position: relative;
  display: flex;
  max-width: 100%;
}

.file-viewer-image__image {
  max-width: 100%;
  pointer-events: auto;
  -o-object-fit: contain;
     object-fit: contain;
}

.file-viewer-image__watermark {
  position: absolute;
  z-index: 1;
  top: var(--s-space-12);
  right: var(--s-space-12);
  display: none;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  pointer-events: none;
}

.file-viewer-image__watermark ::slotted(img) {
    width: 3rem;
    height: auto;
    pointer-events: none;
  }

.file-viewer-image__spinner {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: rgba(0, 0, 0, 0.2);
  inset: 0;
}

.file-viewer-image__error {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
}
