#toaster {
  --flash-toast-nav-offset: 75px;

  position: fixed;
  top: calc(var(--flash-toast-nav-offset) + var(--pico-spacing) + env(safe-area-inset-top, 0px));
  right: max(var(--pico-spacing), env(safe-area-inset-right, 0px));
  left: max(var(--pico-spacing), env(safe-area-inset-left, 0px));
  z-index: 1000;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: calc(var(--pico-spacing) * 0.5);
  pointer-events: none;
}

#toaster .flash-toast {
  --flash-color: var(--pico-color);
  --flash-border: var(--pico-muted-border-color);

  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: start;
  gap: 0.65rem;
  width: min(100%, 24rem);
  padding: 0.85rem 0.75rem;
  margin: 0;
  border: 1px solid var(--flash-border);
  border-radius: var(--pico-border-radius);
  color: var(--flash-color);
  background-color: color-mix(in srgb, var(--flash-color) 10%, var(--pico-card-background-color, var(--pico-background-color)));
  box-shadow: 0 10px 28px rgb(0 0 0 / 14%);
  pointer-events: auto;
  animation: flash-toast-enter 220ms ease-out;
}

@keyframes flash-toast-enter {
  from {
    opacity: 0;
    transform: translateY(-0.35rem);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

#toaster .flash-toast__icon {
  margin-top: 0.1rem;
  color: inherit;
  font-size: 1rem;
  line-height: 1;
}

#toaster .flash-toast__content {
  margin: 0;
  padding-right: 0.25rem;
  line-height: 1.45;
  word-break: break-word;
}

#toaster .flash-toast__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2.75rem;
  height: 2.75rem;
  margin: -0.45rem -0.35rem 0 0;
  padding: 0;
  border: 0;
  border-radius: var(--pico-border-radius);
  color: inherit;
  background: transparent;
  cursor: pointer;
  touch-action: manipulation;
}

#toaster .flash-toast__close i {
  font-size: 1.125rem;
  line-height: 1;
}

#toaster .flash-toast__close:hover,
#toaster .flash-toast__close:focus-visible {
  background-color: color-mix(in srgb, var(--flash-color) 16%, transparent);
}

#toaster .flash-toast--notice {
  --flash-color: rgb(85, 194, 30);
  --flash-border: rgb(44, 108, 12);
}

#toaster .flash-toast--info {
  --flash-color: rgb(156, 167, 250);
  --flash-border: rgb(29, 89, 208);
}

#toaster .flash-toast--error {
  --flash-color: rgb(243, 143, 121);
  --flash-border: rgb(175, 41, 29);
}

#toaster .flash-toast--warning {
  --flash-color: rgb(187, 172, 0);
  --flash-border: rgb(104, 95, 0);
}

@media (pointer: coarse) {
  #toaster .flash-toast__close {
    width: 3rem;
    height: 3rem;
    margin: -0.5rem -0.4rem 0 0;
  }

  #toaster .flash-toast__close i {
    font-size: 1.25rem;
  }
}

@media (max-width: 40rem) {
  main.container-fluid {
    padding-bottom: var(--flash-toast-dock-height, 0px);
    transition: padding-bottom 180ms ease;
  }

  #toaster {
    top: auto;
    right: 0;
    bottom: 0;
    left: 0;
    gap: 0;
    align-items: stretch;
  }

  #toaster .flash-toast {
    width: 100%;
    max-width: none;
    padding: 0.9rem var(--pico-spacing) calc(0.9rem + env(safe-area-inset-bottom, 0px));
    border: 0;
    border-radius: 0;
    box-shadow: none;
    background-color: color-mix(in srgb, var(--flash-color) 14%, var(--pico-card-background-color, var(--pico-background-color)));
    animation: flash-toast-dock-enter 220ms ease-out;
  }

  #toaster .flash-toast + .flash-toast {
    border-top: 1px solid color-mix(in srgb, var(--flash-color) 22%, transparent);
  }

  #toaster .flash-toast__close {
    width: 3rem;
    height: 3rem;
    margin: -0.5rem -0.25rem 0 0;
  }

  #toaster .flash-toast__close i {
    font-size: 1.25rem;
  }

  @keyframes flash-toast-dock-enter {
    from {
      opacity: 0;
      transform: translateY(100%);
    }

    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
}
