/*  CSS Reset */ 
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center, dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}
body {
  line-height: 1;
}
ol, ul {
  list-style: none;
}
blockquote, q {
  quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

/* remember to define focus styles! */
:focus {
  outline: 0;
}

/* remember to highlight inserts somehow! */
ins {
  text-decoration: none;
}
del {
  text-decoration: line-through;
}

/* tables still need 'cellspacing="0"' in the markup */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

/*  /CSS Reset */ 
  
  .clearfix:after,
  #app_body:after { /* not sure if #app_body:after is needed test befreo removing (related to grey column missing in IE bug) */
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
  }
  
  .hedlogo img,
  #featured_image img {
    display: block;
  }
  
  body {
    background-color: #ececec;
    text-align: center;
    font-family: georgia, garamond, serif;
    font-size: 12px;
    line-height: 14px;
    color: #000;
    padding: 8px 0 0 0;
  }
  
  body#admin {
    text-align: left;
    margin: 8px;
  }
  
  
  a:link, 
  a:visited,
  a:active {
    color: #0080fd; text-decoration: none;
  }
  a:hover {
    color: #0080fd; text-decoration: none;
  }
  #nav_links a:link, 
  #nav_links a:visited,
  #nav_links a:active {
    color: #000; text-decoration: none;
  }
  #nav_links a:hover {
    color: #0080fd; text-decoration: none;
  }
  
  h1 {
    font-size: 18px;
    line-height: 23px;
  }
  
  h2 {
    font-size: 14px;
    line-height: 19px;
  }
  
  h3 {
    font-size: 11px;
    line-height: 16px;
  }
  
  
  .fieldWithErrors {
    padding: 2px;
    background-color: red;
    display: table;
  }

  #errorExplanation {
    width: 400px;
    border: 2px solid red;
    padding: 7px;
    padding-bottom: 12px;
    margin-bottom: 20px;
    background-color: #f0f0f0;
  }

  #errorExplanation h2 {
    text-align: left;
    font-weight: bold;
    padding: 5px 5px 5px 15px;
    font-size: 12px;
    margin: -7px;
    background-color: #c00;
    color: #fff;
  }

  #errorExplanation p {
    color: #333;
    margin-bottom: 0;
    padding: 5px;
  }

  #errorExplanation ul li {
    font-size: 12px;
    list-style: square;
  }
  
  
  #container {
    margin: 0 auto;
    width: 937px;
    text-align: left; 
    background-color: #ffffff;
  }
  #main {
    padding: 0 3px;
    background: #fff url(/images/bg_grad.gif) repeat-y 0 0;
    width: 931px;
    margin-bottom: 30px;
    overflow: hidden;
  }

  #hedtxt {
    height: 20px;
    background: #000 url(/images/hed_left.jpg) no-repeat 0 0;
    background-color: #000;
    text-align: right;
  }
  #hedtxt p {
    line-height: 20px;
    color: #fff;
    display: inline; /* this is probably not the best */
    margin: 0 16px 0 0 ;
    font-size: 10px;
    font-weight: bold;
  }
  #main_nav {
    background: #fff url(/images/mailinglist_top.jpg) no-repeat 0 0;
    height: 39px;
  }
  #main_nav #nav_links {
    margin: 0 0 0 193px;
    line-height: 38px;
    border-bottom: 1px solid #000;
    width: 713px;
    padding-left: 15px;
    text-transform: uppercase;
    overflow: hidden;
    white-space: nowrap;
  }
  #main_nav #nav_links .links a {
    font-weight: bold;
    margin-right: 13px; 
  }
  #mailinglist #email_address {
    width: 133px; 
    height: 15px;
    border: 1px solid #cccccc;
    line-height: 12px;
  }

  #main_body {
    padding: 0 8px;
  }
  #main_banner {
    background: #fff url(/images/mailinglist_mid.jpg) no-repeat -8px 0;
    height: 110px;
    border-bottom: 1px solid #000;
    margin-bottom: 2px;
  }
    #main_banner div {
      float: left;
    }
    #main_banner #mailinglist {
      width: 179px;
      background: transparent url(/images/join_the_mailinglist.gif) no-repeat 8px 45px;
      height: 45px;
      padding: 65px 0 0 8px;
    }
    #main_banner #adunit_728x90 {
      margin: 8px 0;
      height: 90px;
      width: 728px;
    }
  #main_app_body {
    border-top: 2px solid #000;
    margin-top: 2px;
    width: 915px;
  }
  
  #main_sponsor {
    border-top: 1px solid #000;
    padding: 8px 0;
    text-align: center;
  }
  #main_sponsor img {
    margin-right: 16px;
  }
  
  
  #add_this_link {
    float: right;
    clear: left;
  }
  
  #app_body {
    float: left;
    width: 915px;
  }
  #app_body .app_column {
    float:left;
    padding-bottom: 8px;
  }

  #app_body.two #app_col1 {
    width: 721px;
    margin: 8px 8px 0 0;

  }
  #app_body.two #app_col2 {
    width: 177px;
    margin: 8px 0 0 9px;
  }
  
  #app_body.three #app_col1 {
    width: 495px;
    margin: 8px 8px 0 0;
  }
  #app_body.three #app_col2 {
    width: 209px;
    margin: 8px 8px 0 9px;
  }
  #app_body.three #app_col3 {
    width: 177px;
    margin: 8px 0 0 9px;
  }
  
  #app_body.three .app_body_col1 {
    float: left;
    width: 258px;
    margin-right: 8px;
    margin-bottom: 16px;
  }
  #app_body .app_body_col1 .video_caption,
  #app_body .app_body_col1 .video_title {
    font-weight: bold;
    font-size: 14px;    
  }
  
  #app_body .app_body_col1 .event_info {
    font-size: 16px;
  }
  
  #app_body .app_body_col1 .event_video {
    margin: 8px 0;
  }

  
  #app_body.three .app_body_col1 p {
    margin-top: 8px;
  }
  #app_body.three .app_body_col1 object,
  #app_body.three .app_body_col1 embed {
    margin-top: 8px;
  }
  
  #app_body.three .app_body_col2 {
    float: left;
    width: 229px;
    margin-left: 8px;
  }
  #app_body.three {
    background: transparent url(/images/bg_three_columns.gif) repeat-y 0 0;
  }
  #app_body.two {
    background: transparent url(/images/bg_two_columns.gif) repeat-y 0 0!important;
  }
  #app_body.two .app_body_col1 {
    float: left;
    margin-right: 8px;
    margin-bottom: 16px;
  }
  
  
  
  .app_column {
    overflow: hidden;
  }
  
  
  
  .pagination a,
  .pagination span {
    margin-left: 4px;
  }
  
  
  
  
  #section_header {
    height: 29px;
