.text-field {
    position: relative;
    display: block;
    width: 100%;
    background: transparent;
    border: 1px solid var(--divider-color);
    border-radius: 8px;
}

.text-field input {
    width: 100%;
    padding: 16px 14px;
    background: transparent;
    color: var(--palette-text-primary);
    font-weight: 400;
    font-size: 16px;
    line-height: 24px;
    border: none;
    outline: none;
}

.text-field input::placeholder {
    color: var(--palette-text-secondary);
    opacity: 1;
}

.text-field label {
    position: absolute;
    left: 10px;
    font-weight: 600;
    color: var(--palette-text-secondary);
    pointer-events: none;
    background: var(--background-color-default);
    padding: 0 4px;
    top: -10px;
    font-size: 12px;
}

.text-field:hover:not(.disabled):not(.error):not(:focus-within) {
    transition: 0.2s ease all;
    border-color: var(--palette-text-primary);
}

.text-field:focus-within {
    border-color: var(--palette-text-primary);
    box-shadow: 0 0 0 1px var(--palette-text-primary);
}

.text-field:focus-within label {
    color: var(--palette-text-primary);
}

.text-field.error {
    border-color: var(--palette-error-main);
}

.text-field.error label {
    color: var(--palette-error-main);
}

.text-field.error:focus-within {
    box-shadow: 0 0 0 1px var(--palette-error-main);
}

.text-field.disabled {
    border-color: var(--palette-text-secondary);
}

.text-field.disabled label {
    color: var(--palette-text-secondary);
}

.text-field.disabled input {
    color: var(--palette-text-secondary);
    cursor: not-allowed;
}
