/*
Theme Name: The Virtue Proposition
Author: Danny Moore
Author URI: http://www.amplifypublishinggroup.com
Description: This theme is a basic blog based book website.
Version: 1.0
License: ©2024 Danny Moore
Text Domain: virtueproposition
*/

/* =Reset default browser CSS. Based on work by Eric Meyer: http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */

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, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
	border: 0;
	font-family: inherit;
	font-size: 100%;
	font-style: inherit;
	font-weight: inherit;
	margin: 0;
	outline: 0;
	padding: 0;
	vertical-align: baseline;
}
:focus {/* remember to define focus styles! */
	outline: 0;
}
body {
	background: #fff;
	line-height: 1;
}
ol, ul {
	list-style: none;
}
table {/* tables still need 'cellspacing="0"' in the markup */
	border-collapse: separate;
	border-spacing: 0;
}
caption, th, td {
	font-weight: normal;
	text-align: left;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: "";
}
blockquote, q {
	quotes: "" "";
}
a img {
	border: 0;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

/******************** body *******************/

html{ font-size:19px; }

body{
	margin:0px;
	padding:0px;
	width:100%;
	height:100%;
	border:0px;
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	font-size:19px;
	line-height:1.5;
	background:#fff;
	color:#000;
	font-family: "aria-text-g2", sans-serif;
}

img{ border:0px; }

#loader{
    width:100%;
    height:100%;
    z-index:1000000;
    position:fixed;
    top:0;
    left:0;
    background:#000;
}

#loaderin{
    width:6vw;
    min-width:80px;
    height:auto;
    position:absolute;
    top:50%;
    left:50%;
}

#loader svg{
    position:absolute;
    fill:#e4972c;
    animation-duration:2s; 
    animation-iteration-count:infinite; 
    transform-origin:center;
    animation-timing-function:linear;
    animation-name:fr0;
}

@keyframes fr0 { 
  0% { transform:translate(-50%,-50%) rotate(0deg); } 
  100% { transform:translate(-50%,-50%) rotate(359deg); }
}  
#loader svg{ animation-name: fr0; }

hr{
	height:1px;
	border:0px;
	background:rgba(0,0,0,0.1);
	margin:2.2em 0 2.3em 0;
	clear:both;
}

h1, .h1{
	font-size:2em;
	margin:0 0 .65em 0;  
    color:inherit;
    line-height:1.18;
    text-align:center;
    font-family:"baskerville-urw", serif;
}

h2, .h2{
    font-size:1.57em;
    line-height:1.3;
    margin:0 auto 1em;
    color:inherit;
}

h3, .h3{
	font-size:1.5em;
	margin-bottom:1em;
    text-align:center;
    line-height:1.2;
    font-family:"baskerville-urw", serif;
}

h4, .h4{ 
    font-size:1.75em;
    margin:0.3em 0 .35em 0;
    color:#ded8c5;
}

.h5, h5{
    margin:0 0 .4em;
    font-size:1.1875em;
    text-align:center;
    line-height:1.3;
    display:inline-block;
    vertical-align:middle;
    text-transform:uppercase;
    font-family:"baskerville-urw", serif;
    letter-spacing:.05em;
    font-weight:bold;
}

.h6, h6, .h7, h7{
    font-size:1.9em;
    margin:0 0 .6em;
    text-align:center;
}

.h7, h7{
    font-size:1.6em;
    color:#c4487e;
    margin-left:7%;
    margin-right:7%;
}

p{ margin:0 0 .2em; }
em, i{ font-style:italic; }
strong, b{ font-weight:bold; }

a{
	text-decoration:none;
	color:#e4972c;
	transition:.4s color;
}

a:hover{ color:#382520; }

#outside{
	width:100%;
	height:100%;
	display:block;
	position:relative;
	margin:0px;
	padding:0px;
    overflow:hidden;
}

#inside{
	width:100%;
	height:auto;
	margin:0 auto;
	padding:0;
}

#top{
	width:100%;
	height:auto;
	position:fixed;
	z-index:10000;
	clear:both;
	float:left;
    background:#000;
    box-shadow:0 3px 6px rgba(0,0,0,0.15);
}

#navMenuSm{
    z-index:200000;
    position:fixed;
    width:auto;
	display:none;
	height:100%;
	padding:0;
    top:0;
    right:0;
    background:#002033;
}

