/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/
html{font-family:sans-serif;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{margin:0}article,aside,details,figcaption,figure,footer,header,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}dfn{font-style:italic}h1{font-size:2em;margin:.67em 0}mark{background:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:1em 40px}hr{box-sizing:content-box;height:0}pre{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}button{overflow:visible}button,select{text-transform:none}button,html input[type="button"],input[type="reset"],input[type="submit"]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input{line-height:normal}input[type="checkbox"],input[type="radio"]{box-sizing:border-box;padding:0}input[type="number"]::-webkit-inner-spin-button,input[type="number"]::-webkit-outer-spin-button{height:auto}input[type="search"]{-webkit-appearance:textfield;box-sizing:content-box}input[type="search"]::-webkit-search-cancel-button,input[type="search"]::-webkit-search-decoration{-webkit-appearance:none}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{border:0;padding:0}textarea{overflow:auto}optgroup{font-weight:700}table{border-collapse:collapse;border-spacing:0}td,th{padding:0}


/*--------------------------------------------------------------
# Typography
--------------------------------------------------------------*/
body,
button,
input,
select,
textarea {
	color: #1F2021;
	font-family: 'Open Sans', sans-serif;
	font-size: 16px;
	font-size: 1rem;
	line-height: 1.5;
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: 'Raleway', sans-serif;
	margin: 0 0 0.5em;
	clear: both;
	line-height: 1;
}

h1 {
	font-size: 2.25em;
}

h2 {
	font-size: 1.8em;
}

h3 {
    font-size: 2em;
    margin-bottom: 1em;
}

h4 {
	font-size: 1.25em;
}

h5 {
	font-size: 1em;
}

.the-content ul li,
p {
	margin: 0;
	font-size: 20px;
	line-height: 1.4;
	margin-bottom: 1.5em;
	font-weight: 400;
}
	p.intro {
		font-size: 24px;
	}
	@media screen and (min-width: 600px) {
		p.intro {
			font-size: 30px;
			max-width: 740px;
			margin-top: 0;
		}
	}

p:last-child {
	margin-bottom: 0;
}

dfn,
cite,
em,
i {
	font-style: italic;
}

blockquote {
	margin: 0 0 2em;
	font-style: italic;
}

address {
	margin: 0 0 1.5em;
}

pre {
	background: #eee;
	font-family: "Courier 10 Pitch", Courier, monospace;
	font-size: 15px;
	font-size: 0.9375rem;
	line-height: 1.6;
	margin-bottom: 1.6em;
	max-width: 100%;
	overflow: auto;
	padding: 1.6em;
}

code,
kbd,
tt,
var {
	font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
	font-size: 15px;
	font-size: 0.9375rem;
}

abbr,
acronym {
	border-bottom: 1px dotted #666;
	cursor: help;
}

mark,
ins {
	background: #fff9c0;
	text-decoration: none;
}

big {
	font-size: 125%;
}

.justify {
	text-align: justify;
}

.sans {
	font-family: Helvetica, Arial, sans-serif;
}

.serif {
	font-family: 'Open Sans', serif;
}

.no-cols {
	max-width: 940px;
}

@media screen and (min-width: 800px) {
	.text-two-col {
		-webkit-column-count: 2;
		-moz-column-count: 2;
		column-count: 2;
		-webkit-column-gap: 2em;
		-moz-column-gap: 2em;
		column-gap: 2em;
		-webkit-column-break-inside: avoid;
		-moz-column-break-inside: avoid;
		-o-column-break-inside: avoid;
		-ms-column-break-inside: avoid;
		column-break-inside: avoid;
	}
}

.text-three-col {
	margin-bottom: 40px;
}
@media screen and (min-width: 1024px) {
	.text-three-col {
		-webkit-column-count: 3;
		-moz-column-count: 3;
		column-count: 3;
		-webkit-column-gap: 2em;
		-moz-column-gap: 2em;
		column-gap: 2em;
		-webkit-column-break-inside: avoid;
		-moz-column-break-inside: avoid;
		-o-column-break-inside: avoid;
		-ms-column-break-inside: avoid;
		column-break-inside: avoid;
	}
}


/*--------------------------------------------------------------
# Elements
--------------------------------------------------------------*/
html {
	box-sizing: border-box;
}

*,
*:before,
*:after {
	box-sizing: inherit;
}

body {
	background: #F2EEE8;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: "";
}

blockquote,
q {
	quotes: "" "";
}

hr {
	background-color: #ccc;
	border: 0;
	height: 1px;
	margin-bottom: 1.5em;
}

ul,
ol {
    margin: 0 0 1.5em 0em;
    padding-left: 0;
}

ul {
	list-style: disc;
}

ol {
	list-style: decimal;
}

li > ul,
li > ol {
	margin-bottom: 0;
	margin-left: 1.5em;
}

.the-content ul li {
	list-style-position: outside;
	margin-left: 20px;
	margin-bottom: 20px;
}

dt {
	font-weight: bold;
}

dd {
	margin: 0 1.5em 1.5em;
}

img {
	height: auto; /* Make sure images are scaled correctly. */
	max-width: 100%; /* Adhere to container width. */
}

table {
	margin: 0 0 1.5em;
	width: 100%;
}
.two-cols,
.three-cols,
.four-cols {

}
	.two-cols .col,
	.three-cols .col,
	.four-cols .col {
		width: 100%;
		margin-bottom: 5%;
		overflow: hidden;
	}
	@media screen and (min-width: 600px) {
		.two-cols,
		.three-cols,
		.four-cols {
			display: flex;
			flex-wrap: wrap;
			justify-content: space-between;
		}
		.two-cols {
			flex-wrap: wrap;
		}
		.three-cols .col,
		.two-cols .col {
			width: 46%;
			margin-bottom: 6%;
		}
	}
	@media screen and (min-width: 900px) {
		.three-cols {
			display: flex;
			justify-content: space-between;
			flex-wrap: wrap;
		}
		.three-cols .col {
			width: 30%;
		}
		.three-cols:after {
		  /* content: "";
		  flex: auto; */
		}
	}
	@media screen and (min-width: 600px) and (max-width: 1024px) {
		.four-cols {
			flex-wrap: wrap;
		}
		.four-cols .col {
			width: 48%;
			margin-bottom: 60px;
		}
		.four-cols .col:nth-last-child(-n+2) {
			margin-bottom: 0;
		}
	}
	@media screen and (min-width: 1025px) {
		.four-cols .col {
			width: 22%;
		}
	}



.row {
	width: 100%;
	clear: both;
	float: left;
	position: relative;
}

.right {
	float: right;
}

.left {
	float: left;
}

.center-wrap {
  position: absolute;
  display: table;
  overflow: hidden;
  height: 100%;
  z-index: 20;
  width: 100%;
  left: 0;
  top: 0;
}

.center-wrap-row {
  display: table-row;
  height: 100%;
}

.center-wrap-cell {
  display: table-cell;
  vertical-align: middle;
  text-decoration: none;
  color: #FFF;
  text-align: left;
  font-size: 1em;
  position: relative;
  z-index: 10;
}

.center-blk {
    position: relative;
    clear: both;
    margin: 0 auto;
    max-width: 1280px;
    width: 90%;
}

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

body.ie a.hot-spot {
	background: transparent url('img/blank.gif'); /* helps IE */
}

.full-bleed {
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}


.hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	border: 1px solid;
    border-radius: 0;
    background: transparent;
    font-size: 0.9em;
    line-height: 1.4;
    padding: 0.5em 1em;
    -webkit-appearance: none;
    outline: 0;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	background: #000;
	color: #FFF;
}

button:focus,
input[type="button"]:focus,
input[type="reset"]:focus,
input[type="submit"]:focus,
button:active,
input[type="button"]:active,
input[type="reset"]:active,
input[type="submit"]:active {
	outline: none;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	color: #666;
	border: 1px solid #ccc;
	border-radius: 3px;
	-webkit-appearance: none;
}

select {
	border: 1px solid #ccc;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
	color: #111;
	outline: none;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"] {
	padding: 3px;
}

textarea {
	padding-left: 3px;
	width: 100%;
}

/* -------- Placeholders ---------- */

input[type="text"]::-webkit-input-placeholder {
   color: #1D1D1D;
}

input[type="text"]::-moz-placeholder { /* Firefox 18- */
   color: #1D1D1D;
}

input[type="text"]::-moz-placeholder {  /* Firefox 19+ */
   color: #1D1D1D;
}

input[type="text"]:-ms-input-placeholder {
   color: #1D1D1D;
}

input[type="email"]::-webkit-input-placeholder {
   color: #1D1D1D;
}

input[type="email"]::-moz-placeholder { /* Firefox 18- */
   color: #1D1D1D;
}

input[type="email"]::-moz-placeholder {  /* Firefox 19+ */
   color: #1D1D1D;
}

input[type="email"]:-ms-input-placeholder {
   color: #1D1D1D;
}


textarea::-webkit-input-placeholder {
   color: #1D1D1D;
}

textarea::-moz-placeholder { /* Firefox 18- */
   color: #1D1D1D;
}

textarea::-moz-placeholder {  /* Firefox 19+ */
   color: #1D1D1D;
}

textarea:-ms-input-placeholder {
   color: #1D1D1D;
}


/*--------------------------------------------------------------
# Navigation
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Links
--------------------------------------------------------------*/
a {
	color: #2b4b7d;
	transition: all .08s ease-in-out;
    -moz-transition: all .08s ease-in-out;
    -webkit-transition: all .08s ease-in-out;
    outline: none;
}

a:hover,
a:focus,
a:active {
	text-decoration: none;
}

a:focus {
	outline: none;
}

a:hover,
a:active {
	outline: 0;
}

article p a {
	text-decoration: none;
	border-bottom: 1px solid;
}
	article p a:not(.btn):hover {
		border:none;
	}


/* -------- Buttons ---------- */

a.btn, .btn {
	color: #FFF;
	font-size: 16px;
	border: 2px solid #60C6B0;
	background: #60C6B0;
	display: inline-block;
	text-decoration: none;
	padding: 17px 20px;
	line-height: 1;
	font-weight: 600;
	position: relative;
	text-align: center;
	border-radius: 40px;
}

.btn:hover,
a.btn:hover,
a.btn.hover {
    background: #318875;
    color: #FFF;
    border-color: #318875;
}


/* Button Large */

a.btn.lrg {
	font-size: 1.2em;
    padding: 1em 0.9em 0.95em;
}

/*--------------------------------------------------------------
## Menus
--------------------------------------------------------------*/
.main-navigation {
	clear: none;
	display: block;
	float: right;
	margin: 7px 0 0;
	font-size: 17px;
	font-weight: 600;
	width: calc(80% - 300px);
}
nav .menu {
	float: left;
	width: 100%;
}

.main-navigation ul {
	list-style: none;
	margin: 0;
	padding-left: 0;
	display: block;
	float: right;
	width: 100%;
	display: flex;
  align-items: center;

     justify-content: flex-end;
}

.main-navigation li {
	position: relative;
}
	.main-navigation li:first-child {
		display: none;
	}
	.main-navigation ul.sub-menu li:first-child {
		display: block;
	}

.main-navigation a {
	display: block;
	text-decoration: none;
	color: #FFF;
	border-radius: 40px;
	border: 1px solid transparent;
	padding: 13px 17px 15px 19px;
	line-height: 1;
}

.main-navigation ul ul {
float: left;
    position: absolute;
    top: 47px;
    left: -999em;
    z-index: 99999;
    width: 200px;
    padding:0;
    display: block;
    background: #022231;
    border-radius: 20px;
    overflow: hidden;
}

.main-navigation ul ul ul {
	left: -999em;
	top: 0;
}

.main-navigation ul ul a {
    width: 100%;
    border: none;
}
.main-navigation ul ul a:hover {
    background: #FFF;
    border-radius: 0;
    color: #022d42;
}

.main-navigation ul ul li {
	width: 100%;
	display: block;
}

.main-navigation li:hover > a,
.main-navigation li.focus > a {
}

.main-navigation ul ul :hover > a,
.main-navigation ul ul .focus > a {
}

.main-navigation ul ul a:hover,
.main-navigation ul ul a.focus {
}

.main-navigation ul li:hover > ul,
.main-navigation ul li.focus > ul {
	left: auto;
}

.main-navigation ul ul li:hover > ul,
.main-navigation ul ul li.focus > ul {
	left: 100%;
}

.main-navigation a:hover,
.main-navigation li:hover > a,
.main-navigation .current_page_item > a,
.main-navigation .current-menu-item > a,
.main-navigation .current_page_parent > a,
.main-navigation .current_page_ancestor > a,
.main-navigation .current-menu-ancestor > a {
	border-color: rgba(255,255,255,0.5);
}


.site-main .comment-navigation,
.site-main .posts-navigation,
.site-main .post-navigation {
    margin: 0 auto;
    overflow: hidden;
    float: left;
    width: 100%;
    padding: 0;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
	float: left;
	width: 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
	float: right;
	text-align: right;
	width: 50%;
}

.mobile-menu .knockout,
.mobile-menu {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 100;
    width: 100%;

}

.mobile-menu .knockout {
	position: fixed;
	background: rgb(37, 55, 84);
	height: 100%;
	overflow: auto;
	overflow-y: scroll;
 }

.mobile-menu div:not(.knockout) {
    position: absolute;
    left: 0;
    float: left;
    padding: 3em 0;
    width: 100%;
    z-index: 110;
    display: block;
    background: none;
    box-shadow: none;
    text-align: center;
}

.mobile-menu ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
}
	.mobile-menu ul li {
		margin-bottom: 25px;
	}
	.mobile-menu ul ul li {
		margin-bottom: 10px;
	}
	.mobile-menu ul ul li a {
		font-size: 20px;
	}


