body {
	background: #666 url(../images/pagebg.jpg) 0 0 repeat-x;	
	font-family: arial, helvetica, sans-serif;
	font-size: 12px;
	line-height: 18px;
	color: #555;
	}

/* Base Styles
---------------------------------------------------------------------------------------------------- */

.skipnav { display: none; }
img { border: 0; vertical-align: text-top; }
i, em { font-style: italic; }
b, strong { font-weight: bold; }
a, a:visited { color: #006b4c; text-decoration: underline; }
a:hover { color: #000; text-decoration: underline; }
td,th {text-align: left; vertical-align: top; }
.clearingdiv { clear: both; }

sup { vertical-align: text-top; line-height:1; font-size: 80%; }

.printonly { display: none; }


/* Primary Page Layout
---------------------------------------------------------------------------------------------------- */

.pagewrap {
	background: #666;
	width: 960px;
	margin: 0 auto;
	}
	


/* Site Header, Main Nav, Secondary Nav, and Site Search Box
---------------------------------------------------------------------------------------------------- */
.siteheader {
	position: relative;
	height: 140px;
	background: #666 url(../images/headerbg.jpg) 0 0 repeat-x;
	}
	
	
	.siteheader h1 {
		position: absolute;
		top: 0;
		left: 18px;
		height: 140px;
		width: 185px;
		}
		
		.siteheader h1 a {
			display: block;
			width: 185px;
			height: 140px;
			background: #666 url(../images/tra_logo.jpg) 0 0 no-repeat;
			text-indent: -9999px;
			overflow: auto;
			}

	.mainnav {
		position: absolute;
		top: 80px;
		left: 215px;
		}
		
	.mainnav li { 
		float: left;
		display: inline;
		line-height: 60px;
		}
	
	.mainnav li a {
		font-size: 16px;
		line-height: 60px;
		font-weight: normal;
		text-transform: uppercase;
		display: block;
		padding: 0 10px;
		text-decoration: none;
		color: #809f96;
		}

	.mainnav li a:visited { color: #809f96; }
	.mainnav li a:hover { color: #003f2d; }
	
	.homepage #homepage a,
	.ourfirm #ourfirm a,
	.lawyers #lawyers a,
	.practices #practices a,
	.library #library a
		{ color: #003f2d; }

		
	.secondarynav {
		position: absolute;
		top: 44px;
		right:0;
		font-size: 11px;
		}
		
		.secondarynav li {
			float: left;
			display: inline;
			border-right: solid 1px #666;
			}

		.secondarynav li a {
			display: block;
			line-height: 20px;
			color: #ccc;
			padding: 0 10px;
			text-decoration: none;
			}
			
		.secondarynav li a:visited { color: #ccc; }
		.secondarynav li a:hover { color: #fff; }

		.lawyerSearch td { font-size: 11px; font-weight: bold; }

		/* main search box */ 
		
		.secondarynav li#searchbox {
			border: none; 
			}
		.secondarynav li#searchbox input {
			vertical-align: text-bottom;
			border: none;
			}
			.searchContainer {
				position: relative;
				top:0px; left:1px;
				height: 25px;
				min-height: 25px;
				z-index:999;
			}
			
			#searchbox input.txt {
				background: #d9d9d9;
				height: 18px;
				padding: 1px 3px;
				width: 150px;
				}
			
			input.txtSearch {
				border: none;
				position:absolute;
				top:0px;
				border: none;
				background: #d9d9d9;
				padding: 1px 3px;
				width:242px;
				height:18px;
			}
			.txtSearchButton {
				position: absolute;
				left: 242px;
				top: 0px;
			}

				#searchbox input.btn { background: #000; }
				#searchbox input.txt:focus { background: #eee; }
				

/* Page Headers and Bread Crumbs
------------------------------------------------------------ */

.pageheader {
	height: 200px;
	padding: 0 30px;
	background: #006b4b;
	}
	
	.homepage .pageheader { height: 300px; background: url(../images/homepage_bnr.jpg) 0 0 no-repeat; }
	.ourfirm .pageheader { background: url(../images/ourfirm_bnr.jpg) 0 0 no-repeat; }
	.lawyers .pageheader { background: url(../images/lawyers_bnr.jpg) 0 0 no-repeat; }
	.practices .pageheader { background: url(../images/practices_bnr.jpg) 0 0 no-repeat; }
	.library .pageheader { background: url(../images/library_bnr.jpg) 0 0 no-repeat; }
	.news .pageheader { background: url(../images/news_bnr.jpg) 0 0 no-repeat; }
	.events .pageheader { background: url(../images/events_bnr.jpg) 0 0 no-repeat; }
	
	#lvl3 .pageheader { height: 100px; }
	.ourfirm#lvl3 .pageheader { background: url(../images/ourfirm_bnr2.jpg) 0 0 no-repeat; }
	.lawyers#lvl3 .pageheader { background: url(../images/lawyers_bnr2.jpg) 0 0 no-repeat; }
	.practices#lvl3 .pageheader { background: url(../images/practices_bnr2.jpg) 0 0 no-repeat; }
	.library#lvl3 .pageheader { background: url(../images/library_bnr2.jpg) 0 0 no-repeat; }
	.news#lvl3 .pageheader { background: url(../images/news_bnr2.jpg) 0 0 no-repeat; }
	.events#lvl3 .pageheader { background: url(../images/events_bnr2.jpg) 0 0 no-repeat; }
	.legal_privacy#lvl3 .pageheader { background: url(../images/blank_bnr2.jpg) 0 0 no-repeat; }
	
.pageheader .breadcrumbs {
	line-height: 20px;
	font-size: 11px;
	color: #fff;
	width: 600px;
	padding-top: 15px;
	}
	
	.breadcrumbs ul {
		float: left;
		width: 100%;
		}

	.breadcrumbs li {
		float: left;
		display: inline;
		padding-right: 9px;
		margin-right: 6px;
		background: url(../images/breadcrumb_arrow.png) right center no-repeat;
		}
		
		.breadcrumbs li.current { background: none; }
	
	.breadcrumbs a, .breadcrumbs a:visited {
		text-decoration: underline;
		color: #99C4B7;
		}

		.breadcrumbs a:hover {	color: #fff; }

.pageheader h2 {
	text-indent: -9999px;
	font-size: 18px;
	line-height: 24px;
	overflow: auto;
	}
			


/* Footer
------------------------------------------------------------ */

.footer {
	position: relative;
	background: #666 url(../images/footerbg.jpg) 0 0 no-repeat;
	min-height: 70px;
	border-bottom: solid 20px #666;
	z-index:10;
	}
	
.footer .copyright {
	font-size: 11px;
	line-height: 18px;
	color: #fff;
	padding: 25px 0 0 465px;
	}
	
	.footer .copyright a {
		color: #ccc;
		text-decoration: underline;
		border-right: solid 1px #888;
		padding-right: 6px;
		margin-right: 6px;
		}

	.footer .copyright a:visited { color: #ccc; }
	.footer .copyright a:hover { color: #fff; }
		
	.footer .memberof {
		position: absolute;
		top: 12px;
		right: 20px;
		width: 120px;
		height: 58px;
		}
		
	.footer .memberof a {
		display: block;
		width: 120px;
		height: 58px;
		text-indent: -9999px;
		overflow: auto;
		}


/* Main Content Area Styles
------------------------------------------------------------ */

#contentwrap {
	background-color: #fff;
	padding: 50px 20px 30px 30px;
	z-index:500;
	}
	
	.three_column {
		background: #fff url(../images/3colbg.gif) 0 0 repeat-y;
		}
	
	#contentwrap h1 {
		margin: 0 0 18px 220px;
		width: 450px;
		font-size: 20px;
		line-height: 24px;
		font-weight: normal;
		color: #00AD7B;
		}
	
	.subnav {
		float: left;
		display: inline;
		width: 185px;
		}



	.content {
		z-index:500;
		}

	
.practicelist_h1 {
		margin: 0 0 18px 0px;
		font-size: 20px;
		line-height: 24px;
		font-weight: normal;
		color: #00AD7B;
		}
/* home page content layout and styles */

.homepage #contentwrap {
	background: #fff url(../images/homecontentbg.gif) 0 0 repeat-y;
	padding-right: 0;
	padding-top: 0;
	}
	
	.homepage .main {
		float: left;
		width: 500px;
		margin-top: 20px;
		z-index:50;
		}
		
		.homepage .main p {
			font-size: 14px;
			line-height: 21px;
			}
		
	.homepage .sidebar {
		float: right;
		display:inline;
		width: 400px;
		}

.homefeatures .nav {
	float: left;
	display: inline;
	width: 100%;
	background: url(../images/homenewsnavbg.jpg) 0 0 no-repeat;
	margin: 0 0 20px;
	}
	
	.homefeatures .nav li {
		float: left;
		display: inline;
		line-height: 55px;
		border-right: solid 2px #FFF2D4;
		}

		.homefeatures .nav a {
			display: block;
			line-height: 55px;
			padding: 0 20px;
			text-transform: uppercase;
			font-weight: bold;
			text-decoration: none;
			color: #777;
			}
			
			.homefeatures .nav a:hover, .homefeatures .nav li.active a {
				color: #003e2c;
				}
				
			.homefeatures .nav a.active {
				background: #FFF2D4;
				}
			
		.homefeatures #homenews, .homefeatures #homeevents, .homefeatures #homelibrary {
			display: none;
			margin: 0 20px 30px;
			clear: both;
			}
			
		.homefeatures #homenews ul li, 
		.homefeatures #homeevents ul li, 
		.homefeatures #homelibrary ul li {
			margin: 0 0 12px;
			}

		.homefeatures #homenews ul li em, 
		.homefeatures #homeevents ul li em, 
		.homefeatures #homelibrary ul li em {
			text-transform: uppercase;
			font-style: normal;
			font-size: 10px;
			font-weight: bold;
			color: #555;
			}

table.searchSuggest td:hover {
	background-color: #d9d9d9;
}
#searchSuggest {
	position: absolute;
	top: 20px;
	right: -1px;
	background-color: #ffffff;
	width: 211px;
	max-height: 500px;
	display:none;
	border: 1px solid #000000;
	overflow: hidden;
	z-index:1000;
}
table.searchSuggest2 td:hover {
	background-color: #d9d9d9;
}
#searchSuggest2 {
	position: absolute;
	top: 20px;
	left: 0px;
	background-color: #ffffff;
	width: 295px;
	max-height: 500px;
	display:none;
	border: 1px solid #000000;
	overflow: hidden;
}
table.searchTable td {
	font-size: 11px;
	font-weight: bold;
	text-align: center;
	background-color:#d9d9d9;
	vertical-align: middle;
	height: 25px;
	width: 100px;
	border:1px solid #ffffff;	
}
table.searchTable td.active a {
	color: #ffffff;
	text-decoration: underline;
	border:1px solid #ffffff;
}
table.searchTable 				{ border-collapse: collapse; }
table.searchTable td			{ cursor: pointer; }
table.searchTable td.active 	{ background-color: #00583f; color: #ffffff; }
table.searchTable td.active a	{ color: #ffffff; }
table.searchTable td:hover 		{ background-color: #00583f; color: #ffffff; }
table.searchTable td:hover a 	{ color: #ffffff; }

/* one column layout */

.one_column .main {
	width: 650px;
	z-index: 50;
	}


/* threee column layout */

.three_column .content {
	float: right;
	display: inline;
	width: 690px;
	}
	
	.three_column .main {
		float: left;
		display: inline;
		width: 450px;
		}

	.three_column .sidebar {
		float: right;
		display: inline;
		width: 190px;
		margin: 0 0 30px;
		font-size: 11px;
		line-height: 15px;
		}
		
	
/* interior search box */	
.main .searchbox {
	padding: 21px;
	margin: 0 0 30px;
	background: #FFF2D4;
	}
	
	.main .searchbox h2 {
		text-transform: uppercase;
		color: #555;
		margin: 0 0 12px;
		}
	
	.main .searchbox .alphaindex {
		margin: 0 0 12px;
		}
		
		.alphaindex a {
			padding: 5px 4px; 
			}
			
			.alphaindex a:hover { background: #fff; }

	.main .searchbox form {
		}
		
	.main .searchbox form select {
		width: 250px;
		margin: 0 6px 0 0;
		font-size: 11px;
		color: #333;
		}
		
		.library .main .searchbox form select { width: 170px; }
		
		optgroup {
			font-style: normal;
			font-weight: bold;
			padding: 2px 3px;
			margin: 3px;
			border-top: solid 1px #d9d9d9;
			color: #809f96;
			text-transform: uppercase;
			font-size: 10px;
			}
			
		form option {
			padding: 0 0 0 9px;
			text-transform: none;
			font-size: 12px;
			color: #333;
			}


.data {
	margin:0 0 21px 0;
	border-bottom: solid 2px #aaa;
	}

.data td, .data th {
	border-top: solid 1px #ccc;
	padding: 5px 20px 10px 0;
	}			

/* sub navigation */

.subnav ul {
	border-top: dotted 1px #aaa;
	margin: 0 0 30px;
	}
	
	.subnav ul li {
		border-bottom: dotted 1px #aaa;
		font-size: 12px;
		line-height: 15px;
		text-transform: uppercase;
		font-weight: bold;
		}
		
		.subnav ul li a {
			display: block;
			text-decoration: none;
			padding: 6px 20px 6px 2px;
			background: url(../images/subnav_arrow_off.jpg) right center no-repeat;
			color: #999;
			}
			
		.subnav ul li a:hover, .subnav ul li.current a {
			color: #006B4C;
			background-image: url(../images/subnav_arrow_on.jpg);
			}



/* main content area type styles */

.main h2 {
	color: #006b4c;
	margin: 0 0 9px;
	font-size: 13px;
	}
	
.main h3, .subsection h3 {
	font-size: 12px;
	color: #003F2D;
	text-transform: uppercase;
	margin: 0 0 9px;
	}
	
.main h4 {
	font-size: 13px;
	color: #000;
	font-weight:bold;
	margin: 0 0 3px;
	}
	
.main h5 {
	font-size: 13px;
	color: #000;
	font-style: italic;
	font-weight: normal;
	margin: 0 0 3px;
	}
	
.main p {
	margin: 0 0 18px;
	}

p.intro {
	font-size: 15px;
	line-height: 21px;
	color: #003F2D;
	margin: 0 0 21px;
	}

	
.main ul {
	list-style: square outside;
	margin: 0 0 18px 24px;
	}

.main li {
	margin: 0 0 6px;
	}

.main ol {
	list-style: decimal;
	margin: 0 0 18px 24px;
	}


/* search results  */

.searchresults {
	margin: 0 0 30px;
	}
.searchresults p strong {
	color: #00AD7B;
	}

.searchresults table {
	width: 100%;
	border-bottom: solid 2px #dedede;
	text-align: left;
	font-size: 11px;
	line-height: 15px;
	}
	
	.searchresults table td {
		padding: 7px 12px;
		border-bottom: solid 2px #fff;
		}
		
	.searchresults table th {
		padding: 4px 12px;
		border-bottom: solid 2px #fff;
		background: #555;
		color: #fff;
		text-transform: uppercase;
		font-size: 10px;
		}
		
	.odd { background: #eee; }
	
		.name a { font-weight: bold; color: #006b4c !important; }
		
	
/* Lawyer Bio Page */	

.lawyers#lvl3 .subnav { margin-top: 0; }
.lawyers#lvl3 .subnav ul { margin-top: 50px; }
.lawyers#lvl3 .sidebar { margin-top: 50px; }

.portrait {
	margin: ;
	}

	.portrait img {
		border: solid 4px #CEE3DE;
		}

.bio_intro {
	border-bottom: solid 1px #d9d9d9;
	margin: 0 0 12px;
	}
	
	.bio_intro h1 {
		margin: 0 0 0 0 !important;
		}

	.bio_intro h3 {
		margin: 0 0 12px 0 !important;
		padding-bottom: 12px;
		border-bottom: solid 1px #d9d9d9;
		}

	.bio_intro table {
		width: 100%;
		font-size: 11px;
		line-height: 15px;
		margin: 0 0 30px;
		}


/* Main Practices Menu */	

.practicelist, .industrylist {
	margin: 0 0 30px;
	border-bottom: solid 1px #d9d9d9;
}
.practicelist {
	width: 430px;
	float: left;
}
.industrylist {
	width: 200px;
	float: right;
}
	
	.industrylist ul {
		padding: 0;
		margin: 0;
		font-weight: normal;
		list-style: none;
		}
		
	.industrylist ul li {
		border-top: solid 1px #d9d9d9;
		font-size: 14px;
		line-height: 30px;
		padding:0 0 0 7px;
		margin:0;
		}

	
	.practicelist h2 {
		position: relative;
		border-top: solid 1px #d9d9d9;
		font-size: 14px;
		line-height: 30px;
		padding: 0 0 0 30px;
		margin: 0;
		font-weight: normal;
		/*background: #fff url(../images/practicelist_arrow_off.gif) 7px center no-repeat;*/
		}
	.practiceCatTitle {
		position: relative;
		font-size: 14px;
		line-height: 30px;
		font-weight: normal;
	}
	.practiceCatTitle a:hover {
		color: #000;
	}
		
	.practicelist .practicecat {
		position: relative;
		border-top: solid 1px #d9d9d9;
		font-size: 14px;
		line-height: 30px;
		padding: 0 0 0 30px;
		margin: 0;
		font-weight: normal;
		/*background: #fff url(../images/practicelist_arrow_off.gif) 7px center no-repeat;*/
	}
	.practicelist div.arrowContainer {

	}
	.practicelist div.arrow {
		position:relative;
		background: #fff url(../images/practicelist_arrow_off.gif) 7px center no-repeat;
		background-position: 10px 10px;
		margin-left: -40px;
		padding-left: 40px;
		z-index:999;
		}
	
	.practicelist .showhide {
		position: absolute;
		top: 0;
		left:0;
		height: 30px;
		width: 30px;
		}
			
	.showhide a {
		display: block;
		height: 30px;
		width: 30px;
		}


		.practicelist h2.active a {
			color: #00AD7B;
			}
		
		.practicelist h2 a {
			text-decoration: none;
			}
			
		.practicelist ul {
			margin: 0 0 15px 30px;
			list-style: none;
			}
			
			.practicelist ul li {
				margin: 0 0 3px;
				}
	
			li.lvl3 {
				margin-left: 15px !important;
				list-style: circle outside;
				}


/* sidebar type styles */

.sidebar h2 {
	font-size: 11px;
	line-height: 15px;
	color: #006b4c;
	margin: 0 0 9px;
	}

.sidebar h3 {
	font-size: 11px;
	line-height: 15px;
	color: #222;
	margin: 0;
	}

.sidebar p {
	font-size: 11px;
	line-height: 15px;
	margin: 0 0 15px;
	}


.main .subsection {
	margin: 0 0 15px;
	border-bottom: solid 1px #ddd;
	padding-bottom: 5px;
	}

.sidebar .subsection {
	margin: 0 0 30px;
	border-top: solid 1px #bbb;
	padding: 6px 0 0;
	}
	
	.sidebar .subsection h3 {
		font-size: 11px;
		line-height: 15px;
		color: #666;
		text-transform: uppercase;
		margin: 0 0 12px;
		}

	.sidebar .subsection h3 em {
		text-transform: none;
		font-size: 10px;
		}
		
		.sidebar .subsection li {
			margin: 0 0 6px;
			}
			
		.sidebar .relatedcontacts li {
			margin: 0 0 9px;
			}
			
			.relatedcontacts li a { font-weight: bold; }
			
		.emailsignup div {
			margin: 0 0 9px;
			}
			
			.emailsignup label {
				font-size: 10px;
				text-transform: uppercase;
				}
				

.listing {
	border-top: dotted 1px #aaa;
	padding: 9px 3px 1px;
	}
	.listing2 {
		padding: 9px 3px 1px;
	}
	.listing2 h3 {
		text-transform: none;
		font-size: 12px;
		line-height: 18px;
		margin: 0 0 6px;
		font-weight: normal;
		}

	.listing2 .date {
		font-size: 10px;
		text-transform: uppercase;
		margin: 0 0 9px;
		font-weight: bold;
		}
	
	.listing h3 {
		text-transform: none;
		font-size: 12px;
		line-height: 18px;
		margin: 0 0 6px;
		font-weight: normal;
		}

	.listing .date {
		font-size: 10px;
		text-transform: uppercase;
		margin: 0 0 9px;
		font-weight: bold;
		}
		
		.date a {
			border-left: solid 1px #d9d9d9;
			margin-left: 6px;
			padding-left: 6px;
			color: #00AD7B;
			}

	.listing p {
		margin: 0 0 9px;
		}
		
		.listing2 p {
		margin: 0 0 9px;
		}
		

.getdirections {
	text-transform: uppercase;
	font-size: 10px;
	font-weight: bold;
	}

.event_date {
	font-size: 13px;
	line-height: 18px;
	font-weight: bold;
	margin: 0 0 15px;
	}

.event_location {
	font-size: 13px;
	line-height: 18px;
	margin: 0 0 18px;
	padding: 0 0 12px;
	border-bottom: dotted 1px #aaa;
	}
	
.newsboiler {
	border-top: dotted 1px #aaa;
	margin-top: 20px;
	padding-top: 10px;
	}
