html,body {
	background-color: #fff;
	font-family: "Lato", sans-serif;
	font-size: 16px;
	font-weight: 400;
}
body {
	color: #333;
}
strong {
	font-weight: 700;
}
p {
	line-height: 150%;
	padding-bottom: 20px;
	word-spacing: 0.125em;
}
a {
	color: #369dae;
	text-decoration: none;
}
a:hover {
	color: #333;
}

.content_wrapper {
	margin: 0 auto;
	max-width: 1140px;
	min-width: 375px;
	padding: 0 10px;
	width: 100%;
}
.read_more {
	background-color: #369dae;
	color: #fff;
	display: inline-block;
	font-size: 0.875em;
	letter-spacing: 0.125em;
	margin: 15px 0;
	padding: 18px 30px;
	text-transform: uppercase;
}
.read_more:hover {
	color: #fff;
	background-color: #18707e;
}
.read_more_wrapper {
	text-align: center;
}

.mobile_cover {
	display: none;
	max-width: 375px;
	height: auto;
	margin: 20px auto;
	width: 100%;
}

.aligncenter {
	display: block;
	margin: 15px auto;
}
.alignright {
	float: right;
	margin-left: 20px;
}
.alignleft {
	float: left;
	margin-right: 20px;
}

@media( max-width: 1100px ) {
	.mobile_cover {
		display: block;
	}
}
@media( max-width: 600px ) {
	.alignright,
	.alignleft {
		display: block;
		float: none;
		margin: 15px auto;
	}

}



/* ******************* */
/* header / navigation */
/* ******************* */
.header_wrapper {
	margin: 0 auto;
	max-width: 1150px;
	min-width: 375px;
	padding: 0 10px;
	width: 100%;
}
#site_header {
	display: table;
	margin-top: 50px;
	width: 100%;
}
#logo {
	display: table-cell;
	vertical-align: middle;
	width: auto;
}
#logo img {
	height: auto;
	max-width: 360px;
	width: 100%;
}
#main_menu {
	display: table-cell;
	width: 720px;
}
#main_menu > ul {
	display: table;
	width: 100%;
}
#main_menu > ul > li {
	display: table-cell;
	padding: 10px 6px;
	text-align: center;
	vertical-align: top;
}
#main_menu a {
	color: #333;
	font-size: 0.875em;
	font-weight: 400;
	letter-spacing: 0.063em;
	text-transform: uppercase;
}
#main_menu a:hover {
	color: #0fa1b9;
}

#burger_button {
	display: none;
}
#menu_bg {
	background-color: rgba( 0, 0, 0, 0.5 );
	display: none;
	left: 0;
	height: 100%;
	position: fixed;
	top: 0;
	width: 100%;
}

@media( max-width: 1100px ) {
	#site_header {
		display: block;
	}
	#logo {
		display: block;
		text-align: center;
	}
	#main_menu {
		background-color: #fff;
		display: block;
		left: -300px;
		height: 100%;
		position: fixed;
		top: 0;
		-o-transition: all 0.5s;
		-ms-transition: all 0.5s;
		-moz-transition: all 0.5s;
		-webkit-transition: all 0.5s;
		transition: all 0.5s;
		width: 300px;
		z-index: 9050;
	}
	body.menu_open #main_menu {
		left: 0;
	}

	#main_menu > ul {
		display: block;
	}
	#main_menu > ul > li {
		display: block;
		padding: 10px;
		text-align: left;
	}


	#burger_button {
		background: transparent url('../images/burger_button.png') no-repeat;
		cursor: pointer;
		display: block;
		margin: 15px auto;
		height: 20px;
		width: 28px;
		-o-transition: all 0.25s;
		-ms-transition: all 0.25s;
		-moz-transition: all 0.25s;
		-webkit-transition: all 0.25s;
		transition: all 0.25s;
	}
	body.menu_open #burger_button {
		-o-transform: rotate(90deg);
		-ms-transform: rotate(90deg);
		-moz-transform: rotate(90deg);
		-webkit-transform: rotate(90deg);
		transform: rotate(90deg);
	}

	body.menu_open #menu_bg {
		display: block;
		z-index: 9000;
	}
}