#content{
	width:100%;
	height:auto;
	padding:0;
	margin:0 auto 0 auto;
	clear:both;
	float:left;
	position:relative;
	z-index:150;
    line-height:0;
}

/******************** insides ********************/

#topinside{
	position:relative;
    display:table;
    padding:.3rem 1.5rem;
    width:calc(100% - 3em);
    transition:.3s padding, .3s width, .3s background;
    line-height:1;
    overflow:hidden;
}

.slid{
    padding:.1em 1em !important;
    width:calc(100% - 2em) !important;
}

/********************* Top ************************/

#title{
	position:relative;
	width:40%;
    display:table-cell;
    vertical-align:middle;
}

.flame{
    width:auto;
    height:4.25em;
    line-height:0;
    margin:0 .5em -.3rem 0;
    vertical-align:middle;
}

.logo{
    width:auto;
    height:1.8em;
    line-height:1;
    vertical-align:middle;
    position:relative;
    top:-.1em;
}

.spacer{
    position:absolute;
    z-index:200;
    top:0;
    left:0;
    width:100%;
    height:100%;
}

#navMenu{
    display:table-cell;
    text-align:right;
    position:relative;
    vertical-align:middle;
    font-style:italic;
    padding-top:.3em;
}

#navMenu div{ display:inline-block; }

.social{
    top:.1em;
	position:relative;
	display:inline-block;
	margin:0 0 0 .6em;
	pointer-events:all;
}

.wp-block-group__inner-container .social{ margin-left:0; }

.social a{
	position:absolute;
	width:100%;
	height:100%;
	z-index:1000;
    top:0;
    left:0;
}

.iconDiv{
	width:1em;
	height:1em;
	margin:0 0 0 .25em;
	position:relative;
	display:inline-block;
	text-align:center;
	cursor:pointer;
}

.iconDiv svg{
	position:absolute;
	left:0;
	top:0;
	width:100%;
	height:100% !important;
}


.iconDiv svg{
	fill:#2acff3;
	transition:.3s fill;
}

.iconDiv:hover svg{
	fill:#c4487e;
}

.wp-block-group__inner-container .iconDiv{
    width:1.3em;
    height:1.3em;
    margin:0 .5em 0 0;
}

/******************** Nav **************************/

#smNavShow{ display:none !important; }

#navMenu .menu, #navMenu ul, #navMenuSm .menu, #navMenuSm ul{
	list-style:none;
	padding:0;
	position:relative;
	z-index:900;
	margin:0 0 0 0;
	display:inline-block;
}

#navMenuSm .menu, #navMenuSm ul{
	width:100%;
	margin:0 0 1em;
	padding:0;
}

#navMenu ul li, #navMenuSm ul li{
	display:inline-block;
	float:none;
	padding:0;
	margin:0;
}

#navMenuSm ul li{
    clear:both;
    float:left;
	height:auto;
}

#navMenu ul li a, #navMenuSm ul li a{
	text-decoration:none;
    color:#fff;
	display:inline-block;
	margin:0 0 0 2em;
	position:relative;
	line-height:1;
	font-size:1.3em;
	transition:.5s color;
    cursor:pointer;
}

#navMenu ul li a:hover, #navMenuSm ul li a:hover, .pove{ color:#e4972c; }

#navMenu .active a, #navMenuSm .active a{ color:#e4972c !important; }

#menucloser{
    width:100%;
    height:.75em;
    margin:1em 0 .8em 1.5em;
    fill:#fff;
    cursor:pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    transition:.5s fill;
}

#menucloser svg{
    height:100%;
    width:auto;
}

#menucloser:hover{ fill:#c4487e; }

/****** sub menu ******/

#navMenu ul ul{
	opacity:0;
	display:none;
	position:absolute;
	z-index:999;
	margin-top:.5em;
	border-radius:0 0 3px 3px;
	width:200px;
	background: rgb(255,255,255);
	background: -moz-linear-gradient(top, #fff 50%, #efefef 100%);
	background: -webkit-linear-gradient(top, #fff 50%,#efefef 100%);
	background: linear-gradient(to bottom, #fff 50%,#efefef 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#efefef',GradientType=0 );
	box-shadow:0 6px 16px rgba(0,0,0,0.2);
}

#navMenu ul ul ul{
	left:200px;
	width:230px;
	margin-top:-2.5em;
}

#navMenu ul ul li{
	clear:both;
	float:left;
	margin:0;
	text-align:left;
	width:100%;
	transition:.5s background;
}

