/*
Theme Name: HighPoint
Version: 1.0
Theme URI: https://highpointfarmevents.com
Author: Radiant Punch Creative
Author URI: https://radiantpunch.com
Description: High Point is a custom theme designed and developed for High Point Farm.
License: GNU General Public License
License URI: https://www.gnu.org/licenses/gpl.html
Text Domain: highpoint
*/

/* ============ NORMALIZE ============ */

html, body, div, header, footer, main, section, article, nav, aside,
h1, h2, h3, h4, h5, h6, p, blockquote, pre, details, summary, dl, dt, dd, ol, ul, li,
img, figure, figcaption, iframe, object, canvas, embed, audio, video,
a, abbr, acronym, address, cite, code, del, dfn, em, ins, kbd, q, ruby, samp, span, strong, var, time,
button, input, fieldset, form, label, legend, output, select, textarea, table, caption, tbody, tfoot, thead, tr, th, td {
	font-size: 100%;
	font: inherit;
	padding: 0;
	border: 0;
	margin: 0;
	vertical-align: baseline;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}

article, aside, details, figcaption, figure, footer, header, nav, section, main {
	display: block
}

body {
	line-height: 1;
}

/* ============ ACCESSIBILITY ============ */

.screen-reader-text {
	clip:rect(1px, 1px, 1px, 1px);
	position:absolute !important
}

/* ============ WP ADMIN ============ */

#wpadminbar {
	position: fixed;
}

.logged-in .site-header {
	margin-top: 46px;
}

/* ============ TYPOGRAPHY ============ */

body,
input,
textarea,
select {
	font-family: Didot, 'Bodoni MT', Baskerville, 'Hoefler Text', Garamond, serif;
	font-size: 16px;
}

body {
	line-height: 1.8;
	color: #000000;
}

p,
h2,
h3,
h4,
h5,
h6,
pre,
address,
ul,
ol,
dl,
blockquote,
hr,
details,
table {
	margin-bottom: 20px;
}

h1,
h2,
h3,
h4,
h5 {
	line-height: 1.2;
}

h2,
.home-section h3,
h3,
.home-section h4,
h5
.home-section h6 {
	font-family: westmount;
	letter-spacing: -0.05em;
}

.home-section h2,
.home-section h5 {
	font-family: Didot, 'Bodoni MT', Baskerville, 'Hoefler Text', Garamond, serif;
	letter-spacing: 0;
	font-weight: normal;
}

h1,
.home-section h2 {
	font-size: 2.25em;
	font-style: italic;
	text-align: center;
}

h1 {
	padding: 15px 30px;
}

h2,
.home-section h3 {
	font-size: 1.8em;
	font-weight: bold;
	color: #333333;
}

h3,
.home-section h4 {
	font-size: 1.6em;
	color: #333333;
}

h4,
.home-section h5 {
	font-size: 1.4em;
	font-style: italic;
}

h5,
.home-section h6 {
	font-size: 1.2em;
	color: #999999;
}

h6 {
	font-weight: bold;
}

a {
	text-decoration: none;
	color: #000000;
	border-bottom: 1px solid #000000;
	padding-bottom: 2px;
}

a:hover {
	color: #333333;
	border-color: #CCCCCC;
}

strong {
	font-weight: bold;
}

em,
cite {
	font-style: italic;
}

abbr[title] {
	text-decoration: none;
	border-bottom: 1px dashed #000000;
	cursor: help;
}

dfn {
	font-weight: bold;
	font-style: italic;
	color: #333333;
}

del {
	color: #999999;
}

ins {
	background-color: #F1F1F1;
	text-decoration: none;
}

mark {
	background-color: #321919;
	color: #FFFFFF;
}

pre {
	white-space: pre-wrap;
	white-space: -moz-pre-wrap;
	white-space: -pre-wrap;
	white-space: -o-pre-wrap;
	word-wrap: break-word;
}

address {
	font-style: italic;
}

ul,
ol {
	margin-left: 20px;
}

ul ul,
ul ol,
ol ol,
ol ul {
	margin-top: 10px;
	margin-bottom: 0;
}

ul ul,
ol ul {
	list-style-type: square;
}

ul ol,
ol ol {
	list-style-type: lower-roman;
}

li {
	margin-bottom: 10px;
	padding-left: 5px;
}

