/* ==== ALL ELEMENT STYLE RESET ==== */

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0px;
	border: 0;
	outline: 0;
	font-weight: inherit;
	font-style: inherit;
	font-family: inherit;
	vertical-align: baseline;
}

:focus {
	outline: 0;
}

ol, ul {
	list-style: none;
}

/* tables still need 'cellspacing="0"' in the markup */
table {
	border-collapse: separate;
	border-spacing: 0;
}

caption, th, td {
	text-align: left;
	font-weight: normal;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: "";
}

blockquote, q {
	quotes: "" "";
}

/* ====  END STYLE RESET ==== */

body {
    font-family: Verdana, Arial, sans-serif;
    font-size: 62.5%;
    text-align: center;
	
    }

.clear {
	clear: both;
	line-height: 0;
	height: 0;
	background-color: #FFFFFF;
    }

#container {
    width: 900px;
    margin: 0 auto;
    text-align: left;
    }

#header,
#header-homepage,
#feature,
#footer {
	width: 900px;
	margin-bottom: 15px;
	margin-left: 0px;
    }

#header {
    margin-top: 30px;
    }

.intro-text {
	width: 870px;
	padding: 5px 15px 20px 0px;
	margin-bottom: 30px;
	background: #fff url(../img/border_fade_3_col.jpg) center bottom no-repeat;
    }
	
.full-body {
	width: 870px;
	padding: 5px 15px 0px 0px;
	margin-bottom: 30px;
	background: #fff;
    }

#sub-nav {
    margin-top: 5px;
    }

.sub-nav {
	width: 870px;
	padding: 5px 15px 20px 0px;
	margin-bottom: 30px;
    }


#content {
	width: 890px;
	padding: 0 0px;
	margin-bottom: 15px;
    }

.content-block {
	width: 890px;
	margin-bottom: 15px;
    }

.content-block.form-1,
.content-block.form-2 {
	background: transparent url(../img/form_2_bottom_brackets.gif) bottom left no-repeat;
	padding-bottom: 25px;
    }

.content-block.form-3 {
    background: transparent url(../img/form_3_bottom_brackets.gif) bottom center no-repeat;
    padding-bottom: 25px;
    }
	
.content-block.form-4 {
    padding-bottom: 25px;
    }

.form-1 .column-1 {
    width: 820px;
    padding: 0 25px;
    }

.form-2 .column-1 {
	width: 575px;
	padding: 0 0 0 0px;
	float: left;
    }

.form-2 .column-1skinny {
	width: 470px;
	padding: 0 25px;
	float: left;
    }
    
.form-2 .column-2 {
	width: 255px;
	padding-right: 20px;
	float: right;
    }
	
.form-2 .column-2wide {
	width: 320px;
	padding-right: 15px;
	float: right;
    }

.form-3 .column-1,
.form-3 .column-2,
.form-3 .column-3 {
    width: 230px;
    padding: 0 25px;
    margin-right: 15px;
    float: left;
    }
.form-3nobg .column-1nobg,
.form-3nobg .column-2nobg,
.form-3nobg .column-3nobg {
    width: 230px;
    padding: 0 25px;
    margin-right: 15px;
    float: left;
    }

.content-block.form-3 .column-3 {
    margin-right: 0;
    }

#header-homepage .column-1 {
	width: 540px;
	margin: 40px 0 0 0;
	padding: 0;
	float: left;
    }

#header-homepage .column-2 {
	width: 320px;
	margin: 0;
	padding: 15px 0 0  0px;
	background: transparent url(../img/border_fade_vert.gif) left top no-repeat;
	float: right;
    }

#feature .content-block.form-1 {
    width: 900px;
    padding: 0;
    margin: 0;
    background-image: none;
    }

#feature .content-block.form-1 .column-1 {
    width: 900px;
    padding: 0;
    margin: 0;
    }

#feature .content-block.form-2 {
	width: 870px;
	padding: 0px 0px 0px 0px;
	background: #000 url(../img/feature_bg.jpg) bottom center no-repeat;
	margin-left: 0px;
    }

#feature .content-block.form-2 .column-1 {
	width: 585px;
	padding: 0;
	margin: 0;
	background-color: #000000;
    }

#feature .content-block.form-2 .column-2 {
	width: 205px;
	padding: 5px 40px 0 20px;
	margin: 0;
    }

.person {
	width: 280px;
	margin: 0 5px 10px 5px;
	float: left;
	background: #fff url(../img/person_bg.jpg) center bottom no-repeat;
	text-indent: 0px;
    }

#footer {
    background: transparent url(../img/border_fade_3_col.jpg) center top no-repeat;
    padding-top: 20px;
    margin-bottom: 30px;
    }

#footer-nav {
    margin-bottom: 5px;
    }

