:root {
  --alert-error: #e41749;
  --alert-info: #0676ed;
  --alert-loading: #89cff0;
  --alert-success: #32cd32;

  --toaster-len: 350px;
  --toaster-badge-size: min(calc(var(--toaster-len) / 50), 50px);
}

.status-bar {
  position: fixed;
  right: 0;
  top: 75px;
  display: flex;
  flex-direction: column;
  width: var(--toaster-len);
  margin-right: 10px;
  z-index: 1100;
}

.status-bar .toaster:not(:last-child) {
  margin-bottom: 1rem;
}

.toaster {
  position: relative;
  border: 1px solid black;
  border-radius: 0.3rem;
  padding: 1rem;
  overflow: hidden;

  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
  width: var(--alert-len, 100%);
  max-width: var(--alert-len, 100%);

  background-color: #fff;

  transform-origin: right;
  animation: slide_in 270ms cubic-bezier(0.68, -0.55, 0.27, 1.55);

  box-shadow: 0 0 1px rgba(0, 0, 0, 0.2);
}

.toaster-text {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 1rem;
}

@keyframes slide_in {
  0% {
    transform: scaleX(0);
  }
  100% {
    transform: scaleX(1);
  }
}

.toast-success {
  border-color: var(--alert-success);
}

.toast-info {
  border-color: var(--alert-info);
}

.toast-error {
  border-color: var(--alert-error);
}

.toast-loading {
  border-color: var(--alert-loading);
}

.toast-loading.toaster {
  padding: 0.6rem;
}

.toaster-badge {
  position: absolute;
  left: 0;
  top: 0;
  width: var(--toaster-badge-size);
  height: 100%;
}

.toast-success .toaster-badge {
  background-color: var(--alert-success);
}

.toast-info .toaster-badge {
  background-color: var(--alert-info);
}
.toast-error .toaster-badge {
  background-color: var(--alert-error);
}

.toast-loading .toaster-badge {
  background-color: var(--alert-loading);
}

.loader svg path,
.loader svg rect {
  fill: var(--alert-loading);
  width: 70%;
}

.toaster-close {
  display: flex;
  justify-content: center;
  align-items: center;

  transition: all 150ms linear;

  cursor: pointer;
}

.toaster-close svg {
  width: 20px;
  aspect-ratio: 1;
}

.toaster-close:hover,
.toaster-close:focus {
  opacity: 0.8;
}

@media (max-width: 757px) {
  .status-bar {
    --toaster-len: 70%;
    top: 70px;
    z-index: 999;
  }
}
