html, body
{
    margin: 0;
    padding: 0;
}
body
{
    font: 12px/1.5em Arial, Helvetica, sans-serif;
    color: #1F3540;
    background: #fff url(../images/body_bg.gif);
    text-align: center;
}
h1, h2, h3, h4, h5
{
    margin: 0 0 1em;
    color: #028968;
}
h2
{
    font-size: 22px;
    font-weight: normal;
}
p{margin: 0 0 1em;}
a,
a:link,
a:visited{color: #028968;}
a:hover,
a:active{color: #1F3540;}
a img{border: none;}
form{margin: 0;}
fieldset{padding: 0;}
hr
{
    height: 1px;
    border: none;
    color: #999;
    background-color: #999;
}

/* ~~~ === POSITIONG SELECTORS ======================================= ~~~ */
#outerWrapper
{
    width: 980px;
    margin: 0 auto;
}
#wrapper
{
    position: relative;
    background: #fff url(../images/wrapper_bg2.gif) repeat-y 0 0;
    margin: 0 24px;
    text-align: left;
}
#masthead
{
    height: 65px;
    background-color: #fff;
}
#masthead h1
{
    font: bold 34px Arial, Helvetica, sans-serif;
    color: #028968;
    border-bottom: 4px solid #028968;
    margin: 0 26px;
    padding: 12px 0 0;
}
#search
{
    height: 29px;
    background: url(../images/search_bar_bg.gif) repeat-x 0 0;
}
    #search p
    {
        margin: 0;
        padding: 2px 0 0 4px;
    }
    #search p input{vertical-align: middle;}
    #search p input.input
    {
        width: 120px;
        margin-top: 1px;
    }
    #page-indicator
    {
        position: absolute;
        top: 65px;
        right: 0;
        width: 219px;
        height: 29px;
        background: url(../images/page_indicator.gif) no-repeat 0 0;
    }
    #page-indicator p
    {
        font-size: 14px;
        font-weight: bold;
        line-height: 29px;
        text-transform: uppercase;
        padding-left: 65px;
    }

#leftcol
{
    position: absolute;
    top: 95px;
    left: 0;
    width: 159px;
}
#midcol
{
    margin: 0 184px;
    padding: 24px 0;
    min-height: 400px;
}
    #productImage
    {
        display: block;
        margin-top: 96px;
    }
#rightcol
{
    position: absolute;
    top: 94px;
    right: 0;
    width: 160px;
}
#footer
{
    clear: both;
    height: 26px;
    background: url(../images/footer_bg.gif) repeat-x 0 0;
    padding-top: 4px
}
    #footer p
    {
        margin: 0;
        line-height: 26px;
        font-weight: bold;
        color: #1F333C;
    }
    #footer p span{padding: 0 16px;}

/* ~~~ === MAIN NAVIGATION ========================================== ~~~ */
#nav
{
    width: 157px;
    list-style-type: none;
    margin: 0;
    padding: 0 0 1px;
    background: url(../images/nav_btm.gif) no-repeat 0 100%;
    border-right: 1px solid #fff;
}
#nav li
{
    padding: 0 0 0 25px;
    line-height: 24px;
    background: url(../images/nav_icon.gif) no-repeat 0 0;
}
#nav a
{
    display: block;
    width: 122px;
    font-weight: bold;
    color: #6B6E73;
    text-decoration: none;
    padding-left: 10px;
    line-height: 24px;
    background: url(../images/link_bg.gif) repeat-x 0 0;
}
#nav a:hover
{
    background-position: 0 -24px;
    color: #028968;
}
#leftcol div.sideBox{width: 158px;}
#leftcol div.sideBox img{border: none;}

/* ~~~ === RIGHTCOLUMN BOXES ======================================== ~~~ */
div.sideBox
{
    width: 150px;
    text-align: center;
    margin: 4px auto;
}
div.sideBox img
{
    display: block;
    margin: 0 auto;
    border: 1px solid #fff;
}
div.sideBox h3
{
    font-size: 10px;
    font-weight: normal;
    color:#fff;
    background: url(../images/box_heading_bg.gif) repeat-x 0 0;
    margin: 0;
    line-height: 16px;
}

/* ~~~ === FORMS =================================================== ~~~ */
.input
{
    font: 12px Arial, Helvetica, sans-serif;
    border: 1px solid #A5ACB2;
}
.button{font: bold 12px Arial, Helvetica, sans-serif;}
table.formbuilder{border-collapse: collapse;}
table.formbuilder head th
{
    padding: 4px;
    text-transform: uppercase;
}
table.formbuilder tbody th{text-align: right;}
table.formbuilder th,
table.formbuilder td{padding: 2px 4px;}

/* ~~~ === SEARCH RESULTS ================================================ ~~~ */
#searchResults dl
{
    margin: 1em 0;
    padding: 1em 0;
    border-top: 1px solid #ccc;
    border-bottom: 1px solid #ccc;
}
#searchResults dd{margin: 0;}


/* ~~~ === PAGINATION ===================================================== ~~~ */
#searchKeywords{font-weight: bold;}
.pagination_summany
{
    font-weight: bold;
    display: block;
    margin-bottom: 4px;
}
p.pagination{clear: both;}
a.pagination_first,
a.pagination_previous,
a.pagination_next,
a.pagination_last,
a.pagination_group
{
    background: url(../images/icons/pagination_left.gif) no-repeat 0 50%;
    text-decoration: none;
    padding: 2px 0 2px 6px;
}
a.pagination_first span,
a.pagination_previous span,
a.pagination_next span,
a.pagination_last span,
a.pagination_group span
{
    background: url(../images/icons/pagination_right.gif) no-repeat 100% 50%;
    padding: 2px 6px 2px 0;
}
a.pagination_first:hover,
a.pagination_previous:hover,
a.pagination_next:hover,
a.pagination_last:hover,
a.pagination_group:hover{color: #1F3540;}
a.pagination_active{font-weight: bold; color: #1F3540;}


.hide{display: none;}


/* ~~~ === CLASSES ============================== ~~~ */
div.captionImageLeft,
div.captionImageRight
{
    font-size: .9em;
    color: #888;
}
div.captionImageLeft
{
    float: left;
    margin: 4px 12px 4px 0;
}
div.captionImageRight
{
    float: right;
    margin: 4px 0 4px 12px;
}
.img-left
{
    float: left;
    margin: 0 12px 4px 0;
}
.img-right
{
    float: right;
    margin: 0 0 4px 12px;
}
.border-none{border: none;}
.border-thin{border: 1px solid #000;}
.border-thick{border: 2px solid #000;}
