It’s not because the floating divs doesn’t have a height, it’s because the floating divs don’t affect the size of the parent element.
You can use the overflow style to make the parent element take the floating elements in consideration:
#outer { overflow: auto; }