button.menu-toggle {
	position: absolute;
	z-index: 200;
	display: none;
	border: none;
	padding: 0;
	background-color: transparent;
	right: 5%;
	top: 33px;
}
	@media screen and (min-width: 600px) {
		button.menu-toggle {
			right: 5%;
			top: 58px;
		}
	}
	button.menu-toggle.toggle-open {
	    display: block;
	}
	.burger-icon {
	    width: 37px;
	    height: 27px;
	    position: relative;
	    margin: 0;
	    -webkit-transform: rotate(0deg);
	    -moz-transform: rotate(0deg);
	    -o-transform: rotate(0deg);
	    transform: rotate(0deg);
	    -webkit-transition: .5s ease-in-out;
	    -moz-transition: .5s ease-in-out;
	    -o-transition: .5s ease-in-out;
	    transition: .5s ease-in-out;
	    cursor: pointer;
	}
	.burger-icon span {
		display: block;
		position: absolute;
		height: 3px;
		width: 100%;
		background: #FFF;
		opacity: 1;
		left: 0;
		-webkit-transform: rotate(0deg);
		-moz-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		transform: rotate(0deg);
		-webkit-transition: .25s ease-in-out;
		-moz-transition: .25s ease-in-out;
		-o-transition: .25s ease-in-out;
		transition: .25s ease-in-out;
	}
	.burger-icon span:nth-child(1) {
	  top: 0px;
	}

	.burger-icon span:nth-child(2),
	.burger-icon span:nth-child(3) {
	  top: 11px;
	}

	.burger-icon span:nth-child(4) {
	  top: 22px;
	}
	button.toggle-open .burger-icon span:nth-child(1) {
	  top: 11px;
	  width: 0%;
	  left: 50%;
	}
	button.toggle-open .burger-icon span:nth-child(2) {
	  -webkit-transform: rotate(45deg);
	  -moz-transform: rotate(45deg);
	  -o-transform: rotate(45deg);
	  transform: rotate(45deg);
	}
	button.toggle-open .burger-icon span:nth-child(3) {
	  -webkit-transform: rotate(-45deg);
	  -moz-transform: rotate(-45deg);
	  -o-transform: rotate(-45deg);
	  transform: rotate(-45deg);
	}
	button.toggle-open .burger-icon span:nth-child(4) {
	  top: 11px;
	  width: 0%;
	  left: 50%;
	}


.mobile-menu a {
	display: inline-block;
	text-decoration: none;
	color: #FFF;
	border-radius: 40px;
	border: 1px solid transparent;
	padding: 12px 27px 16px;
	font-size: 25px;
	line-height: 1;
}

.mobile-menu a:hover,
.mobile-menu .current_page_item > a,
.mobile-menu .current-menu-item > a,
.mobile-menu .current_page_parent > a,
.mobile-menu .current_page_ancestor > a,
.mobile-menu .current-menu-ancestor > a {
	border-color: rgba(255,255,255,0.5);
}


@media screen and (max-width: 1024px) {
	.main-navigation ul {
		display: none;
	}
	button.menu-toggle {
		display: block;
	}
}

/*--------------------------------------------------------------
# Accessibility
--------------------------------------------------------------*/
/* Text meant only for screen readers. */
.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	height: 1px;
	width: 1px;
	overflow: hidden;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	color: #21759b;
	display: block;
	font-size: 14px;
	font-size: 0.875rem;
	font-weight: bold;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000; /* Above WP toolbar. */
}

/* Do not show the outline on the skip link target. */
#content[tabindex="-1"]:focus {
	outline: 0;
}

/*--------------------------------------------------------------
# Alignments
--------------------------------------------------------------*/
.left {
	float: left;
}

.right {
	float: right;
}

.center {
	float: none;
	margin: 0 auto;
	position: relative;
}

.alignleft {
	text-align: left;
}

.alignright {
	text-align: right;
}

.aligncenter {
	text-align: center;
}


/*--------------------------------------------------------------
# Clearings
--------------------------------------------------------------*/
.clear:before,
.clear:after,
.entry-content:before,
.entry-content:after,
.comment-content:before,
.comment-content:after,
.site-header:before,
.site-header:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after {
	content: "";
	display: table;
	table-layout: fixed;
}

.clear:after,
.entry-content:after,
.comment-content:after,
.site-header:after,
.site-content:after,
.site-footer:after {
	clear: both;
}

/*--------------------------------------------------------------
# Widgets
--------------------------------------------------------------*/
.widget {
	margin: 0 0 1.5em;
}

/* Make sure select elements fit in widgets. */
.widget select {
	max-width: 100%;
}

/*--------------------------------------------------------------
# Content
--------------------------------------------------------------*/

#page-wrapper {
	position: relative;
	clear: both;
	margin: 0 auto;
	max-width: 1280px;
	width: 90%;
}

