html, body {
	position: relative;
	height:100%;
	z-index: -100;
}

p, ul, li, ol, a, h1, h2, h3, h4, h5, h6, h7, h8, h9, sup, label, input, textarea {
	font-family: Arial, Helvetica, sans-serif;
	color: #4D4D54;
	font-size: 11pt;
	line-height:1.3;
}

ul {
	list-style-position: inside;
}

/*
h1, h2, h3, h4, h5, h6, h7, h8, h9 {
	/*color: #8f8f8f;
	color: #3367ba;
	font-size: 10pt;
	text-transform: uppercase;
	font-family: Arial, Helvetica, sans-serif;
	font-weight: normal;
}*/

h1 {
	text-transform: uppercase;
	color: #3367ba;
	font-size: 15pt;
	font-weight: bold;
}

h2 {
	text-transform: uppercase;
	color: #3367ba;
	font-size: 12pt;
	font-weight: normal;
}

h3 {
	text-transform: uppercase;
	color: #FFB000;
	font-weight: bold;
	font-size: 13pt;
}

#header {
	height: 138px;
	width: 100%;
	background-color: white;
	position: relative;
	border-bottom: 1px solid #EEEEEE;
}

div#page {
	position: absolute;
	display: block;
	width: 960px;
	height: 100%;
	left:0;
	right:0;
	margin-left: auto;
	margin-right: auto;
	z-index: -3;
}

#content {
	position:relative;
	display: block;
		
	background-color: white;
	z-index: -2;
	
	min-height: 440px;

	box-shadow: 5px 5px 5px #AAAAAA;
	
	/* hack to ensure child element margins can't move #content down, creating an ugly gap: */
	padding-top: 1px; margin-top: -1px;
	padding-left: 15px; padding-right: 15px;
	padding-bottom: 5px;
}

div#content.bg_grad {
	background-image: url(img/bg/bgrad.png);
	background-position: top;
	background-repeat: no-repeat;
}

div#content.bg_grad_bl {
	background-image: url(img/bg/bgrad-bl.png);
	background-position: bottom;
	background-repeat: no-repeat;
}

div#content.manual_layout {
	padding: 0;
	margin: 0;
}

#content form {
	padding-bottom: 5px;
}

/*Force the first element in #content to have no top margin so everything lines up neatly
#content > :first-child { margin-top: 0 !important;}
#content form > :first-child { margin-top: 0 !important;}*/

span.over_image {
	display: inline-block;
	position: relative;
	background: transparent;
	padding: 5px;
	/*overflow: auto;
	max-height: 400px;*/
}

span.content_with_col {
	display: inline-block;
	width: 63%;
	position: relative;
	left: -15px;	
}

#content * {
	z-index: inherit;
}

img.bg_img {
	position: absolute;
	max-height: 100%;
	width: 100%;
	z-index: -2;
	left: 0px;
}

img.bg_img-bl {
	position: absolute;
	max-height: 100%;
	width: 100%;
	z-index: -2;
	bottom: 0px;

}

span.right_col {
	display: inline-block;
	position: absolute;
	width: 32%;
	right:0px; top: 3px;
	border-left: 1px solid #EEEEEE;
	padding-left: 20px;
	margin-top: 3px;
	min-height: 400px;
}

/*span.right_col_prog_serv {
	display: inline;
	display:table-cell;
	position: relative;
	float: right;
	width: 32%;
	top: 0; bottom: 0; right: 0; left: 0;	
	top: 200px;
	left: 10px;
}*/
/*Old Nav System:

div.navbar {
	display: table;
	position:absolute;
	bottom: 0;
	height: 36px;
	width: 100%;
	background-color: white;
	padding-bottom: 0; border-bottom: 0; margin-bottom: 0;
}

a.nav {
	display: table-cell;
	vertical-align: middle;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
	font-size: .85em;
	height: 36px;
	font-family: "Lucida Grande", "Helvetica", arial, sans-serif;
	color: #777777;
	height: 36px;
    background-color: white;
    max-width: 12.5%;
    margin-left: 1em; margin-right: 1em;
}

a.nav:hover{
	background-color: #CCCCCC
}

a.this_page_nav {
	background-color: #EEEEEE;
}
End old nav system*/

/*New Menu System*/
.navmenu {
	position: absolute;
	bottom: 0;
	display: table;
    color: black;
    background-color: transparent;
    width: 100%;
    border-bottom: 2px solid #FFB414;
    z-index: 100;
}

.navmenu, 
.navmenu ul,
.navmenu li {
    padding: 0;
    margin: 0;
}
.navmenu > li
{
	display: table-cell;
    float: left;
}
.navmenu li
{
	display: table;
    list-style-type: none;
    color: black;
    padding: 0;
    margin: 0;
    background-color: transparent;
    bottom: 0;
    padding-bottom: 3px;
    z-index: 10;
    position: relative;

}
.navmenu ul
{
    display: none;
    position: absolute;
    padding: 0;
    margin: 0;
    border: 1px solid #CCCCCC;
    background: white;
	left: 0; top: 100%;
	z-index: 5 !important;
	width: 100%;
}

.navmenu ul > li {
	display:table !important;
	width: 100% !important;
	padding-bottom: 0 !important;

}

