/* v1.0 | 20080212 */

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
	}
	
body {
	line-height: 1.5;
	font-family: Helvetica, Verdana, Arial, sans-serif;
	min-width: 960px;
	}

ol, ul {
	list-style: none;
	}

blockquote, q {
	quotes: none;
	}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
	}

/* remember to define focus styles! */
:focus {
	outline: 0;
	}

/* remember to highlight inserts somehow! */
ins {
	text-decoration: none;
	}

del {
	text-decoration: line-through;
	}

/* tables still need 'cellspacing="0"' in the markup */
table {
	border-collapse: collapse;
	border-spacing: 0;
	}

a {
	color: #369;
	text-decoration: none;
	}

p {
	margin: 0.25em 0 0.75em 0;
	}

a:hover {
	text-decoration: underline;
	}

h1	{
	color: #134;
	font-size: 2em;
	line-height: 1em;
	margin-bottom: 0.5em;
	}

h2 {
	color: #cceaff;
	font-size: 1.5em;
	font-weight: normal;
	line-height: 1em;
	margin-bottom: 0.5em;
	}

h2 strong {
	color: #fff;
	}

h3 {
	color: #369;
	font-size: 1.125em;
	font-weight: normal;
	line-height: 1em;
	margin-bottom: 0.5em;
	}

h3 strong {
	color: #134;
	}

h4 {
	color: #cceaff;
	font-size: 0.875em;
	line-height: 1em;
	margin-bottom: 0.5em;
	}

.hide {
	display: none;
	}

.adr {
	width: 320px;
	line-height: 1.25em;
	float: left;
	}

.tel {
	clear: both;
}

.twelve_pt_type p {
	font-size: 0.75em;
	}

.fourteen_pt_type p {
	font-size: 0.875em;
	}

.white_type {
	color: #fff;
	}

.white_type a {
	color: #cceaff;
	}

.white_type li {
	font-size: 0.75em;
	}

.white_type li a {
	color: #fff;
	}

.white_type ul {
	margin-bottom: 1em;
	}
	
.fieldWithErrors {
	border-color: red;
}

/* ------------------------------ Header ------------------------------ */

#header {
	height: 112px;
	background-image: url('../images/header_bg.png');
	color: #88afca;
	}

#header strong, #header a {
	color: #fff;
	}

#logo {
	width: 960px;
	height: 112px;
	margin: 0 auto 0 auto;
	background-image: url('../images/exempla_logo_dark.png');
	background-repeat: no-repeat;
	}
	
#contact {
	float: right;
	}

#contact p {
	margin: 29px 16px 0 0;
	text-align: right;
	}

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

#navigation {
	height: 64px;
	background-image: url('../images/navigation_bg.png');
	line-height: 1.125em;
	}
	
#navigation ul {
	width: 961px; /*extra 1 pixel for nav border*/
	margin: 0 auto 0 auto;
	}

#navigation li {
	display: inline;
	}

#navigation a, #navigation div {
	width: 127px;
	height: 41px;
	float: left;
	background-image: url('../images/nav_button.png');
	background-repeat: no-repeat;
	display: block;
	border-left: 1px solid #fff;
	padding: 7px 16px 0 16px;
	margin-top: 16px;
	}

#navigation .current {
	background-image: url('../images/nav_button_on.png');	
	}

#navigation .current .nav_title {
	color: #369;
	}

#navigation .current .nav_description {
	color: #134;
	}

.last_nav {
	border-right: 1px solid #fff;
	}

.nav_title {
	font-size: 1.125em;
	font-weight: bold;
	color: #fff;
	}
	
.nav_description {
	font-size: 0.75em;
	color: #cceaff
	}

#navigation a:hover {
	background-image: url('../images/nav_button.png');
	background-position: 0 -48px;
	}


/* ------------------------------ Body ------------------------------ */

.container {
	width: 960px;
	margin: 0 auto 0 auto;
	overflow: auto;
	clear: both;
	}

.one_two_col_bg {
	background-image: url('../images/one_two_col_bg.gif');
	background-repeat: repeat-y;
	background-position: top center;
	}

.two_one_col_bg {
	background-image: url('../images/two_one_col_bg.gif');
	background-repeat: repeat-y;
	background-position: top center;
	}
	
.float_right {
	float: right;
	}

.float_left {
	float: left;
	display: inline;
	}

#top_content {
	background-color: #fff;
	background-image: url('../images/top_content_bg.png');
	background-repeat: repeat-x;
	padding-top: 16px;
	padding-bottom: 16px;
	}

#top_content .container {
/*	margin-top: 16px;
	margin-bottom: 16px;*/
	}

.one_col {
	width: 288px;
	padding: 16px;	
	}

.montage {
	width: 320px;
	padding: 0;
	}

.one_col img {
	float: left;
	padding: 16px;
	}

.two_col {
	width: 640px;
	padding-top: 16px;
	padding-bottom: 16px;
	}

.two_col h1, .two_col h2, .two_col h3, .two_col p {
	padding: 0 16px;		
	}

.two_col img {
	padding: 0;
	}
	
.two_col .one_col {
	width: 320px;
	padding: 0;
	}

.three_col {
	width: 896px;
	padding: 16px;	
	}

.ruby_logo, .rails_logo {
	width: 128px;
	height: 128px;
	background-position: center;
	}

.ruby_logo {
	background-image: url('../images/ruby_logo.png');
	}

.rails_logo {
	background-image: url('../images/rails_logo.png');
	}

.feature {
	border: 1px solid lime;
	}

.feature img {
	width: 640px;
	height: 128px;
	}

div.pull_quote {
	color: #fff;
	font-size: 1.5em;
	text-align: center;
	padding-top: 1em;
	background-image: url('../images/quote_left.gif');
	background-position: top left;
	background-repeat: no-repeat;	
	}

div.pull_quote p {
	padding-bottom: 1em;
	background-image: url('../images/quote_right.gif');
	background-position: bottom right;
	background-repeat: no-repeat;
	}

.weblog_date {
	color: #134;
	}

.weblog_entry {
	width: 100%;
	clear: both;
	border-bottom: 1px solid #134;
	float: left;
	padding-bottom: 16px;
	margin-bottom: 16px;
	}

.weblog_entry.last {
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: 0;	
	}

.weblog_more {
	float: left;
	padding-left: 16px;
	font-size: 0.75em;
	}

.weblog_count {
	float: right;
	padding-right: 16px;
	font-size: 0.75em;
	}

	
/* --------------------------- Contact Form --------------------------- */

#new_contact input.one_col, #new_contact textarea.one_col {
	padding: 2px;
	width: 276px;
	border: 1px solid gray;
	}

#new_contact input.one_col, #new_contact textarea.one_col {
	padding: 2px;
	width: 276px;
	border: 1px solid gray;
	}

#new_contact input.fieldWithErrors, #new_contact textarea.fieldWithErrors {
	border-color: red;
	}	
	
	
/* ------------------------------ Footer ------------------------------ */

#footer {
	width: 960px;
	height: 95px;
	margin: 0 auto 0 auto;
	background-image: url('../images/footer_bg.png');
	text-align: center;
	padding-top: 65px;
	border-top: 6px solid #0F242C;
	}

#buttons {
	width: 960px;
	height: 95px;
	margin: 0 auto 0 auto;
	text-align: center;
	padding-top: 5px;	
}



