/* TODO: удалить когда везде будут использоваться Inputs из macro shared/ui/input.j2 */
.input-group {
  position: relative;
  gap: 0;
}

.input-group__label,
.input-group label {
  display: block;
  font: var(--font-c3);
  letter-spacing: var(--font-c3-spacing);
  margin-bottom: var(--spacing-02);
}

.input-group__label--sm,
.input-group--sm label {
  font: var(--font-c3);
  letter-spacing: var(--font-c3-spacing);
  margin-bottom: var(--spacing-02);
}

.input-group__label--lg,
.input-group--lg label {
  font: var(--font-c2);
  letter-spacing: var(--font-c2-spacing);
  margin-bottom: var(--spacing-02);
}

.custom-input {
  position: relative;
  display: flex;
  align-items: center;
  height: var(--control-height-md);
  border-radius: 12px;
  border: 1px solid var(--color-input-border-default);
  padding: 0 16px;
  gap: var(--spacing-03);

  &:hover {
    border-color: var(--color-input-border-hover);
  }

  &:focus-within {
    border-color: var(--color-input-border-focus);
  }

  &:focus-visible {
    outline: none;
    border: 1px solid var(--neutral-800);
  }
}

.input-group--lg .custom-input {
  font: var(--font-b3);
  letter-spacing: var(--font-b3-spacing);
  height: var(--control-height-lg);
}

.input-group--sm .custom-input {
  font: var(--font-b5);
  letter-spacing: var(--font-b5-spacing);
  height: var(--control-height-sm);
  border-radius: var(--radius-2-xs);
}

.custom-input input {
  font: var(--font-b4);
  letter-spacing: var(--font-b4-spacing);
  appearance: none;
  border: none;
  outline: none;
  height: var(--control-height-md);
  width: 100%;
  background-color: transparent !important;

  &::placeholder {
    opacity: 1;
    color: var(--text-dark-tertiary);
    font: var(--font-b4);
  }
}

.input-group--lg input {
  font: var(--font-b3);
  letter-spacing: var(--font-b3-spacing);
  height: var(--control-height-lg);

  &::placeholder {
    color: var(--text-dark-tertiary);
    font: var(--font-b3);
  }
}

.input-group--sm input {
  font: var(--font-b5);
  letter-spacing: var(--font-b5-spacing);
  height: var(--control-height-sm);

  &::placeholder {
    color: var(--text-dark-tertiary);
    font: var(--font-b5);
  }
}

/* Input States */
.input-helper-text {
  display: block;
  position: absolute;
  bottom: -24px;
  font: var(--font-b5);
  letter-spacing: var(--font-b5-spacing);
  text-align: start;
  left: 0;
  margin-top: var(--spacing-01);

  & li {
    list-style: none;
  }
}

.input-group--lg .input-helper-text {
  font: var(--font-b4);
  letter-spacing: var(--font-b4-spacing);
}

.input-helper-text.pos-static {
  position: static;
  /* margin-top: var(--spacing-02) */
}

.input-helper-text.pos-static:not(:empty) {
  margin-top: var(--spacing-02);
}

.custom-input__helper-text {
  font: var(--font-b5);
  letter-spacing: var(--font-b5);
  color: var(--text-dark-secondary);
}

.custom-input__right-icon {
  padding-left: 12px;
}

.custom-input__left-icon {
  padding-right: 12px;
}

/* Input Error */
.input-group:has(input.error) .custom-input,
.input-group.error .custom-input {
  border: 1px solid var(--color-red);
}

.input-group:has(input.error) .input-helper-text,
.input-group.error .input-helper-text,
.input-group.error input {
  color: var(--color-red);
}

.input-group:has(input.error) .custom-input:after,
.input-group.error .custom-input:after {
  content: url("/static/assets/svg/input-error-md.cacd028375b6.svg");
  height: 16px;
}

.input-group--sm:has(input.error) .custom-input:after,
.input-group--sm.error .custom-input:after {
  content: url("/static/assets/svg/input-error-sm.e145e5b31830.svg");
  height: 12px;
}

.input-group--lg:has(input.error) .custom-input:after,
.input-group--lg.error .custom-input:after {
  content: url("/static/assets/svg/input-error-lg.cdebafd4c29a.svg");
  height: 20px;
}

.input-group:has(input.success) .custom-input,
.input-group.success .custom-input {
  border: 1px solid var(--color-green);
}