#navMenu ul li ul a{
	font-size:1.25em;
	display:block;
	line-height:1.15;
	font-style:italic;
	padding:.6em .65em .3em .65em;
	width:100%;
}

#navMenu ul li ul a:hover{ color:#000 !important; }	

#navMenu ul ul li:hover{
	background:#fff200;
}

#navMenuSm ul ul{
	opacity:1;
	position:relative;
	display:block;
	margin:0;
	border-radius:0;
	box-shadow:none;
	padding:0;
	backfgound:#ddd;
}

/******************** Main Content *******************/

#mainContent{
	width:100%;
	height:auto;
	margin:0 auto;
	position:relative;
}

#mainText{
	width:100%;
	float:left;
	margin-left:0;
}

.pages{
    background-size:cover;
    background-position:center top;
    display:inline-block;
    width:100%;
}

.pageinside{
    max-width:720px;
    margin:0 auto;
    padding:3em 0;
    text-align:left;
    position:relative;
    line-height:1.5;
}

#mainContent ul, #mainContent ol{
	list-style:none;
	margin:1em 0;
}

#mainContent ol{ list-style:decimal; }

#mainContent ol ol{ list-style:lower-latin; }

#mainContent ul li, #mainContent ol li{
	padding:0 0 .5em 1.75em;
	margin-left:1em;
}

#mainContent ul li{
	text-indent:-1.2em;
	line-height:1.3;
	margin-bottom:.35em;
}

#mainContent ul li:before{
	color:inherit;
	content:'•';
	margin-right:.4em;
	font-size:1.25em;
}

/******************* Bottom **********************/

#bottom{
	width:100%;
	height:auto;
	clear:both;
	float:left;
	padding:1.6em 0;
	position:relative;
    background:#000;
    bottom:0;
}

#bottomInside{
	width:100%;
	margin:0 auto;
	position:relative;
	text-align:center;
}

#copyright{
	width:100%;
	clear:both;
	font-size:.75em;
	line-height:1;
	text-align:center;
    font-style:italic;
	color:#fff;
	margin:0;
}

/******************* Blog Posts *************************/

.blogposts{
    width:100%;
    clear:both;
    font-size:0;
    text-align:center;
}

.blogpost{
    font-size:1rem;
    display:inline-block;
    vertical-align:top;
    width:calc(33% - 3em);
    padding:.75em 1.25em;
    margin:.25em;
    background:#f5f4ee;
    text-align:center;
    transition:.5s background;
}

.blogpost:hover{ background:#ded8c5; }

.blogpost .h3{ 
    text-align:center;
    color:#c4487e !important;
}

.blogpost .descr{
    color:#000;
    text-align:left;
}

.postInfo, .postInfo2{
	display:block;
	margin:0 0 .5em 0;
	color:rgba(0,0,0,.45);
	font-size:.85em;
}

.postInfo2{
	margin:0 0 1em 0;
}

#pagination{
	width:80%;
	text-align:center;
	font-size:1.25em;
}

.pagination, .paginationp, .paginationn{
    display:inline-block;
    margin:0;
    width:1em;
    cursor:pointer;
}
.paginationp{ margin-right:.2em; display:none; }
.paginationn{ margin-left:.2em; }

.pageno{ display:none; }

/***************** reset styles for contat form ****************/

.wpcf7{
    max-width:500px;
    margin-left:auto;
    margin-right:auto;
    text-align:center;
}

label{
	font-size:1em;
	vertical-align:baseline;
    width:100%;
    margin:.8em 0 .1em;
	position:relative;
    color:#000;
    display:none;
}

input, textarea{
	font-family:inherit;
	font-size:1rem;
    border:2px solid #e4972c;
    padding:.5em 1em;
    width:calc(100% - 2em - 4px);
    margin:0 0 .5em;
    text-align:left;
}

textarea{ height:8em; }

::placeholder{ font-style:italic; }

.wpcf7-not-valid-tip{ font-size:1rem; }

.wpcf7-spinner{ position:absolute; }

