/* MASTER STYLE SHEET

SUPPORTS		========================================================================================================================
Internet Explorer 6.0, 5.5*, 5.0*, IE 5 for Mac
Firefox 1.5, 1.0
Safari
Netscape 8.0, 7.0, 6.0
Opera 8.0, 7.0, 6.0*
* will work but may not display 100% as intended


CONTENTS		========================================================================================================================
SELECTORS (Default Values)
	Body
	Text
	Headings
	Links
	Images
	Forms
	Tables
	CSS tables
	Lists
	Cursors
	Miscellaneous
CLASSES (Generic Classes)
	Text
IDs (Page-Specific Styling - sorted by directory/page)
	Layout - basic layout for the site


HACKS			========================================================================================================================

IE5, IE6
	html>body
	
IE5
	voice-family: "\"}\"";
	voice-family: inherit;

IE5 for Mac

FIREFOX
	overflow: hidden; - prevents the containing element from collapsing on floated elements

*/





/*
=========================================================================================================================================
SELECTORS (Default Values)
=========================================================================================================================================
*/

/* TEXT			========================================================================================================================*/
body, p, td, textarea, input, select {
	color: #000000;
	font-family: Arial, Helvetica, sans-serif;
	font-family: Verdana, Arial, Helvetica, sans-serif;
	letter-spacing: normal;
	line-height: normal;
	text-align: left;
	word-spacing: normal;
}

/*Text Size*/
body{
	font-size: 0.8em;
}

input, textarea, select {
	font-size: 1em;
}



/* HEADINGS		========================================================================================================================*/
h1 {
	border-bottom: 1px solid #000000;
	font-size: 1.3em;
	font-style: normal;
	font-variant: normal;
	margin-bottom: inherit;
	margin-top: inherit;
	text-transform: none;
	font-family: "Times New Roman", Times, serif;
	letter-spacing: 0.2em;
}

h1:first-child {

}

h2 {
	font-size: 1.2em;
	font-family: "Times New Roman", Times, serif;
	letter-spacing: 0.2em;
}

h3 {
	font-size: 1.1em;
}

h4 {
	font-size: 1em;
	font-family: "Times New Roman", Times, serif;
	letter-spacing: 0.2em;
}

h5 {

}

h6 {

}



/* LINKS		========================================================================================================================*/
a {
	color: #FF9900;
	text-decoration: underline;
}

a:link {

}

a:visited {

}

a:focus {
	color: #CC0000;
	text-decoration: none;
}

a:hover {
	color: #CC0000;
	text-decoration: none;
}

a:active {

}



/* IMAGES		========================================================================================================================*/
img {
	border: 0;
}



/* FORMS		========================================================================================================================*/

form {

}

form * {
	vertical-align: middle;
}

fieldset {

}

legend {

}

label {

}

input {

}

input[type="button"], input[type="submit"], input[type="reset"] { /* styling for non-IE browsers */
	background-color: #CC0000;
	border: none;
	color: #FFFFFF;
	cursor: pointer;
	font-variant: small-caps;
	font-weight: bold;
	text-align: center;
	text-transform: capitalize;
}

input[type="button"]:focus, input[type="submit"]:focus, input[type="reset"]:focus { /* styling for non-IE browsers */
	background-color: #FFFFFF;
	color: #CC0000;
}

input.button  { /* fix for IE */
	background-color: #CC0000;
	border: none;
	color: #FFFFFF;
	cursor: pointer;
	font-variant: small-caps;
	font-weight: bold;
	text-align: center;
	text-transform: capitalize;
}

textarea {
	height: 5.5em;
	width: 99%;
}

select {

}

option {

}

optgroup {

}

button {

}




/* TABLES		========================================================================================================================*/
table {
	border-collapse: collapse;
	empty-cells: show;
	table-layout: auto;
}

td, th {
	border: none;
	margin: 0;
	padding: 0;
	text-align: left;
	vertical-align: top;
}

th {
	vertical-align: middle;
}

caption {
	caption-side: top;
}



/* LISTS		========================================================================================================================*/
ul {
	list-style-image: none;
	list-style-position: outside;
	list-style-type: disc;
}

ol {
	list-style-position: outside;
	list-style-type: decimal;
}



/* CURSORS		========================================================================================================================*/
a[href~="help/"] {
	cursor: help;
}



/* MISC.		========================================================================================================================*/
hr {
	background-color: #000000;
	border: 0;
	font-size: 1em;
	height: 1px;
	margin: 0 auto;
	width: 100%;
}