dl {
	margin-left: 20px;
}

dt {
	font-weight: bold;
}

dd {
	margin-bottom: 10px;
}

q {
	quotes: '\201C' '\201D' '\2018' '\2019';
}

blockquote {
	margin-left: 20px;
	font-style: italic;
	letter-spacing: 0.01em;
	position: relative;
}

blockquote::before {
	content: '\201C';
	color: #999999;
	font-size: 2.25em;
	position: absolute;
	left: -20px;
	top: -10px;
}

blockquote p {
	margin-bottom: 10px;
}

blockquote footer {
	font-style: normal;
	border-top: 1px solid #F1F1F1;
	padding-top: 10px;
	display: inline-block;
}

.credentials {
	color: #333333;
}

.credentials a {
	color: #333333;
	border-color: #333333;
}

.credentials a:hover {
	border-color: #F1F1F1;
}

hr {
	border: none;
	height: 1px;
	background-color: #F1F1F1;
}

summary::-webkit-details-marker {
	display: none;
}

summary::before {
	content: '';
	background-image: url(images/simple-arrow.png);
	background-image: url(images/simple-arrow.svg);
	background-repeat: no-repeat;
	background-size: 20px;
	background-position: right center;
	display: block;
	height: 28px;
	width: 28px;
	position: absolute;
	left: -25px;
	-webkit-transform: rotate(180deg);
  	transform: rotate(180deg);
}

summary {
	margin-left: 25px;
	position: relative;
	font-weight: bold;
}

details[open] > summary::before {
	background-position: left center;
	-webkit-transform: rotate(0deg);
  	transform: rotate(0deg);
}

table {
	border-collapse: collapse;
	border-spacing: 0;
	width: 100%;
	border: 1px solid #F1F1F1;
	table-layout: fixed;
	line-height: 1.2;
}

th,
td {
	border: 1px solid #F1F1F1;
	padding: 10px;
}

tr:nth-child(odd) {
	background-color: #F1F1F1;
}

th,
tfoot td {
	font-family: westmount;
	letter-spacing: -0.05em;
	color: #333333; 
	font-size: 1.2em;
}

caption {
	font-style: italic;
	font-size: 1.2em;
	margin-bottom: 10px;
}

table.bt thead,
table.bt tbody th {
	display: none;
}

table.bt tfoot th,
table.bt tfoot td,
table.bt tbody td {
	border: none;
	display: block;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	vertical-align: top;

	/* IE 9 */
	float: left\9;
	width: 100%\9;
}

table.bt tfoot th::before,
table.bt tfoot td::before,
table.bt tbody td::before {
	content: attr(data-th) ": ";
	display: inline-block;
	-webkit-flex-shrink: 0;
	-ms-flex-shrink: 0;
	flex-shrink: 0;
	font-family: westmount;
	letter-spacing: -0.05em;
	width: 6.5em;
}

table.bt tfoot th.bt-hide,
table.bt tfoot td.bt-hide,
table.bt tbody td.bt-hide {
	display: none;
}

table.bt tfoot th .bt-content,
table.bt tfoot td .bt-content,
table.bt tbody td .bt-content {
	vertical-align: top;
	padding-left: 10px;
}

.bt-wrapper.active {
	max-height: 310px;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
}

table.bt.bt--no-header tfoot td::before,
table.bt.bt--no-header tbody td::before {
	display: none;
}

/* ============ FORMS ============ */

fieldset {
	border: 1px solid #F1F1F1;
	padding: 10px;
}

legend {
	font-weight: bold;
	font-style: italic;
	padding: 0 5px;
	font-size: 1.2em;
}

label {
	font-weight: bold;
}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="file"],
input[type="date"],
input[type="month"],
input[type="number"],
input[type="password"],
input[type="time"],
input[type="week"],
input[type="search"],
textarea,
select {
	border: 1px solid #CCCCCC;
	background: #F1F1F1;
	padding: 10px;
	width: 100%;
	color: #333333;
}

textarea::placeholder,
input::placeholder {
	opacity: 0.5;
}

input[type="checkbox"],
input[type="radio"] {
	margin: 0px 10px 0px 0px;
    -webkit-appearance: none;
    width: 25px;
    height: 25px;
    background: #F1F1F1;
   	border: 1px solid #CCCCCC;
   	vertical-align: text-bottom;
}