/* ******************* */
/* homepage            */
/* ******************* */
.hp_feature {
	background: #fff url('../images/hp_bg_blind2.jpg') repeat-x;
	margin-top: 50px;
	width: 100%;
}
.hp_feature .inner {
	display: table;
	width: 100%;
}
.hp_feature .inner .feature_content {
	color: #fff;
	display: table-cell;
	padding-top: 120px;
	vertical-align: top;
}
.hp_feature .inner .feature_content h2 {
	font-family: "Prata", serif;
	font-size: 6.25em;
	padding-bottom: 20px;
}
.hp_feature .inner .feature_content p {
	font-size: 1.125em;
	letter-spacing: 0.063em;
}
.hp_feature .inner .feature_image {
	display: table-cell;
	text-align: center;
	vertical-align: top;
	width: 550px;
}
.hp_feature .inner .feature_image img {
	box-shadow: 0 3px 8px rgba( 0, 0, 0, 0.5 );
}

@media ( max-width: 1100px ) {
	.hp_feature {
		padding-top: 50px;
	}
	.hp_feature .inner {
		display: block;
	}
	.hp_feature .inner .feature_content {
		color: #333;
		display: block;
		margin: 0 auto;
		padding-top: 20px;
		text-align: center;
		width: 350px;
	}
	.hp_feature .inner .feature_content h2 {
		margin-top: 60px;
		font-size: 4em;
	}
	.hp_feature .inner .feature_image {
		display: none;
	}
}

.quote_rotation blockquote {
	font-family: "Prata", serif;
	font-size: 2em;
	line-height: 150%;
	text-align: center;
	padding: 60px 0;
}
.quote_rotation blockquote cite {
	font-family: "Lato", sans-serif;
	font-size: 0.5em;
	display: block;
	letter-spacing: 1px;
	text-transform: uppercase;
}

.hp_book_feature {
	color: #fff;
	padding: 80px 0;
}
.hp_book_feature .alignleft {
	margin-right: 100px;
}
.hp_book_feature .alignright {
	margin-left: 100px;
}
.hp_book_feature img {
	box-shadow: 0 3px 6px rgba( 0, 0, 0, 0.5 );
	height: auto;
	width: 300px;
}
.hp_book_feature img:hover {
 -moz-transform: scale(1.1);
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}
.hp_book_feature h3 {
	font-family: "Prata", serif;
	font-size: 3.75em;
	padding-bottom: 30px;
}
.hp_book_feature p {
	font-size: 1.125em;
	line-height: 160%;
}
.book_feature_content {
	padding-top: 30px;
}

@media( max-width: 800px ) {
	.hp_book_feature .alignleft,
	.hp_book_feature .alignright {
		display: block;
		float: none;
		margin-left: 0;
		margin-right: 0;
		text-align: center;
	}
	.book_feature_content {
		margin: 0 auto;
		width: 300px;
	}
}


#hp_footer {
	background-color: #369dae;
	color: #fff;
	padding: 80px 0;
}
#hp_footer .inner {
	display: table;
	width: 100%;
}
.hp_about {
	background: transparent url('../images/author_circle_hp22.png') no-repeat;
	display: table-cell;
	padding: 25px 80px 60px 260px;
	line-height: 140%;
	vertical-align: top;
}
.hp_about a {
	font-weight: 700;
	color: #0d464f;
}
.hp_about a:hover {
	color: #fff;
}
.hp_events {
	display: table-cell;
	vertical-align: top;
	padding-top: 20px;
	width: 350px;
}
.hp_events div.event {
	margin-bottom: 5px;
	padding-bottom: 0;
	font-size: 90%;
}
.hp_events div.event a {
	color:#18707e;
}
.hp_events div.event a:hover {
	color:#b3f1fb;
}
.hp_events div.event time {
	color: #b3f1fb;
	letter-spacing: 1px;
	text-transform: uppercase;
}
#hp_footer .read_more {
	background-color: #18707e;
}
#hp_footer .read_more:hover {
	color: #fff;
	background-color: #0b5561;
}

