You have a problem with adding spaces, I get the following offset selection. Is this really the expected behavior?
It is like Chrome / Safari

The problem reproduces here: https://jsfiddle.net/qsa99cc6/
CSS
p:first-letter { text-transform: uppercase; }
HTML:
<p> highlight me! this won't work because there whitespace in the <p> </p> <p>highlight me! This should work because there isn't</p>
source share