input[type="radio"] {
	border-radius: 100%;
}

input[type="checkbox"]:checked,
input[type="radio"]:checked {
    background: #333333;
    border-width: 5px;
}

textarea {
	height: 100px;
	line-height: 1.8;
}

select {
	border-radius: 0;
}

input[type="submit"],
input[type="button"],
input[type="reset"],
.button-wrap a {
	font-family: westmount;
	color: #F1F1F1;
	background-color: #000000;
	padding: 10px 20px;
	font-size: 1.2em;
	display: inline-block;
	min-width: 180px;
}

.button-wrap a,
.button-wrap a:hover {
	border: none;
}

/* ============ MEDIA ============ */

figure,
img {
	max-width: 100%;
	height: auto;
	display: block;
	margin: 0 20px 10px;
}

figure img {
	margin-bottom: 0;
}

figcaption,
.wp-caption-text {
	font-style: italic;
	color: #999999;
	line-height: 1.4;
}

.gallery {
	text-align: center;
	line-height: 1;
}

.gallery figure,
.gallery img {
	display: inline-block;
}

body .mejs-container, 
body .mejs-container .mejs-controls,
body .mejs-embed,
body .mejs-embed body {
	background-color: #333333;
}

body .mejs-container * {
	font-family: Didot, 'Bodoni MT', Baskerville, 'Hoefler Text', Garamond, serif;
}

body .mejs-controls .mejs-horizontal-volume-slider .mejs-horizontal-volume-total, 
body .mejs-controls .mejs-time-rail .mejs-time-total {
	background: rgba(241,241,231,.33)
}

body .mejs-controls .mejs-time-rail .mejs-time-current {
	background: #999999;
}

iframe {
	width: 100%;
	height: 250px;
}

/* ============ BASE STRUCTURE ============ */

html {
	height: 100%;
}

body {
	min-height: 100%;
	position: relative;
	padding-bottom: 60px;
}

.site-main {
	padding-top: 70px; 
}

.content-wrap,
.hfeed .post {
	margin: 10px;
	border: 1px solid #F1F1F1;
	padding: 19px;
}

.no-scroll {
	overflow: hidden;
}

/* ============ HEADER ============ */

.site-header {
	width: 100%;
	position: fixed;
	top: 0;
	z-index: 4;
}

.site-header,
.site-header a {
	color: #333333;
}

.site-header,
.branding-wrap {
	height: 70px;
}