.site-header {
    padding: 15px 0;
		background: #032d43;
}
	body.blog .site-header,
	body.archive .site-header,
	.site.has-header-image .site-header {
		position: absolute;
		top: 0;
		left: 0;
		background: transparent;
		z-index: 10;
	}
	body.blog .site-header:after,
	body.archive .site-header:after,
	.site.has-header-image .site-header:after {
		content: "";
    background: -moz-linear-gradient(top, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0) 100%);
    background: -webkit-linear-gradient(top, rgba(0,0,0,0.65) 0%,rgba(0,0,0,0) 100%);
    background: linear-gradient(to bottom, rgba(0,0,0,0.65) 0%,rgba(0,0,0,0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#a6000000', endColorstr='#00000000',GradientType=0 );
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 220px;
    opacity: 0.7;
	}
	body.blog .site-header .center-blk,
	body.archive .site-header .center-blk,
	.site.has-header-image .site-header .center-blk {
		z-index: 10;
	}
	@media screen and (min-width: 600px) {
		.site-header {
		    padding: 30px 0;
		}
	}

.site-branding {
	float: left;
}
	h1.site-title {
	    font-size: 2em;
	    margin: 0;
	}
	h1.site-title a {
		text-decoration: none;
		font-weight: 600;
		color: #221e1f;
		display: block;
	}
	h1.site-title a:hover {
		opacity: 0.4;
	}
	h1.site-title a img {
		width: 170px;
	}
	@media screen and (min-width: 600px) {
		h1.site-title a img {
			width: 245px;
		}
		.site-footer h1.site-title a img {
			width:165px;
		}
	}

/* -- Footer -- */

.site-footer {
    width: 100%;
    padding: 30px 0;
    clear: both;
		background: #032d43;
		color: #FFF;
		font-weight: 600;
}
	.site-footer .site-info {
		float: left;
		margin-top: 20px;
		width: 100%;
		clear: left;
	}
	@media screen and (min-width: 600px) {
		.site-footer .site-info {
			width: calc(100% - 400px);
	    float: right;
	    margin: 7px 0 0;
			text-align: right;
			clear: none;
		}
	}
	.site-footer p {
		margin: 0;
		font-size: 16px;
		font-weight: 600;
	}
		
.sign-up {
    padding: 30px 0;
    text-align: center;
    background: #e0dcd6;
    margin: 0;
}
	.sign-up h3 {
		font-weight: 300;
		margin: 5px 0 19px;
		font-size: 20px;
	}
	.sign-up input {
	    width: calc(100% - 150px);
	    float: left;
	    border: none;
	    font-weight: 400;
	    padding: 15px;
	    border-radius: 30px 0 0 30px;
	}
	.sign-up button {
		width: 150px;
		float: right;
		border-radius: 0 30px 30px 0;
		background: #3ca38a;
		border-color: #3ca38a;
	}
	.sign-up .center-blk {
		max-width: 760px;
	}

/*--------------------------------------------------------------
## Posts and pages
--------------------------------------------------------------*/


.page-header {
	margin: calc(50px + 2.5vh) 0 50px;
}
	.page-header .center-blk {
			border-bottom: 1px solid #d2cbc8;
				padding-bottom: 50px;
	}
	.page-header h1 {
		margin: 0;
		font-weight: 400;
		max-width: 620px;
		font-size: 30px;
		line-height: 1.15;
	}
	.page-header p {
		font-size: 22px;
		margin-top: 10px;
		font-weight: 400;
	}
	@media screen and (min-width: 600px) {
		.page-header h1 {
			font-size: 45px;
		}
	}

.site.has-header-image {

}
	body.blog .page-header,
	body.archive .page-header,
	.site.has-header-image .page-header {
		min-height: 400px;
    height: 60vh;
    color: #FFF;
    display: flex;
    align-items: center;
    justify-content: center;
    background-position: top center;
    position: relative;
    overflow: hidden;
    text-shadow: 0em 0em 2em #000;
		margin: 0;
		background-color: #000;
	}
	body.blog .page-header .center-blk,
	body.archive .page-header .center-blk,
	.site.has-header-image .page-header .center-blk {
		border: none;
		padding: 0;
	}
	body.blog .page-header::after,
	body.archive .page-header::after,
	.site.has-header-image .page-header::after {
		content: "";
    background: -moz-radial-gradient(center, ellipse cover, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0) 70%);
    background: -webkit-radial-gradient(center, ellipse cover, rgba(0,0,0,0.65) 0%,rgba(0,0,0,0) 70%);
    background: radial-gradient(ellipse at center, rgba(0,0,0,0.65) 0%,rgba(0,0,0,0) 70%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#a6000000', endColorstr='#00000000',GradientType=1 );
    position: absolute;
    left: -40%;
    bottom: -30%;
    width: 120%;
    height: 100%;
	}
	body.blog .page-header .center-blk,
	body.archive .page-header .center-blk,
	.site.has-header-image .page-header .center-blk {
		align-self: flex-end;
		margin-bottom: 50px;
		z-index: 10;
	}
	body.blog .page-header p,
	body.archive .page-header p,
	.site.has-header-image .page-header p {
		max-width: 620px;
	}


.content-pad {
	padding: calc(50px + 5vh) 0;
}
	.site.has-header-image .the-content,
	.content-pad-top {
		padding-top: calc(50px + 5vh);
	}
	.the-content,
	.content-pad-btm {
		padding-bottom: calc(50px + 5vh);
	}


.profile {
	text-align: center;
	padding: 30px;
	width: 100%;
	float: left;
	margin-bottom: 25px;
}
	.partner-profiles .profile {
		background: #fffdfc;
	}
	@media screen and (min-width: 600px) and (max-width: 1023px) {
		.profile {
			width: 48%;
			margin: 0 4% 4% 0;
		}
		.profile:nth-last-of-type(even) {
			margin-right: 0;
		}
	}
	@media screen and (min-width: 1024px) {
		.profile {
			width: 30%;
			padding: 25px;
			margin: 0 5% 5% 0;
		}
		.profile:nth-of-type(3n+3) {
			margin-right: 0;
		}
	}
	.profile img {
		width: 80%;
		margin: 0 10% 7%;
		border-radius: 100%;
		max-width: 260px;
	}
	.partner-profiles img {
		border-radius: 0;
	}
	.profile h3 {
		font-size: 22px;
	}
	.profile h4 {
		margin-bottom: 1em;
		font-size: 18px;
	}
	.profile p {
		font-size: 17px;
	}
	.profile p .urls {
		display: block;
		float: left;
		width: 100%;
		font-size: 16px;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	    padding: 3px;
	}
	.profile p .urls a {
		display: inline-block;
		margin: 3px;
	}
	
	
	

article.type-post {
	background: #FFF;
	padding: 30px;
	position: relative;
	overflow: hidden;
}
	article.type-post.partial:hover {
		background: #f3f3f3;
	}
	article.type-post time {
		color: #0B85A3;
		margin-bottom: 10px;
		display: block;
	}
	article.type-post.partial h2 {
		font-size: 24px;
		font-weight: 300;
		margin-bottom: 15px;
	}
	article.type-post.partial p {
		font-size: 17px;
    line-height: 1.5;
	}
	article.type-post::after {
		content: "";
    position: absolute;
    width: 45px;
    height: 45px;
    right: -25px;
    bottom: -25px;
    background: #F2EEE8;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
	}
	article.type-post h1 {
		max-width: none;
		font-weight: 300;
	}
	article.type-post .page-header {
		margin: 0;
	}
	article.type-post .page-header .center-blk {
		padding-bottom: 30px;
		margin-bottom: 31px;
	}
	article.type-post.single {
		padding: 5%;
	}
	article.type-post.single .center-blk {
		width: 100%;
	}
	article.type-post.single .the-content {
		padding: 0;
	}

.btn-row {
	margin-top: 50px;
}


/*--------------------------------------------------------------
## Shorthand Styling
--------------------------------------------------------------*/

body.page-template-page-shorthand {
	background: #F2EEE8;
}

.hero-img {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}

.site.has-header-image .page-header.sh-header {
	height: 100vh;
	min-height: 600px;
}
	.site.has-header-image .page-header.sh-header .center-blk {
		align-self: center;
    text-align: center;
    margin: 10vh 0 0 0;
	}
	.page-header.sh-header h1,
	.site.has-header-image .page-header.sh-header p {
		max-width: 1000px;
    margin: 0 auto;
	}
	.page-header.sh-header h1 {
		font-size: 30px;
    margin-bottom: 30px;
    font-weight: 700;
    line-height: 1.1;
	}

	@media screen and (min-width: 600px) and (max-width: 1024px) {
		.page-header.sh-header h1 {
			font-size: 60px;
		}
	}
	@media screen and (min-width: 1024px) {
		.page-header.sh-header h1 {
			font-size: 88px;
		}
		.site.has-header-image .page-header.sh-header p {
			font-size: 26px;
		}
	}
	.site.has-header-image .page-header.sh-header::after {
		left: 0;
		bottom: 0;
		width: 100%;
		height: 100%;
	}
	a.btn-down {
		text-decoration: none;
    color: #FFF;
    display: inline-block;
    margin: 30px auto 0;
    border-radius: 100%;
    border: 1px solid rgba(255, 255, 255, 0.45);
    width: auto;
    width: 50px;
    height: 50px;
    font-size: 24px;
    line-height: 1.85;
    text-indent: 0.1em;
		transition: all .3s ease-in-out;
    -moz-transition: all .3s ease-in-out;
    -webkit-transition: all .3s ease-in-out;
	}
	a.btn-down:hover {
		-ms-transform: translate(0px, 5px);
		-webkit-transform: translate(0px, 5px);
		transform: translate(0px, 5px);
	}

.sh-sections p {
	font-size: 20px;
	line-height: 1.7;
}

section.content-pad {
	margin: calc(50px + 5vh) 0 0;
	padding: 0;
}
	section.content-pad:last-of-type {
		margin-bottom: calc(50px + 5vh);
	}

section.section-text {

}
	section.section-text p {
		width: 100%;
		max-width: 660px;
		padding: 20px 30px;
		overflow-wrap: break-word;
		word-wrap: break-word;
		word-break: break-word;
		margin: 0 auto;
	}
	section.section-text p.intro-text {
		font-size: 28px;
    line-height: 1.4;
	}
	section.section-text blockquote {
		max-width: 750px;
		border-top: 1px solid #e2e2e2;
		border-bottom: 1px solid #e2e2e2;
		padding: 30px 0;
		margin: 40px auto;
		text-align: center;
		-webkit-column-break-inside: avoid; /* Chrome, Safari */
    page-break-inside: avoid;           /* Theoretically FF 20+ */
    break-inside: avoid-column;         /* IE 11 */
    display:table;                      /* Actually FF 20+ */
	}
	section.section-text blockquote p {
		max-width: none;
    font-size: 1.8em;
    line-height: 1.5;
    color: #0B85A3;
	}

section.section-fixed-images {
	overflow: hidden;
	background: #000;
}
	section.section-fixed-images .fixed-image {
		height: 100vh;
		background-attachment: fixed;
	}
	section.section-fixed-images .fixed-image p {
		position: absolute;
		bottom: 0;
		left: 0;
		color: #FFF;
		font-weight: 400;
		background: rgba(0, 0, 0, 0.5);
		width: 100%;
		padding: 15px;
		font-size: 17px;
		text-align: center;
	}


section.section-text-summary {

}
	section.section-text-summary .center-blk {
		max-width: 920px;
	}
	.text-summary-row {
		margin: 0 auto calc(50px + 5vh);
	}
	.text-summary-row:last-of-type {
		margin-bottom: 0;
	}
	.text-summary-row aside.summary {
		float: left;
    width: 100%;

	}
	.text-summary-row aside.summary.text {
		color: #0B85A3;
    font-size: 22px;
    margin-bottom: 40px;
    border-top: 2px solid #14a2c5;
    padding-top: 25px;
    margin: 11px 0 70px;
    font-weight: 400;
	}
	.text-summary-row aside.summary.image-graphic {

	}
		.text-summary-row aside.summary.image-graphic p.caption {
			font-style: italic;
	    font-size: 18px;
	    margin-top: 16px;
	    line-height: 1.3;
	    color: #808080;
		}
	.text-summary-row h3.sans {
		font-size: 36px;
		font-weight: 300;
		color: #0B85A3;
	}
	@media screen and (min-width: 1024px) {
		.text-summary-row aside.summary {
			float: left;
			width: 280px;
			top: -1px;
			position: -webkit-sticky;
			position: -moz-sticky;
			position: -o-sticky;
			position: -ms-sticky;
			position: sticky;
			top: 10px;
			z-index: 1;
		}
		.text-summary-row main.main-text {
			float: right;
			width: calc(100% - 350px);
		}
	}

section.section-text-bg-img {
	padding: calc(50px + 5vh) 0;
	overflow: hidden;
	background: #000;
}
	section.section-text-bg-img .center-blk {
		position: relative;
		z-index: 10;
	}
	section.section-text-bg-img .text-content {
		max-width: 660px;
		color: #FFF;
		float: left;
	}
	section.section-text-bg-img .text-content p {
		font-weight: 400;
	}
	section.section-text-bg-img h3 {
		font-size: 36px;
		font-weight: 300;
	}
	section.section-text-bg-img .fixed-image {
		position: absolute;
		width: 100%;
		height: 100%;
		left: 0;
		top: 0;
		opacity: 0.7;
	}
	section.section-text-bg-img:not(.section-quote-image) .fixed-image {
		background-attachment: fixed;
		opacity: 1;
	}

section.section-quote-image {
}
	section.section-quote-image blockquote {
		margin: 5% 0;
	}
	section.section-quote-image blockquote p {
		text-align: center;
    font-size: 80px;
    color: #FFF;
    font-style: normal;
    line-height: 1.2;
	}
	video {
		top: -15%;
		left: -5%;
		width: 110%;
		height: 130%;
		position: absolute;
		opacity: 0.5;
	}










/*--------------------------------------------------------------
## Map Styling
--------------------------------------------------------------*/


article.map-page {
	overflow: hidden
}
	article.map-page aside.map-aside {
    width: 360px;
    float: left;
    background: #e6e6e6;
    height: calc(100vh - 141px);
    overflow: scroll;
    box-shadow: 0px 0px 25px rgba(0, 0, 0, 0.7);
    z-index: 10;
    position: relative;
	}
	article.map-page .map-wrap {
		width: calc(100% - 360px);
		right: 0;
		top:	0;
		background: #CCC;
		height: calc(100%);
		position: absolute;
		overflow: hidden;
		background-image: url(../img/grid2.png);
		background-color: #000;
	}
	@media screen and (max-width: 900px) {
		article.map-page aside.map-aside {
			width: 280px;
		}
		article.map-page .map-wrap {
			width: calc(100% - 280px);
		}
	}
	@media screen and (max-width: 600px) {
		article.map-page aside.map-aside {
			width: 100%;
		}
		article.map-page .map-wrap {
			width: calc(100%);
		}
		article.map-page .map-wrap {
			height: 400px;
		}
		article.map-page aside.map-aside {
			margin-top: 400px;
			height: auto;
			overflow: auto;
		}
		article.map-page aside.map-aside .page-info .side-head {
			height: 120px;
		}
	}
	article.map-page aside.map-aside .map-data {
    margin: 0 40px 20px;
    float: left;
        width: calc(100% - 80px);
	}
	article.map-page aside.map-aside .widget {}
	article.map-page aside.map-aside .widget.active {
	    background: #FFF;
	    padding: 25px;
	    box-shadow: 0px 3px 2px rgba(0, 0, 0, 0.2);
	    border-top: 7px solid #dca873;
	}
	article.map-page aside.map-aside .widget br:nth-of-type(odd) {
		display: none;
	}
	article.map-page aside.map-aside .widget div div:nth-of-type(1) {
font-size: 1.6em !important;
    line-height: 1.2;
    margin-bottom: 5px !important;
	}
	article.map-page aside.map-aside .widget div div:nth-of-type(2) {
		margin-top: 0px;
	}
	article.map-page aside.map-aside .widget div div:nth-of-type(2) br:nth-of-type(1) {
		display: block;
	}
	article.map-page aside.map-aside .widget.active .temporary {
		display: none;
	}
	article.map-page aside.map-aside .widget .temporary {
	    display: block;
	    background: #e0dfdf;
	    border-radius: 15px;
	    width: 100%;
	    text-align: center;
	    padding: 40px;
	    border: 2px dashed #bbbbbb;
	}
	article.map-page aside.map-aside .widget .temporary p {
		font-size: 18px;
	}
	
	article.map-page aside.map-aside .page-info {
	}
	
	
	article.map-page aside.map-aside .page-info p {
		    font-size: 17px;
	}
	article.map-page aside.map-aside .page-info .side-head {
		    height: 220px;
	}
	article.map-page aside.map-aside .page-info h1 {
    font-size: 30px;
    font-weight: 400;
    color: #FFF;
    position: absolute;
    bottom: 30px;
    left: 40px;
    z-index: 10;
	}
	article.map-page aside.map-aside .page-info .side-head:before {
		content: "";
		/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#000000+0,000000+100&0+0,0.65+100 */
		background: -moz-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.65) 100%); /* FF3.6-15 */
		background: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%,rgba(0,0,0,0.65) 100%); /* Chrome10-25,Safari5.1-6 */
		background: linear-gradient(to bottom, rgba(0,0,0,0) 0%,rgba(0,0,0,0.65) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
		filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#a6000000',GradientType=0 ); /* IE6-9 */
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}
	article.map-page aside.map-aside .page-info .page-description {
		padding: 40px;
	}
	

