/* (c)2007 www.cogentmedia.co.uk. All rights reserved. */

/* GENERAL DEFINITIONS --------------------------------------------------------------- */

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

html {}

body
{	position: relative;
	font-family: Arial, Helvetica, sans-serif;
	font-size: 12px;
	line-height: 16px;
	text-align: left;
	color: #333333;
	background: #FFFFFF url(resources/bodyBG.gif) top left repeat-y;
}

h1
{	margin-bottom: 10px;
	font-size: 22px;
	font-weight: bold;
	line-height: 24px;
	color: #666666;
}
h1 a {color: #666666;}
h1.ruled {padding-bottom: 6px; margin-bottom: 10px; border-bottom: 4px dotted #DDDDDD;}
h1.quote {margin-left: -10px; text-transform: capitalize;}

h2
{	margin-bottom: 8px;
	font-size: 16px;
	font-weight: bold;
	line-height: 20px; /* was 14px */
	color: #333333;
}
h2 a {color: #333333;}
h2.ruled {padding-bottom: 4px; margin-bottom: 4px; border-bottom: 1px dotted #DDDDDD;}
h2.mainRuled {margin: 0px 0px 12px 0px; padding-bottom: 12px; background: url(resources/rule.gif) bottom left no-repeat;}
h2.mainRuledSection
{	margin: 10px 0px 12px 0px;
	padding: 12px 0px 12px 0px;
	background: url(resources/rule.gif) bottom left no-repeat;
	border-top: 1px solid #DDDDDD;
}

h3
{	margin-bottom: 4px;
	font-size: 14px;
	font-weight: bold;
	line-height: 16px;
	color: #333333;
}
h3 a {color: #000000;}
h3.ruled {padding-bottom: 2px; margin-bottom: 4px; border-bottom: 1px dotted #DDDDDD;}

h4
{	margin-bottom: 4px;
	font-size: 11px;
	font-weight: bold;
	line-height: 12px;
	color: #000000;
}
h4 a {color: #000000;}
h4.ruled {padding-bottom: 2px; margin-bottom: 6px; border-bottom: 1px dotted #DDDDDD;}

h5
{	margin-bottom: 4px;
	font-size: 9px;
	font-weight: bold;
	line-height: 10px;
	color: #E71F01;
}
h5 a {color: #E71F01;}
h5.mainRuled {margin-bottom: 8px; padding-bottom: 14px; background: url(resources/rule.gif) bottom left no-repeat;}

p {margin-bottom: 8px;}
p a {color: #666666;}
p.ruled {padding-bottom: 2px; margin-bottom: 6px; border-bottom: 1px dotted #DDDDDD;}
p.mainRuled {margin-bottom: 8px; padding-bottom: 14px; background: url(resources/rule.gif) bottom left no-repeat;}

a {font-weight: bold; text-decoration: none;}
a:hover {text-decoration: underline;}

img {display: block; border: 0px;}

strong {font-weight: bold;}
small {font-size: 80%;}
em {font-style: italic; text-decoration: none;}

.floatLeft {float: left; position: relative;}
.floatLeftMargin {float: left; position: relative; margin-left: 10px;}
.floatRight {float: right; position: relative;}
.floatRightMargin {float: right;position: relative; margin-right: 10px;}
.floatRightNoEdge {float: right; position: relative; top: -20px; right: -20px;}

.alignLeft {text-align: left;}
.alignLeftMargin {text-align: left; margin-left: 10px;}
.alignRight {text-align: right;}
.alignRightMargin {text-align: right; margin-right: 10px;}
.alignCentre {text-align: center;}

.withLeftMargin {margin-left: 40px;}
.withRightMargin {margin-right: 20px;}

.imageLeftMargin {float: left; position: relative; margin: 0px 10px 10px 0px;}
.coreIntroImage {position: absolute; top: 0px; left: 0px;}

#header
{	position: relative;
	width: 100%;
	min-width: 980px;
	height: 100px;
	background: #FFFFFF url(resources/headerBG.gif) bottom left no-repeat;
}

#headerImage {width: 740px; height: 100px; position: absolute; top: 0px; right: 0px; z-index: 1;}
#headerMovie {width: 740px; height: 100px; position: absolute; top: 0px; right: 0px; z-index: 1; background: url(resources/headerImageDefault.gif) top right no-repeat;}

#pageLogo {position: absolute; top: 12px; left: 10px; z-index: 2;}

#mainMenuBar
{	position: relative;
	width: 100%;
	min-width: 980px;
	height: 55px;
	background: url(resources/mainMenuBG.gif) top left repeat-x;
}

#menuImage {float: right;}

#mainMenu {list-style-type: none;}
#mainMenu li {float: left;}
#mainMenu a
{	position: relative;	top: 15px;
	float: left;
	width: 140px;
	height: 25px;
	margin: 0px 2px 0px 2px;
	background: url(resources/mainGenericNormal.gif) top left no-repeat;
}
#mainMenu a span {display: none;}
#mainMenu a:hover {background-image: url(resources/mainGenericHover.gif);}
#mainMenu a.buttonSelected {background-image: url(resources/mainGenericSelected.gif);}

/* added float: left to page for bug with top left corner in Firefox */
#page {float: left; position: relative; min-width: 980px; background: url(resources/pageBG.gif) top left no-repeat;}

/* NB: if side contents are not floated, browser window will not scroll to bottom of side content in IE 6 PC */
.side {position: absolute; top: 0px; left: 0px; width: 150px; padding: 0px 0px 10px 0px;}

	/* !!! removed 20px form .main left margin and added 20px left padding to compensate for .main background images !!! */
.main {position: relative; min-height: 540px; margin: 0px 20px 10px 150px; padding: 0px 0px 0px 20px;}

#about0Main {background: url(images/aboutPageBG.jpg) top left no-repeat;}
#about2Main {background: url(images/careersPageBG.jpg) top left no-repeat;}
#news0Main {background: url(images/newsPageBG.jpg) top left no-repeat;}
#contact0Main {background: url(images/contactPageBG.jpg) top left no-repeat;}
#contact1Main {background: url(images/thankyouPageBG.jpg) top left no-repeat;}
#customers0Main {background: url(images/customersPageBG.jpg) top left no-repeat;}
#services0Main {background: url(images/pageBGteligence.jpg) top left no-repeat;}
#services4Main {background: url(images/pageBGwind.jpg) top left no-repeat;}
#services5Main {background: url(images/pageBGsolar.jpg) top left no-repeat;}

	/* !!! added float: left; to .fullWidthColumn to correct right-aligned image problem - NOT IE !!! */
.fullWidthColumn {float: left; clear: both; position: relative; top: 20px; width: 100%; margin: 0px 0px 10px 0px;}
.leftHalfColumn {float: left; position: relative; width: 49%; margin: 20px 0px 0px 0px;}
.rightHalfColumn {float: right; position: relative; width: 49%; margin: 20px 0px 0px 0px;}

.singleColumn {position: relative; width: 31%; padding: 0px 2% 0px 0px; margin: 0px 0px 0px 0px;}
.splitColumn {position: relative; width: 47%; padding: 0px 2% 0px 0px; margin: 0px 0px 0px 0px;}
.doubleColumn {position: relative; width: 64%; padding: 0px 2% 0px 0px;  margin: 0px 0px 0px 0px;}

.contentLeftPadded {position: relative; padding-left: 130px;}

#headerColumn
{	clear: both;
	position: relative; top: 0px; left: -20px;
	margin: 0px -40px 0px 0px;
	background-color: #FFFFFF;
}

#introMovie {display: block; border: 0px; width: 780px; height: 200px;}
#sectionMovie {display: block; border: 0px; width: 780px; height: 160px;}


ul.subMenu {list-style-type: none; display: block; margin-bottom: 30px;}
ul.subMenu li {margin: 0px 2px 5px 2px;}
ul.subMenu li a
{	display: block;
	position: relative;
	width: 133px;
	height: 17px;
	padding: 4px 0px 4px 7px; /* right padding should be 10px */
	background: url(resources/subGenericNormal.gif) top left no-repeat;
	font-size: 10px;
	text-transform: capitalize;
	color: #333333;
	text-decoration: none;
}
ul.subMenu li a:hover {background-image: url(resources/subGenericHover.gif); text-decoration: none;}
ul.subMenu li a.buttonSelected {background-image: url(resources/subGenericSelected.gif);}

ul.subMenu li.menuSelected {background: url(resources/subMenuBG.jpg) bottom left no-repeat; padding: 0px 0px 5px 0px;}
ul.subMenu li.subMenuHidden ul.subsubMenu {display: none;}

ul.subsubMenu {list-style-type: none; display: block;}
ul.subsubMenu li {margin: 2px 5px 0px 5px;}
ul.subsubMenu li a
{	display: block;
	position: relative;
	width: 130px;
	height: 15px;
	padding: 0px;
	background: url(resources/subsubGenericNormal.gif) top left no-repeat;
	font-size: 9px;
	color: #333333;
	text-align: center;
	text-decoration: none;
}
ul.subsubMenu li a:hover {background-image: url(resources/subsubGenericHover.gif); text-decoration: none;}
ul.subsubMenu li a.buttonSelected {background-image: url(resources/subsubGenericSelected.gif);}

#footerMenu
{	display: block;
	clear: both;
	float: left; /* disable? */
	width: 98%;
	margin: 60px 0px 10px -10px;
	padding: 4px 1% 4px 1%;
	font-size: 11px;
	color: #505050;
	background-color: #FFFFFF;
	border-top: 1px solid #DDDDDD;
}
#footerMenu a {margin: 0px 10px 0px 10px; text-decoration: none; color: #333333;}
#footerMenu a:hover {text-decoration: underline;}

#legalText {width: 130px; margin: 0px 0px 20px 10px; line-height: 12px; font-size: 9px; color: #333333;}

#bsiInfo {width: 130px; margin: 0px 0px 20px 10px;}
#bsiInfo img {width: 130px; height: 81px; margin: 0px 0px 5px 0px;}
#bsiInfo h4 {margin: 0px 0px 0px 0px; font-size: 9px; text-align: center;}

#cogentText
{	float: right;
	height: 19px;
	padding: 4px 0px 0px 30px;
	font-size: 9px;
	line-height: 11px;
	color: #333333;
	background: url(resources/cogentLogo.gif) top left no-repeat;
}
#cogentText a {margin: 0px; color: #000000;}

.newsBox {position: relative; margin: 0px 0px 30px 0px; padding: 0px 10px 0px 10px;}
.sideBoxTop {margin: 0px 0px -2px -6px;}
.sideBoxBottom {margin: -6px 0px 0px -6px;}
.newsBox h3, .newsBox h3 a {text-transform: uppercase; font-size: 13px; line-height: 16px; color: #505050; text-decoration: none;}
.newsBox h3 a:hover {text-decoration: underline;}
.newsBox h5, .newsBox h5 a {font-size: 9px; color: #E71F01; text-decoration: none;}
.newsBox h5 a:hover {text-decoration: underline;}
.newsBox p {font-size: 12px; line-height: 14px; color: #000000; margin: 0px 0px 8px 0px; padding: 0px 0px 6px 0px; border-bottom: 4px solid #DDDDDD;}

.newsItem {padding: 10px 0px 10px 0px;}

.mainBoxTop {margin-left: -10px;}
.mainBoxBottom {float: right; margin-right: -10px;}

.blankBox {height: 455px;}

.graphicText {display: block; margin-bottom: 0px;}
.graphicText span {display: none;}

#headline_strategy {height: 40px; width: 140px; background: url(resources/headline_strategy.gif) top left no-repeat;}
#headline_vision {height: 40px; width: 140px; background: url(resources/headline_vision.gif) top left no-repeat;}

#heading_news {height: 24px; width: 100px; background: url(resources/heading_news.gif) top left no-repeat;}
#heading_press {height: 24px; width: 100px; background: url(resources/heading_press.gif) top left no-repeat;}
#heading_press_release {height: 24px; width: 200px; background: url(resources/heading_press_release.gif) top left no-repeat;}

.noticeBox {border: 1px solid #CCCCCC; padding: 10px 20px 10px 20px; margin: 0px 0px 15px 0px; background-color: #FFFFFF;}

.contentListA {display: block; list-style-image: url(resources/listIcon.gif); list-style-position: outside; margin: 10px 0px 10px 0px;}
.contentListA li {font-size: 12px; font-weight: bold; color: #000000; margin: 0px 0px 0px 24px;}
.contentListA li p {position: relative; top: -3px;}

#contactForm {margin: 0px; padding: 5px; border: 1px solid #CCCCCC; background-color: #EEEEEE;}
#contactForm table {width: 100%; padding: 0px;}
#contactForm table td {padding: 5px;}
.fieldLabel {width: 25%; vertical-align: middle;}
.areaLabel {width: 25%; padding-top: 3px; vertical-align: top;}
.buttonLabel {padding-top: 4px; text-align: left; border-top: 1px solid #CCCCCC;}
.inputField, .textAreaInput
{	width: 100%;
	border-top: 1px solid #333333;
	border-left: 1px solid #333333;
	border-bottom: 1px solid #CCCCCC;
	border-right: 1px solid #CCCCCC;
}
.inputField {height: 20px;}
.formButton
{	float: left;
	width: 60px;
	height: 24px;
	padding-bottom: 2px;
	margin-right: 5px;
	border-top: 1px solid #FFFFFF;
	border-left: 1px solid #FFFFFF;
	border-bottom: 1px solid #333333;
	border-right: 1px solid #333333;
}

	/* START: FEEDBACK DEFINITIONS --------------------------------------------------------------- */

.messageBox, .warningBox
{	float: left;
	position: relative;
	padding: 5px 10px 10px 10px;
	margin-bottom: 10px;
	background-color: #CDCCD4;
	border: 1px solid #262044;
	color: #262044;
}
.messageBox, .warningBox {width: 96%; margin-bottom: 15px; padding: 10px 2% 10px 2%;}
.warningBox {background-color: #ffb2b2; border-color: #FF0000;}
.warningBox * {color: #000000;}

.topLeftCorner, .topRightCorner, .bottomLeftCorner, .bottomRightCorner, .topLeftCornerWithBorder, .topRightCornerWithBorder, .bottomLeftCornerWithBorder, .bottomRightCornerWithBorder {width: 12px; height: 12px; position: absolute;}

.topLeftCorner {top: 0px; left: 0px;}
.topRightCorner {top: 0px; right: 0px;}
.bottomLeftCorner {bottom: 0px; left: 0px;}
.bottomRightCorner {bottom: 0px; right: 0px;}

.topLeftCornerWithBorder {top: -1px; left: -1px;}
.topRightCornerWithBorder {top: -1px; right: -1px;}
.bottomLeftCornerWithBorder {bottom: -1px; left: -1px;}
.bottomRightCornerWithBorder {bottom: -1px; right: -1px;}

	/* END: FEEDBACK DEFINITIONS --------------------------------------------------------------- */

div.siteMap {margin-left: -60px; width: 100%;}
div.siteMap div {display: block; padding-left: 60px; background: url(resources/siteMapBottomLeft.gif) 30px -139px no-repeat;}
div.siteMap div.topNode {display: block; background: url(resources/siteMapBottomLeft.gif) 60px -139px no-repeat;}

.siteMap p {min-width: 146px; margin: 0px 0px 6px 0px; padding: 2px 8px 2px 8px; background-color: #F4F4F4; border: 1px solid #DDDDDD;}
.siteMap p span
{	float: left;
	margin: 4px 6px 0px 0px;
	width: 16px;
	height: 16px;
	font-size: 14px;
	font-weight: bold;
	color: #E71F01;
	text-align: center;
	background-color: #FFFFFF;
	border: 1px solid #E71F01;
}
.siteMap p a {text-transform: capitalize; color: #333333;}

.legalTable {margin: 4px 0px 8px 0px; background-color: #DDDDDD;}
.legalTable th, .legalTable td {padding: 8px; border-bottom: 2px solid #FFFFFF;}
.legalTable td {vertical-align: top;}
.legalTable th {width: 15%; font-weight: bold; border-right: 2px solid #FFFFFF; vertical-align: middle; text-align: left;}

ul.legalList {list-style-type: none; margin-left: 30px;}

.pageImageRight, .pageImageRightClear
{	float: right;
	margin: 5px 0px 10px 10px;
	padding: 0px 0px 20px 20px;
	border-left: 1px solid #DDDDDD;
	border-bottom: 1px solid #DDDDDD;
}
.pageImageRightClear {float: none;}

.pageImageLeft, .pageImageLeftClear
{	float: left;
	margin: 5px 10px 10px 0px;
	padding: 0px 20px 20px 0px;
	border-right: 1px solid #DDDDDD;
	border-bottom: 1px solid #DDDDDD;
}
.pageImageLeftClear {float: none;}

.pageImageCentre
{
	margin: auto;
	margin-top: 10px;
	margin-bottom: 10px;
	padding: 0px 20px 20px 20px;
	border-left: 1px solid #DDDDDD;
	border-right: 1px solid #DDDDDD;
	border-bottom: 1px solid #DDDDDD;
}	

.pageBGImageLeft {float: left; margin: 0px -60px -40px 0px;}
.pageBGImageRight {float: right; margin: 0px 0px -40px -60px;}

.treeMap {width: 100%; margin: 10px 0px 10px 0px;}
.treeMap td {height: 20px; vertical-align: middle; text-align: center; padding: 0px 4px 0px 4px;}
.treeMap td.mapLeftCorner {background: url(resources/siteMapLeft.gif) 60px 0px no-repeat;}
.treeMap td.mapRightCorner {background: url(resources/siteMapRight.gif) -340px 0px no-repeat;}
.treeMap td.mapCentre {background: url(resources/siteMapTop.gif) 50% 0px no-repeat;}
.treeMap td.mapDown {background: url(resources/siteMapCentre.gif) center center repeat-y;}

.treeMap td div {width: 100px; height: 60px; margin: auto; padding: 4px 8px 4px 8px; background-color: #F4F4F4; border: 1px solid #DDDDDD;}
.treeMap td div.topNode {width: 140px; height: auto; padding: 8px 8px 6px 8px;}
.treeMap td div h3 {font-size: 12px;}
.treeMap td div p {font-size: 10px; line-height: 12px;}

.managementTable {width: 100%; margin: 20px 0px 20px 0px;}
.managementTable th, .managementTable td {padding: 8px 1% 8px 1%; vertical-align: top; text-align: left; background-color: #DDDDDD;}
.managementTable th {width: 12%; border-bottom: 2px solid #FFFFFF; border-right: 2px solid #FFFFFF; font-weight: bold;}
.managementTable td {width: 26%; border-bottom: 2px solid #FFFFFF; font-weight: normal;}
.managementTable td.seperator {width: 4%; background-color: #FFFFFF; border: none;}
.managementTable .emptyCell {visibility: hidden;}

#clientTable {width: 100%;}
#clientTable td {vertical-align: middle; padding: 0px 0px 15px 0px;}
#clientTable td img {margin: auto;}

.factSheetTable {width: 100%; margin: 5px 0px 5px 0px; background-color: #DDDDDD;}
.factSheetTable th, .factSheetTable td {padding: 4px 8px 4px 8px; vertical-align: middle; border-bottom: 2px solid #FFFFFF; text-align: left;}
.factSheetTable a {font-weight: bold; color: #333333;}

a.productLink {text-decoration: none;}
a.productLink:hover {text-decoration: none;}
a.productLink img {float: none; margin-bottom: 5px;}
a.productLink span {display: block; text-align: center; font-size: 10px; color: #999999;}

.serviceText {position: absolute; font-size: 10px; line-height: 11px;}
.serviceText.leftTop {top: 28px; left: 10px; width: 200px;}
.serviceText.leftMiddle {top: 118px; left: 10px; width: 130px;}
.serviceText.leftBottom {top: 228px; left: 10px; width: 200px;}
.serviceText.rightTop {top: 28px; left: 460px; width: 200px;}
.serviceText.rightMiddle {top: 118px; left: 530px; width: 130px;}
.serviceText.rightBottom {top: 228px; left: 460px; width: 200px;}
.serviceText p {margin-bottom: 4px;}
.serviceText p strong, .serviceText p a {font-size: 11px;}