.branding-wrap {
	background: #FFFFFF;
	background: -moz-linear-gradient(top, #FFFFFF 0%, #F2F2F2 100%);
	background: -webkit-linear-gradient(top, #FFFFFF 0%,#F2F2F2 100%);
	background: linear-gradient(to bottom, #FFFFFF 0%,#F2F2F2 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#FFFFFF', endColorstr='#F2F2F2',GradientType=0 );
}

.branding {
	display: inline-block;
	border: none;
	padding: 0 10px 0 0;
	height: 70px;
}

.site-logo {
	height: 60px;
	width: auto;
	display: inline-block;
	margin: 5px 0 5px 10px;
}

.site-title {
	font-family: westmount;
	letter-spacing: -0.05em;
	font-weight: bold;
	font-style: normal;
	font-size: 18px;
	display: inline-block;
	margin: 20px 0 0 3px;
	vertical-align: top;
	text-align: center;
	line-height: 1;
	padding: 0;
}

.site-title .subline {
	font-weight: normal;
	display: block;
	background-image: url(images/logo-line.svg);
	background-repeat: repeat-x;
	background-position: center;
	background-size: 100% 100%;
	font-size: 14px;
}

/* ============ MAIN NAV ============ */

.site-nav {
	background-color: #F2F2F2;
}

.site-nav,
.site-nav a {
	color: #333333;
}

.menu-toggle {
	width: 32px;
	height: 32px;
	padding: 0;
	border: none;
	background: none;
	position: absolute;
	top: 19px;
	right: 20px;
}

.menu-toggle img {
	margin: 0;
}

.menu-x,
.menu-toggle.open .menu-bars {
	display: none;
}

.menu-bars,
.menu-toggle.open .menu-x {
	display: block;
}

.menu-links {
	display: none;
	font-family: westmount;
	letter-spacing: -0.05em;
	text-align: center;
	line-height: 1.4;
	font-size: 1.4em;
	margin: 0 0 10px;
}

.site-header.menu-open,
.menu-open .site-nav {
	height: 100%;
}

.menu-open .site-nav {
	overflow: scroll;
	padding-bottom: 70px;
}

.menu-links.open {
	display: block;
}

.menu-links,
.menu-links ul {
	list-style-type: none;
}

.menu-links ul {
	margin: 0;
}

.menu-links li {
	margin: 0;
	padding: 0;
}

.menu-links li a{
	border: 0;
	padding: 10px;
	display: block;
}

/* ============ FOOTER ============ */

.site-footer {
	background: #F2F2F2;
	background: -moz-linear-gradient(top, #F2F2F2 0%, #FFFFFF 100%);
	background: -webkit-linear-gradient(top, #F2F2F2 0%,#FFFFFF 100%);
	background: linear-gradient(to bottom, #F2F2F2 0%,#FFFFFF 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#F2F2F2', endColorstr='#FFFFFF',GradientType=0 );
	font-size: 0.75em;
	padding: 10px;
	text-align: center;
	position: absolute;
	width: 100%;
	bottom: 0;
	height: 60px;
	z-index: 4;
}

.copyright {
	font-style: italic;
}

.site-footer .co-name {
	display: none;
}

.site-footer address {
	font-style: normal;
	margin: 0;
}

/* ============ PAGES ============ */

.banner-image,
.banner-image a {
	color: #FFFFFF;
}

.banner-image a {
	border: none;
	padding: 0;
}

.banner-image {
	padding: 30px;
	background-size: cover;
	background-repeat: no-repeat;
}

.banner-image::after {
	content: '';
	display: block;
	background: url(images/h1-line.svg) no-repeat;
	height: 1px;
	width: 200px;
	background-size: 100%;
	background-position: center;
	margin: 0 auto;
	position: relative;
	top: 5px;
}

/* ============ CTAS ============ */

.cta {
	padding-top: 20px;
	margin-top: 20px;
	border-top: 1px solid #F1F1F1;
}

/* ============ BLOG ============ */

.entry-meta,
.entry-footer,
.single-nav,
.index-nav {
	text-align: center;
}

.entry-meta {
	padding: 10px 30px;
}

.entry-footer {
	border-top: 1px solid #F1F1F1;
	padding-top: 15px;
	margin-top: 20px;
}

.single-nav,
.index-nav {
	padding: 15px 30px 30px;
}

.listing-header {
	text-align: center;
}

/* ============ HOMEPAGE ============ */

.home .site-footer {
	position: relative;
}

.home,
.home .site-main {
	padding: 0;
}

.home-section {
	padding-top: 70px;
	width: 100%;
	background-size: cover;
	position: relative;
	background-repeat: no-repeat;
	background-position: center;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100vh;
}

.home-inner-wrapper {
	position: relative;
	padding: 10px;
	width: 100%;
	margin: 0 auto;
}

.outline {
	border: 1px solid #F1F1F1;
	margin: 10px auto;
}

.outline-inner {
	position: relative;
	
}

.home-content {
	background: rgba(255,255,255,0.9);
	margin: 10px;
	padding: 10px;
}

.home-content h2:last-child,
.home-content p:last-child {
	margin-bottom: 0;
}

.arrow {
	border: none;
	padding: 0;
	margin: 15px auto;
}

.arrow:hover {
	cursor: pointer;
}

.arrow-up {
	-webkit-transform: rotate(180deg);
  	transform: rotate(180deg);
}

.arrow,
.arrow img {
	width: 32px;
	height: 32px;
	display: block;
}

.arrow img,
.arrow-down img {
	margin: 0;	
}

/* ============ SEARCH PAGE ============ */

.search-form {
	text-align: center;
}

.search-form input[type="submit"] {
	margin-top: 15px;
}

/* ============ SPECIAL CLASSES ============ */

.button-wrap {
	text-align: center;
	margin: 0;
}

.mobile-hidden {
	display: none;
}

.shortcode-error {
	border: 1px solid red;
	padding: 10px;
}

.aligncenter {
	text-align: center;
}

.sticky {}
.gallery-caption {}
.bypostauthor {}

/* ============ JAVASCRIPT DISABLED ============ */

noscript {
	font-weight: bold;
	position: relative;
	margin-left: 35px;
}

noscript::before {
	content: '!';
	display: block;
	position: absolute;
	left: -35px;
	border-radius: 100%;
	width: 30px;
	height: 30px;
	background-position: center;
	text-align: center;
}

noscript::before,
.site-noscript {
	background-color: #000000;
	color: #FFFFFF;
}

.site-noscript {
	padding: 10px;
	position: fixed;
	bottom: 0;
	z-index: 5;
	margin: 0;
	font-size: 14px;
	width: 100%;
	text-align: center;
}

.site-noscript::before {
	content: none;
}

/* ============ PLUGINS ============ */

/* Simple Booking Calendar */

.availability-calendar {
	margin-bottom: 20px;
}

.availability-calendar,
.availability-calendar h2 {
	border-color: #F1F1F1;
	border-style: solid;	
	border-width: 0 0 1px;
	padding: 0 0 20px;
}

.sbc-calendar-wrapper {
	clear: both;
	overflow: hidden;
}

#sbc-calendar {
	max-width: 286px;
	margin: 0 auto;
}

#sbc-calendar tr:nth-child(odd) {
	background-color: inherit;
}

#sbc-calendar .sbc-status-free {
	background-color: #FFFFFF;
}

#sbc-calendar .sbc-status-booked {
	background-color: #000000;
}

#sbc-calendar .sbc-status-changeover {
	background-color: #999999;
}

#sbc-calendar .sbc-status-booked,
#sbc-calendar .sbc-status-changeover {
	color: #FFFFFF;
}

