After a little testing, I came to the conclusion that you need to set the height in the id="main"div as well
style="width:100%; height:100%"
Since this is a container for a card and without a certain height, nothing will appear. It is like rolling a curtain; the card alone will not push it.
I assume that you already have something similar, since the map works without nesting, but I will repeat it again:
<style type="text/css">
html, body {height:100%}
</style>