3 列の Web サイトを作成しようとしていますが、適切なナビゲーションを正しく表示できないようです。常に他の div の下に表示されます。なぜこれが起こっているのか、どうすれば修正できるのか教えてください。
CSSは次のとおりです。
body {
    background-image:url('images/background.png');
    background: no-repeat center center fix;
    background-size: cover;
    background-attachment: fixed;
}
p {
    margin: 0px;
    color: #231f20;
    font-size: 16px;
    font-family: "Garamond Premier Pro", serif;
    text-align: left;
}
h1 {
    margin: 0px;
    color: #231f20;
    display: inline-block;
    text-align: center;
    font-size: 24px;
    font-family: "Myriad Pro", sans serif;
}
#container {
    margin-left: auto;
    margin-right: auto;
    width: 960px;
    height: 750px;
}
#header {
    width: 960px;
    height: 100px;
}
#marquee {
    width: 960px;
    height: 30px;
    font-size: 24px;
    background-color: #bc34ba;
    font-family: "Garamond Premier Pro", serif;
}
#topnav {
    border-bottom: 1px #000 solid;
    margin: 0px;
    padding: 0px 0px 0px 0px;
    width: 960px;
    height: 20px;
    background-color: fed450;
#leftnav {
    margin: 0px;
    font-family: "Century Gothic", sans serif;
    float: left;
    width: 160px;
    background-color: f58025;
    text-align: left;
    height: 580px;
}
#body {
    margin: 0px;
    border-right: 1px dashed #694717;
    width: 640px;
    height: 580px;
    margin: auto;
    padding: 10px 0px 0px 10px;
    background-color: d80074;
}
#rightnav {
    margin: 0px;
    font-family: "Century Gothic", sans serif;
    float: right;
    width: 160px;
    background-color: c1d82f;
    text-align: right;
    height: 580px;
}
#footer {
    width: 960px;
    height: 20px;
    text-align: center;
    clear: both;
}
HTMLは次のとおりです。
<div id="container">
    <div id="header"></div>
    <div id="marquee"></div>
    <div id="topnav"></div>
    <div id="leftnav"></div>
    <div id="body">
        <h1>Title<h1>
        <br>
        <p>This is where the content is.</p>
    </div>
    <div id="rightnav"></div>
    <div id="footer"></div>
</div>