.acf-map {
	width: 100%;
	height: 100%;
	position: absolute;
	opacity: 0.9;
}

/* fixes potential theme css conflict */
.acf-map img {
   max-width: inherit !important;
}


body.page-id-558 .partner-profiles img {
	margin: -25px -25px 20px;
    width: calc(100% + 50px);
    max-width: none;
}

/*--------------------------------------------------------------
## Asides
--------------------------------------------------------------*/
.blog .format-aside .entry-title,
.archive .format-aside .entry-title {
	display: none;
}

#secondary h1.widget-title {
	font-size: 1em;
	font-weight: 600;
}

#secondary .widget ul {
    margin: 0;
    list-style-position: inside;
    padding: 0;
}

/*--------------------------------------------------------------
## Comments
--------------------------------------------------------------*/
.comment-content a {
	word-wrap: break-word;
}

.bypostauthor {
	display: block;
}



/*--------------------------------------------------------------
# Media
--------------------------------------------------------------*/
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
	border: none;
	margin-bottom: 0;
	margin-top: 0;
	padding: 0;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
	max-width: 100%;
}

.holder-wrap {
	overflow: hidden;
}
	.img-holder {
		position: relative;
		display: block;
		z-index: 0;
		background: rgba(0,0,0,0.1);
		width: 100%;
		height: 100%;
		float: left;
	}
	.img-holder:before {
		position: absolute;
		content: "";
		width: 20px;
		height: 20px;
		border-radius: 100%;
		background: rgba(0,0,0,0.1);
		left: 50%;
		top: 50%;
		margin-left: -10px;
		margin-top: -10px;
		z-index: 90;
	}
	.img-holder:before {
		-webkit-animation-name: 'pulse_animation';
		-webkit-animation-duration: 1s;
		-webkit-animation-iteration-count: infinite;
		-webkit-animation-timing-function: ease-in-out;
	}
	.holder-wrap.image-loaded {
		background-color: #000;
	}
	.img-holder img {
		width: 100%;
		float: left;
		opacity: 0;
		z-index: 10;
		transition: opacity .2s linear;
		-moz-transition: opacity .2s linear;
		-webkit-transition: opacity .2s linear;
	}
	.holder-wrap.image-loaded a.img-holder:hover img {
		opacity: 0.3;
	}
	.image-loaded .img-holder img {
		opacity: 1;
	}
	.image-loaded .img-holder:before {
		display: none;
	}

	@-webkit-keyframes pulse_animation {
		0% { opacity: 0; }
		50% { opacity: 1; }
		100% { opacity: 0; }
	}

