The problem is the default value line-height. Browsers vary depending on how they determine the default line height ("normal"), but many do it more than 1 m (the default height for the range). Try explicitly setting the line height to 1em:
<span style="background-color:cyan;line-height:1em;">Nested</span>
or
<div style="background-color:magenta;line-height:1em;">
1em, display:inline-block, , 1-
<div style="background-color:magenta;line-height:2em;">
<span style="background-color:cyan;display:inline-block;">Nested</span>
</div>