:root {
  --onmacabim-viewport-height: 100vh;
}

@supports (height: 100dvh) {
  :root {
    --onmacabim-viewport-height: 100dvh;
  }
}

html {
  -webkit-text-size-adjust: 100%;
}

body {
  min-height: 100%;
}

#captcha-modal,
#pay-verify-modal,
#pay-summary-modal,
#result-modal {
  overscroll-behavior: contain;
}

#captcha-modal .modal-dialog,
#pay-verify-modal .modal-dialog,
#pay-summary-modal .modal-dialog,
#result-modal .modal-dialog {
  min-height: calc(var(--onmacabim-viewport-height) - 2rem);
  display: flex;
  align-items: center;
}

#captcha-modal .modal-content,
#pay-verify-modal .modal-content,
#pay-summary-modal .modal-content,
#result-modal .modal-content {
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
}

#captcha-modal .modal-body,
#pay-verify-modal .modal-body,
#pay-summary-modal .modal-body,
#result-modal .modal-body {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

#pay-square-card-container {
  min-height: 180px;
  align-items: stretch;
}

#pay-square-card-container > *,
#pay-square-card-container iframe {
  width: 100% !important;
  max-width: 100%;
}

@media (max-width: 575.98px) {
  #captcha-modal .modal-dialog,
  #pay-verify-modal .modal-dialog,
  #pay-summary-modal .modal-dialog,
  #result-modal .modal-dialog {
    margin-top: calc(env(safe-area-inset-top, 0px) + 0.5rem);
    margin-bottom: calc(env(safe-area-inset-bottom, 0px) + 0.5rem);
    min-height: calc(
      var(--onmacabim-viewport-height) - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 1rem
    );
  }

  #captcha-modal .modal-content,
  #pay-verify-modal .modal-content,
  #pay-summary-modal .modal-content,
  #result-modal .modal-content {
    border-radius: 16px;
  }

  #captcha-modal .modal-body,
  #pay-verify-modal .modal-body,
  #pay-summary-modal .modal-body,
  #result-modal .modal-body {
    padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 1rem);
  }
}
