/* CSS
Author: David Brunelle
URL: http://www.brunelleinteractive.com
Created: 04-23-2009

Modified: 05-23-2009
By: David Brunelle

Notes:
*/


/* = Reset 
#########################################*/
body {height: 100%; width: 100%;}
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,p,blockquote,table,tr,th,td,embed,object{margin:0;padding:0;}
table{border-collapse:collapse;border-spacing:0;}
fieldset,img,abbr{border:0;}
caption,th {text-align:left;}
div{text-align: left; vertical-align: top;}
q:before,q:after{content:'';}
a{text-decoration:none;}
strong{font-weight: bold;}
em{font-style: italic;}
*:focus {outline: none;}

/* = Library 
#########################################*/
.clearfix:after {content: "."; display: block; height: 0; clear: both; visibility: hidden;}
.clearfix {display: inline-block;}
* html .clearfix {height: 1%;}
.clearfix {display: block;}
.clear {clear: both; float: none;}
.align-right {text-align: right;}
.align-left {text-align: left;}
.align-center {text-align: center;}
.justify {text-align: justify;}
.float-left {float:left;}
.float-right {float:right;}
.hide {display:none;}
.show {display: block;}
.inline {display: inline;}
.italic {font-style: italic;}
.nomargin {margin: 0;}
.nopadding {padding: 0;}
.subscript {font-size: .75em; vertical-align: bottom;}
.Block {display: block;position: relative}


/* = Default Font Styles
#########################################*/
body {
	background: url('../images/bg_body.gif') no-repeat center 30px;
	color: #636466;
	font-family: Arial, Helvetica, sans-serif;
	font-size: 13px;
	font-weight: normal;
	font-style: normal;
	font-variant: normal;
}

p, ul, ol, blockquote, h1, h2, h3, h4, h5, h6 {
	line-height: 1.5em;
	margin-bottom: 1em; 
}

li {
	margin-bottom: 0;
}

li ul, li ol {
	margin-top: .5em; /* keeps the line spacing even */
	margin-bottom: .5em;
}

ul, ol, blockquote, code {
	padding-left: 3em;
}

dl {
	margin: 0 0 1em 0;
}

dt {
	font-weight: bold;
	display: block;
}

dd {
	display: block;
	margin-bottom: 1em;
}

h1, h2, h3, h4, h5 {
	font-weight: bold;
}

h1 {
	font-size: 2.0em;
	margin-bottom: 1em;
	line-height: 1.2em;
}

h2 {
	font-size: 1.6em;    
	margin-bottom: .5em;
}

h3 {
	font-size: 1.4em;
	margin-bottom: .6.5em;
}

h4 {
	font-size: 1.2em;
	margin-bottom: .8em;
}

h5 {
	font-size: 1.0em;    
	margin-bottom: 1em;
}

h6 {
	font-size: 1.0em;
	font-style: italic;
}

a:link {
	color: #84a632;
	text-decoration: underline;
}

a:active {
	color: #84a632;
	text-decoration: underline;
}

a:visited {
	color: #84a632;
	text-decoration: underline;
}

a:hover {
	color: #84a632;
	text-decoration: underline;
}

hr {
	background: url('../images/hr-trans.png') no-repeat center center;
	border: 0;
	height: 4px;
}

img {
	border: none;
	max-width: 100%;
}

/* = Global Styles
#########################################*/
#Header {
	position: relative;
	width: 1000px;
	height: 85px;
	margin: 30px auto 0 auto;
}

#Logo {
	width: 428px;
	height: 78px;
}

#HeaderContent {
	font-family: Arial;
	position: absolute;
	right: 0;
	top: 27px;
	width: 315px;
	text-align: right;
}

#HeaderSocial {
	float: left;
	width: 50px;
	overflow: auto;
}

#HeaderSocial a.Twitter {
	background: url('../images/icon_twitter.gif') no-repeat center center;
	display: block;
	margin-right: 5px;
	float: left;
	width: 21px;
	height: 23px;
	text-indent: -9999px;
}

#HeaderSocial a.LinkedIn {
	background: url('../images/icon_linkedin.gif') no-repeat center center;
	display: block;
	float: left;
	width: 21px;
	height: 23px;
	text-indent: -9999px;	
}

#cse-search-box {
	float: right;
}

#cse-search-box fieldset {
	border: none;
	margin: 0 auto;
	padding: 0;
}

#cse-search-box fieldset label {
	font-weight: bold;
	font-size: 13px;
	line-height: 23px;
}

#cse-search-box fieldset input.text {
	display: inline;
	height: 18px;
	padding: 2px;
	margin: 0 15px 0 15px;
	width: 190px;
	border: 1px solid #e1e1e1 !important;
}