address {

}

/* quotations */
blockquote {
	
}

q { /* inline quotation */

}

cite { /* citation e.g. name of book or other published source */

}

/* definition lists */
dl {

}

dt {
	font-weight: bold;
}

dd {

}

/* abbreviations, acronymns, definitions */
abbr {

}

acronym {

}

dfn { /* marks the first occurrence of a term */

}

/* programming code */
code {

}

kbd { /* used to signify that the indicated text is to be typed by the user on the keyboard */

}

tt { /* teletype or monospace font */

}

samp {

}

/* editing tags */
del {

}

ins {

}



/*
=========================================================================================================================================
CLASSES
=========================================================================================================================================
*/

/* div.table - CSS-formatted table */
div.table
{
	display: table;
}

div.row
{
	display: table-row;
}

div.cell
{
	display: table-cell;
	vertical-align: top;
}

/* form.frmCM - Content Management form */
form.frmCM div.table
{
	width: 100%;
}

form.frmCM div.table textarea
{
	height: 20em;
}

form.frmCM div.submit
{
	margin: 1em 0;
	text-align: right;
}

form.frmCM div.submit input
{
	margin-left: 1em;
}


/* form.login - Login form */
form.login
{
	width: 30em;
	margin: 0 auto;
	padding-top: 5em;
}

form.login div.table
{
	width: 30em;
}

form.login div.table input
{
	width: 100%;
}

form.login div.submit
{
	text-align: right;
	margin-top: 1em;
}

/* vertical navigation bars */
ul.verticalNav {
	list-style: none;
	padding: 0;
	margin: 0;
	margin-bottom: 1.5em !important;
}

ul.verticalNav li {
	border-top: 1px solid #AAAAAA;
	float: left;
	width: 100%;
}

html>body ul.verticalNav li {
	float: none;
	width: auto;
}

ul.verticalNav li:first-child {
	border-color: #666666;
}

ul.verticalNav a {
	color: #CC0000;
	text-decoration: none;
	display: block;
	padding-left: 20px;
	background: #FFFFFF url(../_images/site/bullet.gif) no-repeat 10px 0.4em;
	position: relative;
}

ul.verticalNav a:focus, ul.verticalNav a:hover {
	background-color: #F6F6F6;
}


/* click-on display text */
dl.dropdown dt {
	cursor: pointer;
	text-decoration: underline;
	background-image: url(../_images/site/icon_plus.gif);
	background-repeat: no-repeat;
	background-position: 0 50%;
	padding-left: 17px;
}

dl.dropdown dt:focus, dl.dropdown dt:hover {
	text-decoration: underline;
	color: #FF9900;
}


/* TEXT			========================================================================================================================*/
.highlight {
	background-color: #FFFF00;
}



/* BOXES			========================================================================================================================*/
/* div.report - for displaying a message to report the successful completion of a task */
div.report {
	margin: 20% 0;
	text-align: center;
}

/* div.error - for displaying error or warning messages */
div.error {
	background-color: #FFFFD5;
	border: 1px solid #CC0000;
	color: #990000;
	margin: 1.5em 0;
	padding: 0.3em;
}

div.error * {
	padding: 0;
	margin: 0;
}



/* LINKS		========================================================================================================================*/

/* a.blockLink - used to make clickable background images - fills containing element with a clickable link area and hides text */
a.blockLink {
	display: block;
	height: 100%;
	overflow: hidden;
	text-decoration: none;
	text-indent: -9999px;
	width: 100%;
}



/* FORMS		========================================================================================================================*/



/* CSS TABLES	========================================================================================================================*/


/* MISC.		========================================================================================================================*/
.hidden {
	display: none;
}




/*
=========================================================================================================================================
IDs
=========================================================================================================================================
*/



/* LAYOUT		========================================================================================================================*/
/* fix for IE: start */
div#container {
	width: 980px; /* width for IE */
	
}

html>body div#container {
	width: auto;
}
/* fix for IE: end */

body {
	margin: 0;
	padding: 0;
}

div#header, div#container, div#footer {
	clear: both;
}

div#container {
	margin: 0 auto;
	max-width: 1024px;
	min-width: 750px;
	min-width: 58.5em;
}

div#centreCol {
	height: 400px;
	min-height: 400px;
}

html>body div#centreCol {
	height: auto;
}

