/*---------------------------RESET------------------------------------------*/
* {margin: 0; padding: 0; }
fieldset,img,a img,:link img,:visited img {border: 0;}
address,caption,cite,code,dfn,th,var {font-style: normal;font-weight: normal;}
ol,ul {list-style: none;}
caption,th {text-align: left;}
h1,h2,h3,h4,h5,h6 {font-size: 100%;}
q:before,q:after {content:'';}


/* ------------------------ type selectors ------------------------ */

body {
	background: #e7e7dd url("../images/bg-body.jpg") repeat-x;
	font: 14px/24px "Adelle", Arial, sans-serif;
}
blockquote {
	margin-left: 10px;
	margin-right: 10px;
}
h1 {
	font-size: 1.2em;
	color:#000;
}
h2 {
	font-size: 1.1em;
	color:#000;
}
h3 {
	font-size: 1.0em;
	color:#000;
}
h1 span, h2 span, h3 span {
	display:none;
}
a:link, a:visited {
	color:#1995c9;
	text-decoration: none;
	outline: none;
}
a:hover, a:active {
	color:#1995c9;
	text-decoration: underline;
	outline: none;
}
/* ------------------------ CLASSES ------------------------ */

.clearafter:after {
	clear: both;
	content: "";
	display: block;
	height: 0;
	visibility: hidden;
}
.clear {
	clear: both;
}
div.clear {
	height:.01em;
	overflow: hidden;
}
p.back-to-top {
	text-align: right;
	display: block;
	padding-right: 15px;
	background: url("../images/bullet-back-to-top.jpg") right no-repeat;
}
p.portfolio {
	background-color: #e1e1d5;
	padding: 0 0 10px 10px;
	margin-bottom:-10px;
}
p.validation { background: url("../images/validation.jpg") no-repeat; height: 30px; position: relative;}

p.validation a.xhtml-btn { top: 3px; width:27px; height: 23px; position: absolute; left: 50px;}

p.validation a.css-btn { top: 3px; width:27px; height: 23px; position: absolute; left: 133px;}


img.img-left {
	float: left;
	margin: 2px 10px 10px 0px;
}
img.img-right {
	float: right;
	margin: 5px 0px 10px 10px;
}
img.img-bottom {
	margin-bottom: 10px;
}
p.twenty-pix-right {
	padding-left: 20px;
}
.ir {
text-indent:-99999px;	overflow: hidden;
	height: 0;
}


/* ------------------------ FORM ELEMENTS ------------------------ */

form label {
	font-size: .95em;
}
form br {
	line-height: 0;
	height: 0;
}
input, textarea, select {
	background-color: #fff !important;
	border: 1px solid #fff;
	color: #000;
	width: 250px;
	height: 18px;
	line-height: 18px;
	vertical-align: middle;
	margin-bottom:4px;
	padding: 1px 0 0 4px;
	font-family: "Arial", Helvetica, Trebuchet MS, sans-serif;
	font-size: 1.0em;
}
select {
	width: 150px;
	padding: 0;
}
textarea {
	height: 90px;
	overflow: auto;
}
#contact {
	display: none;
	background:#FFF;
	padding: 25px 25px 50px;
	z-index: 12;
	}
	#contact #hdr-contact { 
		background: blue; 
		height: 20px; 
		position: relative;
                        margin-bottom:25px;
		}
		#contact #hdr-contact a { 
			top:25px; 
			left: 25px; 
			width: 22px; 
			height: 21px;

			}				
		#contact #left-contact { 
					font-size: 0.75em;			
					background: url("../images/contact-bg.png") repeat-y ;
					float: left;
					height: 195px;
					width: 173px;
					padding: 0 20px 0 87px;	
					}			
				#contact #right-contact { 
					background: url("../images/contact-bg.png") repeat-y ;
					padding: 0 20px 0 87px;	
	
					}
				
				#contact #contact-bottom { 
					background: url("../images/contact-bottom.png") no-repeat; 
					height: 77px;
					}




