.qr-code-directive {
  display: flex;
  flex: 1;
  justify-content: center;
  align-items: center;
  padding: 8px;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  flex-direction: column;
  overflow: hidden;
}

.qr-code-directive qrcode {
  display: flex;
  align-items: center;
}

.qr-code-directive img,
.qr-code-directive canvas {
  width: 100%;
  max-width: 480px;
  max-height: 480px;
  box-sizing: border-box;
}

.qr-code-directive .error-wrapper {
  display: flex;
  flex: 1;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

@media (orientation: landscape) {
  .qr-code-directive qrcode,
  .qr-code-directive img,
  .qr-code-directive qrcode canvas {
    width: auto;
    height: calc(35vh - var(--toolbar-height) - env(safe-area-inset-top, 0));
    object-fit: scale-down;
  }
}
