.s-input {
    position: relative;
    display: flex;
    flex-direction: column;
    --input-height: 24px;
}

textarea.s-input-pure {
    min-height: 24px;
    height: 100px;
}

.s-input__input-area {
    padding: 0.7rem 0.8rem;
    border: 1px solid #e2e3e4;
    background-color: var(--lightest);
    border-radius: 0.5rem !important;
    font-size: 1rem;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    position: relative;
    cursor: text;
    transition: border-color 0.1s;
    align-items: center;
	mask: none !important;
}
    .s-input--hover .s-input__input-area {
        border-color: var(--primary-alpha-500);
    }
    .s-input--focus .s-input__input-area,
    .s-input--error .s-input__input-area,
    .s-input--success .s-input__input-area {
        border-width: 2px;
        padding: calc(0.7rem - 1px) calc(0.8rem - 1px)
    }
    .s-input--focus .s-input__input-area {
        border-color: var(--primary-alpha-500);
    }
    .s-input--error .s-input__input-area {
        border-color: var(--error);
    }
    .s-input--success .s-input__input-area {
        border-color: var(--success);
    }

.s-input__input {
    border: none !important;
    outline: none !important;
    background-color: transparent;
    color: var(--dark);
    font-size: 1rem;
    box-shadow: none !important;
    flex-grow: 1;
    width: 100%;
    min-width: 0px;
    height: var(--input-height);
}
    .s-input__input::selection {
        background-color: var(--primary-alpha-800);
        color: white;
    }

.s-input__placeholder {
    position: absolute;
    color: var(--gray-light);
    transition: all 0.08s cubic-bezier(.63,.74,.33,.97), font-weight 0.05s, padding 0.08s;
    top: unset;
    cursor: text;
    user-select: none;
    will-change: transform;
}
    .s-input--hover .s-input__placeholder {
        color: var(--primary-alpha-700);
    }
    .s-input--focus .s-input__placeholder,
    .s-input--filled .s-input__placeholder {
        padding: 0 6px;
		transform: translate(calc(-0.1em), -112%) scale(0.8);
		transform-origin: bottom left;
        background: linear-gradient(transparent, var(--lightest) 55%);
    }
	.s-input--filled .s-input__placeholder {
		color: var(--gray);
	}
    .s-input--focus .s-input__placeholder {
		font-weight: 500;
        color: var(--primary-alpha-800);
    }
    .s-input--error .s-input__placeholder {
        color: var(--error);
    }
    .s-input--success .s-input__placeholder {
        color: var(--success);
    }

.s-input__message {
    font-size: 0.8rem;
    font-weight: 400;
    text-align: left;
    color: var(--gray);
    position: absolute;
    top: 100%;
    transition: 0.1s;
}
    .s-input__message--error {
        color: var(--error);
        animation: slide-down 0.2s, fade-in 0.16s;
    }
    .s-input__message--success {
        color: var(--success);
        animation: slide-down 0.16s, fade-in 0.12s;
    }

    .s-input__message-icon {
        font-weight: 500;
    }

.s-input--inactive {
    pointer-events: none;
}
    .s-input--inactive * {
        pointer-events: all;
    }
    .s-input--inactive input,
    .s-input--inactive label {
        pointer-events: none;
    }

.s-input__tooltip {
    padding-left: 0.5rem;
}

    .s-input__tooltip-icon {
        display: block;
        width: var(--input-height);
        height: var(--input-height);
        color: var(--gray-lighter);
        border-radius: 50%;
        font-weight: 400;
        line-height: 1.25;
        cursor: help;
        user-select: none;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: all 0.1s, outline 0s;
    }

        .s-input--hover .s-input__tooltip-icon,
        .s-input--focus .s-input__tooltip-icon {
            color: var(--primary-alpha-500);
        }
        .s-input--focus .s-input__tooltip-icon {
			font-weight: 500;
        }
        .s-input--error .s-input__tooltip-icon {
            color: var(--error);
        }
        .s-input--success .s-input__tooltip-icon {
            color: var(--success);
        }

@media screen and (prefers-reduced-motion: reduce) {
    .s-input, .s-input * {
        transition: none;
        animation-duration: 0;
    }
}