@charset "utf-8";
/* Screen styles */

/* ------------------------------------------------------------------- Default tags */

* {
	margin: 0px;
	padding: 0px;
}

html {
	background: #fbfbfb url(../images/bkgnd_tile.png) repeat center top;
}

body {
	color: #444;
	font: 62.5% Helvetica, Arial, sans-serif;
}

a {
	text-decoration: none;
	color: #14b6dd;
}

a:visited {
	color: #EB0A20;
}

a:hover,
a:focus,
a:active {
	color: #999;
	outline: none;
	text-decoration: underline;
}

acronym {
	cursor: help;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
}

dl {
	margin: 0px 0px 10px;
	padding: 0px;
}

dt {
	font-style: normal;
	font-weight: bold;
	margin: 0px 0px 5px;
	padding: 0px;
}

dd {
	margin: 0px 0px 5px;
	padding: 0px 10px;
}

fieldset {
	padding: 5px 5px 0px;
	margin: 0px 0px 15px;
	border: 1px solid #E3E2DB;
}

h1,h2, h3, h4, h5, h6 {
	margin: 0px 0px 10px;
	padding: 3px 0px 5px;
	font-weight: normal;
}

h2 {
	font-size: 1.8em;
}

h3 {
	font-size: 1.6em;
}

h4 {
	font-size: 1.4em;
	font-weight: bold;
}

h5 {
	font-size: 1.2em;
	font-weight: bold;
}

h6 {
	font-size: 1em;
	font-weight: bold;
}

label {
	cursor: pointer;
}

legend {
	padding: 5px 5px 0px;
	color: #000;
	font-size: 1.5em;
	font-weight: normal;
	border: none;
	margin: 0px 0px 5px;
}

p {
	line-height: 1.5em;
	margin: 0px 0px 10px;
	padding: 0px;
}

table {
	table-layout: fixed;
	border-right: 1px solid #E3E2DB;
	border-bottom: 1px solid #E3E2DB;
	margin-bottom: 5px;
}

td, th {
	padding: 4px;
	border-top: 1px solid #E3E2DB;
	border-left: 1px solid #E3E2DB;
}

th {
	background: #999;
	color: #000;
}

ul {
	margin: 0px 0px 20px;
	padding: 0px;
	list-style: square;
}

li {
	margin: 0px 0px 5px 20px;
	padding: 0px;
}

/* ------------------------------------------------------------------- Primary structure */

#header,
#content,
#footer {
	width: 760px;
	margin: 0px auto 20px;
	font-size: 1.2em;
	overflow: hidden;
}


/* ------------------------------------------------------------------- Secondary structure */

.floatWrap {
	width: 100%;
	overflow: hidden;
}

.columnContainer {
	width: 100%;
	overflow: hidden;
	margin: 0px 0px 10px;
}

.splitLeft {
	float: left;
	width: 49%;
	overflow: hidden;
}

.splitRight {
	float: right;
	width: 49%;
	overflow: hidden;
}

.threeColumn {
	float: left;
	width: 30%;
	margin: 0% 1.5% 0% 1.5%;
}

.fourColumn {
	float: left;
	width: 24%;
	margin: 0% 1% 0% 0%;
}

.fiveColumn {
	float: left;
	width: 19%;
	margin: 0% 1% 0% 0%;
}

.pagination {
	width: 100%;
	overflow: hidden;
	margin: 0px;
}

.contentBlock {
	padding: 20px;
}

/* ------------------------------------------------------------------- Content images */

.imageLeft {
	margin: 0px 10px 10px 0px;
	padding: 5px;
	float: left;
	background-color: #FFF;
	color: inherit;
	width: auto;
	display: block;
}

.imageRight {
	margin: 0px 0px 10px 10px;
	padding: 5px;
	float: right;
	background-color: #FFF;
	color: inherit;
	width: auto;
	display: block;
}

.imageCenter {
	padding: 5px;
	background-color: #FFF;
	color: inherit;
	margin: 0px auto 10px;
	clear: both;
	float: none;
	text-align: center;
	display: block;
	width: auto;
}

.inlineImage {
	margin: 0px 0px 10px;
	padding: 5px;
	background-color: #FFF;
	color: inherit;
}