/*    border-bottom: 1px solid #000; this may have to go back in. */
    padding-top: 8px;
    position: relative;
/*    width: 504px;*/
    margin-bottom: 16px;
  }

  #section_header h1 {
    display: inline;
    float:left;
  }
  
  #events_column_listing {
    font-weight: bold;
  }
  #events_column_listing ul {
    margin: 8px 0;
  }
  #events_column_listing li.ecl_name a {
    color: #0080fd;
  }
  ul.ecl_wrapper {
    width: 209px;
    float: left;
  }
  ul.ecl_wrapper li {
    display: inline;
    float: left;
  }
  ul.ecl_wrapper li.ecl_date {
    width: 130px;
  }
  ul.ecl_wrapper li.ecl_name {
    width: 130px;
  }
  li.ecl_image {
    border: 2px solid #000;
    width: 67px;
    height: 67px;
  }
  
  #event_header {
    margin-bottom: 16px;
  }
  #event_header h2 {
    font-size: 20px;
    line-height: 25px;
  }
  
  #event_header h2 span.event_time {
    text-transform: lowercase;
  }
  
  p.event_url a {
    color: #0080fd;
  }
  #featured_image {
    border: 4px solid #000;
    height: 250px;
    width: 250px;
  }
  
  
  #adunit_160x600 {
    width: 160px;
    height: 600px;
    margin-top: 8px;
