.auth-dialog {
  color-scheme: light;
  width: min(calc(100dvw - 28px), 470px);
  max-height: min(88dvh, 720px);
  margin: auto;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--ink);
  opacity: 0;
  transform: translateY(14px) scale(.975);
  transition:
    opacity 220ms ease,
    transform 220ms cubic-bezier(.2, .8, .2, 1),
    overlay 220ms ease allow-discrete,
    display 220ms ease allow-discrete;
}

.auth-dialog[open] {
  opacity: 1;
  transform: translateY(0) scale(1);
}

@starting-style {
  .auth-dialog[open] {
    opacity: 0;
    transform: translateY(18px) scale(.96);
  }
}

.auth-dialog::backdrop {
  background:
    linear-gradient(115deg, rgba(12, 18, 27, .68), rgba(31, 38, 48, .46) 46%, rgba(20, 130, 113, .32)),
    linear-gradient(0deg, rgba(245, 239, 229, .18), rgba(245, 239, 229, .04));
  backdrop-filter: blur(12px) saturate(1.16);
  opacity: 0;
  transition:
    opacity 220ms ease,
    overlay 220ms ease allow-discrete,
    display 220ms ease allow-discrete;
}

.auth-dialog[open]::backdrop {
  opacity: 1;
}

@starting-style {
  .auth-dialog[open]::backdrop {
    opacity: 0;
  }
}

.auth-dialog-frame {
  --auth-surface: #fffaf2;
  --auth-panel: rgba(255, 255, 255, .7);
  --auth-border: rgba(31, 38, 48, .14);
  --auth-field: rgba(255, 255, 255, .84);
  --auth-focus: rgba(241, 100, 63, .24);
  container: auth-dialog / inline-size;
  isolation: isolate;
  position: relative;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  max-height: min(88dvh, 720px);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .72);
  border-radius: 24px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, .94), rgba(255, 250, 242, .9) 44%, rgba(237, 246, 242, .9)),
    var(--auth-surface);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, .88) inset,
    0 28px 70px rgba(13, 20, 31, .34),
    0 8px 22px rgba(31, 38, 48, .16);
}

.auth-dialog-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(241, 100, 63, .28), rgba(32, 153, 137, .22), rgba(246, 216, 79, .28)) top / 100% 4px no-repeat,
    repeating-linear-gradient(135deg, rgba(31, 38, 48, .04) 0 1px, transparent 1px 13px);
  opacity: .78;
  pointer-events: none;
}

.auth-dialog-frame::after {
  content: "";
  position: absolute;
  inset: 1px;
  z-index: -1;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255, 255, 255, .74), rgba(255, 255, 255, 0) 30%);
  pointer-events: none;
}

@supports (corner-shape: squircle) {
  .auth-dialog-frame {
    corner-shape: squircle;
  }
}

.auth-dialog-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  min-height: 86px;
  padding: 18px 18px 14px;
  border-bottom: 1px solid rgba(31, 38, 48, .1);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .86), rgba(255, 255, 255, .48)),
    rgba(255, 250, 242, .7);
}

.auth-dialog-brand {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-width: 0;
}

.auth-logo-tile {
  display: grid;
  place-items: center;
  width: 54px;
  aspect-ratio: 1;
  border: 1px solid rgba(255, 255, 255, .82);
  border-radius: 18px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, .92), rgba(255, 249, 241, .58)),
    rgba(255, 255, 255, .78);
  box-shadow:
    0 12px 26px rgba(31, 38, 48, .13),
    0 1px 0 rgba(255, 255, 255, .82) inset;
}

.auth-dialog-brand img {
  display: block;
  width: 43px;
  height: 38px;
  object-fit: contain;
  filter: drop-shadow(0 5px 8px rgba(31, 38, 48, .12));
}

.auth-brand-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.auth-brand-name {
  color: #148271;
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1.1;
  text-transform: uppercase;
}

.auth-dialog-header h2 {
  margin: 0;
  color: #182332;
  font-family: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
  font-size: 1.34rem;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.08;
  text-wrap: balance;
}

