.mirror-welcome-overlay {
  z-index: 100000;
}

.mirror-welcome-overlay .popup-middleware-bc {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 100%;
  padding: max(0.75rem, env(safe-area-inset-top)) max(0.75rem, env(safe-area-inset-right))
    max(0.75rem, env(safe-area-inset-bottom)) max(0.75rem, env(safe-area-inset-left));
  box-sizing: border-box;
}

.mirror-welcome-card {
  position: relative;
  flex: 0 1 auto;
  width: min(96vw, 42rem, calc((100dvh - 4rem) * 1024 / 684));
  max-width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
}

.mirror-welcome-cta {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  border-radius: clamp(0.35rem, 1.2vw, 0.65rem);
  overflow: hidden;
  box-shadow: 0 1.25rem 3rem rgba(0, 0, 0, 0.65);
  touch-action: manipulation;
}

.mirror-welcome-cta:focus-visible {
  outline: 2px solid rgba(242, 221, 176, 0.85);
  outline-offset: 3px;
}

.mirror-welcome-cta img {
  display: block;
  width: 100%;
  height: auto;
  max-height: calc(100dvh - 4rem);
  aspect-ratio: 1024 / 684;
  object-fit: contain;
  object-position: center;
  pointer-events: none;
}

.mirror-welcome-close {
  position: absolute;
  top: clamp(0.35rem, 1.5vw, 0.65rem);
  right: clamp(0.35rem, 1.5vw, 0.65rem);
  z-index: 2;
  width: clamp(2rem, 8vw, 2.5rem);
  height: clamp(2rem, 8vw, 2.5rem);
  border: none;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  font-size: clamp(1.1rem, 4vw, 1.35rem);
  line-height: 1;
  cursor: pointer;
  touch-action: manipulation;
}

.mirror-welcome-close:hover {
  background: rgba(0, 0, 0, 0.75);
}

html.mirror-welcome-open {
  overflow: hidden;
}

@media (max-width: 1023px) {
  html.is-mobile .mirror-welcome-overlay.popup-holder-bc {
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100vw !important;
    padding: 0 !important;
    inset: 0 !important;
    box-sizing: border-box !important;
  }

  html.is-mobile .mirror-welcome-overlay .popup-middleware-bc {
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 100% !important;
    padding: max(clamp(0.4rem, 2.5vw, 0.85rem), env(safe-area-inset-top))
      max(clamp(0.4rem, 2.5vw, 0.85rem), env(safe-area-inset-right))
      max(clamp(0.4rem, 2.5vw, 0.85rem), env(safe-area-inset-bottom))
      max(clamp(0.4rem, 2.5vw, 0.85rem), env(safe-area-inset-left)) !important;
  }

  html.is-mobile .mirror-welcome-card {
    width: min(
      calc(100vw - 2 * clamp(0.4rem, 2.5vw, 0.85rem)),
      calc((100dvh - 5rem) * 1024 / 684)
    );
    max-width: 100%;
  }

  html.is-mobile .mirror-welcome-cta {
    width: 100%;
    border-radius: clamp(0.25rem, 1vw, 0.5rem);
    box-shadow: 0 0.75rem 2rem rgba(0, 0, 0, 0.55);
  }

  html.is-mobile .mirror-welcome-cta img {
    width: 100%;
    height: auto;
    max-height: calc(100dvh - 5rem);
    aspect-ratio: 1024 / 684;
    object-fit: contain;
    object-position: center;
  }

  html.is-mobile .mirror-welcome-close {
    top: clamp(0.25rem, 1.2vw, 0.5rem);
    right: clamp(0.25rem, 1.2vw, 0.5rem);
    width: clamp(1.85rem, 9vw, 2.35rem);
    height: clamp(1.85rem, 9vw, 2.35rem);
  }
}
