/**
 * Do not edit directly, this file was auto-generated.
 */
@layer jokul.components {
  .jkl-number-input {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  .jkl-number-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-number-input__wrapper:focus-within, .jkl-number-input__wrapper:has([data-focused=true]) {
    --background-color: var(--jkl-color-background-input-focus);
  }
  .jkl-number-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-number-input__wrapper:hover, .jkl-number-input__wrapper:focus-within, .jkl-number-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-number-input__wrapper:hover, .jkl-number-input__wrapper:focus-within, .jkl-number-input__wrapper:has([data-focused=true]) {
      border: 0.125rem solid ButtonText;
    }
  }
  html:not([data-mousenavigation]):not([data-touchnavigation]) .jkl-number-input__wrapper:has(.jkl-text-input__input:focus-visible), html:not([data-mousenavigation]):not([data-touchnavigation]) .jkl-number-input__wrapper:has(.jkl-text-area__text-area:focus-visible) {
    outline: 3px solid var(--jkl-color-border-action);
    outline-offset: 3px;
  }
  .jkl-number-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-number-input__wrapper > .jkl-icon-button:focus-visible {
      --border-color: ButtonText;
    }
  }
  .jkl-number-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-number-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-number-input__wrapper > .jkl-text-input-action-button:hover {
    color: var(--jkl-color-text-interactive-hover);
  }
  @media screen and (forced-colors: active) {
    .jkl-number-input__wrapper > .jkl-text-input-action-button:hover {
      border: 0.125rem inset ButtonText;
    }
  }
  @media screen and (forced-colors: active) {
    .jkl-number-input__wrapper {
      border: 0.125rem inset ButtonText;
    }
  }
  html:not([data-mousenavigation]):not([data-touchnavigation]) .jkl-number-input__wrapper:has(.jkl-number-input__input:focus-visible) {
    outline: 3px solid var(--jkl-color-border-action);
    outline-offset: 3px;
  }
  .jkl-number-input__wrapper:has(.jkl-number-input__input:invalid):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-number-input__wrapper--stepper {
    --jkl-number-input-stepper-min-width: calc(
        3ch + (var(--jkl-text-input-horizontal-padding) * 2)
    );
    --jkl-number-input-stepper-text-color: var(--text-color);
    display: grid;
    grid-template-columns: max-content minmax(var(--jkl-number-input-stepper-min-width), 1fr) max-content;
    overflow: hidden;
  }
  .jkl-number-input__wrapper--stepper:has(button[data-direction]:focus-visible) {
    overflow: visible;
  }
  .jkl-number-input__input {
    padding: var(--jkl-text-input-padding);
    width: 100%;
    appearance: textfield;
    -moz-appearance: textfield;
    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-number-input__input {
    outline: 0;
    border-style: none;
    outline-style: none;
  }
  .jkl-number-input__input:active, .jkl-number-input__input:hover, .jkl-number-input__input:focus {
    outline: 0;
    outline-style: none;
  }
  @media screen and (forced-colors: active) {
    .jkl-number-input__input {
      outline: revert;
      border-style: revert;
      outline-style: revert;
    }
    .jkl-number-input__input:active, .jkl-number-input__input:hover, .jkl-number-input__input:focus {
      outline: revert;
      outline-style: revert;
    }
  }
  .jkl-number-input__input input[type=number]::-webkit-outer-spin-button,
  .jkl-number-input__input input[type=number]::-webkit-inner-spin-button {
    -webkit-appearance: none;
  }
  .jkl-number-input__input input[type=number] {
    -moz-appearance: textfield;
  }
  @media screen and (forced-colors: active) {
    .jkl-number-input__input {
      outline: none;
      border: none;
    }
    .jkl-number-input__input:focus-visible {
      outline: none;
    }
  }
  .jkl-number-input__input::placeholder {
    opacity: 1;
    color: var(--placeholder-color);
  }
  .jkl-number-input__input::-webkit-inner-spin-button, .jkl-number-input__input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
  }
  .jkl-number-input__input--align-right {
    text-align: right;
  }
  .jkl-number-input__input--stepper {
    box-sizing: border-box;
    min-inline-size: var(--jkl-number-input-stepper-min-width);
    text-align: center;
  }
  .jkl-number-input button[data-direction] {
    --text-color: var(--jkl-number-input-stepper-text-color);
    aspect-ratio: 1;
    padding: 0;
    display: inline-grid;
    place-items: center;
    text-align: center;
    height: 100%;
  }
  .jkl-number-input button[data-direction]::before {
    content: "";
    position: absolute;
    width: 1px;
    inset-block: 20%;
    background-color: var(--jkl-color-border-separator);
    transition-timing-function: ease;
    transition-duration: 150ms;
    transition-property: inset;
  }
  .jkl-number-input button[data-direction]:hover::before, .jkl-number-input button[data-direction]:focus-visible::before {
    inset-block: 0.0625rem;
  }
  .jkl-number-input button[data-direction]:disabled {
    opacity: 0.4;
    cursor: not-allowed;
  }
  .jkl-number-input button[data-direction=decrement]::before {
    inset-inline-end: 0;
  }
  .jkl-number-input button[data-direction=increment]::before {
    inset-inline-start: 0;
  }
  .jkl-number-input button[data-direction].jkl-button {
    border-radius: 0;
  }
  .jkl-number-input button[data-direction].jkl-button .jkl-icon {
    margin-block-start: 0.4ex;
  }
}