/* 
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

Title : 
Author : Kevin Klein	
Email : kevin.klein@gmail.com 
We Are : Cast Iron Coding

Description : Master Stylesheet

Created : 3/11/08
Modified : 3/12/08

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
*/

/* global whitespace reset */
* { padding:0; margin:0; }

body {
    background:#fff url(../images/bg-body.gif) top center no-repeat;
	color: #444;
	font-family: Helvetica, Arial, sans-serif;
	font-size:62.5%;
	padding: 24px 0;
	text-align: center;
}

a {
	outline: none;
}

/*********** = structure = ***********/

#container {
	background: url(../images/bg-container.gif) bottom center no-repeat;
	min-height: 500px;
	margin: 0 auto;
	position: relative;
	text-align: left;
	width:872px;
}

div.wrapper {
	margin-left: 12px;
	width: 842px;
}

#content {
	background: url(../images/bg-content.gif) repeat-y;
	border-bottom: 1px solid #cecece;
}

div.copy {
	font-size: 12px;
	margin-left: 1px;
	min-height: 600px;
	padding: 47px 352px 12px 43px;
	position: relative;
}

* html div.copy {
	height: 600px;
}

body.twoCol.leftMargin div.copy {
	padding-left: 73px;
}

div.list {
	height: 570px;
	padding: 0 8px 0 0;
	overflow: auto;
}

body.oneCol .copy {
	padding: 47px 43px 12px 43px;
}

div.home-copy {
	padding: 12px;
}

div.sidebar {
	background: url(../images/bg-sub.gif) no-repeat 0 0;
	left: 532px;
	padding-left: 10px;
	position: absolute;
	top: 48px;
	width: 286px;
}

#header {
	background: url(../images/bg-header.gif) no-repeat 0 0;
	height: 113px;
	position: relative;
}

*html #header {
	overflow: hidden;
}



.sidebar h3 {
	width: 153px;
	background: #0573B8;
	color: #fff;
	font-size: 14px;
	margin: 0 0 15px 0 !important;
	padding: 5px 5px 6px 5px !important;
	text-transform: uppercase;
}

#footer {
	clear: both;
	padding: 40px 0 20px 0;
}

#footer div.secondary {
	float: right;
}

/*********** = headers = ***********/



#header h1 {
	height: 80px;
	width: 180px;
}

#header h1 a {
    display:block;
    height:80px;
	width:180px;
	text-indent:-999em;    
}

.copy h1 {
	color: #444;
	font-weight: normal;
	font-size: 24px;
	margin: 15px 0;
}

h2, h3 {
	font-family: Helvetica, Arial, sans-serif;
}

h2 {
	color: #444;
	font-size:20px;
	font-weight: normal;
	line-height: 18px;
	margin: 15px 0 0 0;
}

h2.project {
	color: #444;
	font-size:36px;
	font-weight: normal;
	line-height: 30px;
	margin: 0 0 5px;
}

h2 em {
	color: #999;
	display: block;
	font-size:14px;
	font-weight: bold;
	line-height: 15px;
	margin: 5px 0 0 0;
	font-style: normal;
}

h2.hdr {
	background-position: 12px 12px;
	background-repeat: no-repeat;
	height: 71px;
	text-indent: -9999em;
	margin: 0 0 5px;
}

h2.projects { background-image: url(../images/hdr-projects.jpg); }
h2.careers { background-image: url(../images/hdr-careers.jpg); }
h2.company { background-image: url(../images/hdr-company.jpg); }
h2.contact { background-image: url(../images/hdr-contact.jpg); }
h2.employees { background-image: url(../images/hdr-employees.jpg); }
h2.news { background-image: url(../images/hdr-news.jpg); }
h2.services { background-image: url(../images/hdr-services.jpg); }

.list h2 {
	font-size: 20px;
	line-height: 17px;
	margin: 0 0 10px 0;
}

.list h2 a,
.list h2 a:visited {
	border: 1px solid #fff;
	padding: 7px 5px; 
	color: #000;
	display: block;                                      
}

.list h2 em {
	font-size: 12px;
}

.list h2 a:hover {
	background: #f3f3f3;
	border: 1px solid #efefef;
	color: #0573b8;
	text-decoration: none;
}

.list h2 a:hover em {
	color: #444;
}

h3 {
	color: #444;
	font: bold 14px Arial;
	margin: 12px 0 15px 0;
}

.list h3 {
	border-top: 3px solid #ccc;
	color: #f8941d;
	margin: 12px 0 12px 0;
	padding: 8px 7px 0 5px;
}

h4 {
	color: #444;
	font: bold 10px Arial;
	text-transform: uppercase;
	margin: 3px 0;
}

#home-promos h4 {
	margin-top: 0;
}

#home-promos h4 a {
	font-weight:bold !important;
	font-size:110%;
	letter-spacing:.65px;
}

h4 a,
h4 a:visited {
	color: #444 !important;
	text-decoration: none !important;
}

