display: none; で消し、チェックボックス用のlabelにアイコンフォントを指定して、チェックボックスのオンオフでアイコンを切り替えています。
<li>
<input type="checkbox" name="one" id="one" />
<label for="one">Create checkbox</label>
</li>
label:before {
content: '\f096'; /*unchecked*/
}
label:after {
content: '\f046'; /*checked*/
max-width: 0;
overflow: hidden;
opacity: 0.5;
transition: all 0.35s;
}