#sbc-calendar table {
	table-layout: fixed;
	border: none;
}

#sbc-calendar form {
	border-width: 1px 1px 0;
	border-style: solid;
	border-color: #CCCCCC;
}

#sbc-calendar td,
#sbc-calendar th {
	vertical-align: middle;
	border: 1px solid #CCCCCC;
	background-color: #F1F1F1;
	text-align: center;
	padding: 9px;
}

#sbc-calendar th {
	text-transform: uppercase;
	font-family: Didot, 'Bodoni MT', Baskerville, 'Hoefler Text', Garamond, serif;
}

.sbc-navigation {
	text-align: center;
}

.sbc-navigation select {
	background-color: #FFFFFF;
	border-width: 0 0 1px;
	border-style: solid;
	border-color: #CCCCCC;
	border-radius: 0;
	display: inline-block;
	padding: 10px;
	width: 120px;
	-webkit-appearance: none; 
   	-moz-appearance: none;
	appearance: none;
	padding: 0;
	cursor: pointer;
	margin-bottom: 10px;
}

.sbc-navigation select:nth-child(1) {
	margin-right: 10px;
}

#sbc-calendar .sbc-loader {
	text-align: center;
	visibility: hidden;
	height: 0;
}

#sbc-calendar .sbc-loader-visible {
	visibility: visible;
	height: auto;
}

#sbc-calendar tfoot td {
	background-color: transparent;
	border: none;
	font-size: 0.9em;
}

.calendar-legend {
	margin: 0;
	list-style-type: none;
}

.calendar-legend li {
	padding: 0;
	display: flex;
	align-items: center;
}

.calendar-legend span {
	display: inline-block;
	height: 40px;
	width: 40px;
	border: 1px solid #CCCCCC;
	margin-right: 10px;
}

.calendar-legend .booked {
	background-color: #000000;
}

.calendar-legend .partially-booked {
	background-color: #999999;
}

/* Contact Form 7 */

.screen-reader-response ul,
div.wpcf7-response-output {
	margin-top: 20px;
}

div.wpcf7-response-output,
.screen-reader-response {
	font-weight: bold;
}

.form-row {
	margin-bottom: 20px;
}

/* Meta Slider */

body .flex-control-paging li a {
	background: transparent;
	border: 2px solid #000000;
}

body .metaslider .flexslider .flex-direction-nav li a {
	background-image: url(images/circle-arrow.png);
	background-image: url(images/circle-arrow.svg);

}

body .metaslider .flexslider:hover .flex-prev,
body .flex-direction-nav .flex-prev {
	left: 0
}