input[type="submit"], .backToBlog a, .button, input[type="button"], .wp-block-button__link{
	cursor:pointer;
	width:auto !important;
	clear:both;
	border:2px solid #e4972c;
	margin:0 auto;
	padding:.5em 1em;
	line-height:1;
	display:inline-block;
	font-size:1.1em;
	transition:.5s color, .5s border;
	color:#000;
    text-align:center;
    font-family:"baskerville-urw", serif;
    text-transform:uppercase;
    font-weight:bold;
    letter-spacing:.05em;
    background:none;
}

.backToBlog a{
	margin:3em 0 35px 0;
	font-size:1.4em;
	transition:.5s background;
}

#pagination .next, #pagination .prev, .read-more{
	padding:.2em .4em .2em .4em;
	margin:0 .3em;
	font-size:.9em;
	display:inline-block;
	transition:.5s color, .5s background;
	color:#000;
	background:none;
}

.read-more{
	font-size:.85em;
	padding:.25em .8em .25em .8em;
}

#pagination .next:hover, #pagination .prev:hover, .read-more:hover, .wp-block-button__link:hover{
	color:#382520;
    border-color:#382520;
}

input[type="submit"]:hover, .backToBlog a:hover, .button:hover, input[type="button"]:hover{
	color:#382520;
    border-color:#382520;
}


/********************** Press *********************************/

.pressb{
	width:calc(100% - 2em);
	clear:both;
	float:left;
	padding:0;
	transition:.5s border;
    border:1px solid #e4972c;
	display:table;
	margin:.1em 0 .2em 0;
}

.pressl{
	width:20%;
	height:100%;
	display:table-cell;
	vertical-align:middle;
	position:relative;
	padding:.75em 1em;
	border-right:1px solid #e4972c;
    transition:.5s border;
    text-align:center;
}

