/**********************************************************
// Body
**********************************************************/
html { height: 100%; }
body {
	height: 100%;
	overflow-x: hidden;
	cursor: default;
	display: block;
	}

body *,
body *:before,
body *:after {
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
			box-sizing: border-box;
	}

/**********************************************************
// Body >> WordPress Admin Bar Fix
**********************************************************/
@media
all and (max-width: 600px),
all and (max-device-width: 600px)
{
	#wpadminbar { position: fixed !important; }
}

/**********************************************************
// Body >> Elements
**********************************************************/
a {
	text-decoration: none;
	cursor: pointer;
	}

a:hover img {
	opacity: 0.85;
	-webkit-transition: opacity 0.2s linear;
	   -moz-transition: opacity 0.2s linear;
		-ms-transition: opacity 0.2s linear;
		 -o-transition: opacity 0.2s linear;
			transition: opacity 0.2s linear;
	}

img {
	max-width: 100%;
	height: auto;
	-webkit-backface-visibility: hidden;
	-webkit-transform: translateZ(0);
    -ms-transform: translateZ(0);
    transform: translateZ(0);
	}

hr {
	margin: 25px auto;
	width: 100%;
	max-width: 450px;
	border: 0;
	border-bottom: 1px solid #000;
	}

h1, h2, h3, h4, h5, h6 {
	margin: auto;
	padding: 0;
	font-weight: 400;
	}

h1 { font-size: 30px; line-height: 34px; }
h2 { font-size: 26px; line-height: 30px; }
h3 { font-size: 22px; line-height: 26px; }
h4 { font-size: 18px; line-height: 22px; }
h5 { font-size: 14px; line-height: 18px; }
h6 { font-size: 12px; line-height: 16px; }

/**********************************************************
// Body >> Microstyles
**********************************************************/
.Float-Left  { float: left;  }
.Float-Right { float: right; }

.Hidden { display: none;  }
.Center {
	margin: auto;
	text-align: center;
	}

.CLR       { *zoom: 1; }
.CLR:after { clear: both; }
.CLR:before,
.CLR:after {
	content: " ";
	display: table;
	}

.Grow,
.Shrink,
.Trans {
	-webkit-transition: all 0.2s ease-in-out;
	   -moz-transition: all 0.2s ease-in-out;
		-ms-transition: all 0.2s ease-in-out;
		 -o-transition: all 0.2s ease-in-out;
			transition: all 0.2s ease-in-out;
	}

.Grow:hover {
	opacity: 1;
	transform: scale(1.20);
	}

.Shrink:hover {
	opacity: 1;
	transform: scale(.90);
	}

/**********************************************************
// Body >> Font Styles
**********************************************************/
.Txt-Std {
	margin: auto;
	text-transform: uppercase;
	letter-spacing: 1px;
	}

.Txt-Upper { text-transform: uppercase;  }
.Txt-Lower { text-transform: lowercase;  }
.Txt-Cap   { text-transform: capitalize; }

.Font-Awesome {
	font-family: "FontAweseome", sans-serif;
	font-style: normal;
	font-weight: normal;
	}

.Font-Antonio       { font-family: "Antonio", sans-serif;       }
.Font-Montserrat    { font-family: "Montserrat", sans-serif;    }
.Font-PosteramaText { font-family: "PosteramaText", sans-serif; }
.Font-Town80Text    { font-family: "Town80Text", sans-serif;    }

/**********************************************************
// Gutenberg Post Styles
**********************************************************/
.post p.has-medium-font-size { line-height: 1.5em; }
.post p.has-large-font-size  { line-height: 1.5em; }
.post p.has-huge-font-size   { line-height: 1.5em; }

.post p.has-background {
	padding-left: 10px;
	padding-right: 10px;
	}

.post .alignwide {
    margin-left: -80px;
    margin-right: -80px;
	}

.post .alignfull > img { width: 100vw; }
.post .alignfull {
    margin-left:  calc( -100vw / 2 + 100% / 2 ) !important;
    margin-right: calc( -100vw / 2 + 100% / 2 ) !important;
    max-width: 100vw !important;
    min-width: 100vw !important;
	}

