._popin-container {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 9999;
  background-color: rgba(0, 0, 0, 0.66);
  cursor: pointer;
  transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
}
._popin-container.open {
  opacity: 1;
  visibility: visible;
  pointer-events: inherit;
}
._popin-container .popin {
  max-height: calc(100vh - 90px);
  max-width: calc(100vw - 80px);
  box-sizing: border-box;
  position: fixed;
  top: 50%;
  left: 50%;
  margin-top: 10px;
  z-index: 10000;
  transform: translateX(-50%) translateY(-50%) translateZ(0);
  overflow: hidden;
  cursor: auto;
}
._popin-container .popin .close {
  line-height: 1;
  position: absolute;
  top: 0.75em;
  right: 0.75em;
}
._popin-container .popin .close::after {
  content: "✕";
}
._noscroll {
  overflow: hidden;
}
*[popin-open] {
  cursor: pointer;
}
*[popin-open] * {
  pointer-events: none;
}