.auth-icon-button {
  position: relative;
  display: grid;
  place-items: center;
  width: 42px;
  aspect-ratio: 1;
  border: 1px solid rgba(31, 38, 48, .13);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .92), rgba(255, 255, 255, .58)),
    rgba(255, 255, 255, .78);
  color: var(--ink);
  cursor: pointer;
  box-shadow:
    0 10px 22px rgba(31, 38, 48, .1),
    0 1px 0 rgba(255, 255, 255, .9) inset;
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease,
    background-color 160ms ease;
}

.auth-icon-button:hover {
  border-color: rgba(241, 100, 63, .42);
  box-shadow:
    0 14px 28px rgba(31, 38, 48, .14),
    0 0 0 4px rgba(241, 100, 63, .1);
  transform: translateY(-1px);
}

.auth-icon-button:active {
  transform: translateY(0) scale(.98);
}

.auth-icon-button:focus-visible,
.auth-switch-button:focus-visible,
.auth-password-toggle:focus-visible,
.auth-form-actions button:focus-visible,
.auth-primary-button:focus-visible {
  outline: 3px solid rgba(241, 100, 63, .44);
  outline-offset: 3px;
}

.auth-close-glyph {
  position: relative;
  width: 16px;
  aspect-ratio: 1;
  display: block;
}

.auth-close-glyph::before,
.auth-close-glyph::after {
  content: "";
  position: absolute;
  width: 14px;
  height: 2px;
  inset: 0;
  margin: auto;
  border-radius: 999px;
  background: #33404d;
}

.auth-close-glyph::before {
  transform: rotate(45deg);
}

.auth-close-glyph::after {
  transform: rotate(-45deg);
}

.auth-dialog-body {
  display: grid;
  gap: 18px;
  overflow-y: auto;
  padding: 18px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .24), rgba(255, 255, 255, .02)),
    rgba(255, 250, 242, .48);
  scrollbar-gutter: stable;
  overscroll-behavior: contain;
}

.auth-view-switch {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  min-height: 50px;
  padding: 4px;
  border: 1px solid rgba(31, 38, 48, .12);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .68), rgba(255, 255, 255, .4)),
    rgba(245, 239, 229, .7);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, .82) inset,
    0 14px 28px rgba(31, 38, 48, .08);
}

.auth-view-switch::before {
  content: "";
  position: absolute;
  inset: 4px auto 4px 4px;
  width: calc(50% - 4px);
  border-radius: 14px;
  background:
    linear-gradient(145deg, #1f2630, #384453),
    #1f2630;
  box-shadow:
    0 12px 22px rgba(31, 38, 48, .22),
    0 1px 0 rgba(255, 255, 255, .16) inset;
  transform: translateX(0);
  transition:
    transform 210ms cubic-bezier(.2, .8, .2, 1),
    opacity 170ms ease;
}

.auth-dialog[data-current-view="signup"] .auth-view-switch::before {
  transform: translateX(100%);
}

.auth-dialog[data-current-view^="password-reset"] .auth-view-switch::before,
.auth-dialog[data-current-view="passkey-setup"] .auth-view-switch::before {
  opacity: 0;
}

.auth-switch-button {
  position: relative;
  z-index: 1;
  min-height: 42px;
  border: 0;
  border-radius: 14px;
  background: transparent;
  color: #56616f;
  cursor: pointer;
  font-weight: 900;
  letter-spacing: 0;
  transition:
    color 160ms ease,
    transform 160ms ease;
}

.auth-switch-button:hover {
  color: #1f2630;
}

.auth-switch-button.is-active {
  color: #fffaf2;
}

.auth-form {
  display: grid;
  gap: 14px;
  padding: 4px 2px 2px;
  animation: auth-view-in 220ms cubic-bezier(.2, .8, .2, 1);
}

.auth-form[hidden] {
  display: none;
}

@keyframes auth-view-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.auth-field {
  display: grid;
  gap: 7px;
}

.auth-field > span,
.auth-field > label span {
  color: #56616f;
  font-size: .75rem;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1.15;
  text-transform: uppercase;
  transition: color 160ms ease;
}

.auth-field:has(input:focus-visible) > span,
.auth-field:has(input:focus-visible) > label span {
  color: #d34f2c;
}

.auth-field input {
  width: 100%;
  min-height: 54px;
  border: 1px solid rgba(31, 38, 48, .14);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .94), rgba(255, 255, 255, .72)),
    var(--auth-field);
  color: var(--ink);
  caret-color: var(--accent-deep);
  font: inherit;
  font-size: 1rem;
  outline: 0;
  padding: 13px 14px;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, .9) inset,
    0 10px 22px rgba(31, 38, 48, .06);
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    background-color 160ms ease,
    transform 160ms ease;
}

