html {
    --fnd-input-color: var(--fnd-surface-2);
    --fnd-input-border-color: var(--fnd-surface-2);
    --fnd-input-focus-border-color: var(--fnd-text-color);
    --height-small: 38px;
    --height-medium: 48px;
    --height-large: 56px;
}

fieldset:disabled {
    --fnd-text-color: var(--fnd-text-tertiary-color);
    --fnd-text-secondary-color: var(--fnd-text-tertiary-color);
}
fieldset:disabled :where(.input-default),
fieldset:disabled :where(.input-default-stub),
fieldset:disabled :where(.input-container, .input-container-column, .input-container-check) :where(.icon, label) {
    pointer-events: none;
    opacity: .4;
}

.input-container {
    border: var(--fnd-border);
    border-radius: var(--shape-l);
    padding: 0 12px;
    min-height: var(--height-medium) !important;
    display: flex;
    flex-direction: row;
    align-items: center;
}
.input-container:disabled {
    opacity: .4 !important;
    background-color: var(--fnd-input-color);
}
.input-container > label {
    font-size: 14px;
    font-weight: 400;
    line-height: 2 !important;
    color: var(--fnd-text-secondary-color);
    text-wrap-mode: nowrap;
}
.input-container > label::after {
    content: "|";
    font-weight: 100;
    margin: 0 8px;
}
.input-container > .icon {
    width: 5%;
    height: fit-content;
    min-width: 28px;
}
.input-container > .icon::after {
    content: " ";
    font-weight: 100;
    margin: 0 8px;
}

.input-container-column {
    border: var(--fnd-border);
    border-radius: var(--shape-l);
    padding: 12px;
    display: flex;
    flex-direction: column;
}
.input-container-column:disabled {
    opacity: .4 !important;
    background-color: var(--fnd-input-color);
}
.input-container-column > label {
    font-size: 14px;
    font-weight: 400;
    color: var(--fnd-text-secondary-color);
    text-wrap-mode: nowrap;
}

.input-container-check {
    border: var(--fnd-border);
    border-radius: var(--shape-l);
    padding: 0 12px;
    min-height: var(--height-medium) !important;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
}
.input-container-check:disabled {
    opacity: .4 !important;
    background-color: var(--fnd-input-color);
}
.input-container-check > label {
    font-size: 14px;
    font-weight: 400;
    line-height: 2 !important;
    color: var(--fnd-text-color);
    text-wrap-mode: nowrap;
    cursor: pointer;
}

.input-double-field {
    display: flex;
    flex-direction: row;
    align-items: center;
    width: 100%;
}
.input-double-field > :last-child {
    text-align: end;
    margin-left: 8px;
}

.input-container.valid,
.input-container-column.valid,
.input-container-check.valid {
    border: 2px solid var(--fnd-green-color);
}

.input-container.invalid,
.input-container-column.invalid,
.input-container-check.invalid {
    border: 2px solid var(--fnd-red-color);
}

/* инпуты */
.input-default {
    /*border-radius: var(--shape-m);*/
    width: 100%;
    background-color: transparent;
    border: none !important;
    color: var(--fnd-text-color);

    display: block;
    font-weight: 400;
    font-size: 1rem;
    line-height: 2 !important;
    background-clip: padding-box;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out
}
.input-default:focus {
    background-color: transparent !important;
    border-color: transparent !important;
    color: var(--fnd-text-color);

    outline: none !important;
    -webkit-box-shadow: none;
    box-shadow: none;
    outline: 0;
}
.input-default:disabled {
    opacity: .4 !important;
    background-color: var(--fnd-input-color);
}
.input-default-stub {
    border-radius: var(--shape-m);
    width: 100%;
    font-size: 0.875rem;
    line-height: 2 !important;
    background-color: var(--fnd-input-color);
    border-color: var(--fnd-input-border-color);
    color: var(--fnd-text-color);
    border: none;
    padding-top: 10px;
    padding-bottom: 10px;
    padding-left: 12px;
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;

    font-weight: 400;
    background-clip: padding-box;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out
}

select {
    text-transform: none;
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    -webkit-appearance: unset;
    -moz-appearance: unset;
    appearance: unset;
}
select>option[disabled] {
    opacity: .4 !important;
    background-color: var(--fnd-input-color);
}

input, optgroup, textarea {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    border-style: unset;
}

input::placeholder {
    color: var(--fnd-text-secondary-color);
}

/* utils */
.input-height-small {
    min-height: var(--height-small) !important;
}
.input-height-medium {
    min-height: var(--height-medium) !important;
}
.input-height-large {
    min-height: var(--height-large) !important;;
}
input:not([type="checkbox"]):not([type="radio"]) {
    /*min-height: var(--height-small);*/
}

.input-default,
.input-default-stub {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
input[type=number] {
    -moz-appearance: textfield;
}
input[type=file] {
    overflow: hidden
}
input[type=file]:not(:disabled):not([readonly]) {
    cursor: pointer
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
input::-webkit-date-and-time-value {
    min-width: 85px;
    height: 1.5em;
    margin: 0
}
input::-webkit-datetime-edit {
    display: block;
    padding: 0
}
input::-moz-placeholder, input::placeholder {
    opacity: 1
}
input::-webkit-file-upload-button, input::file-selector-button {
    padding: .375rem .75rem;
    margin: -.375rem -.75rem;
    -webkit-margin-end: .75rem;
    margin-inline-end: .75rem;
    pointer-events: none;
    border-color: inherit;
    border-style: solid;
    border-width: 0;
    border-radius: 0;
    -webkit-transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out
}

@media (prefers-color-scheme: dark) {
    input[type="date"]::-webkit-calendar-picker-indicator {
        color-scheme: dark;
    }
    input[type="time"]::-webkit-calendar-picker-indicator {
        color-scheme: dark;
    }
}