*
{
	margin: 0;
	padding: 0;
}

h1,h2,h3,h4,h5
{
	font-family: "Lucida Grande", "Lucida Sans Unicode", Lucida, Verdana, Arial, Helvetica, sans-serif;
	letter-spacing: -1px;
}

h1 a
{
	float: left;
	display: block;
	text-indent: -9999px;
	background: url(/_images/_page_design/logo.jpg) no-repeat top left;
	width: 187px;
	height: 87px;
	margin-left: 10px;
	padding-right: 33px;
}

html>body h1 a
{
	margin-left: 25px;
	padding-right: 33px;
}

h2
{
	font-size: 190%;
	color: #3f5364;
	margin: 22px 0 12px 0;
}

h3
{
	color: #222;
	margin: 20px 0 5px 0;
	font-weight: normal;
	font-size: 140%;
}

h3 a
{
	color: #222;
	text-decoration: none;
}

h4
{
	color: #000;
	font-size: 140%;
	font-weight: normal;
	padding: 5px 0;
}

h4 a
{
	text-decoration: none;
	color: #000;
}

h5
{
	color: #5c7986;
	font-size: 110%;
	padding: 5px 0 3px 0;	
}

ul, li
{
	list-style: none;
}

li a
{
	text-decoration: none;
}

li a:hover
{
	text-decoration: underline;
}
 
dl
{
	margin: 0 0 30px 0;
	padding-left: 10px;
	border-left: 2px solid #CCC;
}

dt
{
	float: left;
	width: 5em;
	font-weight: bold;
	margin: 0 0 5px 0;
}

dd
{
	margin: 0 0 5px 6em;
}

dd a
{
	color: #5e768d;
	text-decoration: underline;
}

a
{
	color: #5e768d;
}

p
{
	color: #333;
}

body
{
	text-align: center;
	font-family: "Lucida Sans", Verdana, Helvetica, sans-serif;
	font-size: x-small; /* for IE5/WIN */
	voice-family: "\"}\"";
	voice-family: inherit;
	font-size: small; /* for compliant browsers */
	background: #d8e4ef url(/_images/_page_design/body_background.png) repeat-x top;
}

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

#header
{
	width: 800px;
	float: left;
	background: #d8e4ef url(/_images/_page_design/body_background.png) repeat-x top;
}

/*-----------------------------------------------
-- Navigation Styles 
----------------------------------------------- */

#nav
{
	float: left;
	width: 552px;
}

#nav li
{
	display: inline;
}

#nav li a
{
	display: block;
	float: left;
	height: 87px;
	overflow: auto;
	text-indent: -9999px;
}

#nav #l-services a
{
	width: 133px;
	background: url(/_images/_page_design/nav_services.jpg) no-repeat top left;
}

#nav #l-firms a
{
	width: 113px;
	background: url(/_images/_page_design/nav_firms.jpg) no-repeat top left;
}

#nav #l-about a
{
	width: 153px;
	background: url(/_images/_page_design/nav_about_us.jpg) no-repeat top left;
}

#nav #l-contact a
{
	width: 153px;
	background: url(/_images/_page_design/nav_contact.jpg) no-repeat top left;
}

#services #l-services a,
#firms #l-firms a,
#about #l-about a,
#contact #l-contact a,
#nav #l-services a:hover,
#nav #l-firms a:hover,
#nav #l-about a:hover,
#nav #l-contact a:hover
{
	background-position: bottom left;
}

/*-----------------------------------------------
-- Content Styles 
----------------------------------------------- */

#content 
{
	width: 750px;
	clear: both;
	float: left;
	background: url(/_images/_page_design/container_middle.png) repeat-y;
	padding: 0 25px 0 25px;
}

#content p
{
	line-height: 160%;
	margin: 0 0 15px 0;
}

#quoteContainer
{
	float: left;
	width: 750px;
	background: #d8e4ef url(/_images/_page_design/topDiv_bg.jpg) no-repeat bottom left;
	padding: 0 40px 0px 40px;
}

#quoteContainer .quote
{
	background: url(/_images/_page_design/people_bg.jpg) no-repeat bottom;
	text-align: left; 
	font-size: 190%;
	padding: 70px 50px 15px 20px;
	margin-bottom: 15px;
	width: 750px;
}


/*-----------------------------------------------
-- Main Content Styles 
----------------------------------------------- */