#cse-search-box fieldset button.Btn {
	width: 23px;
	height: 23px;
	cursor: pointer;
	text-indent: -9999px;
	background: #ffffff url('../images/button_search.gif') no-repeat top right;
	border: none;
}

#Footer {
	background: #98c23b;
	width: 1000px;
	margin: 40px auto 20px auto;
	padding: 10px 0;
	text-align: center;
}

#Footer li {
	border-right: 1px solid #58595b;
	display: inline;
	color: #58595b;
	list-style: none;
	line-height: 1;
	margin-right: 10px;
	padding-right: 10px;
}

#Footer li.Last {
	margin: 0;
	padding: 0;
	border: none;
}

#Footer li a {
	color: #58595b;
	text-decoration: none;
}

#PrintFooter {
	display: none;
}

/* = Home Page
#########################################*/
.Home #Content {
	background: url('../images/bg_home_content.jpg') repeat-x left top;
	width: 1000px;
	height: 320px;
	margin: 0 auto 0 auto;
}

.Home #BannerLeft {
	position: relative;
	float: left;
	background: #ffffff;
	padding-right: 5px;
}

.Home #BannerRight {
	position: relative;
	float: right;
	background: #ffffff;
	padding-left: 5px;
}

.Home #Containers {
	width: 1000px;
	margin: 20px auto 0 auto;
}

.Home #Containers .Container {
	background: url('../images/hr-trans.png') no-repeat center 35px;
	position: relative;
	float: left;
	margin-right: 20px;
	width: 235px;	
}

.Home #Containers .Container.Last {
	margin-right: 0;
}

.Home #Containers .Container h2 {
	color: #660a00;
	font-weight: normal;
	font-size: 20px;
	margin-bottom: 1em;
}

/* = Secondary Page
#########################################*/
.Secondary #Canvas {
	width: 1000px;
	margin: 10px auto 0 auto;
}

.Secondary #Content {
	float: left;
	width: 580px;
	min-height: 500px;
	height: auto !important;
	height: 500px;
	padding: 32px 40px 0 40px;
}

.Secondary #Content h1 {
	position: relative;
	font-size: 20px;
	font-weight: normal;
	margin: 0 0 10px 0;
	color: #660a00;
	text-transform: uppercase;
}

.Secondary #SideBar {
	float: right;
	width: 270px;
	padding: 38px 20px 0 30px;
}


/* = Form Template
#########################################*/
body.Form #Canvas {
	width: 1000px;
	margin: 10px auto 0 auto;
	text-align: center;
}

body.Form #Content {
	background: #fff;
	border: 2px solid #f7f7f7;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	border-radius: 10px;
	width: 720px;
	min-height: 500px;
	height: auto !important;
	height: 500px;
	padding: 32px 40px 0 40px;
	margin: 0 auto;
}

body.Form #Content h1 {
	position: relative;
	font-size: 20px;
	font-weight: normal;
	margin: 0 0 10px 0;
	color: #660a00;
	text-transform: uppercase;
}


/* = Search Results Page
#########################################*/
.Secondary #Content.SearchResults {
	padding: 0 40px 0 40px;
	width: 800px;
}


/* = Sidebar Module
#########################################*/
#SideBar .Module {
	position: relative;
	margin: 0 0 60px 0;
	padding-bottom: 20px;
	background: url('../images/bg_module.png');
}

#SideBar .Module h2 {
	background: #660a00;
	color: #ffffff;
	font-size: 18px;
	font-weight: normal;
	margin: 0;
	text-align: center;
	text-transform: uppercase;
}

#SideBar .Module h3 {
	position: relatve;
	color: #660a00;
	font-size: 20px;
	font-weight: normal;
	text-align: right;
}

#SideBar .Module .Content {
	position: relative;
	padding: 15px 30px 0 30px;
}

#SideBar .Module .Quote {
	font-size: 11px;
}

#SideBar .Module ul.Menu {
	text-align: left;
	margin: 1em 0 1em 0;
	padding: 0;
}

#SideBar .Module ul.Menu li {
	font-size: 18px;
	list-style: none;
	margin-bottom: 1em;
}

#SideBar .Module ul.Menu li a {
	color: #4d4d4f;
	text-decoration: none;
}

#SideBar .Module ul.Menu li a:hover {
	color: #660a00;
}



/* = Primary Navigation
#########################################*/
ul#PrimaryNav {
	position: relative;
	background: url('../images/bg_primaryNav.gif') no-repeat left top;
	width: 932px;
	height: 36px;
	margin: 10px auto 0 auto;
	padding: 7px 40px 7px 40px;
	text-align: left;
}

ul#PrimaryNav li {
	position: absolute;
	list-style: none;
	margin: 0;
	padding: 0;
	top: 7px;
}

ul#PrimaryNav li, ul#PrimaryNav li a {
	height: 36px;
	display: block;
	text-indent: -9999px;
}