/**********************************************************
// Wrappers
**********************************************************/
#Wrapper-Outer {
	width: 100%;
	height: 100%;
	position: relative;
	z-index: 5000;
	}

#Wrapper-Inner {
	margin: auto;
	width: 100%;
	max-width: 100%;
	min-width: 300px;
	overflow: hidden;
	}

/**********************************************************
// Content
**********************************************************/
.Content {
	margin: auto;
	padding: 40px 10px;
	width: 100%;
	max-width: 1070px;
	min-width: 300px;
	}

.Content-Left {
	width: 100%;
	max-width: 700px;
	float: left;
	}

.Content-Right {
	width: 100%;
	max-width: 300px;
	float: right;
	}

.Content-Full {
	margin: auto;
	width: 100%;
	max-width: 850px;
	}

/**********************************************************
// General Content
**********************************************************/
.aligncenter,
div.aligncenter {
	margin: 15px auto;
	display: block;
	}

.alignnone,
div.alignnone {
	margin: 15px 0;
	display: inline-block;
	}

.alignleft,
div.alignleft {
	margin: 0 15px 15px 0;
	display: block;
	float: left;
	}

.alignright,
div.alignright {
	margin: 0 0 15px 15px;
	display: block;
	float: right;
	}

.sticky-post {
	text-transform: uppercase;
	line-height: 24px;
	font-size: 14px;
	color: #686868;
	display: block;
	}

.bypostauthor > article .fn:after {
	font: normal normal normal 14px/1 FontAwesome;
	content: "\f007";
	position: relative;
	display: none;
	}

.wp-caption { max-width: 100%; }
figcaption.wp-caption-text {
	margin: auto;
	line-height: 18px;
	text-align: center;
	font-style: italic;
	font-size: 15px;
	}

/**********************************************************
// Mobile Navigation
**********************************************************/
.Mobile-Nav {
	width: 200px;
	box-shadow: inset 1px 0 2px rgba(0, 0, 0, 0.2);
	overflow: hidden;
	position: fixed;
	z-index: 9000;
	right: -200px;
	bottom: 0;
	top: 0;
	}

.Mobile-Nav-Outer {
	width: 250px;
	height: 100%;
	overflow-x: hidden;
	overflow-y: scroll;
	}

.Mobile-Nav-Inner {
	width: 200px;
	float: left;
	}

.Mobile-Nav li {
	width: 100%;
	min-height: 20px;
	line-height: 20px;
	border-bottom: 1px solid rgba(0, 0, 0, 0.1);
	}

.Mobile-Nav li ul {
	margin: 0;
	padding: 0;
	border-top: 1px solid rgba(0, 0, 0, 0.1);
	}

.Mobile-Nav li ul li {
	width: 100%;
	min-height: 20px;
	line-height: 20px;
	border-bottom: 1px solid rgba(0, 0, 0, 0.1);
	}

.Mobile-Nav li ul li:last-child { border-bottom: 0; }

.Mobile-Nav a {
	padding: 10px 0 10px 20px;
	display: block;
	-webkit-transition: background 0.1s ease-in-out;
	   -moz-transition: background 0.1s ease-in-out;
	    -ms-transition: background 0.1s ease-in-out;
	     -o-transition: background 0.1s ease-in-out;
	        transition: background 0.1s ease-in-out;
	}

.Mobile-Nav a:hover {
	text-decoration: none;
	background-color: rgba(0, 0, 0, 0.05);
	}

.Mobile-Nav li ul li a { padding-left: 40px; }

.Mobile-Nav-Close {
	width: 100%;
	height: 100%;
	display: none;
	position: fixed;
	z-index: 9999;
	bottom: 0;
	right: 0;
	left: 0;
	top: 0;
	}

/**********************************************************
// Entry >> List Styles
**********************************************************/
.Entry ol, .post ol,
.Entry ul, .post ul {
	margin-left: 20px;
	padding: 10px 0 10px 20px;
	line-height: 22px;
	}

.Entry ol, .post ol { list-style-type: decimal; }
.Entry ul, .post ul { list-style-type: disc; }