.auth-field input:hover {
  border-color: rgba(31, 38, 48, .22);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, .9) inset,
    0 14px 28px rgba(31, 38, 48, .09);
}

.auth-field input:focus-visible {
  border-color: rgba(241, 100, 63, .74);
  box-shadow:
    0 0 0 4px var(--auth-focus),
    0 16px 32px rgba(241, 100, 63, .11);
  transform: translateY(-1px);
}

.auth-field input:user-valid {
  border-color: rgba(32, 153, 137, .56);
}

.auth-field input:user-invalid {
  border-color: rgba(211, 79, 44, .74);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .94), rgba(255, 244, 240, .86)),
    #fff4f0;
}

.auth-field input:-webkit-autofill {
  -webkit-text-fill-color: var(--ink);
  box-shadow: 0 0 0 1000px #fffaf2 inset;
}

.auth-password-control {
  position: relative;
  display: grid;
}

.auth-password-control input {
  padding-right: 58px;
}

.auth-password-toggle {
  position: absolute;
  top: 50%;
  right: 8px;
  display: grid;
  place-items: center;
  width: 40px;
  aspect-ratio: 1;
  border: 1px solid rgba(31, 38, 48, .12);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .9), rgba(255, 255, 255, .62)),
    rgba(255, 255, 255, .78);
  color: #56616f;
  cursor: pointer;
  transform: translateY(-50%);
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    color 160ms ease,
    background-color 160ms ease;
}

.auth-password-toggle:hover {
  border-color: rgba(241, 100, 63, .36);
  color: #d34f2c;
  box-shadow: 0 0 0 4px rgba(241, 100, 63, .1);
}

.auth-password-toggle:disabled {
  cursor: default;
  opacity: .62;
}

.auth-eye-glyph {
  position: relative;
  display: block;
  width: 20px;
  height: 14px;
  border: 2px solid currentColor;
  border-radius: 999px / 720px;
}

.auth-eye-glyph::before {
  content: "";
  position: absolute;
  inset: 3px 6px;
  border-radius: 999px;
  background: currentColor;
}

.auth-eye-glyph::after {
  content: "";
  position: absolute;
  left: 8px;
  top: -5px;
  width: 2px;
  height: 24px;
  border-radius: 999px;
  background: currentColor;
  opacity: 0;
  transform: rotate(45deg);
  transition: opacity 160ms ease;
}

.auth-password-toggle.is-visible {
  color: #148271;
}

.auth-password-toggle.is-visible .auth-eye-glyph::after {
  opacity: 1;
}

.auth-form:has(input:user-invalid) .auth-primary-button {
  opacity: .76;
}

.auth-form-message {
  margin: 0;
  padding: 12px 13px;
  border: 1px solid rgba(211, 79, 44, .18);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .74), rgba(255, 255, 255, .42)),
    rgba(241, 100, 63, .12);
  color: var(--accent-deep);
  font-size: .9rem;
  font-weight: 850;
  line-height: 1.35;
  box-shadow: 0 10px 22px rgba(31, 38, 48, .06);
}

.auth-form-message.is-success {
  border-color: rgba(32, 153, 137, .22);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .74), rgba(255, 255, 255, .42)),
    rgba(32, 153, 137, .12);
  color: #148271;
}

.auth-primary-button {
  position: relative;
  min-height: 54px;
  overflow: hidden;
  border: 0;
  border-radius: 16px;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .18), transparent 36%, rgba(255, 255, 255, .14) 70%, transparent),
    linear-gradient(145deg, var(--accent), #d34f2c 48%, #b84427);
  color: white;
  cursor: pointer;
  font-weight: 950;
  letter-spacing: 0;
  box-shadow:
    0 18px 34px rgba(211, 79, 44, .28),
    0 1px 0 rgba(255, 255, 255, .28) inset;
  transition:
    filter 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease;
}