@media( max-width: 800px ) {
	#hp_footer .inner {
		display: block;
	}
	.hp_about {
		background: transparent url('../images/author_circle_hp22.png') 50% 0 no-repeat;
		display: block;
		margin: 0 auto;
		padding: 250px 10px 10px 10px;
		width: 350px;
	}
	.hp_events {
		display: block;
		padding-top: 25px;
		margin: 0 auto;
		width: 350px;
	}
}



/* ******************* */
/* sub-pages           */
/* ******************* */
.page_wrapper {
	border-bottom: 4px #e5e5e5 solid;
	border-top: 4px #e5e5e5 solid;
	margin-top: 50px;
	padding: 80px 10px;
}
.page_cols {
	display: table;
	width: 100%;
}
.page_cols .col_left {
	display: table-cell;
	padding-right: 60px;
	vertical-align: top;
	width: 335px;
}
.page_cols .col_main {
	display: table-cell;
	vertical-align: top;
}
.page_cols .col_right {
	display: table-cell;
	padding-left: 60px;
	text-align: center;
	vertical-align: top;
	width: 400px;
}
.page_cols .col_right img.cover_image {
	box-shadow: 0 3px 8px rgba( 0, 0, 0, 0.5 );
	display: block;
	height: auto;
	margin-bottom: 30px;
	width: 100%;
}

h1.page_title {
	color: #f38e0c;
	font-family: "Prata", serif;
	font-size: 3.5em;
	line-height: 140%;
	padding-bottom: 20px;
}
body.book h1.page_title {
	font-size: 5.25em;
	line-height: 110%;
}
h2.section_divide {
	border-bottom: 1px #e7e7e7 solid;
	color: 222;
	font-family: "Prata", serif;
	font-size: 2em;
	margin-top: 80px;
	padding-bottom: 15px;
}
body.about-the-author div.col_main p {
	width: 85%;
}

.page_wrapper ul {
	padding-left: 20px;
}
.page_wrapper ul,
.page_wrapper li {
	list-style: none;
	list-style-position: inside;
}
.page_wrapper li {
	background: url('../images/dot.png') no-repeat left 22px;
	padding: 15px 0 10px 14px;
}
.page_wrapper h3 {
	border-bottom: 3px #f7f7f7 solid;
	color: #999;
	font-family: "Prata", serif;
	font-size: 1.65em;
	letter-spacing: 2px;
	padding: 40px 0 15px 0;
}

div.praise {
	margin-top: 80px;
}
.praise h2 {
	background: transparent url('../images/h2_bg.png') 0 50% repeat-x;
	text-align: center;
}
.praise h2 span {
	background-color: #fff;
	color: #999;
	display: inline-block;
	letter-spacing: 3px;
	font-family: "Prata", serif;
	font-size: 1.8em;
	padding: 0 20px;
	position: relative;
	text-transform: uppercase;
}
.praise blockquote {
	background: transparent url('../images/quote_open.png') 0 0 no-repeat;
	color: #000;
	line-height: 160%;
	margin-top: 30px;
	padding-left: 50px;
}
.praise blockquote cite {
	background: transparent url('../images/quote_close.png') 100% 0 no-repeat;
	display: block;
	font-size: 90%;
	margin-top: -15px;
	letter-spacing: 1px;
	padding-top: 35px;
	position: relative;
	text-transform: uppercase;
}

.books_list {
	text-align: center;
}
.books_list .book {
	display: inline-block;
	margin: 30px;
	width: 276px;
}
.books_list .book .cover {
	display: block;
	margin-bottom: 15px;
}
.books_list .book img {
	box-shadow: 0 3px 8px rgba( 0, 0, 0, 0.5 );
	width: 270px;
}
.books_list .book img:hover {
	-moz-transform: scale(1.1);
  	-webkit-transform: scale(1.1);
  	transform: scale(1.1);
}

