@layer components {
  :root {
    --input-spacing: 0.25rem;
    --input-padding-x: 0.5rem;
    --input-padding-y: 0.75rem;
    --input-border-width: 1px;
    --input-border-width-active: 2px;
    --input-border-width-invalid: 2px;
    --input-error-border-color: var(--color-error);
    --input-radius: var(--radius-site);
    --input-radius-textarea: var(--radius-site);
  }

  .input-wrapper {
    display: flex;
    flex-direction: column;
    gap: var(--input-spacing);
    position: relative;
  }

  .input-label-wrapper {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    padding-left: var(--input-padding-x);
    background-color: transparent;
  }

  .input-label {
    margin: 0;
  }

  .input-field-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    border-radius: var(--input-radius);
  }

  .input-field {
    width: 100%;
    padding: var(--input-padding-y) var(--input-padding-x);
    box-shadow: inset 0 0 0 var(--input-border-width) var(--color-border);
    border-radius: var(--input-radius);
    border: none;
    outline-color: transparent;
  }

  .input-field[aria-invalid='true'] {
    box-shadow: inset 0 0 0 var(--input-border-width-invalid)
      var(--input-error-border-color);
  }

  .input-helper-wrapper {
    display: flex;
    flex-direction: column;
    width: 100%;
    padding: 0;
    background-color: transparent;
  }

  .input-helper {
    padding-left: var(--input-padding-x);
  }

  .input-error {
    display: none;
    width: 100%;
  }

  .input-error-content {
    display: none;
    align-items: center;
    gap: var(--input-spacing);
    width: 100%;
    padding: var(--input-padding-y) var(--input-padding-x);
    border-radius: var(--input-radius);
  }

  .input-error-icon {
    width: 1.2em;
    height: 1.2em;
    display: none;
    flex-shrink: 0;
  }

  .input-wrapper:has(input:disabled),
  .input-wrapper:has(textarea:disabled) {
    .input-field {
      box-shadow: inset 0 0 0 var(--input-border-width)
        var(--color-border-disabled);
    }

    .input-helper,
    .input-error,
    .input-error-content {
      display: none;
    }

    .resize-handle {
      color: var(--color-border-disabled);

      path {
        fill: currentColor;
      }
    }
  }

  .input-wrapper:has(.input-field[aria-invalid='true']:not(:disabled)) {
    .input-field {
      box-shadow: inset 0 0 0 var(--input-border-width-invalid)
        var(--input-error-border-color);
    }

    & .input-helper {
      display: none;
    }

    & .input-error {
      display: block;
    }

    & .input-error-icon {
      display: block;
    }

    & .input-error-content {
      display: flex;
    }
  }

  .input-wrapper:has(textarea.input-field) {
    & .input-field {
      min-height: 100px;
      resize: vertical;
      border-radius: var(--input-radius-textarea);
    }

    & .input-label-wrapper {
      padding-left: var(--input-padding-x);
    }

    & .input-error-content {
      padding-top: 0;
      padding-bottom: 0;
    }

    & .input-char-limit {
      text-align: right;
    }

    & .input-helper-wrapper {
      flex-direction: row;
      justify-content: space-between;
      align-items: flex-start;
      gap: var(--input-spacing);
    }

    & .input-helper-content {
      flex: 1;
    }

    & .input-char-limit {
      flex-shrink: 0;
      text-align: right;
    }

    & .input-error-content {
      padding-top: 0;
      padding-bottom: 0;
    }
  }

  .input-wrapper:has(.resize-handle) {
    & .input-field::-webkit-resizer {
      display: none;
    }

    & .resize-handle {
      position: absolute;
      right: 2px;
      bottom: 2px;
      pointer-events: none;
      width: 16px;
      height: 16px;
    }
  }

  .input-clear {
    position: absolute;
    right: var(--input-padding-x);
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.25rem;
    cursor: pointer;
    z-index: 1;
    border-radius: var(--input-radius-textarea);
  }

  .input-clear svg {
    width: 1rem;
    height: 1rem;
  }

  .input-wrapper:has(.input-field:placeholder-shown) .input-clear {
    display: none;
  }
}