.auth-primary-button:hover {
  filter: saturate(1.08) brightness(1.03);
  box-shadow:
    0 22px 42px rgba(211, 79, 44, .32),
    0 1px 0 rgba(255, 255, 255, .28) inset;
  transform: translateY(-1px);
}

.auth-primary-button:active {
  transform: translateY(0) scale(.995);
}

.auth-primary-button:disabled {
  cursor: default;
  filter: grayscale(.2);
  opacity: .62;
  transform: none;
}

.auth-secondary-button {
  min-height: 50px;
  border: 1px solid rgba(31, 38, 48, .14);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .86), rgba(255, 255, 255, .6)),
    rgba(255, 255, 255, .72);
  color: #1f2630;
  cursor: pointer;
  font-weight: 900;
  letter-spacing: 0;
  box-shadow:
    0 12px 24px rgba(31, 38, 48, .08),
    0 1px 0 rgba(255, 255, 255, .9) inset;
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease;
}

.auth-secondary-button:hover {
  border-color: rgba(32, 153, 137, .34);
  box-shadow:
    0 16px 30px rgba(31, 38, 48, .12),
    0 0 0 4px rgba(32, 153, 137, .09);
  transform: translateY(-1px);
}

.auth-secondary-button:focus-visible {
  outline: 3px solid rgba(32, 153, 137, .32);
  outline-offset: 3px;
}

.auth-secondary-button:disabled {
  cursor: default;
  opacity: .62;
  transform: none;
}

.auth-passkey-view {
  text-align: center;
}

.auth-form-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  min-height: 34px;
}

.auth-form-actions button {
  min-height: 34px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: #56616f;
  cursor: pointer;
  font: inherit;
  font-size: .9rem;
  font-weight: 850;
  letter-spacing: 0;
  padding: 6px 10px;
  transition:
    background-color 160ms ease,
    border-color 160ms ease,
    color 160ms ease,
    transform 160ms ease;
}

.auth-form-actions button:hover {
  border-color: rgba(31, 38, 48, .1);
  background: rgba(255, 255, 255, .58);
  color: #1f2630;
  transform: translateY(-1px);
}

.auth-form-actions button:active {
  transform: translateY(0);
}

.auth-form.is-auth-busy .auth-primary-button[type="submit"] {
  color: transparent;
  pointer-events: none;
  text-shadow: none;
}

.auth-form.is-auth-busy .auth-primary-button[type="submit"]::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 20px;
  aspect-ratio: 1;
  margin: auto;
  border: 2px solid rgba(255, 255, 255, .48);
  border-top-color: #fff;
  border-radius: 999px;
  animation: auth-button-spin 720ms linear infinite;
}

.signup-notice-dialog,
.signup-welcome-dialog {
  color-scheme: light;
  width: min(calc(100dvw - 28px), 460px);
  max-height: min(88dvh, 620px);
  margin: auto;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--ink);
}

.signup-notice-dialog::backdrop,
.signup-welcome-dialog::backdrop {
  background: rgba(15, 23, 42, .5);
  backdrop-filter: blur(8px);
}

.signup-notice-frame,
.signup-welcome-frame {
  display: grid;
  overflow: hidden;
  border: 1px solid rgba(31, 38, 48, .13);
  border-radius: 18px;
  background: #fffdf8;
  box-shadow: 0 28px 70px rgba(15, 23, 42, .28);
}

.signup-notice-header,
.signup-welcome-header {
  padding: 18px 20px 14px;
  border-bottom: 1px solid rgba(31, 38, 48, .1);
  background: linear-gradient(90deg, rgba(20, 130, 113, .1), rgba(34, 102, 168, .08) 54%, rgba(241, 100, 63, .08)), #fff;
}

.signup-notice-header span,
.signup-welcome-header span {
  display: block;
  color: #148271;
  font-size: .72rem;
  font-weight: 900;
  line-height: 1.1;
  text-transform: uppercase;
}

