body.modal-open {
  overflow: hidden;
  position: fixed;
  width: 100%;
}

body.modal-open .layout {
  pointer-events: none;
}

body.modal-open #modal-root {
  pointer-events: auto;
}

.modal {
  align-items: flex-start;
  padding: 14px;
}

.modal::before {
  content: "";
  display: block;
  min-height: 4px;
}

.modal-card {
  margin: auto;
  max-height: calc(100dvh - 28px);
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

.modal-card--wide {
  width: min(680px, 96vw);
}

.modal-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}

.modal-head h3 {
  margin: 0;
}

.modal-note {
  margin-top: 6px;
}

.modal-section {
  margin-top: 10px;
}

.modal-grid {
  margin-top: 8px;
}

.modal-actions-end {
  margin-top: 10px;
  justify-content: flex-end;
}

.modal-actions-between {
  margin-top: 10px;
  justify-content: space-between;
  align-items: center;
}

@media (max-width: 960px) {
  .modal-card,
  .modal-card--wide {
    width: min(100%, 760px);
    padding: 14px;
  }

  .modal-head {
    flex-direction: column;
    align-items: stretch;
  }

  .modal-actions-end,
  .modal-actions-between {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
}

@media (max-width: 760px) {
  .modal {
    padding: 10px;
  }

  .modal-card,
  .modal-card--wide {
    width: 100%;
    max-height: calc(100dvh - 20px);
    border-radius: 10px;
    padding: 12px;
  }

  .modal-actions-end > *,
  .modal-actions-between > * {
    width: 100%;
  }
}