#footer-nav .column-1 {
    width: 295px;
    margin: 0;
    padding: 0;
    float: left;
    }

#footer-nav .column-2 {
    width: 590px;
    padding: 6px 0 0 0;
    margin: 0;
    float: right;
    }

/* =============== FOOTER FORM =============== */

#footer-contact-form {
    width: 900px;
    }

#footer-contact-form .column-1 {
    width: 250px;
    margin: 0 5px 0 0;
    padding: 0;
    float: left;
    }

#footer-contact-form .column-2 {
    width: 635px;
    margin: 0 5px 0 0;
    padding: 0;
    float: right;
    }

#footer-contact-form .form-row {
    margin-bottom: 5px;
    }

input, textarea {
    border: 1px solid #ccc;
    background: #f9f9f9;
    padding: 5px;
    font-family: Verdana, Arial, sans-serif;
    color: #777;
    font-size: 10px;
    overflow: auto;
    }

#footer-contact-form .column-1 input {
    width: 240px;
    }

#footer-contact-form .column-2 .form-row {
    width: 592px;
    float: left;
    }

#footer-contact-form .column-2 textarea {
    margin: 0;
    width: 580px;
    height: 41px;
    }
    
#footer-contact-form .column-2 .button {
    width: 32px;
    float: right;
    }

#submit-button {
    width: 30px;
    height: 41px;
    display: inline;
    background: transparent url(../img/send_button.gif) center center no-repeat;
    }

/* =============== END FOOTER FORM =============== */

a:link,
a:visited,
a:hover,
a:active {
    text-decoration: none;
    font-family: Verdana, Arial, sans-serif;
    color: #d8001d;
    padding: 0 1px;
    }

a:hover,
a:active {
    text-decoration: underline;
    }

.header-news a:link,
.header-news a:visited,
.header-news a:hover,
.header-news a:active {
    margin: 0;
    padding: 0;
    color: #444;
    }

.header-news a:hover,
.header-news a:active {
    color: #d8001d;
    background: transparent;
    text-decoration: none;
    }
    
a.morelink:link,
a.morelink:visited,
a.morelink:hover,
a.morelink:active,
.morelink a:link,
.morelink a:visited,
.morelink a:hover,
.morelink a:active {
    font-family: Trebuchet MS, Trebuchet, Arial, sans-serif;
    font-weight: bold;
    font-size: 10px;
    text-transform: uppercase;
    padding: 0 10px 0 1px;
    background: transparent url(../img/morelink_arrow.gif) right center no-repeat;
    }

a.morelink:hover,
a.morelink:active,
.morelink a:hover,
.morelink a:active {
    color: #fff;
    text-decoration: none;
    background: #d8001d url(../img/morelink_arrow_over.gif) right center no-repeat;
    }

a.no-bg-link:link,
a.no-bg-link:visited,
a.no-bg-link:hover,
a.no-bg-link:active {
    background-color: transparent;
    }

/* =============== MAIN NAVIGATION =============== */

.main-nav a:link,
.main-nav a:visited,
.main-nav a:hover,
.main-nav a:active {
    height: 31px;
    margin: 0;
    padding: 0;
    line-height: 31px;
    text-decoration: none;
    display: block;
    background-color: #fff;
    background-position: center 0;
    background-repeat: no-repeat;
    text-indent: -9999px;
    }

.main-nav a:hover,
.main-nav a:active {
    background-position: center -31px;
    }

a.why-us:link, a.why-us:visited, a.why-us:hover, a.why-us:active {
    width: 74px;
    background-image: url(../img/why_us.gif);
    }

a.our-work:link, a.our-work:visited, a.our-work:hover, a.our-work:active {
    width: 94px;
    background-image: url(../img/our_work.gif);
    }

a.people:link, a.people:visited, a.people:hover, a.people:active {
    width: 72px;
    background-image: url(../img/people.gif);
    }

a.contact:link, a.contact:visited, a.contact:hover, a.contact:active {
    width: 78px;
    background-image: url(../img/contact.gif);
    }

.main-nav a.current:link,
.main-nav a.current:visited,
.main-nav a.current:hover,
.main-nav a.current:active {
    background-position: center -31px;
    }

/* =============== END MAIN NAVIGATION =============== */


h1, h2, h3, h4, h5, h6 {
    font-family: Helvetica, Arial, sans-serif;
    color: #222;
    }

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

h2 {
    font-size: 2.4em;
    line-height: 1.2em;
    margin: .5em 0;
    }

h3 {
    font-size: 2em;
    line-height: 1.2em;
    margin: 0 0 .3em 0;
    }

h4 {
    font-size: 1.6em;
    line-height: 1.3em;
    margin: 0 0 .5em 0;
    }
    
#feature h4 {
    color: #eee;
    }