/**********************************************************
// Sidebar
**********************************************************/
.Sidebar .widget { margin-top: 60px; }
.Sidebar aside:first-child { margin-top: 0; }

/**********************************************************
// WordPress Gallery
**********************************************************/
.gallery { margin-bottom: 20px; }

.gallery:before,
.gallery:after {
	content: "";
	display: table;
	}

.gallery:after { clear: both; }

.gallery-item {
	margin: 0 4px 4px 0;
	overflow: hidden;
	position: relative;
	line-height: 0;
	float: left;
	}

.gallery-columns-1 .gallery-item { max-width: 100%; }

.gallery-columns-2 .gallery-item {
	max-width: 48%;
	max-width: -webkit-calc(50% - 4px);
	max-width:         calc(50% - 4px);
	}

.gallery-columns-3 .gallery-item {
	max-width: 32%;
	max-width: -webkit-calc(33.3% - 4px);
	max-width:         calc(33.3% - 4px);
	}

.gallery-columns-4 .gallery-item {
	max-width: 23%;
	max-width: -webkit-calc(25% - 4px);
	max-width:         calc(25% - 4px);
	}

.gallery-columns-5 .gallery-item {
	max-width: 19%;
	max-width: -webkit-calc(20% - 4px);
	max-width:         calc(20% - 4px);
	}

.gallery-columns-6 .gallery-item {
	max-width: 15%;
	max-width: -webkit-calc(16.7% - 4px);
	max-width:         calc(16.7% - 4px);
	}

.gallery-columns-7 .gallery-item {
	max-width: 13%;
	max-width: -webkit-calc(14.28% - 4px);
	max-width:         calc(14.28% - 4px);
	}

.gallery-columns-8 .gallery-item {
	max-width: 11%;
	max-width: -webkit-calc(12.5% - 4px);
	max-width:         calc(12.5% - 4px);
	}

.gallery-columns-9 .gallery-item {
	max-width: 9%;
	max-width: -webkit-calc(11.1% - 4px);
	max-width:         calc(11.1% - 4px);
	}

.gallery-columns-1 .gallery-item:nth-of-type(1n),
.gallery-columns-2 .gallery-item:nth-of-type(2n),
.gallery-columns-3 .gallery-item:nth-of-type(3n),
.gallery-columns-4 .gallery-item:nth-of-type(4n),
.gallery-columns-5 .gallery-item:nth-of-type(5n),
.gallery-columns-6 .gallery-item:nth-of-type(6n),
.gallery-columns-7 .gallery-item:nth-of-type(7n),
.gallery-columns-8 .gallery-item:nth-of-type(8n),
.gallery-columns-9 .gallery-item:nth-of-type(9n) { margin-right: 0; }

.gallery-columns-1.gallery-size-medium figure.gallery-item:nth-of-type(1n+1),
.gallery-columns-1.gallery-size-thumbnail figure.gallery-item:nth-of-type(1n+1),
.gallery-columns-2.gallery-size-thumbnail figure.gallery-item:nth-of-type(2n+1),
.gallery-columns-3.gallery-size-thumbnail figure.gallery-item:nth-of-type(3n+1) { clear: left; }

.gallery-caption {
	margin: 0;
	padding: 25% 8px 0 8px;
	width: 100%;
	max-width: 100%;
	max-height: 100%;
	line-height: 1.5;
	background: rgba(0, 0, 0, 0.58);
	-webkit-box-sizing: border-box;
	-moz-box-sizing:    border-box;
	box-sizing:         border-box;
	color: #FFF;
	font-size: 20px;
	opacity: 0;
	-webkit-transition: all 0.2s ease-in-out;
	   -moz-transition: all 0.2s ease-in-out;
		-ms-transition: all 0.2s ease-in-out;
		 -o-transition: all 0.2s ease-in-out;
			transition: all 0.2s ease-in-out;
	text-align: center;
	position: absolute;
	bottom: 0;
	right: 0;
	left: 0;
	top: 0;
	}

.gallery-item:hover .gallery-caption { opacity: 1; }

.gallery-columns-7 .gallery-caption,
.gallery-columns-8 .gallery-caption,
.gallery-columns-9 .gallery-caption { display: none; }