/* ------------------------ submit button form elements ------------------------ */

input.submit, input.submit-contact-main {
	width: 60px;
	height: 20px;
	cursor: pointer;
	padding: 0;
}
input.submit-contact-main {
	margin: 95px 0 0 243px;
} /* defines placement of contact-main submit button */
input.submit-image, input.submit-contact-main { /* REMOVE IF NOT USED */
	background: url("../images/btn-submit.jpg");
	width: 64px;
	height: 20px;
	border: none;
	cursor: pointer;
}
/* ------------------------------- CONTENT FRAMEWORK ------------------------------- */

#bg-img {
	background: url(../images/bg-img.jpg) top center no-repeat;
	width:100%;
}
#wrap {
	background: url(../images/bg-wrap.jpg) top center repeat-y;
	margin: 0 auto;
	width: 960px;
	position: relative;
}
#client-log-in {
	background:url("../images/client-log-in.jpg") top center no-repeat;
	height: 49px;
	position: relative;
}
#client-log-in a {
	left: 769px;
	top: 0px;
	width: 121px;
	display: block;
	height: 28px;
	position: absolute;
}
/* ------------------------ SITE-ID FRAMEWORK ------------------------ */

#site-id {
	position:relative;
	background: url("../images/site-id.jpg") no-repeat;
	height: 72px;
}
#site-id a {
	left: 15px;
	top: 6px;
	width: 371px;
	display: block;
	height: 56px;
	position:absolute;
        text-indent:-99999px;

}
#site-id a span {
	display: none;
}
/* ------------------------ PORTFOLIO FRAMEWORK ------------------------ */

h2#portfolio {
	background: url("../images/portfolio.jpg") no-repeat;
	height: 159px;
	position:relative;
}
h2#portfolio a {
	height: 70px;
	top: 59px;
	width: 868px;
	display: block;
	height: 56px;
	position:absolute;
}
h2#portfolio .btn-up {
	background-image: url("../images/btn-up.jpg");
	left:879px;
	top: 74px;
	width: 29px;
	display: block;
	height: 20px;
	position:absolute;
}
h2#portfolio .btn-up:hover {
	background-position:0 -21px;
	height: 26px;
}
h2#portfolio .btn-dwn {
	background-image: url("../images/btn-dwn.jpg");
	left:912px;
	top: 74px;
	width: 29px;
	display: block;
	height: 20px;
	position:absolute;
}
h2#portfolio .btn-dwn:hover {
	background-position:0 -21px;
	height:26px;
}
#tn-content {
	background-color: #d7d7c8;
	padding: 0 10px;
	float: left;
}
#tn-content .case {
	position: relative;
	float: left;
	padding: 12px 6px;
	margin: 0 auto;
}
#tn-content .case p {
	font-size: 0.88em;
	line-height: 1.13em;
}
#tn-content .case p a {
}
#tn-portfolio-end {
	background: url("../images/tn-portfolio-end.jpg");
	height: 26px;
}
/* ------------------------ ABOUT FRAMEWORK ------------------------ */

#about {
	background: url("../images/about.jpg") no-repeat;
	height: 154px;
	position: relative;
}
#about a {
	height: 70px;
	top: 48px;
	width: 868px;
	display: block;
	height: 56px;
	position:absolute;
	left: -8px;
}
#about .btn-up {
	background-image: url("../images/btn-up.jpg");
	left:879px;
	top: 65px;
	width: 29px;
	display: block;
	height: 24px;
	position:absolute;
}
#about .btn-up:hover {
	background-position:0 -21px;
}
#about .btn-dwn {
	background-image: url("../images/btn-dwn.jpg");
	left:912px;
	top: 65px;
	width: 29px;
	display: block;
	height: 23px;
	position:absolute;
}
#about .btn-dwn:hover {
	background-position:0 -21px;
}