.signup-notice-header h2,
.signup-welcome-header h2 {
  margin: 4px 0 0;
  color: #111827;
  font-family: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
  font-size: 1.28rem;
  line-height: 1.12;
}

.signup-notice-body,
.signup-welcome-body {
  display: grid;
  gap: 12px;
  padding: 18px 20px;
}

.signup-notice-body p,
.signup-welcome-body p {
  margin: 0;
  color: #33404d;
  font-weight: 760;
  line-height: 1.45;
}

.signup-notice-actions,
.signup-welcome-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
  padding: 0 20px 18px;
}

.signup-notice-actions .dialog-primary-button,
.signup-welcome-actions .dialog-primary-button,
.signup-welcome-actions .dialog-secondary-button {
  min-height: 46px;
  border-radius: 12px;
  cursor: pointer;
  font: inherit;
  font-weight: 900;
  padding: 0 16px;
}

.signup-notice-actions .dialog-primary-button,
.signup-welcome-actions .dialog-primary-button {
  border: 0;
  background: linear-gradient(145deg, var(--accent), #d34f2c);
  color: #fff;
  box-shadow: 0 14px 28px rgba(211, 79, 44, .22);
}

.signup-welcome-actions .dialog-secondary-button {
  border: 1px solid rgba(31, 38, 48, .14);
  background: rgba(255, 255, 255, .8);
  color: #1f2630;
}

.signup-notice-actions .dialog-primary-button:focus-visible,
.signup-welcome-actions .dialog-primary-button:focus-visible,
.signup-welcome-actions .dialog-secondary-button:focus-visible {
  outline: 3px solid rgba(241, 100, 63, .34);
  outline-offset: 3px;
}

.signup-welcome-actions .dialog-primary-button:disabled {
  cursor: default;
  opacity: .62;
}

@keyframes auth-button-spin {
  to {
    transform: rotate(360deg);
  }
}

@container auth-dialog (min-width: 400px) {
  .auth-dialog-header,
  .auth-dialog-body {
    padding-inline: 22px;
  }

  .auth-dialog-body {
    padding-bottom: 22px;
  }
}

@media (max-width: 420px) {
  .auth-dialog {
    width: min(calc(100dvw - 18px), 470px);
    max-height: calc(100dvh - 18px);
  }

  .auth-dialog-frame {
    max-height: calc(100dvh - 18px);
    border-radius: 20px;
  }

  .auth-dialog-header {
    min-height: 78px;
    padding: 15px 14px 12px;
  }

  .auth-dialog-body {
    gap: 15px;
    padding: 15px 14px 16px;
  }

  .auth-logo-tile {
    width: 48px;
    border-radius: 16px;
  }

  .auth-dialog-brand img {
    width: 39px;
    height: 35px;
  }

  .auth-dialog-header h2 {
    font-size: 1.22rem;
  }

  .signup-notice-dialog,
  .signup-welcome-dialog {
    width: min(calc(100dvw - 18px), 460px);
  }

  .signup-notice-header,
  .signup-welcome-header,
  .signup-notice-body,
  .signup-welcome-body {
    padding-inline: 16px;
  }

  .signup-notice-actions,
  .signup-welcome-actions {
    padding-inline: 16px;
  }

  .signup-notice-actions .dialog-primary-button,
  .signup-welcome-actions .dialog-primary-button,
  .signup-welcome-actions .dialog-secondary-button {
    flex: 1 1 150px;
  }

  .auth-field input,
  .auth-primary-button {
    min-height: 52px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .auth-dialog,
  .auth-dialog::backdrop,
  .auth-dialog-frame,
  .signup-notice-dialog,
  .signup-notice-dialog::backdrop,
  .signup-welcome-dialog,
  .signup-welcome-dialog::backdrop,
  .auth-view-switch::before,
  .auth-switch-button,
  .auth-form,
  .auth-field span,
  .auth-field input,
  .auth-icon-button,
  .auth-password-toggle,
  .auth-eye-glyph::after,
  .auth-primary-button,
  .auth-form.is-auth-busy .auth-primary-button[type="submit"]::after,
  .auth-secondary-button,
  .auth-form-actions button {
    animation-duration: 1ms;
    transition-duration: 1ms;
  }
}