div#leftCol {
	float: left;
	width: 150px;
	min-width: 11.7em;
}

div#header {
	height: 120px;
}

div#content {
	padding: 10px 0 0 50px;
	margin-bottom: 10px;
}

div.leftCol {
	margin-left: 160px;
}

html>body div.leftCol {
	margin-left: 12.48em;
}

div#footer {
	margin-left: 50px;
}



/* /_INCLUDES/HEADER.ASP	=============================================================================================================*/
div#header {
	background-image:  url(../_images/site/bg_header.jpg);
	background-repeat: no-repeat;
	background-position: 95% 5px;
	position: relative;
}

img#logoMain {
	position: absolute;
	top: 20px;
	left: 0;
}

div#siteTitle {
	background-image: url(../_images/site/text_site_title.gif);
	background-repeat: no-repeat;
	background-position: left top;
	width: 225px;
	height: 20px;
	position: absolute;
	bottom: 44px;
	right: 25%;
}

div#navBar {
	background-image:  url(../_images/site/bg_navbar_top.gif);
	background-repeat: repeat-x;
	background-position: 200px 0;
	background-color: #9898C8;
	height: 30px; /* IE5 & IE6 */
	margin-left: 50px;
	margin-top: -30px;
	position: relative;
	z-index: 5;
}

html>body div#navBar {
	height: 2.34em; /* non-IE browsers */	
}

div#navBarBottom {
	background: url(../_images/site/bg_navbar_bottom.gif) repeat-x right bottom;
	height: 100%;
}

div#mosaic {
	background: url(../_images/site/bg_mosaic.gif);
	position: absolute;
	right: 0;
	top: 0;
	height: 100%;
	width: 200px;
	height: 30px;
}

div#noscript h4 {
	float: left;
	padding-right: 5px;
}
/* Size-to-Content Navigation Dropdown Menu (Vertical) =========================================================================================== */
/* fix for IE5 & IE6: begin */
ul#mainNav li {
	position: relative !important;
}

ul#mainNav li ul {
	position: absolute;
	left: 0;
	top: 30px !important;
}

html>body ul#mainNav li ul {
	top: auto;
}

ul#mainNav li a {
	padding: 0 20px;
	float: left;
}

ul#mainNav li.lastChild {
	border-right: none;
}

html>body ul#mainNav a {
	float: none;
}

ul#mainNav li ul li {
	float: left;
	clear: both;
}

ul#mainNav li ul li a {
	width: 100%;
}

html>body ul#mainNav li ul li a {
	width: auto;
}

.over ul { /* class added using JavaScript */
	display: block !important;
}

/* fix for IE5 & IE6: end */


ul#mainNav {
	padding: 0;
	margin: 0;
	list-style: none;
	white-space: nowrap;
	font-weight: bold;
	font-size: 12px; /* IE browsers */
}

html>body ul#mainNav {
	font-size: 0.9em; /* non-IE browsers */	
}

ul#mainNav * {
	padding: 0;
	margin: 0;
}

ul#mainNav li {
	float: left;
}

ul#mainNav li:focus, ul#mainNav li:hover {
	background: #FFCC00 url(../_images/site/bg_navbar_over_bottom.gif) repeat-x left bottom;
}

ul#mainNav li a:hover { /* fix for IE */
	background: #FFCC00 url(../_images/site/bg_navbar_over.gif) repeat-x left bottom;
}

ul#mainNav li a {
	color: #FFFFFF;
	display: block;
	text-decoration: none;
	padding-top: 0;
	padding-bottom: 0;
	line-height: 30px;
}

html>body ul#mainNav li a {
	float: none;
	padding: 0 1.38em;
	height: 30px; /* DELETE */
	height: 100%;
	line-height: 30px;
}

ul#mainNav li:focus a, ul#mainNav li:hover a {
	background: url(../_images/site/bg_navbar_over_top.gif) repeat-x left top;
}

ul#mainNav li.selected>a:link { /* IE only */
	background: #C3C3DF url(../_images/site/bg_navbar_on.gif) repeat-x left top;
	color: #000000;
}

html>body ul#mainNav li.selected {
	background: #C3C3DF url(../_images/site/bg_navbar_on_top.gif) repeat-x left top;
}

ul#mainNav li.selected > a {
	background: url(../_images/site/bg_navbar_on_bottom.gif) repeat-x left bottom;
	color: #000000;
}

ul#mainNav > li:focus ul, ul#mainNav > li:hover ul {
	display: block;
}