#column-left {
	background: #e3e3d8 url("../images/col-left-inner-wrap.jpg") repeat-y;
	width:539px;
	float:left;
}
#column-left h2#title-michael {
	background: url("../images/title-michael.jpg") no-repeat;
	width: 539px;
	height: 81px;
	position: relative;
	margin: 0 auto;
}
h2#title-michael a.resume-btn { top: 55px; width:27px; height: 23px; position: absolute; left: 440px;}

h2#title-michael a.linked-in { top: 55px; width:27px; height: 23px; position: absolute; left: 474px;}


#column-left #col-left-close-wrap {
	background: url("../images/col-left-close-wrap.gif") no-repeat;
	height: 50px;
	margin-bottom: 20px;
}
#column-left p, #column-left h1, #column-left h2, #column-left h3, #column-left ul, #column-left dl {
	float: left;
	margin: 10px 50px;
}
/* single column list */
	#column-left ul {
	padding-left:5px;
}
#column-left ul li {
	background: url("../images/bullet.jpg") 0px 6px no-repeat;
	padding-left: 10px;
}
/* multi column list */
	#column-left ul {
	padding-left: 5px;
}
#column-left ul li {
	background: url("../images/bullet.jpg") 0px 6px no-repeat;
	padding-left: 10px;
	float: left;
	width: 539px;
	line-height:20px;
}
/* definition list */
	#column-left dl {
	padding-left: 5px;
}
#column-left dl dt {
	font-weight: bold;
	color: #99CC00;
}
#column-left dl dd {
	background:transparent url("../images/bullet.jpg") 0px 6px no-repeat;
	padding-left: 10px;
	margin-left: 5px;
}
#column-right {
	background: #e3e3d8 url("../images/col-right-inner-wrap.jpg") repeat-y;
	width: 421px;
	float:left;
}
#column-right p, #column-right h1, #column-right h2, #column-right h3, #column-right ul, #column-right dl {
	margin: 10px 50px;
}
#column-right form {
	margin-left:0px;
}
/* single column list */
	#column-right ul {
	padding-left:5px;
}
#column-right ul li {
	background:transparent url("../images/bullet.jpg") 0px 6px no-repeat;
	padding-left:10px;
}
/* multi column list */
	#column-right ul {
	padding-left:5px;
}
#column-right ul li {
	background:transparent url("../images/bullet.jpg") 0px 6px no-repeat;
	padding-left:10px;
	float:left;
	width:150px;
	line-height:20px;
}
/* definition list */
	#column-right dl {
	padding-left:5px;
}
#column-right dl dt {
	font-weight:bold;
	color:#99CC00;
}
#column-right dl dd {
	background:transparent url("../images/bullet.jpg") 0px 6px no-repeat;
	padding-left:10px;
	margin-left:5px;
}
#column-right h2#title-testimonials {
	background: url("../images/title-testimonials.jpg") no-repeat;
	width:421px;
	height:81px;
	margin: 0 auto;
}
#column-right #col-right-close-wrap {
	background: url("../images/col-right-close-wrap.gif") no-repeat;
	height:50px;
	margin-bottom: 20px;
}
#col-close-wrap {
	background: url(../images/col-close-wrap.jpg);
	height: 50px;
}
#col-close-wrap-end {
	background: #dedfd3 url(../images/col-close-end.jpg) no-repeat;
	height: 62px;
}
/* ------------------------ header framework ------------------------ */

