
/* RESET */

html, body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, 
fieldset, input, textarea, p, blockquote, th, td { margin: 0; padding: 0; }
fieldset, img, abbr, acronym { border: 0; }
table { border-collapse: collapse; border-spacing: 0; }

/* ---------------------------------------------------------------------------

	STRUCTURE

--------------------------------------------------------------------------- */

body {
	font: small/1.5em "Lucida Grande", "Lucida Sans Unicode", Helvetica, Arial, Verdana, sans-serif;
	color: #333;
	text-align: center;
	background: #f4f4f4 url(../images/bg_body_home.gif) repeat-x 0 0;
}

body.sub {
	background: #f4f4f4 url(../images/bg_body_sub.gif) repeat-x 0 0;
}

#wrapper {
	position: relative;
	margin: 0 auto 25px auto;
	width: 930px;
	text-align: left;
}

#main {
	margin-top: 340px;
}

.sub #main {
	margin-top: 90px;
}

#content {
	float: left;
	width: 580px;
}

body.sub #content {
	float: left;
	width: 615px;
}

#sidebar {
	float: right;
	width: 300px;
}

body.sub #wrapper #main #sidebar {
	float: right;
	width: 280px;
}

#sidebar p.first {
	margin-top: 30px;
}

.box {
	float: left;
	width: 300px;
	min-height: 220px;
	background: #fff;
	margin-right: 10px;
	text-align: right;
}

.box a {
	display: block;
	padding: 8px 10px 0 0;
}

.box2 {
	float: left;
	width: 290px;
	min-height: 180px;
	margin-right: 10px;
	padding: 0 0 0 10px;
}


/* ---------------------------------------------------------------------------
	
	LINKS

--------------------------------------------------------------------------- */

a:link { color: #d30; }
	
a:visited { color: #900; }
	
a:hover { color: #680000; text-decoration: none; }

/* ---------------------------------------------------------------------------
	
	=typography

--------------------------------------------------------------------------- */

h1 {
	width: 400px;
	height: 90px;
	background: url(../images/logo.gif) no-repeat 0 20px;
	text-indent: -9999px;
}

h1 a {
	display: block;
	width: 100%;
	height: 100%;
	text-decoration: none;
}

h2 {
	height: 61px;
	margin-bottom: 25px;
	text-indent: -9999px;
}

h2 a {
	display: block;
	width: 100%;
	height: 100%;
	text-decoration: none;
}

h3 {
	color: #000;
	font-family: "Lucida Grande", "Lucida Sans Unicode", Helvetica, Arial, Verdana, sans-serif;
	font-size: 150%;
	font-weight: normal;
	margin-bottom: 5px;
}

h4 {
	margin-bottom: 25px;
	font-size: 120%;
	font-weight: normal;
	color: #000;
	font-family: Georgia, "Times New Roman", Times, serif;
	font-style: italic;
}

h5 {
	margin-bottom: 15px;
	font-size: 120%;
	color: #000;
}

h6 {
	margin-bottom: 15px;
	font-size: 110%;
	text-transform: uppercase;
	color: #000;
}

p { margin-bottom: 25px; }

p.star {
	background: url(../images/star.gif) 0 4px no-repeat;
	padding: 0 20px 0 30px;
	margin: 0 0 15px 0;
	font-weight: bold;
	line-height: 130%;
}

p.star1line {
	background: url(../images/star.gif) 0 4px no-repeat;
	padding: 5px 0 5px 30px;
	margin: 0 0 15px 0;
	font-weight: bold;
	line-height: 130%;
}

p.nomargin {
	margin: 0;
}

p.caption {
	font-size: 0.9em;
	margin: 3px 0 15px 0;
}

a.linkstar {
	display: block;
	background: url(../images/linkstar.gif) right 8px no-repeat;
	margin: 0 5px 0 0;
	padding: 6px 24px 3px 0;
}

/* ---------------------------------------------------------------------------
	
	=quotes

--------------------------------------------------------------------------- */

.quote {
	clear: both;
	background: #fff url(../images/bg_quote_top.gif) top left no-repeat;
}

blockquote {
	background: url(../images/bg_quote_btm.gif) bottom right no-repeat;
	margin: 20px 0 20px 110px;
	padding: 10px 95px 10px 0;
	color: #ef4223;
	line-height: 1.4em;
	letter-spacing: -0.03em;
	font-size: 160%;
	font-style: italic;
}

blockquote span {
	color: #888;
	text-align: right;
	font-style: normal;
}


/* ---------------------------------------------------------------------------
	
	LISTS

--------------------------------------------------------------------------- */

ul, ol {
	margin: 10px 0 25px 30px;
}

li {
	margin-bottom: 2px;
}

ul.contactlist {
	list-style-type: none;
	padding: 0;
	margin: 5px 0 0 0;
}

ul.contactlist li.phone {
	background: url(../images/icon_phone.gif) center left no-repeat;
	padding: 3px 0 3px 28px;
	margin: 0 0 0 30px;
}

ul.contactlist li.email {
	background: url(../images/icon_email.gif) center left no-repeat;
	padding: 3px 0 3px 28px;
	margin: 0 0 0 30px;
}
/* ---------------------------------------------------------------------------
	
	IMAGES

--------------------------------------------------------------------------- */

#content img.topimage {
	margin: 0 0 30px 0;
	padding: 0;
}

#content img.topimagewc {
	margin: 0 0 10px 0;
	padding: 0;
}

#content img {
	margin: 0;
	padding: 0;
}
	
