/* RESET
------------------------------------------------------------------------------------*/
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, 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, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; outline: 0; font-size: 100%; /*font: inherit;*/ vertical-align: baseline; max-width: 100%;}
.container, iframe { max-width: 100%;}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block;}
html, body	{ height:100%; }
a img,:link img,:visited img { border:none }
:focus { outline: 0; }
a  { text-decoration:none !important;} 
a, a:active, a:visited {outline: 0 !important; } /* Firefox */
table { border-collapse: collapse; border-spacing: 0; }
html { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
*, *:before, *:after {  -webkit-box-sizing: inherit; -moz-box-sizing: inherit; box-sizing: inherit; }
.clearFloat::before, .clearFloat::after { display:table; content:"";}
.clearFloat::after	{ clear:both; }
img	{ max-width: 100%; height: auto; width: auto9; /* ie8 */ }

/* PALETTE
------------------------------------------------------------------------------------*/
body { background: #fff; color: #444; }
h1.siteName, a { color: #999; }
.mainContent a	{color: #333;}
a:hover	{ color: #000; } 
.heroRed {color: #801f26;}
.paleBG {color: #e1c9b4;}
.newPaleBG {color: #f0d2af;}


/* FONTS 
------------------------------------------------------------------------------------*/
body {
    font-family:  'Source Sans Pro', 'Open Sans', sans-serif; 
    display: optional;  
    font-size: 18px; 
    font-weight: 300;
}

h1, h2, h3, h4, p{	
	/*max-width: 700px;)*/
}

.homecontent{
	color: #ccc;
}
.homecontent h1	{
    text-align: center;
    margin-top: 65px;
    font-size: 1.8em;
    font-weight: 400;
    color: #fff;
}

h1.pageHeader {
	font-size: 2em;
    font-weight: 400;
    color: #999;
    text-align: left;
    margin-top: 30px;
    margin-bottom: 20px;
}

.page-child h1.pageHeader	{
	margin-top:-10px;
	font-size: 2em;
	color: #801f26;
}
 
.page-child h2 {
	 margin-top: 30px;
	 padding-top: 30px;
	 border-top: 1px solid #e1c9b4;
	 border-top: 1px solid #f0d2af;
}

h2.row-heading {
    margin-top: -10px;
    font-size: 1.3em;
    font-weight: 400;
    color: #666;
}

h2 a {color: #801f26;}

.center h2{
	text-align: center;
}

h3 {
    font-size: 1.2em;
    font-weight: 300;
    margin: 20px auto 8px;
}

.homecontent h4 {
	font-weight: 400;
	text-align: center;
}
h4 a {
	color: #fff;
	padding: 10px 30px;
	border: 1px solid #fff;
	border-radius: 10px;
}
h4 a:hover {
	background-color: #e1c9b4;
	background-color: #f0d2af;
	border: 1px solid #000;
}


p {
	margin-bottom: 20px;
	margin-top:20px;
}
@media only screen and (max-width:768px) and (max-device-width: 1024px) and (orientation: portrait)	{
	h1, h2, h3, h4, p {max-width: 500px;}
	p { text-align: justify;}
	.page-contact .contact p {max-width: 100%; text-align: center;}
}

p.nav_title	{
	font-family: 'Libre Baskerville', serif;
	margin-left:20px;
}

p::-moz-selection { color: white; background: #4b5e81;}
p::selection { color: white; background: #4b5e81; }
em	{font-style:italic;}
strong	{font-weight: 400;}


/* HEADER / NAVIGATION
------------------------------------------------------------------------------------*/

/* container ------------------------------------------------------------*/
.navbar-wrapper {margin-bottom: 20px;}
.container-fluid {}
.navbar {margin-bottom: 0;}
.navbar-default{ background-color: initial;border: 0px;}
.navbar-static-top	{}

/* site title/logo ------------------------------------------------------------*/
.navbar-header	{ width: 100%;}
.navbar-default  .navbar-brand	{/* width: 200px;*/ max-width: 80%}
.navbar-brand, a.header_logo_link {}
.navbar-default a.navbar-brand, a.header_logo_link {  color: BLACK}
.navbar-default a.navbar-brand:hover, a.header_logo_link:hover	{color: #801f26;}

/* navigation ------------------------------------------------------------*/

.navbar-nav	{ 
    float: right; 
    font-family: Oswald, sans-serif; 
    font-weight: 300; 
    text-transform: uppercase;
    font-size: 20px;
}

ul#menu-main-navigation.navbar-nav	{list-style: none;}
ul#menu-main-navigation.navbar-nav>li	{/*display:inline-block; float: left;*/ padding: 10px;}
.navbar-nav	 ul.sub-menu	{text-transform: none;}
.navbar-default .navbar-collapse	{}
.navbar-header .navbar-toggle {display: none;}
/*.navbar-collapse.collapse {display: none !important;} */
.navbar-collapse.collapse.in {display: block !important;}

@media screen and (max-width:768px){
    .navbar-header {margin-right:0px !important;}
    .navbar-header .navbar-toggle{margin-right:0px !important;}
    .navbar-header .navbar-toggle {display:block;}
    #menu-main-navigation {}
    .navbar-header	{ width: 100%; position:absolute; margin-top: 0px; padding-right: 15px;}
    .mobile_view {display:block; }
    .container.mainContent .gallery_main {display:none;}
    #navbar ul {width:100%;}
    .navbar-nav {margin:0px;}
    .navbar-collapse {padding-right:0px;}
    div.mainContent {height:auto!important}
}
@media screen and (min-width:960px){
    .navbar-header .navbar-toggle {display:none!important;}
    #menu-main-navigation{display:block;}
    .current-menu-ancestor > .sub-menu{display:block !important;}
    .current-menu-ancestor > a{color:black !important;}
    .navbar-header	{ width: 44%; position:absolute;}
    .mobile_view{display:none;}
}

.sectionheadertitle {
    margin-bottom: 20px;
    font-size: 2.5em;
    color: #bbb;
}

.navbar-default .navbar-toggle	{background-color: transparent; border-color: #888;    margin-top: -45px;}
.navbar-default .navbar-toggle .icon-bar	{background-color: #888;}

.navbar-default .navbar-toggle:hover	{border-color: #801f26;}
.navbar-default .navbar-toggle:hover	{background-color: #e1c9b4;background-color: #f0d2af;}


/*BIG LINKS ON ALL PAGES */
/*#navbar ul {list-style-type: none;padding: 100px 0px 20px 0;}*/
#navbar ul li {display: block; text-align: left; font-size: 20px; margin: 0px auto 0px; padding-bottom: 0px;border-bottom: 1px solid #000;}
#navbar ul li a:hover	{color: #801f26; /*text-shadow: 1px 1px 5px white;*/text-decoration: none;}

.home .navbar-default .navbar-toggle	{border-color: GREY}
.home .navbar-default .navbar-toggle .icon-bar	{background-color: GREY}

@media screen and (max-width: 768px)	{
    #navbar  ul ul {display: none;text-transform:uppercase;}
    #navbar li:hover > ul {display: block;}
    #navbar ul ul li{border-bottom:0px solid #801f26!important;padding-left:30px;}
	#navbar ul ul {padding: 20px 0px 0px 0;}
	li#menu-item-34 a{margin-left:25px;margin-top: 5px;}
	#navbar ul li:hover{background-color: #e1c9b4;}
}
@media screen and (min-width: 769px)	{
    #navbar{/* display: none!important; */}
}

#navmenu ul ul {
    display: none;
    position: absolute;
    top: 50px;
    float: left;
    margin-left: -20px;
    background: white;
    padding: 15px;
}
#navmenu ul li:hover > ul {
    display: block;
}
#navmenu ul ul li {
    list-style:none;
    text-transform:uppercase;
}

/* MAIN CONTENT
------------------------------------------------------------------------------------*/
div.mainContent	{
	padding: 0 15px 50px;
	min-height: 87%;
}

.row-heading {
    padding-bottom: 10px;
}

div.row	{	
	margin-left: 0;
	margin-right: 0;
}

div.row div	{
   padding-bottom: 30px;
}

span.unem	{
	font-style: normal !important;
}

.wide {display: none;}
.narrow {display:block;}

@media only screen and (min-width: 401px) {
.wide {display: block;}
.narrow {display:none;}
}

/* FOOTER
------------------------------------------------------------------------------------*/
footer {
	text-align: center;
    padding: 45px 20px 50px;
	background-color: #e1c9b4;
	background-color: #c6b19f;
	background-color: #c4ac8f;
	border-top: 1px solid BLACK;
	min-height: 10%;
}

.copyright	{
	text-align:center;
	font-size: .9em;
}

/* HOME
------------------------------------------------------------------------------------*/

.home h2.row-heading {display: none;}

.homeImage	{
    text-align: center;
}

.homeImage img	{
    margin: auto;
}

.homecontent p	{
	color: inherit;
}

.homecontent a	{
	color: #EEE;
}

.homecontent a:hover	{
	text-decoration:underline !important;
	color: #000;
}


div#parent-39 {
	background-image: url('/wp-content/themes/johnstep/images/BlueMountains-3751-1632.jpg');
	background-repeat: no-repeat;
    background-attachment: fixed; 
    background-position: center center;
	-o-background-size: cover;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	background-size: cover;  
	color: #FFF; 
	color: #c4c8c3;
} /* about JS */

div#parent-39 img	{
	border: 1px solid #2a2f29;
}

div#parent-39 h2.posttitle	{
	color: #a7aba6;
}

div#parent-39  a	{
	color: #EEE !important;
}

div#parent-39  a:hover	{
	text-decoration:underline !important;
}

/* ABOUT
------------------------------------------------------------------------------------*/


/* BOOKS
------------------------------------------------------------------------------------*/
body.page-books	{
	background-color: #fdf0e0;
	background-color: #fdf2e0;
	background-color: #fdf6e0;
}

.page-books .child-page .row	{
	border-bottom: 1px solid #e1c9b4;
	padding-top: 24px;
}

.page-books .child-page:last-child .row	{
border-bottom: 0px solid #e1c9b4;
}

p.readMore	{
	text-align: right;
	margin-top: 60px;
}

@media only screen and (min-device-width: 1367px) {
.page-the-optimist {
	background-image:url('/wp-content/themes/johnstep/images/OPTCOVER-fullBG.jpg');
	background-repeat: no-repeat;
    background-attachment: fixed; 
    background-position: center center;
	-o-background-size: cover;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	background-size: cover;  
}
}


/* CONTACT
------------------------------------------------------------------------------------*/
.page-contact .row	{
	background-image: url('/wp-content/themes/johnstep/images/BlueMountains-3751-1632.jpg');
	background-repeat: no-repeat;
    background-attachment: fixed; 
    background-position: center center;
	-o-background-size: cover;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	background-size: cover;   
	min-height: 86%;
}

.page-contact .contact	{
	text-align: center;
	font-size: 1.4em;
	color: #fff;
	margin-top: 35%;
}
@media only screen and (max-device-width: 812px) and (orientation: landscape) 	{
	.page-contact .contact	{margin-top: 25%;}
}
@media only screen and (max-device-width: 1024px) and (orientation: portrait)	{
	.page-contact .contact	{margin-top: 65%;}
}

.page-contact .contact p	{
	max-width: 100%;
	margin-bottom: 50px;
}

.credit	{
    margin-top: 10px;
    font-size: .6em;
    color: #666;
    text-align: center;
    display: none;
}
.page-contact .credit	{
	display: block;
}

.credit a	{color: #999}
.credit a:hover	{color: #fff;}


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

.navbar-collapse
{
	padding-left: 0px!important;
}
.navbar-nav>li>a
{
	    padding-left: 26px;
		padding-top: 15px;
		padding-bottom: 15px;
}
}
@media screen and (min-width:768px){
	.container {
    width:100%;
    max-width:1300px;
    padding-right: 15px;
    padding-left: 15px;
}
}


.customheader_wrapper {
    position: fixed;
    z-index: 10;
    width: 100%;
    top: 0px;
}
.homesticky_wrapper {
    top: 0px;
    display: none;
}
.customheader_wrapper {
    position: relative;
    height: 70px;
    background-color: #7dbdff;
    padding-left: 0px;
    padding-right: 0px;
    margin-bottom: 65px;
}
.down-arrow {
    position: absolute;
    bottom: 70px;
    left: 50%;
    cursor: pointer;
}
.navbar.navbar-default {
    margin-bottom: 0px;
}
.navbar.navbar-default {
    width: 100%;
    background-color: black;
    border-color: black;
}
.navmenu_align {
    /* width: 900px; */
    float: right;
    margin: 0 auto;
    display: block;
}

@media only screen and (min-width:768px) and (max-width: 1110px){
	.navmenu_align { float:right; }
	.navbar-nav { float: right; margin-right:20px; margin-top: 5px !important; }
	.nav>li>a { padding:10px 20px; } 
}
.navbar-default .navbar-nav>li>a {
	color: white;
}
.navbar-default .navbar-nav>li>a:hover {
	color: #c48f4f;
}
.navbar-nav {
	margin-top: 5px;
}
@media only screen and (max-width: 767px) { 
	.navbar-default .navbar-nav>li>a { text-align: center;}
	.navbar.navbar-default { /*position: fixed;*/ top: 0px;}
}
@media only screen and (max-width: 768px) { 
	.navbar.navbar-default { position: fixed; top: 0px;}
	.homefimage {
    margin-top: 50px;
	}
	.home_fullimage {    
    width: 100%;
    height: auto;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    overflow: auto;
    position: relative;
	background-color:#801f26;
	}
}
@media only screen and (max-width: 767px){
	.navmenu_align {width: 100%;}
}
@media (min-width: 768px){
	.navbar-header {float: left;}
	.navbar-toggle {display: none;}
	.navbar-nav {float: left;margin: 0;}
	.banner_title p {position: absolute;}
	.home_fullimage {    
    width: 100%;
    height: 100vh;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    overflow: auto;
    position: relative;
	background-color:#801f26;
}
}
.navbar-toggle {
    position: relative;
    float: right;
    padding: 9px 10px;
    margin-top: 8px;
    margin-right: 15px;
    margin-bottom: 8px;
    background-color: transparent;
    background-image: none;
    border: 1px solid transparent;
    border-radius: 4px;
}
.navbar-nav {
    margin-top: 5px;
}
.banner_title p {
    top: 10px;
    left: 10px;    
    color: #fff;
    z-index: 10000000;
	line-height: 20px;
}

@media only screen and (min-width: 375px) {
	.banner_title p {font-size: x-large;}
}
.navbar.navbar-default {
    margin-bottom: 0px;
}
.navbar.navbar-default {
    width: 100%;
    background-color: black;
    border-color: black;
}
.grid-hide-header {
    position: fixed;
    top: 0;
}

.homecontent {
	padding:30px 0;
}
@media only screen and (min-width: 768px) {
	.homecontent {padding: 30px;}
	.homefimage  {max-height:500px; width:auto;margin-top: 65px;}
	.bookfimg {
	max-height:300px;
	width:auto;
}
}
@media only screen and (max-width:768px) {
	.homefimage { width: 100%; height: auto;}
	.nav_title{margin-top:0!important;}
	.bookfimg {	
	width:100%;
}
}
.child-page{
	padding-top:30px;
}
.posttitle {
	font-size: 1.4em;
    font-weight: bold;
    margin-top: 62px;
}

div#parent-37 h2.posttitle {
margin-top: 18px;
}

.onavbar.navbar-default {
    width: 100%;
    background-color: black;
    border-color: black;
}
.onavbar.navbar-default {
    width: 100%;
    background-color: black;
    border-color: black;
}

@media only screen and (min-width: 768px)	{
	.page-child .fmargin	{ padding-top: 150px;}
}

.page-about .fmargin img	{
	margin-left: -15px;
	margin-top: 20px;
}

#parent-37{
	background-color: #e1c9b4;
	background-color: #f0d2af;
	color: #000;
}


#breadcrumbs, .row-heading
{
	padding-top:20px;
}
#breadcrumbs a, .breadcrumb_last
{
	font-size: .8em;
}

p.reviewer	{
	text-align: right;
	margin-top: -10px;
	margin-bottom: 40px;	
}

/* BOOKS
-----------------------------------*/
div.row  div.openQuotes	{
	width: 78px;
	height: 61px;
	background-image: url('/wp-content/themes/johnstep/images/openQuotes.png');
	margin: 0 0 20px;
	padding-bottom: 0px;	
}
div.reviewsRow	{
	padding-top: 50px;
	margin-top: 50px;
	border-top: 1px solid #e1c9b4;
}
div.row div.reviewer,
div.row div.review_url {
	font-size: .9em;
	text-align: right;
	margin-top: 0;
	padding-bottom: 4px;
}
span.reviewer { font-weight:400;}
span.publication {}
span.publication_date {}
span.review_url {}
.fromTheBook {font-style: italic;}	


/* BUY THE BOOK / BUTTONS
-----------------------------------*/

h3.buyTheBook 	{
	text-align: center;
	color: #801f26;
	margin-top: 30px;
	padding-top: 30px;
	border-top: 1px solid #e1c9b4;
}

p.button	{
	margin: 40px auto 50px;
	line-height: auto;
	text-align: center;
	display: block;
}

a.button {
	padding: 10px 30px;
	border-radius: 10px;
	border: 1px solid #fff; /* for solid backgrounds */
}

.rowText a.button 	{
	border: 1px solid #000;
	color: #000;
}

.rowText a.button 	{
	background-color: #801f26 !important;
	color: #fff;
}

.rowText p.button a.button:hover {
	background-color: #e1c9b4 !important;
	color: #000;
}

.page-books a.button {
	color: #801f26;
	border: 1px solid #801f26; 
	font-weight: 400;
}

.page-books a.button:hover {
	background-color: #e1c9b4;
}

.page-contact a.button {
	color: #fff;
}

.page-contact a.button:hover	{
	background-image: url('/wp-content/themes/johnstep/images/transp/bmBlue-40pc.png');
}


/*
.heroRed {color: #801f26;}
.paleBG {color: #e1c9b4;}
*/