/**   Styles for "Screen" Media
*     File: styles.css
*     Theme: 0018
*     Author: Nate Hanna
*     Auth Web: http://www.mediasation.com
*     modified: 2010-01-14 (by Nate Hanna)
* --------------------------------------------------------------
**/

/** Element/Global Styles (including Typography)
-------------------------- **/
html { 
   font-size: 62.5%; /* about 10px if browser size is set at default (16px) */
   font-family: "Trebuchet MS", Arial, Helvetica, Geneva, "microsoft sans serif", sans-serif;
   height: 100%;
}
body { padding-bottom: 50px; }
   a { text-decoration: underline; }
      a:hover { text-decoration: none; }
      a img { border: 0; }

   h1, h2, h3, h4, h5, h6,
   .content h1, .content h2, .content h3, .content h4, .content h5, .content h6,
   #topNavigation,
   #footer {
      line-height: 1.25em;
      margin-bottom: 0.2em;
      font-family: "Helvetica Neue Light","Helvetica Neue", Helvetica, Arial, Geneva, sans-serif;
   }
      h1, .content h1 { 
         font-size: 2.5em; 
         margin-top: 0; 
         font-weight: normal;
         text-transform: uppercase;
      }
      h2, .content h2 { font-size: 1.3em; }
      h3, .content h3 { font-size: 1.2em; }
      h4, .content h4 { font-size: 1.1em; }
      h5, .content h5 { font-size: 1.0em; }
      h6, .content h6 { font-size: 0.9em; }

div.hr {
   height: 1px;
   margin: 5px 0 1.6em 0;
   background: transparent no-repeat scroll center;
}
   div.hr hr { display: none; }

.content td { padding: 0 20px 0 0; }

#wrapper {
   position: relative;
   width: 951px;
   min-height: 500px;
   margin: 50px auto;
}
   #header, #contentWrapper { padding: 0 25px 0 26px; }

pre { color: #000; }


/** Header
-------------------------- **/
/** @group header */
#default.default #header { height: 441px; }
#default.home #header, #default .has_flash_banner #header { height: 550px; }
#default.store #header { height: 140px; }

#header #masthead a, 
#header #masthead a:visited {
   position: absolute;
   display: block;
   text-indent: -10000px;
   text-decoration: none;
   overflow: hidden;
   z-index: 5;
}

/** @group hdrImg */
#hdrImg { position: relative; }
   
   #hdrImg #img { 
      position: absolute;
      left: 0;
      z-index: 1;
      overflow: hidden;
      width: 900px;
   }
      #default.default #img {
         top: 125px;
         height: 290px;
      }
      #default.home #img,
      #default .has_flash_banner #img {
         top: 105px;
         height: 405px;
      }
      #hdrImg #img img { width: 900px; }

   #corner1, #corner2, #corner3, #corner4 { display: none; }
/* @end hdrImg **/
/* @end header **/

/** ContentWrapper
-------------------------- **/
/** @group contentWrapper */
#contentWrapper { padding-top: 0; margin-top: -10px; }
/** @group contentSlot */
#contentSlot {
   width: 650px;
   float: right;
}
   #contentSlot iframe { width: 588px; }
   #layout { padding: 12px 31px 24px; }
   .store #layout { padding: 12px 16px 24px 31px; }
/* @end contentSlot **/
/** @group sideBar */
#sideBar {
   width: 250px;
   float: left;
   line-height: 0.9em;
}
   #sideBarHook { padding: 10px 12px; }

   #sideBar div.title {
      font-size: 1.4em;
      padding-bottom: 10px;
         padding: 0.55em 0 0.4em;
   }
   #sideBar div.input { margin: 0; position: relative; }
   #sideBar input {
      border-width: 1px;
      border-style: solid;
      padding: 4px 5px 4px 5px;
      margin: 5px 1px 3px 0px;
   }
      #sideBar input.email { width: 213px; }
      #sideBar input#authcode { width: 78px; }
         #sideBar .authcode, #sideBar .flash_embedded { vertical-align: middle; }
         #sideBar .flash_embedded {
            position: absolute;
            top: 5px;
            right: 2px;
         }
   #sideBar input.search { width: 150px; }
   #sideBar button {
      margin: 5px -1px 5px 0px;
      padding: 3px 5px;
      border-width: 1px;
      border-style: solid;
      line-height: normal;
      font-weight: bold;
      background: transparent top left repeat-x;
      cursor: pointer;
   }
   #sideBar #marginContent { 
      margin-top: 20px;
      line-height: 1.5em;
      padding-top: 0.5em; 
   }
      .margin_empty #sideBar #marginContent { border: 0; }

#sideBar #newsletter { padding-top: 0; }