#content img.large {
	float: none;
	margin: 0 0 5px 0;
}

#content img.flickr {
	padding-bottom: 26px;
	background: #fff url(../img/icon_flickr.gif) no-repeat bottom right;
}

/* ---------------------------------------------------------------------------
	
	=tables

--------------------------------------------------------------------------- */

table {
	margin-bottom: 25px;
	width: 100%;
	border-bottom: 2px solid #000;
}

th { 
	padding-bottom: 12px;
	color: #000; 
	text-transform: uppercase; 
	border-bottom: 2px solid #000;
	text-align: left;
}

td {
	padding: 12px 0;
	border-bottom: 1px solid #9d9d9d;
	vertical-align: top;
}

/* ---------------------------------------------------------------------------
	
	=header

--------------------------------------------------------------------------- */

#quick_contact {
	position: absolute;
	top: 40px;
	right: 0;
	width: 555px;
	text-align: right;
	font-size: 90%;
	font-weight: bold;
	margin: 0;
	padding: 0;
}

#quick_contact a:link, #quick_contact a:visited {
	color: #521;
	text-decoration: underline;
}

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

/* ---------------------------------------------------------------------------
	
	=feature

--------------------------------------------------------------------------- */

/* large "feature" size header */

body.feature {
	background-image: url(../images/pg_bg_large.gif);
}

body.feature #header {
	margin-bottom: 310px;
}

body.feature #nav { 
	top: 351px; 
	background: url(../images/nav_bg_home.gif) no-repeat 0 0;
}

body.feature #content {
	float: left;
	padding-top: 50px;
}

body.feature #sidebar { float: right; }

#feature {
	background-image: url(../images/bg_sketch.gif);
	position: absolute;
	top: 70px;
	left: 00px;
	width: 930px;
	height: 267px;
	background-position: 0 20px;
	background-repeat: no-repeat;
	font-size: 85%;
}

#feature_text {
	background-image: url(../images/feature.gif);
	position: absolute;
	top: 20px;
	left: 0;
	width: 930px;
	height: 267px;
	background-position: 0 20px;
	background-repeat: no-repeat;
	font-size: 85%;
}


#feature h2 {
	position: absolute;
	top: 0;
	left: -9999px;
}

#feature p {
	margin: 60px 0 0 550px;
	color: #fff;
	font-size: 15px;
	background: #a7250e;
	padding: 8px 10px;
}

#feature p strong {
	font-size: 18px;
	font-weight: normal;
}

#feature a { font-weight: bold; }

#feature a:hover { color: #fff; }

#feature p.feature_about {
	margin-bottom: 0;
}


/* ---------------------------------------------------------------------------
	
	=sidebar

--------------------------------------------------------------------------- */

#sidebar h2 {
	margin-bottom: 15px;
}

#sidebar h4 {
	margin-bottom: 5px;
	font-weight: bold;
	font-style: normal;
	color: #000;
	font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
	text-transform: uppercase;
}


/* ---------------------------------------------------------------------------
	
	FOOTER

--------------------------------------------------------------------------- */

#foot_container {
	margin: 0 auto;
	padding: 0 0 20px 0;
	color: #6b6b6b;
	background-color: #161616;
	border-top: 6px solid #EF4223;
}

#foot {
	margin: 0 auto;
	width: 930px;
	font-size: 90%;
	text-align: left;
}

#foot a:link, #foot a:visited {
	color: #eee;
	text-decoration: none;
}

#foot a:hover { 
	color: #ef4223;
	text-decoration: underline;
}

#foot ul {
	float: left;
	width: 800px;
	margin: 0 0 5px 0;
	padding-top: 35px;
	list-style: none;
}

#foot li {
	display: inline;
	margin: 0 2px 0 0;
	padding: 0 4px 0 0;
	background: url(../img/foot_div.gif) no-repeat 100% 50%;
}

#foot li.last {
	margin-right: 0;
	padding-right: 0;
	background-image: none;
}

#foot li.info {
	display: block;
	margin-right: 0;
	padding-right: 0;
	background-image: none;
}

#attitude {
	float: right;
	width: 400px;
	height: 91px;
	font-family: Georgia, "Times New Roman", Times, serif;
	font-style: italic;
	font-size: 12px;
	color: #fff;
	background: url(../img/foot_bg_attitude.gif) no-repeat bottom left;
}

#attitude p {
	padding: 27px 20px 0 25px;
}



/* ---------------------------------------------------------------------------
	
	=misc

--------------------------------------------------------------------------- */
.field-confirm { display: none; }


/* self-clearing floats */

#wrapper:after,
#nav:after,
#highlights_inside:after,
#foot:after,
div.comment_info:after,
#project_listing:after {
	content: "."; 
    display: block; 
    height: 0; 
    clear: both; 
    visibility: hidden;
}