.pressb:hover, .pressb:hover .pressl{ border-color:#fff; }

.pressl img{
	width:85%;
	height:auto;
    max-height:75px;
    object-fit:contain;
}

.presst{
	width:calc(80% - 1em);
	padding:.75em 1em;
	height:100%;
	display:table-cell;
	vertical-align:middle;
	color:#fff;
    font-style:italic;
}

.presst em, .presst i{ font-style:normal; }

/********************** Buy Now Button ***********************/

.buyNowArea{
	width:100%;
	height:auto;
	text-align:center;
}

.buyNowButtons{
	margin:.5em auto 0;
	width:80%;
	clear:both;
	position:relative;
    text-align:center;
}

.buyNowButton{
    width:29%;
    margin:0 1.5%;
    display:inline-block;
    cursor:pointer;
    position:relative;
    border-radius:.4em;
    overflow:hidden;
    line-height:0;
    background:#e4972c;
    transition:.5s background;
}

.buyNowButton a{
    position:absolute;
    width:100%;
    height:100%;
    z-index:100;
    left:0;
    top:0;
}

.svgcolor1{ transition:.5s fill; fill:#fff; }
.svgcolor2{ transition:.5s fill; fill:#000; }
.svgback{ transition:.5s fill; fill:#e4972c; }

.buyNowButton:hover .svgback{ fill:#382520; }
.buyNowButton:hover{ background:#382520; }

/********************************** 404 *********************************/

.lost{
	margin:6em 0 3em;
	padding:0;
    text-align:center;
}

.lostH{
	font-size:8em;
	margin:0 0 -.2em;
	line-height:1;
}

.lostP{
	margin:0;
}

/********************************* Events Calendar **********************/

.mbecout{ 
	border-width:3px;
	margin:2em 0 2.75em 0;
}
.mbecout, .edate{ border-color:#eee; }
.mbectop, .calendar-day-np, .elocation{ background:#eee; }
.npbut, .mbecbutton, .mbecout .h3, a.mbeca{ color:black; }
.mbeccloseButton svg{ fill:black; }
table.mbeccalendar, .mbeccalendar td{ border-color:#ddd; }
.calendar-day-head th{
	border-bottom-color:#ddd;
	background:#123;
	color:#fff;
}
.calendar-day-head th:last-child{ border-right-color:#ddd; }
.mbcalevent{ background:white; }
.mbeccloseButton{ top:-30px; }

/*************************** Book Covers *************************/

.bookcover{
	width:100%;
	height:auto;
	margin:3% auto -4% auto;
	padding:0 0 7% 0;
	position:relative;
	background:url("images/bookshadow.png") no-repeat;
	background-size:93% 100%;
	background-position:80% top;
}

.coverdiv{
	position:relative;
	width:77%;
	height:auto;
	z-index:1;
	top:0;
	left:10%;
	line-height:0;
	border-radius:3px;
	overflow:hidden;
	border-top:1px solid rgba(0,0,0,0.13);
	border-bottom:1px solid rgba(0,0,0,0.4);
}

.cover{
	position:relative;
	z-index:1;
	width:100%;
	top:0;
	left:0;
	height:100%;
}

.overcover{
	position:absolute;
	top:0;
	left:0;
	z-index:30;
	width:100%;
	height:100%;
	pointer-events:none;
	box-shadow:inset 0 0 2px rgba(0,0,0,0.1);
}

.coverhover{
	position:absolute;
	left:0;
	top:0;
	width:100%;
	height:100%;
	background:rgba(1,2,3,0);
	z-index:10000;
	transition:.5s background;
}

.coverhover:hover{ background:rgba(1,2,3,0.4); }

/*************************** Testimonials ************************/

.testimonials{
	width:100%;
	margin:3em 0 0;
	padding:2.5em 0;
	clear:both;
	float:left;
    background-color:#000;
    display:block;
    text-align:center;
    position:relative;
    color:#fff;
}

.testimonials h1{
    color:#e4972c;
    margin-bottom:1.3em;
}

.testimonialsin{ 
    position:relative; 
    height:100%;
    width:86%;
    margin:0 auto;
}

.testimonial{
	position:absolute;
    top:46%;
    -ms-transform:translateY(-50%);
    transform:translateY(-50%);
    left:0;
    width:100%;
    display:none;
    padding-bottom:2em;
}

.testimonial:first-child{ display:block; }

.testbuttons{
    width:100%;
    clear:both;
    text-align:center;
    position:absolute;
    left:0;
    bottom:0;
}

.testbutton{
    width:.9em;
    height:.9em;
    margin:0 .17em;
    display:inline-block;
    border:1px solid #fff;
    line-height:1;
    position:relative;
    cursor:pointer;
    overflow:hidden;
    border-radius:1em;
}

.testbutton:first-child { opacity:1; }

.tbl{ opacity:0; }
.testbutton:first-child .tbl{ opacity:1; }

.square{
    width:calc(60% - 2px);
    height:calc(60% - 2px);
    position:absolute;
    left:20%;
    top:20%;
    border:1px solid #e4972c;
    border-radius:1em;
}

/******************************* Extras *******************************/

.intext{
	width:32%;
	height:auto;
	margin:.3em 0 .5em 1.5em;
	float:right;
    box-shadow:.1em .1em .3em rgba(0,0,0,0.3);
}

.shadowFrame{
	border:10px solid #fff;
	background:#fff;
	margin-bottom:20px;
	box-shadow:0px 2px 6px rgba(0,0,0,0.3);
}

.wide{
	width:100%;
	margin:0;
	padding:3em 0;
	clear:both;
	float:left;
}

.bcolor{ 
    background:#000;
    color:#fff;
}

.table{ display:table; }

.left, .right, .lft, .rgt{ 
	display:table-cell;
	vertical-align:middle;
}

.rgt{
	width:45%;
    max-width:480px;
	padding-left:5%;
}

.right{
	width:40%;
    max-width:380px;
	padding-left:5%;
}

.clear{
	clear:both;
	height:30px;
}

.firstP{
    width:100%;
    background-color:#000;
    background-size:cover;
    background-position:center top;
    position:relative;
    overflow:hidden;
}

.firstP .pageinside{
    position:relative;
    text-align:center;
    width:100%;
    z-index:5;
    padding:6em 0 1.5em;
    display:table;
    height:100%;
    max-width:1050px;
}

.firstP .left{
    font-size:1.1em;
    color:#fff;
}

.firstP .yellow{
    display:inline-block;
    margin:0 .35em;
}

.firstP .right{ 
    width:40%;
    max-width:none;
	padding-left:0%;
}

.firstP .right .buyNowArea{ 
    max-width:330px;
    margin:0 auto;
}

.firstP h1{ font-size:2.8em; }

.firstP h1 strong{
    font-weight:normal;
    text-decoration:underline;
    text-underline-offset:.18em; 
    text-decoration-thickness:.04em;
}

.firstP .buyNowButtons{ max-width:500px; }

.firstP h3{ margin-bottom:1.8em; }

hr.wp-block-separator, hr{
    max-width:10em;
    margin:2em auto;
    background:none;
    height:1px;
    border-top:0;
    border-bottom:2px solid #e4972c;
}

.text{
    padding-left:5%;
    display:table-cell;
    vertical-align:middle;
    text-align:left;
}

.firstP .text{ padding-top:1em; }

.text p{ margin-bottom:0; }

.text .yellow{
    display:inline-block;
    margin:0;
}

.sidetext{
    width:35%;
    display:table-cell;
    vertical-align:middle;
    box-shadow:3px 4px 6px rgba(0,0,0,0.3);
    background-size:cover;
    background-position:center;
}

.firstP .sidetext{ box-shadow:.1em .1em .34em rgba(0,0,0,0.8); }

.main{
    max-width:720px;
    margin:0 auto;
}

.main p{ text-indent:1.75em; }
.main p:first-of-type{ text-indent:0; }

.buttons{ 
    margin:1em auto 0;
    text-align:center;
}

.buttons .buyNowArea{
    display:inline-block;
    max-width:17em;
    vertical-align:middle;
    position:relative;
    top:-.15em;
}

.center{
    text-align:center;
    max-width:720px;
    margin-left:auto;
    margin-right:auto;
    margin-bottom:1.5em;
}

/********************************** Resized CSS *************************/

@media all and (max-width:1300px){
    .firstP .pageinside{ 
        width:95%;
        margin-left:auto;
        margin-right:auto;
        font-size:1.35vw;
    }
}

@media all and (max-width: 1175px){
    #navMenu ul li a, #navMenuSm ul li a{
        padding:0 .7vw;
        font-size:1.85vw;
    }
    .pageinside{
        margin:0 5%;
        width:90%;
    }
}

@media all and (max-width:950px){
    #navMenu .menu{ display:none; }
	#smNavShow{ 
		display:inline-block !important; 
		width:1.4em;
        fill:#2acff3;
		margin:0 0 0;
		cursor:pointer;
		position:relative;
		z-index:1100;
        transition:.5s fill;
	}
    #smNavShow:hover{ fill:#c4487e; }
    #smNavShow svg{
        width:100%;
        height:auto;
    }
	#navMenuSm ul li a{
		padding:.6em 1.2em;
		font-size:1.25em;
		height:auto;
		top:0;
		text-align:left;
        color:#fff;
	}
	#navMenu ul ul{
        opacity:1;
        display:block;
        position:relative;
        margin-top:0;
		margin-bottom:0;
        border-radius:0;
        width:100%;
        background:#000;
        box-shadow:0 0 0 rgba(0,0,0,0);
		padding-top:.8em;
    }
    #navMenu ul ul ul{
        left:auto;
        width:100%;
        margin-top:0;
    }
    #navMenu ul li ul a{
        font-size:1em;
        padding:0 0 .8em 0;
        width:100%;
    }
    #navMenu ul li ul a:hover{ color:#9a1f8b !important; }	
    #navMenu ul ul li a:hover{ color:#fff; }
    .firstP .pageinside{ 
        width:90%;
        margin-left:5%;
        margin-right:5%;
        font-size:.9rem;
        display:block;
    }
    .left, .right, .firstP .right, .firstP .left{
		display:block;
		clear:both;
		float:left;
		width:100%;
		padding:0;
		margin:0 0 1em 0;
	}
}

@media all and (max-width:880px){
    .text, .sidetext{
        display:block;
        clear:both;
        width:90%;
        padding:0;
        margin:0 auto;
    }
    .text{ margin-bottom:1.6em; }
    .text h1, .text .h1{ text-align:center; }
    .sidetext{ 
        min-height:23em;
        max-width:19em;
    }
    .lft, .rgt{ 
        display:block;
        clear:both;
        float:none;
        width:90%;
        padding:0;
        margin:0 auto 1em;
    }
}

@media all and (max-width:500px){
	.intext{
		width:90%;
		float:left;
		margin:0 0 1em 3%;
	}
}