.navmenu ul > li > a {
	display: table-cell !important;
	
}
.navmenu li:hover > ul,
.navmenu ul.parent_hover,
.navmenu li > ul:hover {

    display: block;
    
}
.navmenu li > a
{
	height: 36px;
	display: table-cell !important;
	vertical-align: middle !important;
	margin: auto 0;
	text-decoration: none;
    text-transform: capitalize;
    font-size: .85em;
    text-align: center;
}

.navmenu > li > a {
	padding-left: 3%; padding-right: 5%;
}

.navmenu li.this_page_nav > a {
	color: gold;
	background-color: #3367ba;
	/*color: #3367ba;*/
}

.navmenu li.this_page_nav a:hover {
	/*color: white;
	background-color: #B3C7E8;*/
	background-color: #6B9EF2;
	color: white;
}



.navmenu ul > li > a {
	display: table-cell !important;
	width: 100%;

}

li.contains_page_nav {
	border-bottom-color: #3367ba;
	border-bottom-width: 3px;
	border-bottom-style: solid;
	padding-bottom: 0px;
}

.navmenu li.hover,
.navmenu a:hover
{
    color: black;
    background-color: #CCCCCC;
}
.navmenu span {
    display: block;
}

.navmenu + * {
	clear:left;
}

.endmenu
{
    display:block;
    width: 100%;
    height: 0px;
    border-bottom: 1px solid #FF7614;
    position: relative;
    top: -1px;
    clear: left; clear: right;
    z-index: 0 !important;
}


/*End New Menu System*/
div.footer {
	padding-top: 10px;
	display: block;
	position: relative;
	width: 100%;
	height: auto;
}

div.footer * {
	margin: 0; padding: 0;
}

div.footer span.footer-contact {
	display: inline-block;
	position: relative;
	left: 0; bottom: 0;
	float: left;
}

div.footer span.footer-copyright {
	display: inline-block;
	position: relative;
	right: 0; bottom: 0;
	float: right;
}

div#logo-bar {
	position: relative;
	display: block;
	background-color: white;
	width: 100%;
}

span#logo-img {
	position: relative;
	left: 15px;
	top: 25px;

	height: 100%;
}

span#page-title {
	float: right;
	position: relative;
	right: 15px;
	top: 25px;
}


.clear {
	clear:left; clear: right;
}

/*

===================
      Forms
===================

*/

form {
	z-index: -1 !important;
}

p.error_msg, p.success_msg {

	text-align: center;
	display: block;
}

p.error_msg {
	border: 1px dotted red;
	color: red;
}

p.success_msg {
	border: 1px dotted green;
	color: green;
}

div.field {
	/*border-bottom: 1px solid #DDDDDD;*/
	overflow:auto;
	font-size: 9pt;
}

div.field > label {
	vertical-align: top;
	float:left;
	min-width: 30%;
	height: 22px;
	overflow:hidden;
	
}

div.field sup {
	/* deprecated */
	display:block;
	margin-bottom: 10px;
	margin-left: 33%;
	font-weight: bold;
	border: 1px solid black;
}

/* > means only direct children */
/* allows us to put non-required fields on the same line as required fields */
div.required > input, div.required > textarea, div.required > select {
	background-color: #FFFCD6;
}


div.required > label::after {
	/* place a bolded * after the label of each required field.*/
	content:" *";
	font-weight: bold;
}

form.form_with_sidebar {
	display: inline-block;
	left: 0;	
	width: 60%;
}

form h1.form_header, h2.form_header, h3.form_header {
	background-color: #EEEEEE;
	text-align: center;
	padding: 5px;
	color: gray;
	margin-left: -10px; margin-right: -10px;
}

div.field input, div.field textarea, div.field select {
	background-attachment: scroll;
	border: 1px solid rgb(221, 221, 221);
	color: rgb(0, 0, 0);
	cursor: auto;
	display: inline-block;
	font-family: Arial, Helvetica, sans-serif;
	font-size: 13px;
	height: 17px;
	letter-spacing: normal;
	line-height: normal;
	margin-bottom: 5px;
	margin-left: 2px;
	margin-right: 2px;
	margin-top: 5px;
	width: 328px;
}

div.field select {
	width: auto;
}

div.field textarea {
	min-height: 100px;
	max-width: 100%;
}

div.field label {
	margin: 6px 0 0 5px;
	text-align: right;
	margin-right: 10px;	
}

div.other_field {
	display:inline-block;
}

div.other_field input {
	width: 100px;
}

div.other_field label {
	width: 20%;
}

input[value="Submit"] {
	/*float: left;
	padding: 5px 10px 5px 10px;
	margin-left: 100px;
	margin-right: 50px;*/
	z-index: 10 !important;
}

div.submit {
	left: 20%;
	position: relative;
	z-index: 9 !important;
}

/*textwrap*/

.wrapright {
	clear: both;
	float: right;
	margin: 10px;
}

.wrapleft {
	clear: both;
	float: left;
	margin: 10px;
	max-width: 250px;
	height: auto;
}


#content img.top_right {
	position: absolute;
	top: 0;
	right: 0;
}



a img {
text-decoration: none;
border: 0;
}