ul#PrimaryNav li.item1 {width: 120px; left: 35px}
ul#PrimaryNav li.item1 a:hover, ul#PrimaryNav li.item1 a.Active {background: url('../images/bg_primaryNav.gif') no-repeat -35px -56px;}

ul#PrimaryNav li.item2 {width: 165px; left: 207px}
ul#PrimaryNav li.item2 a:hover, ul#PrimaryNav li.item2 a.Active {background: url('../images/bg_primaryNav.gif') no-repeat -207px -56px;}

ul#PrimaryNav li.item3 {width: 133px; left: 428px}
ul#PrimaryNav li.item3 a:hover, ul#PrimaryNav li.item3 a.Active {background: url('../images/bg_primaryNav.gif') no-repeat -428px -56px;}

ul#PrimaryNav li.item4 {width: 80px; left: 611px}
ul#PrimaryNav li.item4 a:hover, ul#PrimaryNav li.item4 a.Active {background: url('../images/bg_primaryNav.gif') no-repeat -611px -56px;}

ul#PrimaryNav li.item5 {width: 108px; left: 741px}
ul#PrimaryNav li.item5 a:hover, ul#PrimaryNav li.item5 a.Active {background: url('../images/bg_primaryNav.gif') no-repeat -741px -56px;}

ul#PrimaryNav li.item6 {width: 120px; left: 898px}
ul#PrimaryNav li.item6 a:hover, ul#PrimaryNav li.item6 a.Active {background: url('../images/bg_primaryNav.gif') no-repeat -898px -56px;}


/* = Secondary Navigation
#########################################*/
#SecondaryNav {
	position: relative;
	height: 20px;
	width: 1000px;
	margin: 5px auto 0 auto;
}

#SecondaryNav ul {
	background: #e2f0c6;
	height: 20px;
	margin: 0;
	padding: 0 30px 0 30px;
}

#SecondaryNav ul li {
	float: left;
	list-style: none;
	margin-right: 30px;
}

#SecondaryNav ul li a {
	color: #58595b;
	font-size: 12px;
	height: 20px;
	line-height: 20px;
	text-decoration: none;
	text-transform: uppercase;
}

#SecondaryNav ul li a.Active, #SecondaryNav ul li a:hover {
	color: #660a00;
}



/* = Utility Navigation
#########################################*/
ul#UtilityNav {
	float: right;
	font-family: Arial;
	margin: 0 0 20px 0;
	padding: 0;
	list-style: none;
}

ul#UtilityNav li {
	float: left;
	color: #636466;
	margin-right: 5px;
	padding-right: 5px;
	border-right: 1px solid #636466;
	line-height: 1;
}

ul#UtilityNav li.Last {
	margin-right: 0;
	padding-right: 0;
	border-right: none;
}

ul#UtilityNav li a {
	color: #636466;
	text-decoration: none;
}

ul#UtilityNav li a:hover {
	color: #9cc43c;
	text-decoration: underline;
}

/* Forms
-----------------------------------------------------------------------------*/

fieldset {
	border: none;
}

legend { 
	font-size: 1.4em;
	color: #0000FF;
	display: none;
	background: #fff;
	padding: 0 2px;
}

div.labelInput, span.labelInput {
	clear: left;
	margin-bottom: .7em;
	display: block;
}

input[type='text'], input[type='password'], select, textarea {
	width: 16em;
	font-size: 1em;
	font-family: Lucida Sans, Verdana, Arial, Tahoma, Sans-Serif;
	font-weight: normal;
	font-style: normal;
	font-variant: normal;
	padding: 3px;
	border: 1px solid #666;	
	display: block;
	z-index: 1000;
	color: #000;
}

select.Select {
	width: 16.55em;
}

textarea {
	height: 12em;
}

label {
	line-height: 2em;
	width: 12em;
	float: left;
	display: block;
}

label.Radio, label.Checkbox {
	width: auto !important;
	padding: 0;
	margin: 0;
	float: none;
	line-height: inherit;
	display: block;
}

div.FullWidth label {
	width: auto;
	float: none;
	display: block;
	text-align: left;
	padding: 0;
}

div.FullWidth {
	width: 310px;
}

div.FullWidth input[type='text'], div.FullWidth input[type='password'], div.FullWidth select, div.FullWidth textarea {
	width: 100%;
	font-size: 1em;
	font-family: Verdana, Arial, Tahoma, Sans-Serif;
	font-weight: normal;
	font-style: normal;
	font-variant: normal;
}

div#Right div.CAPTCHA img {
	border: 1px solid #666;
}

div.CAPTCHA img {
	margin-right: .5em;
	float: left;
}


div.CAPTCHA input[type='text'] {
	width: 5em;
	font-size: 2em;
	font-family: Georgia, Times New Roman, Times, Serif;
	font-weight: normal;
	font-style: normal;
	font-variant: normal;
	text-align: center;
	padding: 3px;
	border: 1px solid #666;
	color: #000;
}


