First we have:
body {
font-family : 'Helvetica Neue', Helvetica, Arial, sans-serif;
}
Cool, thats fine. But then we have:
html, body, input, button, <snipped...> {
font: inherit;
}
So font
get overwritten by this rule which also applies to body, it is now inherit
.
So what does inherit do? It says "use the styling property assigned to my parent element". In this case, the parent of <body>
element is <html>
which has no parent. So no specified font family at all at the root, so nothing can inherit.
What inherit
does not do, is use the previously defined value for that element. It inherits from the parents, not the previous style that would have applied. inherit
is about HTML structure, not CSS structure.
In the end, you set the entire universe to inherit a font from its parent, including all parents. So you never actually find a parent with a real set font. Instead the browser applies its default font, just so it can render something.
If you move your body
font rule after to giant reset rule there, it should start working. Fonts will then inherit all the way up to the body tag, which has a real font now.
initial
is supposed to exist on its own, just likeinherit
, so you can't haveinitial initial
for your background properties. – BoltClock