.imageGallery {
	margin: 0px 0px 5px;
	width: 340px;
	overflow: hidden;	
}

.imageGallery a {
	height: 80px;
	width: 80px;
	display: block;
	float: left;
	margin: 0px 1px 1px 0px;
	padding: 1px;
	border: 1px solid #D6D6D6;
}


/* ------------------------------------------------------------------- Header */

#header {
	position: relative;
	height: 102px;
	margin: 0px auto;
}

#logo {
	margin: 0px auto 50px;
	padding: 0px;
	height: 46px;
	width: 170px;
	display: block;
	background: url(../images/logo.png) no-repeat center top;
	position: absolute;
	top: 32px;
	left: 0px;
}

#logo a {
	height: 46px;
	width: 170px;
	display: block;
}

#logo span {
	display: none;
}

#primaryNav {
	width: auto;
	position: absolute;
	top: 55px;
	right: 0px;
	padding: 0px;
}

#primaryNav ul,
#primaryNav li {
	float: right;
	list-style: none;
	margin: 0px;
	padding: 0px;
}

#primaryNav li {
	float: left;
	margin: 0px 0px 0px 20px;
}

#primaryNav li a,
#primaryNav li a:visited {
	float: left;
	text-decoration: none;
	color: #14b6dd;
}

#primaryNav li a:hover,
#primaryNav li a:focus,
#primaryNav li a:active,
#primaryNav li.activePageLink a {
	color: #EB0A20;
	border-bottom: 2px solid #EB0A20;
}

#primaryNav li.menu_external_138 {
	display: none;	
}

#pageHeading {
	font-weight: normal;
	font-size: 1.8em;
	margin: 0px 0px 22px;
	padding: 0px 0px 4px;
	background: url(../images/bkgnd_heading_line.gif) repeat-x left bottom;
}

#page_home #pageHeading {
	display: none;	
}

#breadCrumb {
	width: 760px;
	overflow: hidden;
	margin: -20px 0px 10px;
	padding: 0px;
}

#breadCrumb li {
	display: inline;
	margin: 0px;
	padding: 0px;
	font-size: 0.9em;
}

/* ------------------------------------------------------------------- Footer */

#footer {
	height: 30px;
	width: 740px;
	line-height: 30px;
	margin: 0px auto 20px;
	padding: 3px 10px 0px;
	font-size: 0.9em;
	background: url(../images/bkgnd_heading_line.gif) repeat-x center top;
}

#footerPrimary {
	float: left;
	width: 50%;
}

#footerPrimary ul,
#footerPrimary li {
	margin: 0px;
	padding: 0px;
	list-style: none;
}

#footerPrimary li {
	display: inline;
	margin: 0px 5px 0px 0px;
}

#footerSecondary {
	margin: 0px;
	padding: 0px;
	float: right;
	width: 50%;
	text-align: right;
	line-height: 30px;
	height: 30px;
}

/* ------------------------------------------------------------------- Home page */

#introduction {
	font: italic 1.6em Georgia, "Times New Roman", Times, serif;
	margin: 0px 0px 20px;
	padding: 5px;
	background: #FEFDDE;
}

#services {
	margin: 0px 0px 20px;
	padding: 0px;
	width: 100%;
	overflow: hidden;
}

#services ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}

#services ul li {
	list-style: none;
	margin: 0px 0px 6px;
	padding: 0px 0px 6px 10px;
	border-bottom: 1px solid #E3E2DB;
}

#services ul li a,
#services ul li a:visited {
	display: block;	
}

#services ul li a:hover,
#services ul li a:focus,
#services ul li a:active {
	background: url(../images/icon_visit.png) no-repeat right center;
	text-decoration: none;
}

/* ------------------------------------------------------------------- Portfolio */

#portfolioList {
	margin: 0px;
	padding: 0px;
	width: 100%;
	overflow: hidden;
}

#portfolioList .block {
	float: left;
	width: 170px;
	background: url(../images/bkgnd_portfolio_items.png) no-repeat center top;
	margin: 0px;
	padding: 10px;
	overflow: hidden;
	height: 140px;
}