/*.input-group.success input,*/
.input-group:has(input.success) .input-helper-text,
.input-group.success .input-helper-text {
  color: var(--color-green);
}

.input-group:has(input.success) .custom-input:after,
.input-group.success .custom-input:after {
  content: url("/static/assets/svg/input-success-md.c23203c69c17.svg");
  height: 16px;
}

.input-group--sm:has(input.success) .custom-input:after,
.input-group--sm.success .custom-input:after {
  content: url("/static/assets/svg/input-success-sm.7e07c03df832.svg");
  height: 12px;
}

.input-group--lg:has(input.success) .custom-input:after,
.input-group--lg.success .custom-input:after {
  content: url("/static/assets/svg/input-success-lg.873ef84a9a8f.svg");
  height: 20px;
}

.input-group:has(input.warning) .custom-input,
.input-group.warning .custom-input {
  border: 1px solid var(--color-orange);
}

/*.input-group.success input,*/
.input-group:has(input.warning) .input-helper-text,
.input-group.warning .input-helper-text {
  color: var(--color-orange);
}

.input-group:has(input.warning) .custom-input:after,
.input-group.warning .custom-input:after {
  content: url("/static/assets/svg/input-warning-md.71fa842440e1.svg");
  height: 16px;
}

.input-group--sm:has(input.warning) .custom-input:after,
.input-group--sm.warning .custom-input:after {
  content: url("/static/assets/svg/input-warning-sm.821feafbb1f3.svg");
  height: 12px;
}

.input-group--lg:has(input.warning) .custom-input:after,
.input-group--lg.warning .custom-input:after {
  content: url("/static/assets/svg/input-warning-lg.a64e1b6e4407.svg");
  height: 20px;
}

/* Для сообщений которые должны быть позиционированы не absolute */
.input-error-message {
  display: none;
  font: var(--font-b5);
  letter-spacing: var(--font-b5-spacing);
  color: var(--color-red);
}

.custom-input input:-webkit-autofill {
  height: 30px;
  -webkit-box-shadow: 0 0 0 1000px #fff inset;
}

.custom-textarea {
  font: var(--font-b3);
  width: 100%;
  letter-spacing: var(--font-b3-spacing);
  font-family: "Golos Text", sans-serif;
  align-items: center;
  padding: 8px 16px;
  border: 1px solid var(--color-input-border-default);
  border-radius: var(--radius-2-xs);
  outline: none;
  background-color: transparent;
  resize: vertical;

  &:hover {
    border: 1px solid var(--color-input-border-hover);
  }

  &:focus-within {
    border: 1px solid var(--color-input-border-focus);
  }
}

.custom-textarea.error {
  border: 1px solid var(--color-red);
}

.custom-textarea::placeholder {
  font: var(--font-b4);
  letter-spacing: var(--font-b4-spacing);
  color: var(--text-dark-tertiary);
}

.search-input input,
.search-input .custom-input {
  border: none;
}

.search-input .custom-input {
  padding-right: 40px;
  background-color: var(--color-button-secondary);
}

.search-input .custom-input:hover {
  outline: 1px solid var(--color-input-border-hover);
}

.search-input .custom-input:focus-within {
  outline: 1px solid var(--color-input-border-focus);
}

.search-input img {
  position: absolute;
  right: 16px;
  top: 50%;
  cursor: pointer;
  transform: translateY(-50%);
}

/* Radio */
.custom-radio-button {
  cursor: pointer;
}

.custom-radio-button:focus-within {
  color: var(--text-dark-primary);
}

.custom-radio-wrapper {
  display: flex;
  gap: 8px;
  align-items: center;
  cursor: pointer;
  font: var(--font-b4);
  letter-spacing: var(--font-a4-spacing);
}

input[type="radio"] {
  -webkit-appearance: none;
  appearance: none;
  background-color: var(--color-background-page);
  margin: 2px 0 0 0;

  width: 16px;
  height: 16px;
  border: 2px solid var(--neutral-900);
  border-radius: 50%;
  transform: translateY(-0.075em);
  cursor: pointer;

  display: grid;
  place-content: center;
}

input[type="radio"]::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  transform: scale(0);
  transition: 120ms transform ease-in-out;
  box-shadow: inset 16px 16px var(--neutral-900);
}

input[type="radio"]:checked::before {
  transform: scale(1);
}
