html, body {
  margin: 0;
  padding: 0;
}

body {
  font-family: Georgia, serif;
  font-size: 11px;
  line-height: 1.4em;
}

h1, h2, h3, h4, h5, h6 {
  color: #336685;
  font-family: Georgia, serif;
  font-weight: normal;
  line-height: 1.2em;
  margin: .6em 0;
  padding: 0;
}

h1 { font-size: 2.6em; }
h2 { font-size: 1.85em; }
h3 { font-size: 1.45em; }
h4 { font-size: 1.2em; }
h5 { font-size: 1em; font-weight: bold;}
h6 { font-size: 1em; }


a { color: #336685; }
a:hover { color: #666; }
a img { border: 0px; }

blockquote {
  border-left: 8px solid #f3f2f1;
  font-style: italic;
  margin: 1em;
  padding: 0 1em;
}
blockquote p {
  font-size: 1.1em;
}

ol {
  list-style: none;
  margin: 0;
  padding: 0;
}
ol li {
  background: url(images/bg_ol_li.gif) no-repeat 0 2px;
  margin: 0;
  padding: 0 0 0 20px;
}
#resort2 { background-position: 0 -29px; }
#resort3 { background-position: 0 -60px; }
#resort4 { background-position: 0 -91px; }
#resort5 { background-position: 0 -122px; }
#resort6 { background-position: 0 -153px; }
#resort7 { background-position: 0 -184px; }
#resort8 { background-position: 0 -215px; }
#resort9 { background-position: 0 -246px; }
#resort10 { background-position: 0 -277px; }
#resort11 { background-position: 0 -309px; }
#resort12 { background-position: 0 -340px; }
#resort13 { background-position: 0 -371px; }
#resort14 { background-position: 0 -403px; }
#resort15 { background-position: 0 -434px; }
#resort16 { background-position: 0 -465px; }
#resort17 { background-position: 0 -496px; }
#resort18 { background-position: 0 -527px; }

p {
  font-size: 1.1em;
  line-height: 1.3em;
  margin: .3em 0 1.4em 0;
}

#header, #container, #footer {
  clear: both;
  margin: 0 auto;
  position: relative;
  text-align: left;
  width: 1003px;
}

#header {
  margin-top: 15px;
}

#logo {
  display: block;
  height: 106px;
  left: 2px;
  position: relative;
  top: 53px;
  width: 267px;
}

#nav {
  background: url(images/nav_bg.gif) no-repeat 0 10px;
  clear: both;
  height: 74px;
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
  width: 1003px;
}
#nav li { float: left; }
#nav li a {
  color: #fff;
  display: block;
  float: left;
  font-family: Arial, sans-serif;
  font-size: 13px;
  font-weight: bold;
  margin: 17px 0 0 0;
  outline: 0px;
  padding: 9px 14px;
  text-decoration: none;
}
#nav li.first a {
  margin-left: 7px;
}
#nav li a:hover { text-decoration: underline; }


/* Container / Content */

#content, #sidebar, #promotion {
  display: inline; /* IE6 fix, see below */
  float: left;
  margin: 0 8px 10px 0;
}

#content {
  margin-left: 16px;
  width: 510px;
}
#content h2, #content h3, #content h4, #content h5, #content h6 {
  margin: 1.4em 0 .6em 0;
}
#content img.thumb {
  float: right;
  margin: 0 0 8px 8px;
}
#map {
  background: url(images/map.jpg) no-repeat;
  display: block;
  height: 329px;
  position: relative;
  width: 510px;
}
#map dt { display: none; }
#map a {
  display: block;
  opacity: .7;
  overflow: hidden;
  position: absolute;
}
#map #up {
  background: url(images/map_up.gif) no-repeat 1px -224px;
  height: 224px;
  left: 0;
  line-height: 230px;
  text-indent: 500px;
  top: 0;
  width: 445px;
}
#map #up:hover {
  background-position: 1px 1px;
}
#map #lp {
  background: url(images/map_lp.gif) no-repeat 1px 170px;
  bottom: 0;
  height: 170px;
  line-height: 200px;
  right: 0;
  text-indent: 300px;
  width: 270px;
}
#map #lp:hover {
  background-position: -1px -1px;
}