h4 a:hover {
	color: #0573b8 !important;
	text-decoration: underline !important;
}

/*********** = misc typography = ***********/

a, a:link { 
	color:#0573b8; 
	text-decoration: none;
}

a:visited { color: #0573b8; }

a:hover { 
	color:#000; 
	text-decoration: underline; 
}

.sidebar a {
	font-weight: bold;
}

.sidebar img {
	clear: both;
	float: right;
	margin: 0 0 0 10px;
}

.sidebar .imageControls img {
	float: left;
	clear: none;
	margin: 0;
	cursor: pointer;
}

.sidebar .imageControls {
	margin-top: 5px;
	color: #f6911d;
	font-weight: bold;
	font-size: 10px;
}

.sidebar .imageControls span {
	float: left;
	padding: 4px 3px 3px 3px;
}

.sidebar .imageControls span em {
	font-style: normal;
}

p {
	color: #444;
	margin: 3px 0 5px 0;
	line-height: 16px;
}

div.text p {
	line-height: 17px;
	margin: 7px 0 15px 0;
}

div.text em {
	color: #0573b8;
	font-size: 12px;
	font-style: normal;
	font-weight: bold;
}

div.text p,
div.quickfacts p {
	font-size: 11px;
	margin: 3px 0;
}

div.quickfacts p {
	line-height: 14px;
}
#footer,
#footer p {
	font-family: Arial, sans-serif;
	font-size: 10px;
	color: #aaa;
}

#footer div a,
#footer div a:visited {
	color: #555;
	text-decoration: none;
}

#footer div a:hover {
	color: #777;
	text-decoration: underline;
}

input, 
select {
	font-family: 'Lucida Grande', Verdana, Arial, Sans-Serif;
	font-size:12px;
}

/*********** = misc divs and classes = ***********/

div#home-banner {
	background: url(../images/bg-home-banner.jpg) no-repeat 0 0;
	height: 334px;
	position: relative;
}

div#home-banner a {
	background: url(../images/bg-home-cta.gif) no-repeat 0 0;
	display: block;
	height: 122px;
	left: 15px;
	position: absolute;
	text-indent: -9999em;
	top: 60px;
	width: 327px;
}

div#home-banner a:hover {
	background-position: 0 -122px;
}

div#home-promos {
	position: relative;
	padding: 12px 0 22px 0;
	min-height: 1px;
}

* html div#home-promos {
	height: 1px;
}

div#home-promos div.projects {
	min-height: 1px;
	position: relative;
	background: url(../images/bg-home-projects.gif) no-repeat 0 0;
	float: left;
	padding-left: 177px;
	width: 287px;
}

* html div#home-promos div.projects {
	height: 1px;
	width: 464px;
}

div#home-promos div.news {
	min-height: 1px;
	position: relative;
	background: url(../images/bg-home-news.gif) no-repeat 0 0;
	float: right;
	padding-left: 109px;
	width: 221px;
}

* html div#home-promos div.news {
	height: 1px;
	width: 330px;
}

div.quickfacts {
	background: url(../images/bg-quick-facts.gif) no-repeat 0 0;
	padding: 0 0 0 134px;
	margin: 35px 25px 0 0;
}

div.text {
	height: 262px;
	margin-left: 134px;
	overflow: auto;
	padding: 0 15px 0 0;
}

div.columns.three {
	display: block;
	margin:25px 0;
}

div.columns.three .column {
	display:inline;
	float:left;
	margin:0px 30px 0 0px;
	width:28%;
}

div.hr {
	border-top: 3px solid #b5b5b5;
	font-size: 1px;
	height: 3px;
	line-height: 3px;
	margin: 21px 0;
}

.copy div.hr {
	margin:12px 0 12px 0;
}

/*********** = lists = ***********/

div.copy ul {
	list-style-type: none;
	margin: 15px 0 15px 15px;
}

* html div.copy ul {
	margin-top: 5px;
	height: 1px;
	position: static;
}

div.copy .csc-textpic-text {
	margin: 0;
}

div.copy li {
	margin:5px 0;
	padding: 0 0 0 15px;
	background: url(../images/bg-arrow-blue.gif) no-repeat 0 0;
	position: static;
	zoom: 1;
}

* html div.copy li {
	position: static;
}

/*********** = navigation = ***********/

ul#primary {
	background: url(../images/bg-nav.gif) repeat-x 0 100%;
	left: 0;
	list-style-type: none;
	height: 32px;
	position: absolute;
	top: 81px;
	width: 842px;    
}

ul#primary li {
	float: left;
}

ul#primary li a, 
ul#primary li a:visited {
	background-repeat: no-repeat;
	background-position: 0 0;
    display:block;
    height: 32px;
    text-indent: -9999em;
    width: 122px;
}

a#company {
	background-image: url(../images/bg-nav_01.gif);
}

a#services {
	background-image: url(../images/bg-nav_02.gif);
}

a#projects {
	background-image: url(../images/bg-nav_03.gif);
}