.sixteen-nine {
  position: relative;
  background-size: 110%;
}
.sixteen-nine:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 60%;
}
.sixteen-nine > .content {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
}
figure.video .sixteen-nine > figcaption.content {
	background: rgba(42, 35, 35, 0.35);
	transition: all .2s linear;
    -moz-transition: all .2s linear;
    -webkit-transition: all .2s linear;
    margin: 0;
}

figure.video:hover .sixteen-nine > figcaption.content {
	background: rgba(42, 35, 35, 0.8);
}

figure.video .sixteen-nine > figcaption.content h4 {
    position: absolute;
    width: 100%;
    bottom: 0;
    left: 0;
    padding: 2em 10%;
    text-align: center;
    color: #FFF;
    font-size: 1.2em;
    font-weight: bold;
    text-shadow: 0 0 2em rgba(0, 0, 0, 0.9);
}



.tabbed-content ul.tabs{
	margin: 0px;
	padding: 0px;
	list-style: none;
}
.tabbed-content ul.tabs li{
	background: transparent;
    padding: 1.5em 1.5em 1em;
    margin-left: -1px;
    position: relative;
    left: 1px;
    font-size: 1.2em;
    font-weight: 700;
    line-height: 1;
    display: inline-block;
    cursor: pointer;
    vertical-align: top;
}

.tabbed-content ul.tabs li.current{
	background: #FBFBFB;
}

.tabbed-content .tab-inner {
	background: #FBFBFB;
    padding: 2em;
    display: none;
    overflow: hidden;
}

.tabbed-content .tab-inner.current {
	display: inherit;
}

/*--------------------------------------------------------------
##  Plugins
--------------------------------------------------------------*/

/* -- Infinite Scroll -- */

/* Globally hidden elements when Infinite Scroll is supported and in use. */
.infinite-scroll .posts-navigation, /* Older / Newer Posts Navigation (always hidden) */
.infinite-scroll.neverending .site-footer { /* Theme Footer (when set to scrolling) */
	display: none;
}

/* When Infinite Scroll has reached its end we need to re-display elements that were hidden (via .neverending) before. */
.infinity-end.neverending .site-footer {
	display: block;
}

/* -- GForms -- */

.gform_wrapper {
}

.gform_body ul,
.gform_body li {
	list-style: none;
	padding: 0;
	margin: 0;
}

.gform_body li {
	display: block;
	width: 100%;
	float: left;
	clear: both;
	position: relative;
	margin-bottom: 20px;
	margin-left: 0 !important;
}

.gform_wrapper .validation_error,
.gform_wrapper .validation_message {
	display: none;
}

.gform_body label.gfield_label {
    display: block;
    position: relative;
    z-index: 20;
    margin-bottom: 5px;
}

.gform_body .ginput_container {
	position: relative;
	float: left;
	width: 100%;
	display: block;
	z-index: 10;
}

.gform_body input,
.gform_body textarea,
.gform_body select {
	background: #FFF;
    padding: 10px 15px;
    font-size: 18px;
    font-weight: 300;
    margin: 0;
    width: 100%;
    border: 1px solid #CCC;
}

.gform_body input[type="radio"] {
	-webkit-appearance: radio;
	    width: auto;
}
.gform_body input[type="checkbox"] {
	-webkit-appearance: checkbox;
	    width: auto;
}

.gform_body .gfield_checkbox li {
	margin-bottom: 0;
}
.gform_body input[type=checkbox] {
    width: auto;
    margin-right: 5px;
}

.gform_body textarea {
	height: 200px;
	resize:none;
}


.gform_body span.gfield_required {
	color: #FF0000;
}

.gform_footer {
	position: relative;
	clear: both;
	width: 100%;
}

.gform_wrapper .gform_ajax_spinner {
	padding-left: 0;
	position: absolute;
	right: 10px;
	top: 10px;
	border-radius: 100%;
	z-index: 100;
}

.validation_message {
	color: #FF0000;
}

.gfield_error input,
.gfield_error textarea,
.gfield_error button {
	border-color: #FF0000;
	background: rgba(255, 0, 0, 0.05);
}

.gform_body input[type=text]::-webkit-input-placeholder {
   color: #404040;
}
.gform_body input[type=text]:-moz-placeholder { /* Firefox 18- */
   color: #404040;
}
.gform_body input[type=text]::-moz-placeholder {  /* Firefox 19+ */
   color: #404040;
}
.gform_body input[type=text]:-ms-input-placeholder {
   color: #404040;
}

.gform_body input[type=email]::-webkit-input-placeholder {
   color: #404040;
}
.gform_body input[type=email]:-moz-placeholder { /* Firefox 18- */
   color: #404040;
}
.gform_body input[type=email]::-moz-placeholder {  /* Firefox 19+ */
   color: #404040;
}
.gform_body input[type=email]:-ms-input-placeholder {
	color: #404040;
}

.gform_body textarea::-webkit-input-placeholder {
   color: #404040;
}
.gform_body textarea:-moz-placeholder { /* Firefox 18- */
   color: #404040;
}
.gform_body textarea::-moz-placeholder {  /* Firefox 19+ */
   color: #404040;
}
.gform_body textarea:-ms-input-placeholder {
	color: #404040;
}

