/**
 * Do not edit directly, this file was auto-generated.
 */
@layer jokul.components {
  .jkl-button {
    --jkl-button-font-size: var(--jkl-typography-body-base-font-size);
    --jkl-button-line-height: var(--jkl-typography-body-base-line-height);
    --jkl-button-padding-block: var(--jkl-unit-10);
    --jkl-button-padding-text: var(--jkl-unit-30);
    --jkl-button-padding-icon: var(--jkl-unit-20);
    --jkl-button-padding-icon-button: var(--jkl-unit-10);
    --jkl-button-tertiary-padding-icon: var(--jkl-unit-05);
    --jkl-button-text-ink-offset: 0.1em;
    --jkl-icon-weight: var(--jkl-icon-weight-bold);
    --text-color: var(--jkl-color-text-default);
    --background-color: transparent;
    --border-radius: 0;
    --border-width: 0.0625rem;
    display: inline-block;
    font-size: var(--jkl-font-size-3);
    line-height: var(--jkl-line-height-tight);
    font-weight: 400;
    --jkl-icon-weight: 300;
    font-weight: 700;
    cursor: pointer;
    user-select: none;
    background: var(--background-color);
    color: var(--text-color);
    border: unset;
    text-decoration: none;
    -webkit-tap-highlight-color: transparent;
    border-radius: var(--border-radius);
    padding-inline: var(--jkl-button-padding-text);
    padding-block: var(--jkl-button-padding-block);
    position: relative;
    overflow: hidden;
    max-width: 100%;
    animation: a 0.3s linear;
    transition-timing-function: ease;
    transition-duration: 150ms;
    transition-property: background-color;
  }
  .jkl-button:has(.jkl-button__text) {
    min-width: 9.5ch;
  }
  .jkl-button:has(.jkl-icon:first-child) {
    padding-inline-start: var(--jkl-button-padding-icon);
  }
  .jkl-button:has(.jkl-icon:last-child) {
    padding-inline-end: var(--jkl-button-padding-icon);
  }
  .jkl-button:has(.jkl-icon:first-child):has(.jkl-icon:last-child) {
    padding-inline: var(--jkl-button-padding-icon-button);
  }
  .jkl-button__label {
    transition-timing-function: ease;
    transition-duration: 250ms;
    transition-property: translate;
    width: 100%;
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: calc(var(--jkl-unit-base) * 0.25);
    pointer-events: none;
  }
  .jkl-button__loader {
    transition-timing-function: ease;
    transition-duration: 250ms;
    transition-property: opacity, translate;
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% 350%;
    opacity: 0;
    pointer-events: none;
  }
  .jkl-button__text {
    display: block;
    width: 100%;
    max-width: 100%;
    padding-block-start: var(--jkl-button-text-ink-offset);
    margin-block-start: calc(var(--jkl-button-text-ink-offset) * -1);
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
  }
  .jkl-button[data-loading=true] .jkl-button__label {
    --button-loading-offset: calc(-100% - var(--jkl-button-padding-block) * 2 - var(--jkl-button-text-ink-offset));
    translate: 0 var(--button-loading-offset);
  }
  .jkl-button[data-loading=true] .jkl-button__loader {
    translate: -50% -50%;
    opacity: 1;
  }
  .jkl-button:focus-visible {
    outline: 3px solid var(--jkl-color-border-action);
    outline-offset: 3px;
  }
  .jkl-button:hover {
    background-color: color-mix(in srgb, var(--background-color), var(--text-color) 15%);
  }
  @media (forced-colors: active) {
    .jkl-button:hover {
      outline: 3px solid var(--jkl-color-border-action);
      outline-offset: 3px;
    }
  }
  .jkl-button--primary, .jkl-button--secondary, .jkl-button--ghost {
    --border-radius: 999px;
  }
  .jkl-button--primary {
    --background-color: var(--jkl-color-background-action);
    --text-color: var(--jkl-color-text-on-action);
  }
  @media (forced-colors: active) {
    .jkl-button--primary {
      border: calc(var(--border-width) * 2) solid Highlight;
    }
  }
  .jkl-button--secondary {
    border: var(--border-width) solid var(--text-color);
  }
  .jkl-button--tertiary {
    border-bottom: var(--border-width) solid var(--text-color);
    padding-inline: var(--jkl-button-tertiary-padding-icon);
  }
  .jkl-button--tertiary:has(.jkl-icon:first-child) {
    padding-inline: var(--jkl-button-tertiary-padding-icon) calc(var(--jkl-button-tertiary-padding-icon) * 2);
  }
  .jkl-button--tertiary:has(.jkl-icon:last-child) {
    padding-inline: calc(var(--jkl-button-tertiary-padding-icon) * 2) var(--jkl-button-tertiary-padding-icon);
  }
}