a#careers {
	background-image: url(../images/bg-nav_04.gif);
}

a#news {
	background-image: url(../images/bg-nav_05.gif);
}

a#contact {
	background-image: url(../images/bg-nav_06.gif);
	width: 110px !important;
}

a#dentrification {
	background-image: url(../images/bg-nav-denitrification.gif);
}


a#denitrification {
	background-image: url(../images/bg-nav-denitrification.gif);
}

a#employees {
	background-image: url(../images/bg-nav_07.gif);
	width: 110px !important;
}

ul#primary li a:hover {
	background-position: 0 -32px;
}

ul#primary li a.active {
	background-position: 0 -64px;
}

/*********** = sidebar = ***********/

div.sidebar ul {
	margin: -5px 0 0 5px !important;
	padding: 0 !important;
	text-transform: uppercase;
	list-style-type: none;
}

div.sidebar ul li {
	margin: 0 !important;
	padding: 0 !important;
	background: none;
}

div.sidebar ul li.last {
	background: none;
}

div.sidebar ul a,
div.sidebar ul a:visited {
	color: #444;
	font-size: 12px;
	text-decoration: none;
	display: block;
	padding: 9px !important;
}

div.sidebar ul a:hover {
	background-color: #eee;
	color: #0573b8;
}

div.sidebar ul li.active a,
div.sidebar ul li.active a:visited {
	color: #0573b8;
}

div.sidebar ul ul {
	margin: -5px 0 5px 9px !important;
}

div.sidebar ul ul li {
	margin: 0 !important;
	padding: 0 !important;
}

div.sidebar ul ul a,
div.sidebar ul ul a:visited {
	color: #0573b8;
	padding: 3px 0 3px 12px !important;
	text-transform: none;
}

div.sidebar ul ul li.active a,
div.sidebar ul ul li.active a:visited {
	background: url(../images/bg-arrow.gif) no-repeat 2px 3px;
	color: #f8941d;
}

div.sidebar .img-container {
	margin: 25px 0 0 0;
	width: 244px;
}

div.sidebar .img-container img {
	display: block;
	margin: 0 0 5px 0 !important;
}

div.sidebar .img-container p {
	color: #0573b8;
	font-size: 11px;
	font-weight: bold;
	line-height: 13px;
	margin: 0 !important;
	padding: 0 !important;
}

/*********** = utility classes = ***********/

.clearfix {
	display:inline-block; /* IE 6 & 7 */
}

.clearfix:after { /* modern browsers */
	content:"."; 
    display:block; 
    height:0; 
    clear:both; 
    visibility:hidden;
}

*html .clearfix {
	height:1%; /* fIE 6 */
}

.clear {
	clear:both;
	height:1px;
	margin:-1px 0 0 0;
	padding:0;
}

.clear.left {
	clear:left;
}

.clear.right {
	clear:right;
}

.center {
	text-align:center;
}

.centered {
	margin-left:auto;
	margin-right:auto;
}

.alignright {
	float:right;
}
	
.alignleft {
	float:left
}

/* images */

img { border:none; }

img.pdf {
	margin:10px 0;
}

img.float-r {
	float:right;
    margin:0px 0 2px 15px;
}

img.float-l {
	float:left;
	margin:0px 15px 2px 0;
}

/* forms */

#header form.search {
	position: absolute;
	right: 0;
	top: 14px;
}

#header form.search label {
	color: #f7941d;
	float: left;
	font: bold 10px Arial;
	height: 17px;
	line-height: 17px;
	text-transform: uppercase;
}

#header form.search input#search {
	border: 1px solid #ddd;
	float: left;
	margin: 0 3px 0 7px;
	height: 17px;
}

#header form.search input.submit {
	float: left;
}

/* FORMS */
.form-container {
	
}

label.desc {
	display: block;
	font-size: 1.2em;
	font-weight: bold;
	color: #333333;
	padding: 10px 0 5px 0;
}

input.text {
	padding: 3px;
	border: 1px solid #999999;
	border-top: 1px solid #333333;
	border-bottom: 1px solid #CCCCCC;
}

.form-container .submit {
	margin: 10px 0;
}

.form-container .submit input {
	border: 3px groove #CCCCCC;
	padding: 4px;
	background: #0571B5;
	
	color: #FFFFFF;
}

/* search styles */
.tx-indexedsearch-browsebox {
	margin: 10px 0;
}

.tx-indexedsearch-res {
	margin-bottom: 5px;
}

.tx-indexedsearch-res .title {
	font-size: 1.3em;
	padding: 0 0 7px 0;
	margin: 0;
}

/* sitemap */
div.csc-sitemap ul {
	margin: 0;
	text-indent: none;
	padding: 0;
}

div.csc-sitemap ul li {
	margin: 5px 0 5px 10px;
}

.csc-textpic-text {
	min-height: 1px;
}

* html .csc-textpic-text {
	height: 1px;
}

table.sfForm td {
	padding:3px;
}