#portfolioList .image {
	margin: 0px 0px 15px;
	padding: 0px;	
}

#portfolioList h3 {
	font-size: 1em;
	margin: 0px;
	padding: 0px;
}

#portfolioList .year {
	float: left;
	margin: 0px;
	padding: 0px;
	width: 115px;
	font-size: 0.9em;
	font-style: italic;
	font-weight: normal;
	color: #B9B9B9;
}

#portfolioList .link {
	float: right;
	margin: 0px;
	padding: 0px;
	width: 55px;
	text-align: right;
	font-size: 0.9em;
}

#portfolioList .link a,
#portfolioBlock .link a {
	line-height: 16px;
	height: 16px;
	width: 35px;
	padding: 0px 20px 0px 0px;
	display: block;
	background: url(../images/icon_visit.png) no-repeat right center;
}

#portfolioBlock .imageBlock {
	background: url(../images/bkgnd_portfolio.png) no-repeat center top;
	height: 310px;
	width: 760px;
	padding: 0px;
	position: relative;
	margin: 0px 0px 15px;
}

#portfolioBlock .imageBlock img {
	background: url(../images/bkgnd_portfolio.png) no-repeat center top;
	height: 290px;
	width: 620px;
	position: absolute;
	left: 70px;
	top: 10px;
}

#portfolioBlock .year {
	float: right;
	margin: -25px 0px 0px;
	padding: 0px;
	width: 45%;
	text-align: right;
	font-size: 0.9em;
}

#portfolioBlock .gallery {
	margin: 0px 0px 5px;
	padding: 0px 0px 15px;
	border-bottom: 1px solid #E3E2DB;
	width: 760px;
	height: 55px;
	text-align: center;
	overflow: hidden;
}

#portfolioBlock .gallery img {
	background: #FFF;
	padding: 1px;
	margin: 0px 5px 0px 0px;
	height: 51px;
	width: 51px;
	border: 1px solid #E3E2DB;
}

#portfolioBlock .description {
	
}

#portfolioBlock .contactLink {
	margin: 0px;
	padding: 5px;
	float: left;
	font-style: italic;
	background: #E4F2FD;
}

#portfolioBlock .link {
	margin: 0px;
	padding: 5px;
	float: right;
	width: 500px;
	text-align: right;
}

#portfolioBlock .link a {
	float: right;
	width: 500px;
}

.prevButton,
.nextButton {
	display: block;
	height: 40px;
	width: 40px;
	margin: 0px;
	padding: 0px;
	position: absolute;
	z-index: 2;
	top: 135px;
	background-repeat: no-repeat;
	background-position: top center;
}

.prevButton a,
.nextButton a {
	display: block;
	height: 40px;
	width: 40px;
}

.prevButton span,
.nextButton span {
	display: none;
}

.prevButton {
	left: 0px;
	background-image:url(../images/prev_button.png);
}

.nextButton {
	right: 0px;
	background-image:url(../images/next_button.png);	
}

.prevButton:hover,
.nextButton:hover {
	background-position: bottom center;
}

/* ------------------------------------------------------------------- Contact */

#form_contact_us {
	height: 240px;
	width: 760px;
	position: relative;
}

#form_contact_us .formBlock dt,
#form_contact_us .formBlock dd {
	margin: 0px;
	padding: 0px;	
}

#form_contact_us .formBlock {
	position: absolute;
}

#contact_name_block {
	height: 60px;
	width: 360px;
	left: 390px;
	top: 0px;
	padding: 5px;
}

#contact_email_block {
	height: 60px;
	width: 360px;
	left: 390px;
	top: 70px;
	padding: 5px;
}

#contact_message_block {
	height: 230px;
	width: 370px;
	left: 0px;
	top: 0px;
	padding: 5px;
}

#contact_message_block .label {
	margin: 0px;
	padding: 0px;
	float: left;
	width: 30%;	
}

#contact_message_block .description {
	margin: 0px;
	padding: 0px;
	float: right;
	width: 70%;
	text-align: right;
}

#contact_attachment_block {
	height: 60px;
	width: 360px;
	left: 390px;
	top: 140px;
	padding: 5px;
}