/** @group topNavigation */
#topNavigation { 
   width: 238px;
   margin: 8px 0 0 0;
   padding-bottom: 50px;
   line-height: normal;
}
   #topNavigation ul.sf-menu { 
      list-style: none;
      float: none;
      margin: 0;
   }
      #topNavigation ul.sf-menu li { 
         margin: 0 0 4px 0;
         float: none;
      }
         #topNavigation ul.sf-menu li.sfHover ul { z-index: 99; }
         #topNavigation ul.sf-menu li a {
            display: block;
            text-decoration: none;
            letter-spacing: .1em;
            text-transform:uppercase;
            font-size: 1.4em;
            margin: 0;
            padding: 0;
            border: 0;
            text-align: right;
         }
            #topNavigation ul.sf-menu li a span {
               display: block;
               padding: 8px 15px 6px;
            }
            #topNavigation ul.sf-menu li a.sf-with-ul { padding-right: 0; }
            #topNavigation ul.sf-menu li:hover ul,
            #topNavigation ul.sf-menu li.sfHover ul { 
               top: 0; /* match top ul list item height */
               left: 238px;
               margin: 0;
               width: 200px;
            }
               #topNavigation ul.sf-menu li li a span { padding: 6px 13px 7px; }
               #topNavigation ul.sf-menu li:hover ul li ul,
               #topNavigation ul.sf-menu li.sfHover ul li ul { 
                  top: 0; /* match top ul list item height */
                  margin-left: 0;
                  left: 200px;
               }
                  #topNavigation ul.sf-menu li li { padding: 0; margin: 0; }
                     #topNavigation ul.sf-menu li li a {
                        margin: 0;
                        width: 100%;
                        letter-spacing: 0.1em;
                        text-align: left;
                     }
                        #topNavigation ul.sf-menu li.selected li a,
                        #topNavigation ul.sf-menu li.selected li a { padding-right: 0; }

#topNavigation ul.sf-menu .sf-sub-indicator { display: hidden; }
/* @end topNavigation **/
/* @end sideBar **/
/* @end contentWrapper **/


/** @group store */
.store .dialog {
   border: 0;
   padding-left: 10px;
}

.store .flc-buttons, .has_store_menu .flc-buttons { padding-bottom: 10px; }

.store button.main-button,
.store button.button,
.has_store_menu button.main-button,
.has_store_menu button.button {
   height: auto;
   margin-bottom: 6px;
}

.store button.menu-button .button-right, .store div.button a, .has_store_menu button.menu-button .button-right, .has_store_menu div.button a { font-size: 11px; }


.store button.menu-button .button-right, .has_store_menu button.menu-button .button-right { padding: 0; min-height: 19px; height: auto; }
.store button.menu-button .button-left, .has_store_menu button.menu-button .button-left { padding: 0; min-height: 0; height: auto; line-height: 19px;}

.store table.register-table { margin-top: 0; }

/*.store table.register-table .register-section-title { display: none; }*/

.store #sideBar button.menu-button,
.has_store_menu #sideBar button.menu-button {
   padding-top: 0;
   margin: 0;
   margin-right: 8px;
}

.data-table textarea {
   min-width: 300px;
   width: 420px;
}

.cart-content tr td, .cart-content tr th { padding: 2px 10px; }

.store .title h2 {
   margin: 0;
}
.store .dialog .title h2 { font-size: 1.8em; }

.store #product-widgets .dialog .title h2 { font-size: 1.3em; }

.store #location {
   margin-bottom: 20px;
   padding: 5px 0 6px;
}
/* @end store **/


/** @group vcard */
#default .vcard {
   position: absolute;
   top: 0;
   left: 0;
   font-weight: bold;
   color: #AAAAAA;
   line-height: 1.1em;
}
   .vcard .fn, .vcard .seperator { display: none; }
   .vcard .adr {
      position: absolute;
      top: 47px;
      left: 39px;
      width: 220px;
   }
      .vcard .adr .street-address,
      .vcard .phone_wrapper .type,
      .vcard .phone_wrapper .action {
         font-size: 0.85em;
         display: block;
      }
         .vcard .adr .locality, .vcard .adr .region, .vcard .adr .postal-code,
         .vcard .phone_wrapper .value { font-size: 1.1em; }
   .vcard .phone_wrapper {
      position: absolute;
      top: 47px;
      left: 764px;
      width: 200px;
   }
   
   .vcard .fax_wrapper, .vcard .email_wrapper { display: none; }
/* @end vcard **/


/** Footer
-------------------------- **/
/** @group footer */
#footer { 
   height: 18px; 
   letter-spacing: .1em;
   line-height: 1.5em;
   padding: 7px 15px;
   font-size: 1.2em;
   margin: 0;
}
   #footer, #footer a { color: #CCC; }
   #footer a { text-decoration: none; }
      #footer a:hover{ text-decoration: underline; }

#footer #copyright { float: left; }
#footer #siteBy { float: right; }
/* @end footer **/

/** @group formContent */
#formContent td.content label { font-weight: normal; }
/* @end formContent **/

/** Class Styles
-------------------------- **/
.content, .vcard {
   line-height: 1.7em;
   font-size: 1.3em;
}

.spacer { padding: 10px 0; }

.hidden, .printOnly { display: none; }
.clear {
  clear:both;
  height:1px;
  overflow:hidden;
  margin-bottom:-1px;
}
