/**
 * Do not edit directly, this file was auto-generated.
 */
@layer jokul.components {
  .jkl-toast-region {
    z-index: 10000;
    background: transparent;
    display: flex;
    justify-content: center;
    position: fixed;
    bottom: var(--jkl-unit-30);
    right: 0;
    left: 0;
    width: 100%;
    pointer-events: none;
  }
  .jkl-toast-region__toasts {
    min-width: 18rem;
    pointer-events: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--jkl-unit-20);
  }
  .jkl-toast-region--left {
    justify-content: flex-start;
    left: var(--jkl-unit-30);
  }
  .jkl-toast {
    --background-color: var(--jkl-color-background-container-high);
    --text-color: var(--jkl-color-text-default);
    --jkl-toast-padding: var(--jkl-unit-20);
    color: var(--text-color);
    background-color: var(--background-color);
    border-radius: 4px;
    box-sizing: border-box;
    align-items: start;
    overflow: hidden;
    width: clamp(15em, 100%, min(30rem, 85vw));
    padding: var(--jkl-toast-padding);
    position: relative;
    font-size: var(--jkl-font-size-3);
    line-height: var(--jkl-line-height-relaxed);
    font-weight: 400;
    --jkl-icon-weight: 300;
  }
  .jkl-toast__progress {
    --bar-color: var(--text-color);
    --track-color: transparent;
    border-radius: 0;
    position: absolute;
    inset: 0 0 auto;
  }
  @media screen and (forced-colors: active) {
    .jkl-toast__icon {
      stroke: CanvasText;
    }
    .jkl-toast__icon svg, .jkl-toast__icon path {
      stroke: CanvasText;
    }
  }
  .jkl-toast:not(:has(.jkl-toast__title)) .jkl-toast__icon {
    margin-block-start: 0.0625rem;
  }
  .jkl-toast:has(.jkl-toast__title) .jkl-toast__icon {
    margin-block-start: 0;
  }
  .jkl-toast__content {
    flex-grow: 1;
    flex-basis: 100vw;
  }
  .jkl-toast__action {
    margin-top: var(--jkl-unit-15);
  }
  .jkl-toast__title {
    font-size: var(--jkl-font-size-4);
    line-height: var(--jkl-line-height-tight);
    font-weight: 700;
    --jkl-icon-weight: 400;
  }
  .jkl-toast__dismiss-button {
    background-color: transparent;
    padding: 0;
    cursor: pointer;
    color: inherit;
  }
  @media screen and (forced-colors: active) {
    .jkl-toast__dismiss-button {
      stroke: ButtonText;
    }
    .jkl-toast__dismiss-button svg, .jkl-toast__dismiss-button path {
      stroke: ButtonText;
    }
  }
  @media screen and (forced-colors: active) {
    .jkl-toast__dismiss-button {
      background-color: ButtonFace;
    }
  }
  .jkl-toast__dismiss-button::after {
    --tap-size: 44px;
    content: "";
    position: absolute;
    inset: calc((var(--tap-size) - 100%) / 2 * -1);
  }
  .jkl-toast--info, .jkl-toast--warning, .jkl-toast--error, .jkl-toast--success {
    --text-color: var(--jkl-color-text-on-alert);
  }
  .jkl-toast--info {
    --background-color: var(--jkl-color-background-alert-info);
  }
  .jkl-toast--warning {
    --background-color: var(--jkl-color-background-alert-warning);
  }
  .jkl-toast--error {
    --background-color: var(--jkl-color-background-alert-error);
  }
  .jkl-toast--success {
    --background-color: var(--jkl-color-background-alert-success);
  }
  @media screen and (forced-colors: active) {
    .jkl-toast {
      border: 2px solid CanvasText;
    }
    .jkl-toast--info {
      border-style: dotted;
    }
    .jkl-toast--warning {
      border-style: dashed;
    }
    .jkl-toast--error {
      border-style: double;
      border-width: 4px;
    }
  }
  .jkl-toast[data-animation=entering],
  .jkl-toast[data-animation=queued] {
    animation: jkl-entering-udsse7u 200ms ease-out forwards;
  }
  .jkl-toast[data-animation=exiting] {
    animation: jkl-exiting-udsse8t 150ms ease-in forwards;
  }
  @keyframes jkl-entering-udsse7u {
    from {
      opacity: 0;
      transform: translate3d(0, 50%, 0);
    }
    to {
      opacity: 1;
      transform: translate3d(0, 0, 0);
    }
  }
  @keyframes jkl-exiting-udsse8t {
    from {
      opacity: 1;
      transform: translate3d(0, 0, 0);
    }
    to {
      opacity: 0;
      transform: translate3d(0, 50%, 0);
    }
  }
}