/*Base*/
.input {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.input .input-label {
  min-height: 20px;
  line-height: 20px;
  font-size: 14px;
  font-weight: 400;
}

.input .input-label .input-label-text {
  color: var(--text-primary);
  transition: color 0.1s;
}

.input .input-field-container {
  display: flex;
}

.input .input-field-container .input-field,
.input .input-field-container .input-field:-webkit-autofill,
.input .input-field-container .input-field:-webkit-autofill:hover,
.input .input-field-container .input-field:-webkit-autofill:focus,
.input .input-field-container .input-field:-webkit-autofill:active {
  all: unset;

  flex-grow: 1;
  color: var(--text-primary);
  cursor: text;
  padding: 1px 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 22px;
}

.input .input-field-container .input-field:-webkit-autofill,
.input .input-field-container .input-field:-webkit-autofill:hover,
.input .input-field-container .input-field:-webkit-autofill:focus,
.input .input-field-container .input-field:-webkit-autofill:active {
  /*Fix for autofilled inputs*/
  -webkit-text-fill-color: var(--text-primary);
  caret-color: var(--text-primary);
  -webkit-background-clip: text;
}

.input .input-field-container .input-field::placeholder {
  color: var(--text-primary);
}

.input .input-field-container .input-toggle-password-visibility {
  width: 24px;
  height: 24px;
  cursor: pointer;
}

.input .input-field-container .input-toggle-password-visibility.hidden {
  display: none;
}

.input .input-underline {
  border-bottom: 1px solid;
  border-bottom-color: var(--border-primary);
  transition: border-bottom-color 0.1s;
}

.input .input-info {
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;

  color: var(--text-secondary);
}

.input .input-error {
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;

  color: var(--text-negative);
}

/*Error*/
.input.error .input-label .input-label-text, .input.form-error .input-label .input-label-text {
  color: var(--text-negative);
}

.input.error .input-underline, .input.form-error .input-underline {
  border-bottom-color: var(--text-negative);
}

.input.error .input-info {
  /*Hiding info node if there is an error, only for non-global errors, because when have form-level error - don't have errors under inputs*/
  display: none;
}

/*readonly*/
.input.readonly .input-field {
  cursor: default;
}

.input.readonly .input-label .input-label-text,
.input.readonly .input-field-container .input-field {
  color: var(--text-disabled);
}

.input.readonly .input-field-container .input-field:-webkit-autofill,
.input.readonly .input-field-container .input-field:-webkit-autofill:hover,
.input.readonly .input-field-container .input-field:-webkit-autofill:focus,
.input.readonly .input-field-container .input-field:-webkit-autofill:active {
  /*Fix for autofilled inputs*/
  -webkit-text-fill-color: var(--text-disabled);
  caret-color: var(--text-disabled);
  -webkit-background-clip: text;
}

.input.readonly .input-underline, .input.readonly:focus-within .input-underline {
  border-bottom-color: var(--text-disabled);
  border-bottom-style: dashed;
}

.input.readonly:focus-within .input-label .input-label-text {
  color: var(--text-disabled);
}

/*Focus*/
.input:focus-within .input-underline {
  border-bottom-color: var(--surface-action);
}

.input:focus-within .input-label .input-label-text {
  color: var(--text-action);
}

/*Phone*/
.input .iti {
  display: flex;
  flex-grow: 1;
  height: 24px;
}

.input .iti .iti__flag-container {
  width: 22%;
  color: var(--text-primary);
  font-weight: 400;
  font-size: 16px;
  line-height: 22px;
  position: relative;
}

.input.readonly .iti .iti__flag-container {
  color: var(--text-disabled);
}

.input .iti .input-field {
  width: 78%;
  padding: 1px 0 !important;
}

.input .iti .iti__selected-flag {
  background: none;
  padding: 0;
  display: flex;
  justify-content: space-between;
}

.input .iti .iti__selected-flag:focus-visible {
  outline: none;
}

.input .iti--allow-dropdown .iti__flag-container:hover .iti__selected-flag {
  background: none;
}

.input .iti__arrow {
  all: unset;
  position: relative;
  width: 24px;
  height: 24px;
  background-image: url("../img/svg/phonetriangle.svg");
}

.input .iti__country-list {
  border-radius: 4px;
  border: 1px solid var(--border-secondary);
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.30), 0 1px 3px 1px rgba(0, 0, 0, 0.15);

  left: 0;
  padding: 8px 0;
  /*width: 300px;*/
  max-height: 300px;
}

.input .iti__country-list .iti__divider {
  border-bottom: 1px solid var(--border-primary);
}

.input .iti__country {
  display: flex;
  flex-direction: row-reverse;
  justify-content: start;
  align-items: baseline;
  gap: 12px;

  padding: 6px 16px;
  font-weight: 400;
  font-size: 16px;
  line-height: 22px;
}

.input .iti__country .iti__country-name {
  margin: 0;
}

.input .iti__country .iti__dial-code {
  color: inherit;
  display: block;
  position: relative;
}

.input .iti__country .iti__dial-code::after {
  display: block;
  content: "·";
  position: absolute;
  right: -9px;
  top: 0;
}

.input .iti__country.iti__active,
.input .iti__country.iti__highlight {
  color: var(--text-primary-inverse);
  background: var(--surface-action);
}