#contact_send_block {
	height: 20px;
	width: 360px;
	left: 390px;
	top: 210px;
	padding: 5px;
}

#form_contact_us .inputTextField,
#form_contact_us .inputFileField,
#form_contact_us .inputTextArea {
	width: 218px;
	border: 1px solid #E3E2DB;
	padding: 5px;
}

#form_contact_us .inputTextArea {
	width: 358px;
	height: 203px;
}

#form_contact_us .description {
		
}

/* ------------------------------------------------------------------- Modal boxes */

#modalOverlay {
	background-color: #000000;	
}

#modalContentBox {
	background-color: #FFFFFF;
	border: 10px solid #000000;
	padding: 10px;
}

#modalTitleBar {
	width: 100%;
	overflow: hidden;
	height:25px;
	background: #EB0A20;
	margin-bottom: 5px;
}

#modalTitleBar h1 {
	font-size: 1em;
	font-weight: normal;
	color: #FFFFFF;
	padding: 5px;
	width: 75%;
	float: left;
}

#modalCloseButton {
	height: 25px;
	width: 26px;
	float: right;
	text-align: right;
	background: #FFFFFF url(../images/icon_delete.png) no-repeat right center;
	display: block;
}

#modalCloseButton span {
	display:none;
}

/* ------------------------------------------------------------------- Slimbox */

#lbOverlay {
	position: fixed;
	z-index: 9999;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: #000;
	cursor: pointer;
	color: inherit;
}

#lbCenter, #lbBottomContainer {
	position: absolute;
	z-index: 9999;
	overflow: hidden;
	color: inherit;
	background: #FFF;
}

.lbLoading {
	background: #FFF url(../images/loading.gif) no-repeat center center;
	color: inherit;
}

#lbImage {
	position: absolute;
	left: 0;
	top: 0;
	border: 10px solid #FFF;
	background-repeat: no-repeat;
	background-position: center center;
	padding-right: 50px;
	padding-left: 50px;
}

#lbPrevLink, #lbNextLink {
	display: block;
	position: absolute;
	top: 0;
	width: 50%;
	outline: none;
}

#lbPrevLink {
	left: -50px;
}

#lbPrevLink:hover {
	background: transparent url(../images/prev_button.png) no-repeat 0 50%;
}

#lbNextLink {
	right: -50px;
}

#lbNextLink:hover {
	background: transparent url(../images/next_button.png) no-repeat 100% 50%;
}

#lbBottom {
	font-family: Helvetica, Arial, sans-serif;
	font-size: 10px;
	color: #666666;
	line-height: 1.4em;
	text-align: left;
	border-top: none;
	border-right: 10px solid #FFF;
	border-bottom: 10px solid #FFF;
	border-left: 10px solid #FFF;
	background-color: inherit;
}

#lbCloseLink {
	display: block;
	float: right;
	width: 70px;
	height: 30px;
	background: transparent url(../images/closelabel.png) no-repeat center top;
	margin: 5px 0;
	outline: none;
}

#lbCaption, #lbNumber {
	margin-right: 71px;
}

#lbCaption {
	font-weight: bold;
}


/* ------------------------------------------------------------------- Miscellaneous */

.topLink {
	text-align: right;	
}

.messageBlock {
	border: 1px solid #FFD700;
	background: #FEFDE7;
	padding: 4px;
	margin-bottom: 5px;
}

.messageFail, .formError {
	background: #FEE7EE;
	border-color: #FF0006;
}

.formBlock .error {
	color: #FF0006;
	font-size: 0.9em;
	font-style: normal;
}

.messageNone {
	background: #E4F2FD;
	border-color: #93CAF7;
}

.messageNotice {
	background: #E4F2FD;
	border-color: #93CAF7;
}

#globalMessage {
	background: #FEFDE7;
	padding: 4px 0px;
	margin-bottom: 5px;
	border-top: 1px solid #FFD700;
	border-bottom: 1px solid #FFD700;
	width: 100%;
	font-size: 1.2em;
	text-align: center;
}

.highLite {
	background: #E4F2FD;
	padding: 5px;
}

label,
button,
.formButton,
#lbOverlay {
	cursor: pointer;
}