#header-graphic {
	height:363px;
} /* sets height for all non-flash headers */
body#index #header-graphic {
	background:url("../images/featured.jpg");
}
#header-graphic #header-left {
	width: 390px;
	height: 243px;
	float: left;
	padding: 43px 30px 43px 33px;
	position: relative;
}
#header-left IMG {
	position: absolute;
	z-index:8;
}
#header-left IMG.active {
	z-index:10;
}
#header-left IMG.last-active {
	z-index:9;
}
#header-graphic #header-right {
	position: relative;
	width: 373px;
	height: 243px;
	float: left;
	padding: 87px 0px 32px 50px;
}
#header-graphic #header-right h1 {
	font-size: 28px;
	color: #fff;
	font-weight: bold;
}
#header-graphic #header-right h2 {
	color: #fff;
	line-height: 35px;
	font-size: 18px;
}
#header-graphic #header-right p {
	color: #FFF;
	font-size: 16px;
	margin-top: 10px;
}
#header-graphic #header-right a {
	position: absolute;
	left: 48px;
	display: block;
	top: 282px;
	width: 207px;
	height: 49px;
}
#header-right .quote-btn {
	background-image: url("../images/quote-btn.png");
	top: 65px;
	width: 29px;
	display: block;
	height: 18px;
	position:absolute;
}
#header-right .quote-btn:hover {
	background-position:0 -49px;
}
/* ------------------------ subhead framework ------------------------ */
#subhead {
	height:20px;
} /* sets height for all subheads */
body#index #subhead {
	background:url("../images/subhead-index.jpg");
}
/* ------------------------ subhead framework with varying heights ------------------------ */
#subhead-meet-doc {
	height:55px;
	background:url("../images/subhead-meet-doc.jpg");
}
/* ------------------------ bottom-wrap framework ------------------------ */

#bottom-wrap {
	background:url("../images/bottom-wrap.jpg");
	width:100%;
	height:20px;
	clear:both; /* important */
}
#bg-footer-wrap {
	background:#2c2c2c url("../images/bg-footer-wrap.jpg") top center repeat-x;
	height: 60px;
}
/* ------------------------footer framework ------------------------ */
#footer {
	background:#2c2c2c repeat;
	font-size: 1.00em;
	height: 232px;
}
#footer p {
	font-size:.88em;
	color: #fff;
	margin: 20px 0 10px;
}
#footer a:link, #footer a:visited {
	color:#1995c9;
}
#footer a:hover, #footer a:active {
	color:#1995c9;
}
#footer ul {
	margin-top: 0px;
}
#footer li {
	padding:0 5px 0 7px;
	display: inline;
	border-left: 1px solid #fff;
}
#footer li.first {
	border: none;
}
#footer .container {
	padding-top: 20px;
	margin: 0 auto;
	width: 960px;
}
#footer .mini-column1 {
	background:#2c2c2c repeat-y;
	width: 161px;
	float: left;
}
#footer .mini-column2 {
	background-color:#2c2c2c;
	width: 740px;
	float: left;
	padding-left: 40px;
}
/* ------------------------ NAVIGATION ------------------------ */

#nav {
	height: 28px;
	margin-bottom: 0;
}
#nav, #nav a {
	background-image: url("../images/nav.jpg")
}
#nav li {
	float: left;
	list-style-type: none;
	display:inline;
}
#nav a {
	display: block;
	height: 0;
	overflow: hidden;
	padding-top: 28px;
}
#nav li#nav-01 {
	margin-left: 607px;
}
#nav li#nav-01 a {
	background-position: -608px 0;
	width: 58px;
}
#nav li#nav-02 a {
	background-position: -666px 0;
	width: 84px;
}
#nav li#nav-03 a {
	background-position: -750px 0;
	width: 70px
}
#nav li#nav-04 a {
	background-position: -820px 0;
	width: 60px;
}
#nav li#nav-05 a {
	background-position: -880px 0;
	width: 70px
}
#nav li#nav-01 a:hover {
	background-position:  -608px 28px
}
#nav li#nav-02 a:hover {
	background-position: -666px -28px
}
#nav li#nav-03 a:hover {
	background-position: -750px 28px
}
#nav li#nav-04 a:hover {
	background-position: -820px -28px
}
#nav li#nav-05 a:hover {
	background-position: -880px 28px
}
body#index #nav li#nav-01 a {
	background-position:  -608px -28px
}
body#portfolio #nav li#nav-02 a {
	background-position: 600px -28px
}
body#blog #nav li#nav-03 a {
	background-position: -900px -28px
}
body#contact #nav li#nav-04 a {
	background-position: 800px -28px
}

/* ------------------------ ACCORDION ------------------------ */