/*    margin-left: 17px;*/
  }
  
  #footer {
    height: 20px;
    background-color: #000;
    text-align: right;
    color: #fff;
    line-height: 20px;
    padding-right: 16px;
  }
  
  #login_link         { float: left; padding-left: 8px; }
  #login_link a       { color: #000; }
  #login_link a:hover { color: #0080fd; }
  
  .admin_links { 
    float: right; 
    background-color: pink;
    }
    
    
  body#home .body_copy {
    font-size: 16px;
    line-height: 20px;
  }
  body#home .body_copy h2 {
    font-size: 20px;
    line-height: 24px;
  }
  
  body#home #home_ad_banner_cycle {
    height: 146px;
  }  
  
  body#home #blog img {
    float: left;
    margin-right: 10px;
    margin-bottom: 10px;
  }
  
  
  body#about .body_copy {
    font-size: 16px;
    line-height: 20px;
  }
  
  body#photogallery #gallery_header h3
  body#videogallery #gallery_header h3 {
    float: left;
  }
  body#photogallery #gallery_header .pagination
  body#videogallery #gallery_header .pagination {
    float: right;
  }
  body#photogallery .app_body img
  body#videogallery .app_body img {
    margin-bottom: 8px;
  }
  body#photogallery .app_body,
  body#videogallery .app_body {
    padding-bottom: 25px;
    margin-bottom: 2px;
    border-bottom: 1px solid #000;
  }
  body#photogallery #photo_archive,
  body#videogallery #video_archive {
    border-top: 2px solid #000;
    padding-top: 8px;
  }
  
  body#admin li {
    padding-left: 8px;
  }
  
  .nav_dropdown {
    border: 1px solid #000; 
    width: 150px; 
    float: right; 
    position: relative;
    background: #fff;
  }
  
  .nav_dropdown div.label {
    float: left;
    cursor: pointer;
    width: 132px;
    padding-left: 2px;
  }
  .nav_dropdown div.arrow {
    border-left: 1px solid #000; 
    text-align: center; 
    width: 15px; 
    float: right;
    cursor: pointer;
  }
  .nav_dropdown table {
    clear: both; 
    display: none; 
    border: 1px solid #333; 
    position: absolute; 
    top: 15px; 
    width: 151px;
    background: #fff;
    table-layout:fixed;
  }
  
  .nav_dropdown td {
    overflow: hidden; 
    text-overflow: ellipsis; 
    white-space: nowrap;
    padding-left: 2px;
  }
  .nav_dropdown tr.even {
    background-color: #eaeaea;
  }
  
  .body_copy p {
    margin-bottom: 8px;
  }
  
  
  .archive_table td {
    vertical-align: top;
    padding: 3px;
  }
  
  .archive_table td.archive_date {
    width: 140px;
  }
  
  .archive_table td.archive_description {
    width: 520px;
  }
  
  #photo_archive ul.inner img,
  #video_archive ul.inner img {
    border: 2px solid #000;
  }

  #photo_archive ul.outer,
  #video_archive ul.outer {
    float: left;
    width: 495px;
    margin-bottom: 16px;
  }
  
  #photo_archive ul.outer li,
  #video_archive ul.outer li {
    float: left;
  }
  
  #photo_archive ul.inner,
  #video_archive ul.inner {
    float: left;
    width: 161px;
    margin-right: 4px;
  }
  ul.inner li {
    width: 161px;
  }
    
  #post_archive .posting {
    padding: 0 8px 8px 8px;
    float: left;
    width: 480px;
    margin-bottom: 2px;
  }
  
  #post_archive .posting span.permalink {
    line-height: 20px;
  }
  
  #post_archive .posting p {
    margin-top: 8px;
  }
  
  #post_archive .posting img {
    padding-top: 10px;
    padding-right: 10px;
    float:left;
  }
  
  #post_archive .odd {
    background-color: #ececff;
  }
  
  #post_archive .even {
    background-color: #eaeaea;
  }
  
  #posts #app_col1 img {
    float: left;
    margin-right: 10px;
    margin-bottom: 10px;
  }
  
  #post_image_container {float: left;}
  
  #homePromoUnit-Nav {
    width: 483px;
    text-align: right;
  }
  #homePromoUnit-Nav a {
    margin: 4px;
  }
  
  
  .press_posting {
    border-bottom: 1px solid #ccc;
    margin-bottom: 24px;
    padding-bottom: 8px;
  }