@charset "utf-8";

* {	margin: 0; padding: 0; }
body {
	font-family: Arial, Helvetica, sans-serif;
	font-size: 12px;
	color: #414141;
	background: #ffffff url('images/background.gif') 0 0 repeat-x scroll;
}
img, a img { border: 0; }
td,th { vertical-align: top; }
ul li, ol li {
	list-style-position: outside;
	list-style-type: none;
	list-style-image: none;
}
a { color: #3388ce; }
	a:hover, a:active { color: #216caa; }

/****** Typography ****/
h1,h2,h3 { font-weight: normal; color: #084482; }
h5,h6 { font-weight: normal; }
h1 { }
h2 { margin: 0 0 1em; font-size: 1.6em; }
h3 { margin: 0 0 1em; font-size: 1.4em; }
h4 { font-size: 1.4em; margin: 0 0 1em; color: #545454; }
h5 { font-size: 1.2em; margin: 0 0 1em; font-weight: bold; color: #666666; }
h6 { font-size: 1.2em; margin: 0 0 1em; color: #666666; }
p { line-height: 2em; margin: 0 0 1em; }
.head { padding: 0 0 2.4em; }

.middle .content ul { margin: 0 0 0 2.5em; padding: 0.5em 0; }
.middle .content ol { margin: 0 0 0 2.5em; padding: 0.5em 0; }
.middle .content ul li,
.middle .content ol li { list-style-position: inherit; padding: 0 0 0.0em 0.5em; line-height: 1.5em; }
	.middle .content li { list-style-type: inherit; }
	.middle .content ol li li { list-style-type: lower-latin; }
	.middle .content ol li li li { list-style-type: lower-roman; }

hr { margin: 1.5em 0; }

/****** Boxes ****/
.wrapper { background: transparent url('images/background.jpg') 50% 0 no-repeat scroll; padding: 0 0 3em;}
.header-container { padding: 0 0 5px; }
.middle-container { 
	width: 1000px; 
	margin: 0 auto 1em; 
	padding: 0 0 6px; 
	background: #ffffff url('images/background-middle-container.gif') 0 bottom no-repeat scroll;
}
.footer-container {
	width: 1000px;
	margin: 0 auto;
	padding: 8px 0 0;
	background: transparent url('images/background-footer-container.gif') 0 0 no-repeat scroll;
}

/****** Header ****/
.header {
	width: 1000px;
	height: 195px;
	margin: 0 auto;
	position: relative;
	overflow: hidden;
	}
	.header #logo {
		display: block;
		position: absolute;
		left: 80px;
		top: 30px;
		}
	.header #tagline {
		display: block;
		position: absolute;
		top: 60px;
		right: 70px;
	}

	/****** Header Navigation ****/
	.header-navigation {
		width: 1000px;
		height: 40px;
		overflow: hidden;
		margin: 0 auto;
		position: relative;
		}
		.header-navigation #nav {
			position: absolute;
			left: 50px;
			top: 0;
			display: block;
			}
			.header-navigation #nav li, 
			.header-navigation #nav a, 
			.header-navigation #nav a span { display: block; color: #ffffff; line-height: 12px; }
		.header-navigation #nav li { float: left; padding: 0 7px 0 0; }
			.header-navigation #nav li a {
				background: #3f93d3 url('images/nav/top-nav-left.gif') left 0 no-repeat scroll;
				padding: 0 0 0 15px;
				text-decoration: none;
				}			
			.header-navigation #nav li a span {
				background: transparent url('images/nav/top-nav-right.gif') right 0 no-repeat scroll;
				padding: 10px 15px 11px 0;
			}
			.header-navigation #nav li.active a,
			.header-navigation #nav li a:hover { background-position: left bottom; }	
			.header-navigation #nav li.active a span,
			.header-navigation #nav li a:hover span { background-position: right bottom; }	

/****** Middle ****/
.middle { 
	width: 1000px; 
	background: transparent url('images/background-middle.jpg') 0 bottom repeat-x scroll;
	min-height: 600px;
	}
	.middle #main { padding: 40px 35px; }
	
	/****** Middle: Homepage ****/
	.cms-home .middle { min-height: 470px; background: transparent url('images/background-middle-home.gif') 0 bottom repeat-x scroll; }
	.cms-home #main { padding: 55px 35px 1em; }
	.cms-home #main .head { padding: 0 0 2em; }
	.cms-home #main h1 { font-size: 1.6em; }
	.cms-home #main p { color: #084482; }	
	.cms-home .brand-logos { 
		background: transparent url('images/background-home-brand-logos.gif') 0 0 repeat-x scroll; 
		padding: 40px 0px 10px;
		text-align: center;
		}
		.cms-home .brand-logos img { padding: 0 1em; }
	/****** Middle: About Us ****/
	.cms-about-us #main { background: transparent url('images/media/watermark-about-us.gif') no-repeat 95% bottom scroll; }
	/****** Middle: Portfolio ****/
	.cms-portfolio #main { 
		background: transparent url('images/background-portfolio.jpg') no-repeat center bottom scroll;
		min-height: 510px;
		}
	.cms-portfolio #main td p { padding: 8px 0 0; }
	
/****** Footer ****/
.footer { 
	background: transparent url('images/background-footer.gif') no-repeat 0 bottom scroll; 
	padding: 0 0 8px;
	}
	.footer .footer-content {
		background: #579fd8 url('images/background-footer-content.gif') 0 bottom repeat-x scroll;
		padding: 2px 20px;
		}
	.footer p, .footer {
		font-size: 95%;
		font-family: "Trebuchet MS", Arial, Helvetica, sans-serif;
		color: #d2e3f2;
	}
	
