.rate {
    float: left;
    height: 20px;
    padding: 0 0;
}
.rate:not(:checked) > input {
    position:absolute;
    top:-9999px;
}
.rate:not(:checked) > label {
    float:right;
    width: 15px;
    overflow:hidden;
    white-space:nowrap;
    cursor:pointer;
    font-size: 18px;
    color:#ccc;
    line-height: 18px;
}
.rate:not(:checked) > label:before {
    content: "★";
}
.rate > input:checked ~ label {
    color: #ffc700;    
}
.rate:not(:checked) > label:hover,
.rate:not(:checked) > label:hover ~ label {
    color: #deb217;  
}
.rate > input:checked + label:hover,
.rate > input:checked + label:hover ~ label,
.rate > input:checked ~ label:hover,
.rate > input:checked ~ label:hover ~ label,
.rate > label:hover ~ input:checked ~ label {
    color: #c59b08;
}