dialog {
  inline-size: 80vw;
  margin: auto;
  animation: fade-out 0.3s ease-out;

  &::backdrop {
    background: black;
    opacity: 0.5;
  }

  header {
    display: flex;
    align-items: center;

    h2 {
      flex: 0 1 100%;
    }
  }
}

dialog[open] {
  animation: fade-in 0.3s ease-out;
}

dialog[open]::backdrop {
  animation: backdrop-fade-in 0.3s ease-out forwards;
}

/* ------------------------------------------------------------------ */
/* Shared modal partial                                                */
/* ------------------------------------------------------------------ */

.shared-modal {
  position: fixed;
  inset: 0;
  align-items: center;
  justify-content: center;
  inline-size: 100%;
  block-size: 100%;
  background: rgb(var(--palette-black) / 0.7);
}

.shared-modal--hidden {
  display: none;
}

.shared-modal--shown {
  display: flex;
}

.shared-modal__panel {
  inline-size: 91.6667%;
  margin-inline: auto;
  border-radius: var(--radius-sm);
  background-color: var(--color-surface);
  box-shadow: var(--shadow-lg);
}

@media (min-width: 768px) {
  .shared-modal__panel {
    max-inline-size: 36rem;
  }
}

@media (min-width: 1024px) {
  .shared-modal__panel {
    max-inline-size: 48rem;
  }
}

.shared-modal__content {
  padding-block: 1rem;
  padding-inline: 1.5rem;
  text-align: start;
}

.shared-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block-end: 0.75rem;
}

.shared-modal__title {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 700;
}

.shared-modal__close {
  z-index: 50;
  cursor: pointer;
}

.shared-modal__close-icon {
  color: var(--color-ink);
  fill: currentColor;
}

.shared-modal__body {
  margin-block: 1.25rem;
}

/* ------------------------------------------------------------------ */
/* Turbo modal component                                               */
/* ------------------------------------------------------------------ */

.turbo-modal {
  min-inline-size: 20rem;
  padding-block: 1.5rem 1rem;
  padding-inline: 2.5rem;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
}

.turbo-modal--prose {
  max-inline-size: 65ch;
}

.turbo-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-block-end: 0.5rem;
}

.turbo-modal__title {
  margin: 0;
  color: var(--color-ink);
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.5rem; /* leading-6 */
}

.turbo-modal__close {
  z-index: 50;
  flex-shrink: 0;
  cursor: pointer;
}

.turbo-modal__close-icon {
  color: var(--color-ink);
  fill: currentColor;
}

.turbo-modal__content {
  margin-block: 1.25rem;
}

/* Animation keyframes */

@keyframes fade-in {
  0% {
    opacity: 0;
    transform: scaleY(0);
    display: none;
  }

  100% {
    opacity: 1;
    transform: scaleY(1);
    display: block;
  }
}

@keyframes fade-out {
  0% {
    opacity: 1;
    transform: scaleY(1);
    display: block;
  }

  100% {
    opacity: 0;
    transform: scaleY(0);
    display: none;
  }
}

@keyframes backdrop-fade-in {
  0% {
    background-color: rgb(var(--palette-black) / 0%);
  }

  100% {
    background-color: rgb(var(--palette-black) / 25%);
  }
}