h4.phone,
h4.fax {
    color: #999;
    line-height: 1.6em;
    padding-left: 30px;
    }

h4.phone {
    background: #fff url(../img/phone_icon.gif) left center no-repeat;
    }

h4.fax {
    background: #fff url(../img/fax_icon.gif) left center no-repeat;
    }

h5 {
    font-size: 1.3em;
    line-height: 1.3em;
    margin: 1em 0 .3em 0;
    color: #000;
    text-transform: uppercase;
    }

h6 {
    font-size: 1.3em;
    line-height: 1.3em;
    margin: 1em 0 .3em 0;
    color: #d8001d;
    text-transform: uppercase;
    }
    

p {
    font-family: Verdana, Arial, sans-serif;
    margin-bottom: 1em;
    color: #444;
    font-size: 1em;
    line-height: 1.5em;
    }

strong {
    font-weight: bold;
    }

.intro-text p {
    font-family: Verdana, Arial, sans-serif;
    font-size: 1.1em;
    line-height: 1.6em;
    color: #222;
    }
	
.full-body p {
    font-family: Verdana, Arial, sans-serif;
    font-size: 1.1em;
    line-height: 1.6em;
    color: #222;
    }

#footer p {
    margin-bottom: 5px;
    font-size: 10px;
    color: #777;
    }

p.morelink {
    text-align: right;
    padding-bottom: 0;
    margin-bottom: 0;
    line-height: 1em;
    }
    
#feature p {
    color: #999;
    }

ul {
    margin: 0 0 15px 15px;
    list-style: circle url(../img/list_arrow.gif) outside;
    }

.service-list {
    border: 1px solid #ccc;
    background: #f9f9f9;
    padding: 15px;
    margin-bottom: 15px;
    }

.service-list ul {
    margin: 0;
    }

li {
    font-family: Verdana, Arial, sans-serif;
    font-size: 1em;
    line-height: 1.6em;
    color: #444;
    margin: 0 0 .5em 0px;
    }
    
.person ul {
    margin: 10px 5px 15px 0;
    list-style-image: none;
    list-style-position: inside;
    list-style-type: none;
    padding: 0;
    }

.person ul li {
	margin-bottom: 0;
	line-height: 1.4em;
	text-indent: 5px;
    }

.person ul li.name {
	font-size: 1.4em;
	color: #d8001d;
	text-transform: lowercase;
	text-indent: 5px;
    }

.person ul li.title {
	text-transform: uppercase;
	color: #000;
	text-indent: 5px;
    }

ul.horiz-list li {
    float: left;
    width: 140px;
    font-size: 1em;
    margin-bottom: .3em;
    }

ul.main-nav {
    padding: 0;
    margin: 0;
    list-style: none;
    }

ul.main-nav li {
    padding: 1px 12px 1px 0;
    margin: 0;
    height: 31px;
    line-height: 0;
    display: inline;
	float: left;
	position: relative;
	background: transparent url(../img/nav_border.gif) right center no-repeat;
    }

ul.main-nav li.last-main-nav {
    background: none;
    }


ul.header-news {
	margin: 0;
	padding: 0px 15px 0px 5px;
	list-style-image: none;
	list-style-type: none;
    }

ul.header-news li {
    font-size: 10px;
    line-height: 1.2em;
    color: #999;
    margin: 0 0 5px 5px;
    padding: 0 0 0 25px;
    background: transparent url(../img/news_icon.gif) left 2px no-repeat;
    }


/* =============== HOVERGALLERY =============== */

.hovergallery {
	cursor: default;
	list-style: none;
	margin: 0;
	padding: 0;
	list-style-type: none;
	list-style-image: none;
}

.hovergallery a {
	cursor: default;
}

.hovergallery a .preview {
	display: none;
}

.hovergallery a:hover .preview {
	display: block;
	position: absolute;
	top: -22px;
	left: -50px;
	z-index: 1;
}

.hovergallery img {
	background: #fff;
	border: 1px solid #aaa;
	padding: 2px;
	vertical-align: top;
	width: 60px;
	height: 60px;
}

.hovergallery li {
	display: inline;
	float: left;
	margin: 0 5px 7px 0;
	position: relative;
    }

.hovergallery .preview {
	width: 160px;
	height: 104px;
    }

/* =============== END HOVERGALLERY =============== */

/* =============== CLIENT GALLERY =============== */

.client-links {
	margin: 0px 0px 0px 10px;
	padding: 0;
	list-style-type: none;
	list-style-image: none;
}

.client-links a .rollover {
    display: none;
    }

.client-links a:hover .rollover {
    display: block;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
    }

.client-links img {
    vertical-align: top;
    }

.client-links li {
	display: inline;
	float: left;
	margin: 0;
	padding: 0;
	position: relative;
    }
    
/* =============== END CLIENT GALLERY =============== */