/****** Clears ****/
.clear {
	clear: both;
	height: 0;
	line-height: 0;
	visibility: hidden;
	overflow: hidden;
}

/****** Forms ****/
.button {
	background-color: #204A7D;
	color: #FFFFFF;
	border-top-style: solid;
	border-right-style: solid;
	border-bottom-style: solid;
	border-left-style: solid;
	border-top-color: #2E6AB4;
	border-right-color: #2B63A8;
	border-bottom-color: #204A7D;
	border-left-color: #CCCCCC;
	margin-top: 0.3em;
	margin-bottom: 0.3em;
	padding: 4px;
	border-top-width: 1px;
	border-right-width: 1px;
	border-bottom-width: 1px;
	border-left-width: 1px;
	line-height: 140%;
}
.button-save {
	background-color: #CCCCCC;
	color: #333333;
	border-top-style: solid;
	border-right-style: solid;
	border-bottom-style: solid;
	border-left-style: solid;
	border-top-color: #CCCCCC;
	border-right-color: #CCCCCC;
	border-bottom-color: #999999;
	border-left-color: #CCCCCC;
	margin-top: 0.3em;
	margin-bottom: 0.3em;
	padding: 4px;
	border-top-width: 1px;
	border-right-width: 1px;
	border-bottom-width: 1px;
	border-left-width: 1px;
	line-height: 140%;
}

/* 6B. CO (form field) styles */

fieldset {
	float: left;
	clear: both;
	width: 100%;
	background-color: #ECF1F7;
	margin-top: 0;
	margin-right: 0;
	margin-bottom: 1em;
	margin-left: 0;
	padding-top: 0;
	padding-right: 0;
	padding-bottom: 1em;
	padding-left: 0;
	border: 1px solid #D3DFED;
}

legend {
	margin-left: 1em;
	padding: 0;
	color: #1F497C;
}
fieldset ol {  
padding: 1em 1em 0 1em;  
list-style: none;  
}  
fieldset li {
	float: left;
	clear: left;
	width: 100%;
	padding-bottom: 0.8em;
}
label {    
float: left;    
width: 10em;    
margin-right: 1em;  
}

/*
==========================================================================
7 - Tables
==========================================================================
*/

tr.title  {
	font-weight: bold;
	line-height: 140%;
}
legend    {
	font-size: 18px;
	line-height: 180%;
}
caption {
	font-size: 14px;
	line-height: 180%;
	text-align: left;
	display: block;
	padding-top: 10px;
	padding-bottom: 10px;
	width: 100%;
}
.table-generic {
	text-align: left;
	line-height: 1.4em;
	border: 1px solid #E2E2E2;
	width: 100%;
}
td.border {
	border: 1px dotted #999999;
}
.table-generic input.text {
	background-color: #FFFFFF;
	border: 1px solid #CCCCCC;
	margin: 0px;
	padding: 0px;
}
.table-invisible {
	border: 0px solid #CCCCCC;
	text-align: left;
	width: 95%;
	line-height: 1.4em;
}

/* GREY TABLE */

#grey-table {
	font-size: 12px;
}
#grey-table th {
	letter-spacing: 2px;
	text-align: left;
	padding: 6px 6px 6px 12px;
	background-color: #F5F5F5;
	text-transform: uppercase;
	border: 1px solid #CCCCCC;
}
#grey-table  th.key {
	background-image: none;
	background-color: #E9E9E9;
	font-weight: normal;
	letter-spacing: normal;
	padding-top: 20px;
	padding-right: 10px;
	padding-bottom: 20px;
	padding-left: 10px;
	text-align: justify;
}
#grey-table .key img {
	margin: 10px;
	float: left;
	border: 1px solid #999999;
}
#grey-table td  {
	background: #fff;
	padding: 6px 6px 6px 12px;
	border-right-width: 1px;
	border-left-width: 1px;
	border-style: solid;
	border-right-color: #D4D0C8;
	border-left-color: #D4D0C8;
	border-top-width: 1px;
	border-bottom-width: 1px;
	border-top-color: #D4D0C8;
	border-bottom-color: #D4D0C8;
}
#grey-table a {
	text-decoration: underline;
}
#grey-table input {
	background-color: #E8E8E8;
}

/* GENERIC TABLE */

#generictable {
	font-size: 12px;
}
#generictable th {
	letter-spacing: 2px;
	text-align: left;
	padding: 6px 6px 6px 12px;
	background-color: #F5F5F5;
	border: 1px solid #CCCCCC;
}
#generictable  th.key {
	background-image: none;
	background-color: #E9E9E9;
	font-weight: normal;
	letter-spacing: normal;
	padding-top: 20px;
	padding-right: 10px;
	padding-bottom: 20px;
	padding-left: 10px;
	text-align: justify;
}
#generictable .key img {
	margin: 10px;
	float: left;
	border: 1px solid #999999;
}
#generictable td  {
	background: #fff;
	padding: 6px 6px 6px 12px;
	border-right-width: 1px;
	border-left-width: 1px;
	border-style: solid;
	border-right-color: #D4D0C8;
	border-left-color: #D4D0C8;
	border-top-width: 1px;
	border-bottom-width: 1px;
	border-top-color: #D4D0C8;
	border-bottom-color: #D4D0C8;
}
#generictable a {
	text-decoration: underline;
}
#generictable input {
	background-color: #E8E8E8;
	padding: 2px;
}