body .metaslider .flexslider:hover .flex-next,
body .flex-direction-nav .flex-next {
	right: 0;
}

body .metaslider .flexslider:hover .flex-prev,
body .metaslider .flexslider:hover .flex-next,
body .metaslider .flexslider .flex-direction-nav li a {
	opacity: 0;
}

body .metaslider .flexslider .flex-prev {
	-webkit-transform: rotate(90deg);
  	transform: rotate(90deg);
}

body .metaslider .flexslider .flex-next {
	-webkit-transform: rotate(-90deg);
  	transform: rotate(-90deg);
}

@media screen and (min-width: 768px) {

	/* ============ WP ADMIN ============ */

	.logged-in .site-header {
		margin-top: 32px;
	}

	/* ============ TYPOGRAPHY ============ */

	body,
	input,
	textarea,
	select {
		font-size: 18px;
	}

	h1,
	.home-section h2 {
		font-size: 3em;
	}

	h1 {
		padding: 30px 60px;
	}

	h2,
	.home-section h3 {
		font-size: 2em;
	}

	summary::-webkit-details-marker {
		display: none;
	}

	summary::before {
		height: 32px;
		width: 32px;
	}

	table {
		border: 2px solid transparent;
	}

	tr:nth-child(odd) {
		background-color: transparent;
	}

	/* ============ FORMS ============ */

	textarea {
		height: 150px;
		line-height: 1.8;
	}

	/* ============ MEDIA ============ */

	.alignleft {
		float: left;
		margin-right: 20px;
	}

	.alignright {
		float: right;
		margin-left: 20px;
	}

	.alignright,
	.alignleft {
		max-width: 450px;
	}

	/* ============ BASE STRUCTURE ============ */

	body {
		padding-bottom: 90px;
	}

	.site-main {
		padding-top: 100px; 
	}

	.content-wrap,
	.hfeed .post {
		padding: 49px;
	}

	.no-scroll {
		overflow: auto;
	}

	/* ============ HEADER ============ */

	.site-header,
	.branding-wrap,
	.branding {
		height: 100px;
	}

	.site-header {
		padding: 0 40px;
		display: flex;
		background: #FFFFFF;
		background: -moz-linear-gradient(top, #FFFFFF 0%, #F2F2F2 100%);
		background: -webkit-linear-gradient(top, #FFFFFF 0%,#F2F2F2 100%);
		background: linear-gradient(to bottom, #FFFFFF 0%,#F2F2F2 100%);
		filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#FFFFFF', endColorstr='#F2F2F2',GradientType=0 );
	}

	.branding-wrap {
		background: none;
		width: 200px;
	}

	.site-logo {
		height: 80px;
		margin: 10px 0 10px 10px;
	}

	.site-title {
		margin-top: 32px;
		font-size: 20px;
	}

	.site-title .subline {
		font-size: 16px;
	}

	/* ============ MAIN NAV ============ */

	.menu-toggle {
		display: none;
	}

	.site-nav {
		background: none;
		display: flex;
		align-items: center;
		height: 100px;
		width: calc(100% - 200px);
		overflow: hidden;
	}

	.menu-links {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-end;
		margin: 0;
		font-size: 1em;
	}

	.menu-links li {
		display: inline-block;
		margin-left: 20px;
	}

	.menu-links li a {
		padding: 5px;
	}

	.menu-open .site-nav {
		padding: 0;
	}

	.site-header.menu-open,
	.menu-open .site-nav {
		height: auto;
	}

	/* ============ FOOTER ============ */

	.site-footer {
		height: 90px;
		font-size: 0.9em;
		padding: 15px;
	}

	.home .site-footer,
	.site-footer {
		position: fixed;
	}

	.site-footer .co-name {
		display: inline;
		font-weight: bold;
	}

	.site-footer .co-name::after {
		content: ': ';
	}

	/* ============ PAGES ============ */

	.banner-image {
		padding: 60px;
		background-size: 100%;
	}

	/* ============ CTAS ============ */

	.cta {
		padding-top: 30px;
		margin-top: 30px;
	}

	/* ============ BLOG ============ */

	.entry-meta {
		padding: 10px 0 30px;
	}

	.entry-footer {
		margin-top: 30px;
	}

	.single-nav,
	.index-nav {
		padding: 15px 60px 30px;
	}

	/* ============ HOMEPAGE ============ */

	.home-section {
		padding: 100px 0 90px;
	}

	.home-inner-wrapper {
		margin: 10px;
		border: 1px solid #F1F1F1;
		height: calc(100% - 20px);
		display: flex;
		justify-content: center;
		align-items: center;
		flex-wrap: wrap;
		flex-direction: column;
	}

	.outline {
		margin: 0 100px 20px;
	}

	.home-section.first .outline {
		margin: 0 120px 20px;
	}

	.outline-inner {
		position: relative;
		
	}

	.home-content {
		padding: 20px;
	}

	.arrow {
		position: absolute;
		margin: 0;
	}

	.arrow-up {
		top: 20px;
	}

	.arrow-down {
		bottom: 20px;
	}

	.home-section.first .arrow {
		position: relative;
		bottom: 0;
	}

	/* ============ SPECIAL CLASSES ============ */

	.mobile-hidden {
		display: inline;
	}

	.one-half {
		width: calc(50% - 20px);
		display: inline-block;
		margin-right: 17px;
	}

	.one-half.last {
		margin-right: 0;
		margin-left: 17px;
	}


	/* ============ PLUGINS ============ */

	/* Calendar */

	.sbc-calendar-wrapper,
	.calendar-legend {
		display: inline-block;
		vertical-align: top;
	}
	.sbc-calendar-wrapper {
		margin-right: 20px;
	}

	#sbc-calendar {
		max-width: 460px;
	}

	/* Meta Slider */

	body .metaslider .flexslider:hover .flex-prev,
	body .metaslider .flexslider:hover .flex-next,
	body .metaslider .flexslider .flex-direction-nav li a {
		opacity: 1;
	}

	body .metaslider-flex.metaslider .flexslider ul.slides {
		width: calc(100% - 90px);
		margin:  0 auto;
		max-width: 1080px;
	}
}

@media screen and (min-width: 1025px) {

	/* ============ TYPOGRAPHY ============ */

	h1 {
		font-size: 3.8em;
	}

	/* ============ MEDIA ============ */

	.alignright,
	.alignleft {
		max-width: 100%;
	}

	/* ============ BASE STRUCTURE ============ */

	body,
	.site-main {
		padding: 0;
	}

	.site-main {
		margin-left: 268px;
	}

	.content-wrap,
	.hfeed .post {
		padding: 69px;
	}

	/* ============ HEADER ============ */

	.site-header {
		left: 0;
		height: calc(100% - 250px);
		width: 268px;
		display: block;
		text-align: center;
		padding: 40px;
		background: background: #ffffff;
		background: -moz-linear-gradient(top, #ffffff 0%, #f6f6f6 100%);
		background: -webkit-linear-gradient(top, #ffffff 0%,#f6f6f6 100%);
		background: linear-gradient(to bottom, #ffffff 0%,#f6f6f6 100%);
		filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#f6f6f6',GradientType=0 );
	}

	.branding {
		position: relative;
		padding: 0;
	}

	.branding-wrap, .branding {
		height: auto;
	}

	.branding-wrap {
		width: 100%;
	}

	.site-logo {
		height: 168px;
		margin: 0;
	}

	.site-title {
		position: absolute;
		margin: 0;
		display: block;
		width: 100%;
		bottom: 47px;
		font-size: 16px;
	}

	.site-title .subline {
		background: none;
		font-weight: bold;
	}

	/* ============ MAIN NAV ============ */

	.site-nav {
		height: auto;
	}

	.site-nav,
	.menu-links,
	.menu-links li  {
		display: block;
	}

	.menu-links {
		font-size: 1.2em;
	}

	.site-nav,
	.menu-links {
		width: 100%;
	}

	.menu-links li {
		margin: 0;
	}

	.menu-links li a {
		padding: 10px;
	}

	.menu-open .site-nav {
		padding: 0;
	}

	/* ============ FOOTER ============ */

	.site-footer {
		width: 268px;
		padding: 0 40px 40px;
		left: 0;
		height: 250px;
		line-height: 1.8;
		background: none;
		background: background: #f6f6f6;
		background: -moz-linear-gradient(top, #f6f6f6 0%, #f2f2f2 100%);
		background: -webkit-linear-gradient(top, #f6f6f6 0%,#f2f2f2 100%);
		background: linear-gradient(to bottom, #f6f6f6 0%,#f2f2f2 100%);
		filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f6f6f6', endColorstr='#f2f2f2',GradientType=0 );
	}

	.site-footer address {
		margin-bottom: 30px;
		padding-bottom: 30px;
		border-bottom: 1px solid #CCCCCC;
	}

	.footer-line {
		display: block;
	}

	.site-footer .co-name::after {
		content: none;
	}

	.footer-sep {
		display: none;
	}

	.copyright {
		font-size: 0.9em;
	}

	@media (max-height: 690px) {
		.site-header {
			height: 100%;
		}
		.site-footer {
			display: none;
		}
	}

	/* ============ CTAS ============ */

	.cta .button-wrap {
		margin-top: 30px;
	}

	/* ============ HOMEPAGE ============ */

	.home-section,
	.home-section.first {
		padding: 0;
	}

	.outline,
	.home-section.first .outline {
		margin-left: auto;
		margin-right: auto;
	}

	.outline {
		max-width: 600px;
	}

	.home-section .button-wrap {
		margin-top: 20px;
	}

	.home-content {
		padding: 40px;
	}

	.home-section.first .home-content {
		padding: 20px 40px;
	}

}

@media screen and (min-width: 1280px) {

	.home-section.first .outline {
		max-width: 600px;
	}

	.outline {
		max-width: 800px;
	}

}

@media screen and (min-width: 1025px) and (-ms-high-contrast: none), (min-width: 1025px) and (-ms-high-contrast: active) {
    .site-title {
    	visibility: hidden;
    }
    
}

@media print {

	/* ============ BASE STRUCTURE ============ */

	body,
	.site-main,
	.content-wrap,
	.hfeed .post {
		padding: 0;
		margin: 0;
		border: none;
	}

	/* ============ HEADER ============ */

	.site-header,
	.branding-wrap,
	.branding {
		height: auto;
		background: none;
		padding: 0;
		margin: 0;
	}

	.site-header {
		text-align: center;
		position: relative;
		border-bottom: 1px solid #F1F1F1;
	}

	.branding-wrap {
		width: auto;
	}

	.branding {
		position: relative;
	}

	@media (min-width: 1025px) {
		.site-logo {
			margin: 0;
			height: 150px;
		}

		.site-title {
			position: absolute;
			margin: 0;
			display: block;
			width: 100%;
			bottom: 43px;
			font-size: 14px;
		}

		.site-title .subline {
			background: none;
			font-weight: bold;
			font-size: inherit;
		}
	}

	/* ============ MAIN NAV ============ */

	.site-nav {
		display: none;
	}

	/* ============ FOOTER ============ */

	.site-footer {
		background: none;
		position: relative;
		font-size: inherit;
		height: auto;
	}

	.copyright {
		font-style: italic;
	}

	.site-footer .co-name {
		display: block;
		font-weight: bold;
	}

	/* ============ PAGES ============ */

	.banner-image,
	.banner-image a {
		color: #000000;
	}

	.banner-image {
		padding: 15px 0;
		background: none !important;
	}

	.banner-image::after {
		display: none;
	}

	/* ============ CTAS ============ */

	.cta {
		display: none;
	}

	/* ============ HOMEPAGE ============ */

	.home-section {
		height: auto !important;
		margin: 15px 0;
	}

	.home-section,
	.home-content {
		margin: 15px 0;
	}

	.home-section,
	.home-inner-wrapper,
	.home-content {
		padding: 0;
		background: none !important;
	}

	.outline {
		border: none;
		margin: 0;
	}

	.arrow {
		display: none;
	}

	.mobile-hidden {
		display: block;
	}

	/* ============ SPECIAL CLASSES ============ */

	.button-wrap {
		display: none;
	}

	/* ============ PLUGINS ============ */

	body .metaslider .flexslider {
		margin: 0;
	}

	.slides {
		text-align: center;
	}

	.slides li {
		float: none !important;
		margin: 0 0 15px 0 !important;
		opacity: 1 !important;
		display: inline-block !important;
		max-width: 49% !important;
	}

	body .metaslider .flex-control-nav {
		display: none;
	}

}