.gform_body input[readonly="readonly"] {
    color: #00421d;
    font-weight: 600;
}


.gform_body .gform_validation_container {
	display: none;
}

.gforms_confirmation_message {
	text-align: center;
	font-size: 1.2em;
	color: #00421d;
	font-style: italic;
}


/* fancyBox v3 */
.fancybox-enabled {
  overflow: hidden; }

.fancybox-enabled body {
  overflow: visible;
  height: 100%; }

.fancybox-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 99993;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden; }

/* Make sure that the first one is on the top */
.fancybox-container ~ .fancybox-container {
  z-index: 99992; }

.fancybox-bg {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: #0f0f11;
  opacity: 0;
  transition-timing-function: cubic-bezier(0.55, 0.06, 0.68, 0.19);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden; }

.fancybox-container--ready .fancybox-bg {
  opacity: 0.87;
  transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1); }

.fancybox-controls {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  text-align: center;
  opacity: 0;
  z-index: 99994;
  transition: opacity .2s;
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  direction: ltr; }

.fancybox-show-controls .fancybox-controls {
  opacity: 1; }

.fancybox-infobar {
  display: none; }

.fancybox-show-infobar .fancybox-infobar {
  display: inline-block;
  pointer-events: all; }

.fancybox-infobar__body {
  display: inline-block;
  width: 70px;
  line-height: 44px;
  font-size: 13px;
  font-family: "Helvetica Neue",Helvetica,Arial,sans-serif;
  text-align: center;
  color: #ddd;
  background-color: rgba(30, 30, 30, 0.7);
  pointer-events: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  -webkit-font-smoothing: subpixel-antialiased; }

.fancybox-buttons {
  position: absolute;
  top: 0;
  right: 0;
  display: none;
  pointer-events: all; }

.fancybox-show-buttons .fancybox-buttons {
  display: block; }

.fancybox-slider-wrap {
  overflow: hidden;
  direction: ltr; }

.fancybox-slider-wrap,
.fancybox-slider {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  padding: 0;
  margin: 0;
  z-index: 99993;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-tap-highlight-color: transparent; }

.fancybox-slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  overflow: auto;
  outline: none;
  white-space: normal;
  box-sizing: border-box;
  text-align: center;
  z-index: 99994;
  -webkit-overflow-scrolling: touch; }

.fancybox-slide::before {
  content: '';
  display: inline-block;
  vertical-align: middle;
  height: 100%;
  width: 0; }

.fancybox-slide > * {
  display: inline-block;
  position: relative;
  padding: 24px;
  margin: 44px 0 44px;
  border-width: 0;
  vertical-align: middle;
  text-align: left;
  background-color: #fff;
  overflow: auto;
  box-sizing: border-box; }

.fancybox-slide--image {
  overflow: hidden; }

.fancybox-slide--image::before {
  display: none; }

.fancybox-content {
  display: inline-block;
  position: relative;
  margin: 44px auto;
  padding: 0;
  border: 0;
  width: 80%;
  height: calc(100% - 88px);
  vertical-align: middle;
  line-height: normal;
  text-align: left;
  white-space: normal;
  outline: none;
  font-size: 16px;
  font-family: Arial, sans-serif;
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
  -webkit-overflow-scrolling: touch; }

.fancybox-iframe {
  display: block;
  margin: 0;
  padding: 0;
  border: 0;
  width: 100%;
  height: 100%;
  background: #fff; }

.fancybox-slide--video .fancybox-content,
.fancybox-slide--video .fancybox-iframe {
  background: transparent; }


.fancybox-slide--video .fancybox-content {
  position: relative;
      height: auto;
}
.fancybox-slide--video .fancybox-content:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 56.25%;
}
.fancybox-slide--video .fancybox-content iframe {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}



.fancybox-placeholder {
  position: absolute;
  top: 0;
  left: 0;
  margin: 0;
  padding: 0;
  border: 0;
  z-index: 99995;
  background: transparent;
  cursor: default;
  overflow: visible;
  -webkit-transform-origin: top left;
  -ms-transform-origin: top left;
  transform-origin: top left;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden; }

.fancybox-image,
.fancybox-spaceball {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  border: 0;
  max-width: none;
  max-height: none;
  background: transparent;
  background-size: 100% 100%; }

.fancybox-controls--canzoomOut .fancybox-placeholder {
  cursor: -webkit-zoom-out;
  cursor: zoom-out; }

.fancybox-controls--canzoomIn .fancybox-placeholder {
  cursor: -webkit-zoom-in;
  cursor: zoom-in; }

.fancybox-controls--canGrab .fancybox-placeholder {
  cursor: -webkit-grab;
  cursor: grab; }

.fancybox-controls--isGrabbing .fancybox-placeholder {
  cursor: -webkit-grabbing;
  cursor: grabbing; }

.fancybox-spaceball {
  z-index: 1; }

.fancybox-tmp {
  position: absolute;
  top: -9999px;
  left: -9999px;
  visibility: hidden; }

.fancybox-error {
  position: absolute;
  margin: 0;
  padding: 40px;
  top: 50%;
  left: 50%;
  width: 380px;
  max-width: 100%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  background: #fff;
  cursor: default; }

.fancybox-error p {
  margin: 0;
  padding: 0;
  color: #444;
  font: 16px/20px "Helvetica Neue",Helvetica,Arial,sans-serif; }

.fancybox-close-small {
  position: absolute;
  top: 0;
  right: 0;
  width: 44px;
  height: 44px;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 0;
  outline: none;
  background: transparent;
  z-index: 10;
  cursor: pointer; }

.fancybox-close-small:after {
  content: '×';
  position: absolute;
  top: 5px;
  right: 5px;
  width: 30px;
  height: 30px;
  font: 20px/30px Arial,"Helvetica Neue",Helvetica,sans-serif;
  color: #888;
  font-weight: 300;
  text-align: center;
  border-radius: 50%;
  border-width: 0;
  background: #fff;
  transition: background .2s;
  box-sizing: border-box;
  z-index: 2; }