#buy_links_button {
	cursor: pointer;
	width: 280px;
}
.buy_links {
	color: #fff;
	background-color: #2f8d9d;
	display: none;
	margin-left: -30px;
	margin-top: 18px;
	position: absolute;
	text-align: left;
	width: 280px;
	z-index: 300;
}
#buy_links_button:hover .buy_links {
	display: block;
}
.buy_links a {
	color: #fff;
	display: block;
	font-size: 0.875em;
	padding: 12px 20px;
	text-transform: uppercase;
}
#buy_links a:hover {
	color: #0e5560 !important;
}

@media( max-width: 800px ) {
	.page_cols {
		display: block;
	}
	.page_cols .col_left {
		display: block;
		margin: 0 auto;
		padding-right: 0;
	}
	.page_cols .col_main {
		display: block;
	}
	.page_cols .col_right {
		display: block;
		margin: 0 auto;
		padding-left: 0;
		width: 400px;
	}
	.page_cols .col_right .cover_image {
		height: auto !important;
		margin: 20px auto !important;
		width: 320px !important;
	}
}

@media( max-width: 400px ) {
	.books_list .book {
		display: block;
		margin: 30px auto;
	}
}


/* ******************* */
/* events              */
/* ******************* */
.events_list {
	margin: 0 auto;
	max-width: 800px;
	min-width: 350px;
	width: 100%;
}
.event {
	display: table;
	margin-bottom: 20px;
	width: 100%;
}
.event_date {
	background: transparent url('../images/event_date_bg.png') no-repeat;
	color: #fff;
	display: table-cell;
	text-align: center;
	vertical-align: top;
	width: 91px;
}
.event_month {
	font-size: 0.875em;
	display: block;
	letter-spacing: 0.063em;
	padding-top: 12px;
	text-transform: uppercase;
}
.event_day {
	display: block;
	font-size: 2.625em;
	font-family: "Prata", serif;
	padding-bottom: 30px;
	letter-spacing: 0.125em;
}
.event_details {
	display: table-cell;
	padding-left: 15px;
	vertical-align: top;
	width: auto;
}
.event_details time {
	font-size: 0.875em;
	font-weight: 700;
	display: block;
	letter-spacing: 0.063em;
	padding-bottom: 8px;
	text-transform: uppercase;
}


/* ******************* */
/* blog                */
/* ******************* */
.news article {
	margin-bottom: 30px;
}
.news article h2 {
	font-family: "Prata", serif;
	font-size: 1.5em;
	letter-spacing: 0.063em;
	padding-bottom: 10px;
}
.news article h2 a {
	color: #666;
}
.news article time {
	font-size: 0.875em;
	font-weight: 700;
	display: block;
	letter-spacing: 0.063em;
	padding-bottom: 8px;
	text-transform: uppercase;
}


/* ******************* */
/* contact form        */
/* ******************* */
#contact_form {
	background: #f7f7f7;
	padding-top: 20px;
	text-align: center;
}
#contact_form fieldset {
	display: inline-block;
	text-align: left;
}
#contact_form p {
	padding-bottom: 30px;
}
#contact_form label {
	display: block;
	margin-bottom: 10px;
}
#contact_form input[type="text"],
#contact_form input[type="email"],
#contact_form textarea {
	border: 1px #ccc solid;
	padding: 5px;
	width: 350px;
}
#contact_form textarea {
	height: 100px;
}
#contact_form input[type="submit"] {
	background-color: #369dae;
	border: 0;
	color: #fff;
	display: inline-block;
	font-size: 0.875em;
	letter-spacing: 0.125em;
	margin: 15px 0;
	padding: 18px 30px;
	text-transform: uppercase;
}
#contact_form .error {
	color: #f00;
	display: block;
}

/* ******************* */
/* site footer         */
/* ******************* */
#site_footer {
	color: #a9a9a9;
	font-size: 0.75em;
	padding: 60px 0;
	text-align: center;
	text-transform: uppercase;
}
#site_footer p {
	letter-spacing: 0.063em;
}
