/**
 * Do not edit directly, this file was auto-generated.
 */
@layer jokul.components {
  .jkl-text-input-wrapper {
    --jkl-text-input-padding: var(--jkl-text-input-vertical-padding)
        var(--jkl-text-input-horizontal-padding);
    --jkl-text-input-vertical-padding: var(--jkl-unit-15);
    --jkl-text-input-horizontal-padding: var(--jkl-unit-15);
    --jkl-text-input-action-button-size: var(--jkl-unit-60);
    --jkl-text-input-action-button-icon-size: var(--jkl-unit-30);
    --jkl-text-input-action-button-padding: var(--jkl-unit-10) 0;
    --jkl-text-input-action-button-focus-position: var(--jkl-unit-05);
    --text-color: var(--jkl-color-text-default);
    --background-color: var(--jkl-color-background-input-base);
    --border-color: var(--jkl-color-border-input);
    --placeholder-color: var(--jkl-color-text-subdued);
    border-radius: var(--jkl-border-radius-s);
    box-sizing: border-box;
    max-width: 100%;
    position: relative;
    display: flex;
    align-items: center;
    font-size: var(--jkl-font-size-3);
    line-height: var(--jkl-line-height-tight);
    font-weight: 400;
    --jkl-icon-weight: 300;
    transition-timing-function: ease;
    transition-duration: 150ms;
    transition-property: color, box-shadow, background-color;
    background-color: var(--background-color);
    color: var(--text-color);
    box-shadow: inset 0 0 0 0.0625rem var(--border-color), 0 0 0 0.0625rem transparent;
  }
  .jkl-text-input-wrapper:focus-within, .jkl-text-input-wrapper:has([data-focused=true]) {
    --background-color: var(--jkl-color-background-input-focus);
  }
  .jkl-text-input-wrapper[data-invalid=true]:not(:focus-within):not(:has([data-focused=true])) {
    --background-color: var(--jkl-color-background-alert-error);
    --text-color: var(--jkl-color-text-on-alert);
    --placeholder-color: color(from currentColor sRGB r g b / 75%);
  }
  .jkl-text-input-wrapper:hover, .jkl-text-input-wrapper:focus-within, .jkl-text-input-wrapper:has([data-focused=true]) {
    --border-color: var(--jkl-color-border-input-focus);
    box-shadow: inset 0 0 0 0.0625rem var(--border-color), 0 0 0 0.0625rem var(--border-color);
  }
  @media screen and (forced-colors: active) {
    .jkl-text-input-wrapper:hover, .jkl-text-input-wrapper:focus-within, .jkl-text-input-wrapper:has([data-focused=true]) {
      border: 0.125rem solid ButtonText;
    }
  }
  html:not([data-mousenavigation]):not([data-touchnavigation]) .jkl-text-input-wrapper:has(.jkl-text-input__input:focus-visible), html:not([data-mousenavigation]):not([data-touchnavigation]) .jkl-text-input-wrapper:has(.jkl-text-area__text-area:focus-visible) {
    outline: 3px solid var(--jkl-color-border-action);
    outline-offset: 3px;
  }
  .jkl-text-input-wrapper > .jkl-icon-button:focus-visible {
    outline: 3px solid var(--jkl-color-border-action);
    outline-offset: -8px;
  }
  @media screen and (forced-colors: active) {
    .jkl-text-input-wrapper > .jkl-icon-button:focus-visible {
      --border-color: ButtonText;
    }
  }
  .jkl-text-input-wrapper > .jkl-text-input-action-button {
    flex-shrink: 0;
    display: flex;
    box-sizing: border-box;
    align-items: center;
    justify-content: center;
    padding: var(--jkl-text-input-action-button-padding);
    height: var(--jkl-text-input-action-button-size);
    width: var(--jkl-text-input-action-button-size);
    margin-inline-start: calc(var(--jkl-text-input-horizontal-padding) * -1);
  }
  .jkl-text-input-wrapper > .jkl-text-input-action-button .jkl-icon-button__icon {
    height: var(--jkl-text-input-action-button-icon-size);
    width: var(--jkl-text-input-action-button-icon-size);
  }
  .jkl-text-input-wrapper > .jkl-text-input-action-button:hover {
    color: var(--jkl-color-text-interactive-hover);
  }
  @media screen and (forced-colors: active) {
    .jkl-text-input-wrapper > .jkl-text-input-action-button:hover {
      border: 0.125rem inset ButtonText;
    }
  }
  @media screen and (forced-colors: active) {
    .jkl-text-input-wrapper {
      border: 0.125rem inset ButtonText;
    }
  }
  .jkl-text-input {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  .jkl-text-input__input {
    padding: var(--jkl-text-input-padding);
    width: 100%;
    background: none;
    -webkit-appearance: none;
    color: inherit;
    font-size: var(--jkl-font-size-3);
    line-height: var(--jkl-line-height-tight);
    font-weight: 400;
    --jkl-icon-weight: 300;
  }
  .jkl-text-input__input {
    outline: 0;
    border-style: none;
    outline-style: none;
  }
  .jkl-text-input__input:active, .jkl-text-input__input:hover, .jkl-text-input__input:focus {
    outline: 0;
    outline-style: none;
  }
  @media screen and (forced-colors: active) {
    .jkl-text-input__input {
      outline: revert;
      border-style: revert;
      outline-style: revert;
    }
    .jkl-text-input__input:active, .jkl-text-input__input:hover, .jkl-text-input__input:focus {
      outline: revert;
      outline-style: revert;
    }
  }
  .jkl-text-input__input input[type=number]::-webkit-outer-spin-button,
  .jkl-text-input__input input[type=number]::-webkit-inner-spin-button {
    -webkit-appearance: none;
  }
  .jkl-text-input__input input[type=number] {
    -moz-appearance: textfield;
  }
  @media screen and (forced-colors: active) {
    .jkl-text-input__input {
      outline: none;
      border: none;
    }
    .jkl-text-input__input:focus-visible {
      outline: none;
    }
  }
  .jkl-text-input__input::placeholder {
    opacity: 1;
    color: var(--placeholder-color);
  }
  .jkl-text-input__input--align-right {
    text-align: right;
  }
  .jkl-text-input__unit {
    padding-inline-end: var(--jkl-text-input-horizontal-padding);
    padding-block: var(--jkl-text-input-vertical-padding);
  }
  .jkl-text-input__action-button {
    margin-inline-start: calc(var(--jkl-text-input-horizontal-padding) * -1);
  }
  .jkl-text-input--inline {
    display: inline-block;
    vertical-align: middle;
    margin: -0.125rem 0.25rem;
  }
}