#sidebar {
  width: 154px;
}
#sidebar h4, #sidebar h4 a {
  color: #AE4C52;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
}
#sidebar h4 a:hover {
  text-decoration: underline;
}
#sidebar h5 {
  margin-bottom: 3px;
}
#sidebar h5, #sidebar p {
  color: #000;
  line-height: 1.4em;
  margin-left: 8px;
  margin-right: 8px;
  text-align: left;
}
#sidebar p {
  margin-bottom: 1.4em;
}

#promotion {
  margin-right: 0;
  width: 300px;
}

#download_calendar {
  text-align: center;
}

#travel_newsletter_subscription {
  /* border rules fix verticals for IE */
  border: 1px solid #fff;
  border-left: 0;
  border-right: 0;
  margin: 0 0 16px 0;
  padding: 0 0 26px 0;
  position: relative;
  width: 100%; /* IE6, see below */
}
#travel_newsletter_subscription .submit, #travel_newsletter_subscription .textbox {
  position: absolute;
  bottom: 0;
}
#travel_newsletter_subscription .textbox {
  background: #F2F7F7;
  border: 1px solid #336685;
  color: #336685;
  font-family: Georgia, serif;
  font-size: 12px;
  font-style: italic;
  height: 16px;
  margin: 0 2px 0 0;
  padding: 2px 0 0 0;
  text-indent: 3px;
  width: 224px;
}
#travel_newsletter_subscription .submit {
  right: 0;
}
#travel_newsletter_subscription p {
  background: #fff url(images/snipe_email.jpg) no-repeat 0px 0px;
  font-size: 10px;
  height: 7em;
  padding: 0 0 0 56px;
  margin: 0;
}

#footer {
  border-top: 3px double #eee;
  color: #666;
  font-size: 10px;
  font-weight: bold;
  margin: 10px auto;
  text-align: center;
}


.map_legend {
  float: left;
  width: 255px;
}
#content .map_legend h2 { margin-top: .3em; }
.resort_desc {
  clear: both;
}
.resort_stats {
  float: left;
  list-style: none;
  margin: -6px 0 12px 0;
  padding: 0;
}
.resort_stats li {
  float: left;
  width: 170px;
}
.section {
  background: #f3f2f1 url(images/sidebar_section_top.gif) no-repeat;
  padding: 10px 0 0 0;
  margin: 0 0 8px 0;
  text-align: center;
  width: 154px;
}
.section p {
  color: #a5a5a5;
  font-size: 10px;
  margin: 0 0 4px 0;
}

.section_cap {
  background: #f3f2f1 url(images/sidebar_section_btm.gif) no-repeat bottom;
  height: 10px;
}

.body_matchbook_rule {
  background: url(images/body_matchbook_rule.gif) no-repeat;
  clear: both;
  height: 12px;
  margin: 0;
  padding: 0;
  width: 510px;
}
.matchbook_rule {
  background: url(images/matchbook_rule.gif) no-repeat;
  clear: both;
  height: 20px;
  margin: 0;
  padding: 0;
  width: 299px;
}


/* Advertising */

.advertisement {
  background: #eee;
  text-align: center;
}

#header .advertisement {
  display: inline; /* IE6 fix, see below */
  clear: both;
  float: right;
  height: 120px;
  margin: 0 7px -8px 0;
  width: 700px;
}

#promotion .advertisement {
  height: 250px;
  margin: 8px 0;
  width: 300px;
}

/* Hacks and explanations
 * ---
 *
 * Building this I hit a few bugs I haven't seen in a while.
 * The best was the IE6 double-margin bug, which was fixed
 * by adding "display: inline;" to the floated elements.
 *
 * Another common IE6 fix was adding hasLayout to the form
 * in the promotions column. A simple width declaration was
 * all that it took.
 *
 * More info on all of these hacks:
 *   http://www.positioniseverything.net/
 *   God bless you, PiE.
 *
 */