.fancybox-close-small:focus:after {
  outline: 1px dotted #888; }

.fancybox-slide--video .fancybox-close-small {
  top: -36px;
  right: -36px;
  background: transparent; }

.fancybox-close-small:hover:after {
  color: #555;
  background: #eee; }

/* Caption */
.fancybox-caption-wrap {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 60px 30px 0 30px;
  z-index: 99998;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  box-sizing: border-box;
  opacity: 0;
  transition: opacity .2s;
  pointer-events: none; }

.fancybox-show-caption .fancybox-caption-wrap {
  opacity: 1; }

.fancybox-caption {
	padding: 0 0 25px;
	font-size: 16px;
	color: #fff;
	line-height: 20px;
	-webkit-text-size-adjust: none;
	text-align: center;}

.fancybox-caption a,
.fancybox-caption button {
  pointer-events: all; }

.fancybox-caption a {
  color: #fff;
  text-decoration: underline; }

/* Buttons */
.fancybox-button {
  display: inline-block;
  position: relative;
  width: 44px;
  height: 44px;
  line-height: 44px;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  cursor: pointer;
  background: transparent;
  color: #fff;
  box-sizing: border-box;
  vertical-align: top;
  outline: none; }

.fancybox-button--disabled {
  cursor: default;
  pointer-events: none; }

.fancybox-infobar__body, .fancybox-button {
  background: rgba(30, 30, 30, 0.6); }

.fancybox-button:hover {
  background: rgba(0, 0, 0, 0.8); }

.fancybox-button::before,
.fancybox-button::after {
  content: '';
  pointer-events: none;
  position: absolute;
  border-color: #fff;
  background-color: currentColor;
  color: currentColor;
  opacity: 0.9;
  box-sizing: border-box;
  display: inline-block; }

.fancybox-button--disabled::before,
.fancybox-button--disabled::after {
  opacity: 0.5; }

.fancybox-button--left::after {
  left: 20px;
  top: 18px;
  width: 6px;
  height: 6px;
  background: transparent;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  -webkit-transform: rotate(-135deg);
  -ms-transform: rotate(-135deg);
  transform: rotate(-135deg); }

.fancybox-button--right::after {
  right: 20px;
  top: 18px;
  width: 6px;
  height: 6px;
  background: transparent;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg); }

.fancybox-button--left {
  border-bottom-left-radius: 5px; }

.fancybox-button--right {
  border-bottom-right-radius: 5px; }

.fancybox-button--close {
  float: right; }

.fancybox-button--close::before, .fancybox-button--close::after {
  content: '';
  display: inline-block;
  position: absolute;
  height: 2px;
  width: 16px;
  top: calc(50% - 1px);
  left: calc(50% - 8px); }

.fancybox-button--close::before {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg); }

.fancybox-button--close::after {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg); }

/* Loading spinner */
.fancybox-loading {
  border: 6px solid rgba(100, 100, 100, 0.4);
  border-top: 6px solid rgba(255, 255, 255, 0.6);
  border-radius: 100%;
  height: 50px;
  width: 50px;
  -webkit-animation: fancybox-rotate .8s infinite linear;
  animation: fancybox-rotate .8s infinite linear;
  background: transparent;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -25px;
  margin-left: -25px;
  z-index: 99999; }

@-webkit-keyframes fancybox-rotate {
  from {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  to {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg); } }

@keyframes fancybox-rotate {
  from {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  to {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg); } }

/* Styling for Small-Screen Devices */
@media all and (max-width: 800px) {
  .fancybox-controls {
    text-align: left; }
  .fancybox-button--left,
  .fancybox-button--right,
  .fancybox-buttons button:not(.fancybox-button--close) {
    display: none !important; }
  .fancybox-caption {
    padding: 20px 0;
    margin: 0; } }

/* Fullscreen  */
.fancybox-button--fullscreen::before {
  width: 15px;
  height: 11px;
  left: 15px;
  top: 16px;
  border: 2px solid;
  background: none; }

/* Slideshow button */
.fancybox-button--play::before {
  top: 16px;
  left: 18px;
  width: 0;
  height: 0;
  border-top: 6px inset transparent;
  border-bottom: 6px inset transparent;
  border-left: 10px solid;
  border-radius: 1px;
  background: transparent; }

.fancybox-button--pause::before {
  top: 16px;
  left: 18px;
  width: 7px;
  height: 11px;
  border-style: solid;
  border-width: 0 2px 0 2px;
  background: transparent; }

/* Thumbs */
.fancybox-button--thumbs span {
  font-size: 23px; }

.fancybox-button--thumbs::before {
  top: 20px;
  left: 21px;
  width: 3px;
  height: 3px;
  box-shadow: 0 -4px 0, -4px -4px 0, 4px -4px 0, 0 0 0 32px inset, -4px 0 0, 4px 0 0, 0 4px 0, -4px 4px 0, 4px 4px 0; }

.fancybox-container--thumbs .fancybox-controls,
.fancybox-container--thumbs .fancybox-slider-wrap,
.fancybox-container--thumbs .fancybox-caption-wrap {
  right: 220px; }

.fancybox-thumbs {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: auto;
  width: 220px;
  margin: 0;
  padding: 5px 5px 0 0;
  background: #fff;
  z-index: 99993;
  word-break: normal;
  -webkit-overflow-scrolling: touch;
  -webkit-tap-highlight-color: transparent;
  box-sizing: border-box; }

.fancybox-thumbs > ul {
  list-style: none;
  position: absolute;
  position: relative;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  overflow-y: auto;
  font-size: 0; }

.fancybox-thumbs > ul > li {
  float: left;
  overflow: hidden;
  max-width: 50%;
  padding: 0;
  margin: 0;
  width: 105px;
  height: 75px;
  position: relative;
  cursor: pointer;
  outline: none;
  border: 5px solid #fff;
  border-top-width: 0;
  border-right-width: 0;
  -webkit-tap-highlight-color: transparent;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  box-sizing: border-box; }

li.fancybox-thumbs-loading {
  background: rgba(0, 0, 0, 0.1); }

.fancybox-thumbs > ul > li > img {
  position: absolute;
  top: 0;
  left: 0;
  min-width: 100%;
  min-height: 100%;
  max-width: none;
  max-height: none;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none; }

.fancybox-thumbs > ul > li:before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  border-radius: 2px;
  border: 4px solid #4ea7f9;
  z-index: 99991;
  opacity: 0;
  transition: all 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94); }

.fancybox-thumbs > ul > li.fancybox-thumbs-active:before {
  opacity: 1; }

/* Styling for Small-Screen Devices */
@media all and (max-width: 800px) {
  .fancybox-thumbs {
    display: none !important; }
  .fancybox-container--thumbs .fancybox-controls,
  .fancybox-container--thumbs .fancybox-slider-wrap,
  .fancybox-container--thumbs .fancybox-caption-wrap {
    right: 0; } }



/*--------------------------------------------------------------
##  Animations
--------------------------------------------------------------*/

/* Fade in */

@-webkit-keyframes FadeIn {
  0% {
    opacity: 0;
  }
  100% {
  	opacity: 1;
  }
}
@keyframes FadeIn {
  0% {
    opacity: 0;
  }
  100% {
  	opacity: 1;
  }
}


/* Fade in and up */

@-webkit-keyframes FadeInAndUp {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, 20px, 0);
            transform: translate3d(0, 20px, 0);
  }
  100% {
  	opacity: 1;
    -webkit-transform: translate3d(0, 0px, 0);
            transform: translate3d(0, 0px, 0);
  }
}
@keyframes FadeInAndUp {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, 20px, 0);
            transform: translate3d(0, 20px, 0);
  }
  100% {
  	opacity: 1;
    -webkit-transform: translate3d(0, 0px, 0);
            transform: translate3d(0, 0px, 0);
  }
}


/* Fade in */

@-webkit-keyframes FadeIn {
  0% {
    opacity: 0;
  }
  100% {
  	opacity: 1;
  }
}
@keyframes FadeIn {
  0% {
    opacity: 0;
  }
  100% {
  	opacity: 1;
  }
}

.js .reveal {
	opacity:0;
	will-animate: opacity, translate3d;
}
	.js .reveal.revealed {
	  -webkit-animation: FadeInAndUp 2s ease-out;
	          animation: FadeInAndUp 2s ease-out;
	  -webkit-animation-fill-mode:both;
	          animation-fill-mode:both;
	}
	.js .reveal.FadeIn.revealed {
	  -webkit-animation: FadeIn 2s ease-in-out;
	          animation: FadeIn 2s ease-in-out;
	  -webkit-animation-fill-mode:both;
	          animation-fill-mode:both;
	}