div.FormControls {
	padding-left: 14em;
	clear: both;
	display: block;
	margin-bottom: 4em;
	margin-top: 4em;
}	

fieldset {
	border-top: 1px solid #666;
	padding: 1em 0;
	border: none;
}

legend { 
	margin: 0;
	padding: 0;
	font-size: 1.4em;
}

.labelInput {
	border-bottom: none;
	padding: .5em 0;
	display: block;
	
}

.radio .labelInput, .checkbox .labelInput {
	padding-left: 14.5em;
}

input[type='text'], input[type='password'], select, textarea {
	width: 20em;
	font-family: lucida grande, arial, sans-serif;
	font-size: 12px;
}

input[type='text'], input[type='password'], textarea {
	border: 1px solid #999;
	padding: 3px;
}

textarea {
	width: 30em;
}

select {
	width: 20.7em;
}

textarea {
	height: 10em;
}

label {
	font-weight: bold;
	width: 12em;
	float: left;
	display: block;
	color: #666;
	text-align: right;
	padding: 0 1em 0 1em;
}

.radio label, .checkbox label {
	display: inline !important;
	float: none;
	width: auto;
}

input[type='radio'], input[type='checkbox'] {
	margin-right: .5em;
}

.formControls {
	display: block;
	padding: 1em; /* right padding for label width plus label padding */
}

.vertical label {
	width: auto;
	float: none;
	display: block;
	text-align: left;
	padding: 0;
}

.vertical .radio .labelInput, .vertical .checkbox .labelInput {
	padding-left: 0;
}


/* Validation messages delivered by validate.js
-----------------------------------------------------------------------------*/

.error {
	background: #F3E5A1;
}
div.errorMessage {
	background: #F3E5A1 url(../site/icon_error.gif) no-repeat 10px 6px;
	border: 1px solid #FFCC00;
	margin: 0 0 0 10px;
	padding: 5px 5px 5px 35px;
	display: block;
	line-height: 1.6em;
	position: absolute;
	width: 240px;
}


/* Info, Error & Success Messages
-----------------------------------------------------------------------------*/

.Alert, .Info, .Error, .Success, .ErrorInline, .Help {
	margin-bottom: 14px;
	padding: 5px 5px 5px 35px;
	display: block;
	line-height: 1.6em;
	position: relative;
}

.Alert a, .Info a, .Error a, .Success a, .ErrorInline a {
	color: #000;
	text-decoration: underline;
}

.Alert, .Info {
	background: #BFC8F1 url(../admin/information.png) no-repeat 10px 8px;
	border: 1px solid #4574AE;
}

.Error {
	background: #F3E5A1 url(../admin/error.png) no-repeat 10px 6px;
	border: 1px solid #FFCC00;
}

.Success {
	background: #B5E1AE url(../admin/accept.png) no-repeat 10px 6px;
	border: 1px solid #3B9E2B;
}

.Help {
	background: #BFC8F1 url(../site/icon_info.gif) no-repeat 10px 6px;
	border: 1px solid #4574AE;
}


/* Modal Dialog Box
-----------------------------------------------------------------------------*/

.modalBox {
	background: #fff url(../images/loading.gif) 50% 50% no-repeat; 
	position: relative; 
	border: 10px solid #fff; 
	-moz-border-radius: 5px; 
	-webkit-border-radius: 5px; 
	-khtml-border-radius: 5px; 
	border-radius: 5px; 
	-moz-box-shadow: 0 0 10px #000; 
	-webkit-box-shadow: 0 0 10px #000;
}

.modalMessage { 
	overflow: hidden; 
	background: #fff; 
}

.modalClose { 
	position: absolute; 
	top: -25px; 
	right: -25px; 
	display: block; 
	width: 32px; 
	height: 32px; 
	overflow: hidden; 
	text-indent: 40px; 
	color: #fff; 
	font-size: 10px; 
	letter-spacing: .1em; 
	text-transform: uppercase; 
	line-height: 2em; 
	text-decoration: none; 
	background: url(../images/button_close.png) no-repeat 0 0; 
}

.modalNext { 
	position: absolute; 
	bottom: 0; 
	right: 0; 
	padding: 0 10px; 
	color: #fff; 
	font-size: 10px; 
	letter-spacing: .1em; 
	text-transform: uppercase; 
	line-height: 35px; 
	text-decoration: none; 
}

.modalPrevious { 
	position: absolute; 
	bottom: 0; 
	left: 0; 
	padding: 0 10px; 
	color: #fff; 
	font-size: 10px; 
	letter-spacing: .1em; 
	text-transform: uppercase; 
	line-height: 35px; 
	text-decoration: none; 
}


