.input-group-custom {
    position: relative;
    margin-top: 10px;
}

.input {
    width: 100%;
    border: solid 1.5px #9e9e9e;
    border-radius: 1rem;
    background: none;
    padding: 1rem;
    font-size: 1rem;
    color: #000;
    transition: border 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.user-label {
    position: absolute;
    left: 15px;
    color: #000;
    pointer-events: none;
    transform: translateY(1rem);
    transition: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    background: transparent;
}

.input:focus,
input:valid {
    outline: none;
    border: 1.5px solid #1a73e8;
    background-color: transparent;
}

.input:focus~label,
input:valid~label {
    transform: translateY(-50%) scale(0.8);
    background-color: #fff;
    border-radius: 1rem;
    padding-left: 8px;
    padding-right: 8px;
    color: #2196f3;
}