.wrapper {
    position: relative;
    font-size: 15px;
}

.wrapper label {
    display: block;
    padding: 0 0 12px 30px;
    cursor: pointer;
}

.wrapper input {
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    height: 17px;
    width: 17px;
}

.wrapper input + label::before {
    content: '';
    left: 0;
    position: absolute;
    top: 4px;
    height: 17px;
    width: 17px;
    border-radius: 50%;
    background-color: #adb8bf;
}

.wrapper label {
    font-weight: 400;
}

.wrapper input + label::after {
    content: '';
    border: 3px solid;
    border-left: 0;
    border-top: 0;
    height: 12px;
    left: 5px;
    opacity: 0;
    position: absolute;
    top: 5px;
    transform: rotate(45deg);
    transition: opacity 0.2s ease-in-out;
    width: 7px;
}

.wrapper input:checked + label::after {
    opacity: 1;
}

.wrapper input:focus + label::before {
    box-shadow: 0 0 0 3px #ffbf47;
    background-color: #faa635;
}

.wrapper input:checked + label::before {
    background-color: #faa635;
}