ul#mainNav li ul {
	background-color: #FFFFFF;
	border-top: none;
	list-style: none;
	position: absolute;
}

html>body ul#mainNav li ul {
	display: none;
}

ul#mainNav li ul li {
	border: none;
	border-bottom: 1px solid #999999;
	font-weight: normal;
	width: 16.5em;
}

html>body ul#mainNav li ul li {
	float: none;
}

ul#mainNav li ul li:focus, ul#mainNav li ul li:hover {
	background-image: none;
}

ul#mainNav li ul li a {
	color: #333333;
	padding: 0;
	padding-left: 0.5em;
	height: auto;
	line-height: normal;
	background-image: none !important;
}

ul#mainNav li ul li:focus a:focus, ul#mainNav li ul li a:hover {
	background-image: none;
}

div#leftCol * {
	margin: 0;
}

/* /_INCLUDES/FOOTER.ASP	=============================================================================================================*/
div#footer {
	font-size: 0.9em;
	border-top: 1px solid #000000;
	border-bottom: 1px solid #000000;
	padding: 0.5em 5px;
	margin-bottom: 1em;
}

div#footer * {
	padding: 0;
	margin: 0;
}

div#footer a {
	color: #000000;
	text-decoration: none;
}

div#footer a:focus, div#footer a:hover {
	color: #FF9900;
	text-decoration: underline;
}

div#footer ul {
	list-style: none;
	text-align: center;
}

div#footer ul li {
	display: inline;
}

/* /INDEX.ASP	=============================================================================================================*/
body#home div#content {
	background-image: url(../_images/site/bg_home.jpg);
	background-repeat: no-repeat;
	background-position: 50px 10px;
}

body#home div#centreCol {
	padding-left: 280px;
}


/* /awards/award.asp	=============================================================================================================*/
div.award img {
	float: left;
	margin-right: 10px;
}


/* /COMPANY/CONTACT.ASP	=============================================================================================================*/
body#company dl.contact dt {
	float: left;
	width: 6.24em;
}

body#company dl.contact dd {
	margin-left: 6.24em;
}


/* /_PRACTICE/	=============================================================================================================*/
body.practice div#content {
	background-image: url(../_images/site/bg_practice.jpg);
	background-repeat: no-repeat;
	background-position: 100% 10px;
}

body.practice div#centreCol {
	margin-right: 280px;
}

/* /_PRODUCTS/	=============================================================================================================*/
body#products div#content {
	background-image: url(../_images/site/bg_products.jpg);
	background-repeat: no-repeat;
	background-position: 100% 10px;
}

body#products div#centreCol {
	margin-right: 280px;
}

img#photoProduct {
	float: right;
}

/* /_PRODUCTS/EXAMPLES.ASP	=============================================================================================================*/

div#beforeAfterPhotos {
	margin-top: 1em;
}

div.beforeAfterPhoto {
	width: 33.3%;
	float: left;
	height: 200px;
	min-height: 200px;
	min-height: 14.2em;
}

html>body div.beforeAfterPhoto {
	height: auto;
}

div.beforeAfterPhoto * {
	margin: 0;
	padding: 0;
}

div.beforeAfterPhoto h2 {
	background: #E7E3EF url(../_images/site/bg_beforeafter.gif) no-repeat top right;
	font-size: 0.85em;
	padding: 0.2em 5px;
	font-family: Verdana, Arial, Helvetica, sans-serif;
	letter-spacing: normal;
	margin-bottom: 0.4em;
}

div.beforeAfterPhoto div.content {
	width: 200px;
	min-width: 10em;
	margin: 0 auto;
}

div.beforeAfterPhoto div.link {
	float: right;
	font-size: 0.85em;
	padding-right: 15px;
	padding-top: 0.1em;
}

div.beforeAfterPhoto div.link a {
}

div.beforeAfterPhoto img {
	width: 200px;
}

div.beforeAfterPhoto div.before {
	float: left;
	width: 50%;
}

div.beforeAfterPhoto div.after {
	margin-left: 50%;
}

div.beforeAfterPhoto div.credit {
	font-size: 0.7em;
	text-align: center;
}

div#mainPhoto {
	width: 100%;
	height: 240px;
	min-height: 240px;
	margin-bottom: 1em;
}

html>body div#mainPhoto {
	height: auto;
}

div#mainPhoto div.content {
	width: 420px;
}

div#mainPhoto img {
	width: 420px;
}