#mainContent
{
	float: left;
	width: 475px;
}

body#firms p, body#contact p
{
	margin: 5px 0 10px 0;
}

img.right
{
	float: right;
	padding: 10px;
}

/*-----------------------------------------------
-- Main Content Styles -- About Us/Employment
----------------------------------------------- */

#about .employment
{
	padding-bottom: 15px;
}

#about .employment .more 
{
	float: right;
}

#about .employment .more a
{
	text-decoration: none;
	background: #e8ecef;	
	border: 1px solid #dee6ee;
	padding: 4px;
}

#about .employment .more a:hover
{
	background: #dee6ee;
	border: 1px solid #dee6ee;
}

#about .employment h3
{
	color: #000;
	font-weight: normal;
}

#about .employment h4 a
{
	color: #5c7986;
	padding: 0 0 5px 0px;
	font-size: 85%;
}


/*-----------------------------------------------
-- Context Content Styles 
----------------------------------------------- */

#contextContent
{
	float: right;
	width: 250px;
	background: #FFF url(/_images/_page_design/contextContent_background.png) repeat-y top left;
	margin-top: 15px;
	padding: 10px 0 5px 15px;
}

#contextContent ul
{
	list-style-type: none;
	padding: 3px 0;
	margin-left: 10px;
}

#contextContent li
{
	background: url(/_images/_page_design/bullets.gif) no-repeat;
	background-position: 0 .4em;
	padding: 0 0 5px .9em;
}

#contextContent li a
{
	color: #000;
}

.allJobs a
{
	color: #5c7986;
	font-size: 90%;
	padding-top: 5px;
	margin-left: 120px;
}

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

#footer
{
	clear: both;
	width: 800px;
	background: url(/_images/_page_design/container_bottom.png) no-repeat top;
}

#footer p
{
	text-align: right;
	color: #444;
	padding: 20px 15px 10px 0;
}

#footer a
{
	text-decoration: none;
}

#footer ul
{
	float: left;
} 

#footer  li 
{
	display: inline;
} 

#footer li a
{
	display: block;
	float: left;
	padding: 20px 10px;
}

/*-----------------------------------------------
-- Checklist Styles 
----------------------------------------------- */

ul.checklist 
{
	border: solid 1px #AAA;
	overflow: hidden;
}

ul.checklist li
{
	background-color: #FFF;
}

ul.checklist li a:hover
{
	color: #888;
	background-color: transparent;
}

ul.checklist li.alt_row
{
	background-color: #F5F5F5;
}

ul.checklist label
{
	border-bottom: solid 1px #FFF; 
	cursor: pointer;
}

ul.checklist label:hover 
{ 
	background: #777; 
	color: #fff; 
}


input[type=button], input[type=submit]{
    background-color:gray;
    border: none;
    color: white;
    padding: 16px 32px;
    text-decoration: none;
    margin: 4px 2px;
    cursor: pointer;
}

input[type=text], textarea {
	border: 1px solid black;
    border-radius: 0px;
    width: 100%;
    padding: 12px 20px;
    margin: 6px 0;
    box-sizing: border-box;
}

input[type=tel], textarea {
	border: 1px solid black;
    border-radius: 0px;
    width: 100%;
    padding: 12px 20px;
    margin: 6px 0;
    box-sizing: border-box;
}

/*-----------------------------------------------
-- sIFR Styles 
----------------------------------------------- */

/* These are standard sIFR styles... do not modify */
/*
.sIFR-flash {
	visibility: visible !important;
	margin: 0;
}

.sIFR-replaced {
	visibility: visible !important;
}

span.sIFR-alternate {
	position: absolute;
	left: 0;
	top: 0;
	width: 0;
	height: 0;
	display: block;
	overflow: hidden;
}
*/
/* These "decoy" styles are used to hide the browser text before it is replaced... the negative-letter spacing in this case is used to make the browser text metrics match up with the sIFR text metrics since the sIFR text in this example is so much narrower... your own settings may vary... any weird sizing issues you may run into are usually fixed by tweaking these decoy styles */
/*
.sIFR-hasFlash h2 {
	visibility: hidden;
	letter-spacing: -9px;
	font-size: 32px;
}

.sIFR-hasFlash h3 {
	visibility: hidden;
	letter-spacing: -9px;
	font-size: 21px;
}
*/