/*
==============================================================================================================
 Theme Name:	Ebb & Flow Yoga 2017
 Theme URI:		http://www.ebbflowyoga.com
 Description:	New design and build for the 2017 development of the Ebb & Flow Yoga website.
 Author:		Rooster Marketing
 Author URI:	http://www.roostermarketing.com
 Version:		1.0
 Tags:			stone, blue, pink, gold, light, clean, responsive, responsive-layout, accessibility-ready
==============================================================================================================
*/

/*
==============================================================================================================
 Table of Contents
==============================================================================================================

 * Table of contents for easily navigating this stylesheet
*/

/*
 * 1. Colour palette
 * 2. Resets
 * 3. Global elements & classes
 	  * 3.1. HTML elements
 	  * 3.2. Classes/ID's
 * 4. Layout & structure
 	  * 4.1. Container(s)
 	  * 4.2. Slideout menu
 	  * 4.3. Banner area
 	  * 4.4. Regular content area
 	  * 4.5. Full-height content area
 	  * 4.6. Tabbed content area
 	  * 4.7. Link blocks
 	  * 4.8. CTA banners
 	  * 4.9. Pricing boxes
 	  * 4.10. Schedule table
 	  * 4.10.1 Membership Calculator
 	  * 4.10. Training table
 	  * 4.10. FAQs
 	  * 4.10. Image & Text Blocks
 	  * 4.10. Webinar CTA
 	  * 4.10. Video CTA
 	  * 4.10.1 Workshops list
 	  * 4.11. Blog
 	  * 4.12. Contact details
 	  	* 4.12.1 Generate Video's (Form)
 	  	* 4.12.2 Password Protection (Form)
 	  * 4.13. Lightbox pop-up(s)
 	  * 4.*. Footer area
 	  		 * 4.*.1. Social media
 	  		 * 4.*.2. Newsletter sign-up
 	  		 * 4.*.3. Main footer
 	  		 * 4.*.4. Popup
 * 5. Legacy browser bar
 * 6. Brads Amends 
 	  * 6.1. Video Banner
 	  * 6.2. Social Sharing
 	  * 6.3. Schedule
 	  * 6.4. FAQs
 	  * 6.5. Team Members
 	  * 6.6. Banner Animation
 	  * 6.7. Browser Fixes
*/

/*
==============================================================================================================
 1. Colour palette
==============================================================================================================

 * Define the HEX & RGB values of the primary colours of the website
 * These will be continually used throughout this stylesheet
*/

/*
 * White:	    #ffffff (255,255,255)
 * Grey:	    #f3f2f2 (243,242,242)
 * Blue:	    #30373d (48,55,61)
 * Pink:	    #ab1a5c (171,26,92)
 * Light Pink:  #b37776 (179,119,118)
 * Green:	    #7e876d (126,135,109)
 * Light Green: #99a384 (153,163,132)
 * Stone:	    #ddd6c6 (221,214,198)
 * Gold:        #898066 (137,128,102)
*/

/*
==============================================================================================================
 2. Resets
==============================================================================================================

 * Global CSS resets for most HTML elements
 * Removes all browser-specific styling
*/

/* Ensure all elements don't expand their specified width with padding, borders etc. */
*,
*:before,
*:after {
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
		    box-sizing: border-box;
}

/* Remove browser-specific styling (margin, padding etc.) from most major HTML elements */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend, input, textarea, select, button,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: top;
	border: 0;
}

ol, ul {
	list-style: none inside none;
}

input[type="button"],
input[type="submit"],
input[type="tel"],
input[type="email"],
input[type="text"],
input[type="file"],
textarea {
	-webkit-appearance: none;
	   -moz-appearance: none;
			appearance: none;
	-webkit-border-radius: 0;
	   -moz-border-radius: 0;
			border-radius: 0;
}

input[type=number]::-webkit-inner-spin-button, 
input[type=number]::-webkit-outer-spin-button { 
	-webkit-appearance: none; 
	margin: 0; 
}

select {
    outline: none;
	outline: 0;
	border: 0;
	-webkit-border-radius: 0;
	   -moz-border-radius: 0;
			border-radius: 0;
}

select:focus {
	outline: none;
	outline: 0;
	border: 0;
}

select:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #000;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

/* Display settings for HTML5 elements for legacy browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
	display: block;
}

audio,
canvas,
progress,
video {
	display: inline-block;
	vertical-align: baseline;
}

audio:not([controls]) {
	display: none;
	height: 0;
}

/* Change colour of placeholder text in input fields */
::-webkit-input-placeholder {
	color: #fff;
	opacity: 1;
}

:-moz-placeholder {
	color: #fff;
	opacity: 1;
}

::-moz-placeholder {
	color: #fff;
	opacity: 1;
}

:-ms-input-placeholder {
	color: #fff;
	opacity: 1;
}

::-ms-input-placeholder {
	color: #fff;
	opacity: 1;
}

/* Change colour of text/background in highlighted text */
::-moz-selection {
    color: #fff;
    text-shadow: none;
    background-color: #30373d;
}

::selection {
    color: #fff;
    text-shadow: none;
    background-color: #30373d;
}

/*
==============================================================================================================
 3. Global elements & classes
==============================================================================================================

 * Styling for global HTML elements, and reusable classes and ID's
 * These will appear throughout various pages in the markup
*/

/*
====================
 3.1. HTML elements
====================
*/

/* Font declarations */
html {
	font: normal 400 1em/1 "freight-text-pro", Arial, 'Helvetica Neue', Helvetica, sans-serif;
}

body {
	background-color: #f3f2f2;
}

/* Headings */
h1,
h2,
h3 {
	font: 500 2.5em/1.5 'Montserrat';
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: #fff;
	margin-bottom: 28px;
}

.full-height-content h1,
h2 {
	font-size: 2.188em;
	line-height: 1.428;
	color: #30373d;
}

h3 {
	font-size: 2em;
	line-height: 1.341; 
}

/* Paragraphs/span's etc. */
strong {
	font-weight: 600; /* Adjust font-weight accordingly to your font-face - just make sure it's bold! */
}

/* Links */
a {
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

a[href^="tel:"] {
	text-decoration: none;
	color: #fff;
}

blockquote {
	width: 100%;
	max-width: 550px;
	font-style: italic;
	text-align: center;
	margin: 55px auto;
}

blockquote:before,
blockquote:after {
	content: "";
	width: 155px;
	height: 3px;
	display: block;
	margin: 0 auto;
	background-color: #7e876d;
}

blockquote:before {
	margin-bottom: 24px;
}

blockquote:after {
	margin-top: 24px;
}

blockquote p,
.main-content blockquote p {
	font-size: 1.5em;
	line-height: 1.625;
	margin-bottom: 22px;
}

blockquote p:last-child {
	font-size: 1.125em;
	line-height: 1.444;
}

hr {
	width: 80%;
	height: 3px;
	color: #7e876d;
	display: block;
	border: 0;
	background-color: #7e876d;
}

img.aligncenter {
	display: block;
	margin: 0 auto;
}

p.centered-text {
	text-align: center;
}

/*
===================
 3.2. Classes/ID's
===================
*/

/* Main content styles */
.main-content p + h2,
.main-content p + h3,
.main-content p + h4,
.main-content p + h5,
.main-content p + h6 {
	margin-top: 35px;
}

.read-more {
	position: relative;
	font: 500 0.938em 'Montserrat';
	font-weight: 500 !important;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-align: center;
	text-decoration: none;
	color: #fff !important;
	display: inline-block;
	margin: 45px 10px 0 0;
	padding: 20px 30px;
	cursor: pointer;
	-webkit-transition: width 0.4s ease-in-out;
	   -moz-transition: width 0.4s ease-in-out;
		 -o-transition: width 0.4s ease-in-out;
			transition: width 0.4s ease-in-out;
	-webkit-transform: rotate(0deg);
	   -moz-transform: rotate(0deg);
		 -o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
			transform: rotate(0deg); /* This is needed for the hover effect! */
}

.read-more:last-child {
	margin-right: 0;
}

/*[data-link-class="read-more pink-bg"] > .read-more,
[data-link-class="read-more pink-bg"] > .read-more,
[data-link-class="read-more green-bg"] > .read-more,
[data-link-class="read-more green-bg"] > .read-more {
	margin-top: 15px;
}*/

.read-more:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 0%;
	height: 100%;
	z-index: -1;
	-webkit-transition: width 0.4s ease-in-out;
	   -moz-transition: width 0.4s ease-in-out;
		 -o-transition: width 0.4s ease-in-out;
			transition: width 0.4s ease-in-out;
}

.read-more.pink-bg:before {
	background-color: #b37776;
}

.read-more.green-bg:before {
	background-color: #99a384;
}

.read-more.play-btn:after {
    display: inline-block;
    margin-left: 15px;
    content: url(../img/play-btn.svg);
    width: 14px;
    height: 14px;
    vertical-align: -2px;
    position: static;
    top: unset;
    left: unset;
    z-index: 0;
    opacity: 1;
    background-color: transparent;
}

.no-touchevents .read-more.play-btn:hover:after {
	width: 14px;
}

.read-more.pdf-btn:after {
    display: inline-block;
    margin-left: 15px;
    content: url(../img/pdf-btn.svg);
    width: 14px;
    height: 14px;
    vertical-align: -2px;
    position: static;
    top: unset;
    left: unset;
    z-index: 0;
    opacity: 1;
    background-color: transparent;
}

.no-touchevents .read-more.pdf-btn:hover:after {
	width: 14px;
}

.no-touchevents .read-more:hover:before {
	width: 100%;
}

.back-to-parent {
	position: relative;
	font-style: italic;
	font-weight: 800;
	font-size: 1.125em;
	text-decoration: none;
	color: #7e876d;
	display: table;
	z-index: 1;
	margin: 20px 0 40px;
}

.underline {
	font: 800 1.75em/1 "Bara Grande";
	color: #30373d;
	display: inline-block;
}

.main-content p + .underline {
	margin-top: 30px;
}

.blue-bg .underline {
	text-align: center;
	color: #fff;
}

.underline:after,
.banner-text .logo-wrap:after {
	content: "";
	width: 70%;
	height: 3px;
	display: block;
	margin: 14px 0 25px;
	background-color: #7e876d;
}

.blue-bg .underline:after {
	margin: 14px auto 25px;
}

.blue-bg .left-col-content .underline:after {
	margin: 14px 0 25px;
}

.left-col-content {
	padding-right: 80px;
}

.main-content p {
	font-size: 1.125em;
	line-height: 1.444;
	color: #30373d;
	margin-bottom: 26px;
}

.main-content p:last-of-type,
.main-content p:last-child {
	margin-bottom: 0;
}

.main-content p a {
	position: relative;
	font-weight: 700;
	text-decoration: none;
	color: #7e876d;
	z-index: 1;
}

.main-content p a:after,
.back-to-parent:after {
	content: "";
	position: absolute;
	top: 0;
	left: -2px;
	width: 0%;
	height: 100%;
	z-index: -1;
	opacity: 0.25;
	background-color: #7e876d;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.no-touchevents .main-content p a:hover:after,
.no-touchevents .back-to-parent:hover:after {
	width: 100%;
}

.main-content ul,
.main-content ol {
	margin-bottom: 26px;
}

.main-content p + ul,
.main-content p + ol {
	margin-top: 26px;
}

.main-content ol {
	counter-reset: count-me;
}

.main-content ul li ul,
.main-content ol li ol {
	margin-bottom: 0;
}

.main-content ul li,
.main-content ol li {
	position: relative;
	font-size: 1.125rem;
	line-height: 1.444;
	color: #30373d;
	margin-bottom: 10px;
	padding-left: 15px;
}

.main-content ul li:before {
	content: "\2022";
	position: absolute;
	top: 3px;
	left: 0;
	font-size: 0.75em;
	color: #30373d;
}

.main-content ol li {
	counter-increment: count-me;
	margin-bottom: 20px;
	padding-left: 30px;
}

.main-content ol li:before {
	content: counter(count-me)". ";
	position: absolute;
	top: 0;
	left: 0;
	color: #30373d;
}

.main-content ul li a,
.main-content ol li a {
	text-decoration: none;
	color: #30373d;
	display: inline-block;
}

 .main-content ul li.page_item_has_children > a {
 	margin-bottom: 10px;
 }

.no-touchevents .main-content ul li a:hover,
.no-touchevents .main-content ol li a:hover {
	color: #7e876d;
}

.main-content p + .tick-list,
.main-content p + .tick-list {
	margin-top: 26px;
}

.main-content .tick-list ul li {
	padding-left: 30px;
}

.main-content .tick-list ul li:before {
	content: "\f00c";
	font: 400 1.1em/1 "FontAwesome";
	color: #ab1a5c;
}

.main-content p + img {
	margin-top: 50px;
}

.indent {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
}

.indent + img,
.indent + .wp-caption {
	margin: 50px 0;
	width: 100%;
    max-width: 100%;
}

.main-content p.wp-caption-text {
	font-style: italic;
	font-size: 1em;
	text-align: right;
	margin-top: 4px;
}

.main-content .table-wrap {
	padding: 30px 0; /* Adjust padding accordingly to your design */
}

.main-content table {
	width: 100%;
	font-size: 1em; /* Adjust font-size accordingly to match your body text */
	text-align: left;
	color: #000;
}

.main-content table tr {
	width: 100%;
}

.main-content table tr th {
	font-weight: 600; /* Adjust font-weight accordingly to your font-face - just make sure it's bold! */
}

.main-content table tr th,
.main-content table tr td {
	line-height: 1; /* Adjust line-height accordingly to match your body text */
	padding: 10px; /* Adjust padding accordingly to your design */
	border: 1px solid #ddd; /* Adjust border styles accordingly to your design */
}

/* Extra padding for misc. pages (Search Results, 404 etc.) */
.misc-page {
	padding-top: 30px;
}

/* Vertical centre */
.vertical-centre {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	text-align: center;
	margin: 0 auto;
	-webkit-transform: translateY(-50%);
	   -moz-transform: translateY(-50%);
		 -o-transform: translateY(-50%);
		-ms-transform: translateY(-50%);
			transform: translateY(-50%);
}

/* Hide desktop content (for mobile elements only) */
.desktop-hide {
	display: none;
}

/* Full-screen element(s) */
.full-screen {
	width: 100%;
	height: 100vh;
}

.full-height {
	position: relative;
	height: 100vh;
}

/* Background colours */
.blue-bg {
	background-color: #30373d;
}

.pink-bg {
	background-color: #ab1a5c;
}

.green-bg {
	background-color: #7e876d;
}

.stone-bg {
	background-color: #ddd6c6;
}

/* Full-screen background image(s) */
.cover {
	background: none center top no-repeat transparent;
	-webkit-background-size: cover;
	   -moz-background-size: cover;	
		 -o-background-size: cover;	
			background-size: cover;
}

.ie8 .cover {
	-ms-behavior: url(/backgroundsize.min.htc);
}

/* Remove right-hand margin */
.last-in-row {
	margin-right: 0 !important;
}

/* Force element to clear its floated children */
.clearfix:after,
.clear:after {
	content: "";
	height: 0;
	display: block;
	visibility: hidden;
	clear: both;	
}

/*
==============================================================================================================
 4. Layout & structure
==============================================================================================================
 
 * Styling for the actual layout and structure of the site
 * Organised by section(s), templates and pages
*/

/*
===================
 4.1. Container(s)
===================
*/

.page-wrap {
	width: -webkit-calc(100% - 85px);
	width:	  -moz-calc(100% - 85px);
	width:		   calc(100% - 85px);
	float: right;
}

.page-id-21 .container {
	max-width: 1280px;
}

.container {
	max-width: 1180px;
	margin: 0 auto;
	padding: 0 20px;
}

.container.wider {
	padding-right: 0;
	padding-left: 0;
}

/* Grid columns */
.full {
	width: 100%;
	clear: both;
}

.half {
	width: -webkit-calc(50% - 5px);
	width:	  -moz-calc(50% - 5px);
	width:		   calc(50% - 5px);
	float: left;
	margin-right: 10px;
}

.half:last-of-type,
.half:nth-child(2n+2) {
	margin-right: 0;
}

.ie8 .half {
	width: 50%;
	margin-right: 0;
}

.one-third {
	width: -webkit-calc(33.333% - 6.666px);
	width:	  -moz-calc(33.333% - 6.666px);
	width:		   calc(33.333% - 6.666px);
	float: left;
	margin-right: 10px;
}

.one-third:last-of-type {
	margin-right: 0;
}

.ie8 .one-third {
	width: 33.333%;
	margin-right: 0;
}

.one-quarter {
	width: -webkit-calc(25% - 7.5px);
	width:	  -moz-calc(25% - 7.5px);
	width:		   calc(25% - 7.5px);
	float: left;
	margin-right: 10px;
}

.one-quarter:last-of-type,
.one-quarter:nth-child(4n+4) {
	margin-right: 0;
}

.ie8 .one-quarter {
	width: 25%;
	margin-right: 0;
}

.one-fifth {
	width: 20%;
	float: left;
}

.one-sixth {
	width: 16.666%;
	float: left;
}

.misc-page {
	padding-top: 30px;
	padding-bottom: 60px;
}

/*
====================
 4.2. Slideout menu
====================
*/

.slideout-menu {
	position: fixed;
	top: 0;
	left: -300px;
	width: 385px;
	height: 100vh;
	z-index: 10;
	-webkit-transition: all 0.5s ease-in-out;
	   -moz-transition: all 0.5s ease-in-out;
		 -o-transition: all 0.5s ease-in-out;
			transition: all 0.5s ease-in-out;
}

.ie8 .slideout-menu {
	height: 100%;
}

.slideout-menu.open {
	left: 0;
}

.slideout-menu .menu-wrap {
	position: relative;
	width: 300px;
	height: 100%;
	float: left;
	padding: 30px 30px 0;
	background-color: #30373d;
}

/* Logo */
.logo {
	width: 100%;
	max-width: 230px;
	margin: 0 auto 90px;
}

.logo img {
	width: 100%;
}

/* Menu */
nav.main-menu ul li {
	font-family: "Bara Grande";
	font-size: 1.625em;
	margin-bottom: 34px;
}

nav.main-menu ul li:last-child {
	margin-bottom: 0;
}

nav.main-menu ul li a {
	position: relative;
	text-decoration: none;
	color: #fff;
	z-index: 1;
	padding: 2px 4px;
}

.no-touchevents nav.main-menu ul li a:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 0%;
	height: 100%;
	z-index: -1;
	background-color: #7e876d;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.no-touchevents nav.main-menu ul li a:hover:before,
nav.main-menu ul li.current-menu-item > a:before,
nav.main-menu ul li.current-page-ancestor > a:before {
	width: 100%;
}

nav.main-menu ul li ul {
	display: none;
}

nav.main-menu ul li ul li {
	font: 500 0.875rem 'Montserrat';
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 19px 0 0 26px;
}

.ie9 nav.main-menu ul li ul li,
.ie10 nav.main-menu ul li ul li {
	font-weight: 500;
	font-size: 0.875rem;
	font-family: 'Montserrat', sans-serif;
}

nav.main-menu ul li ul li a {
	padding: 6px;
}

nav.main-menu ul li .expand {
	position: relative;
	width: 18px;
	height: 18px;
	cursor: pointer;
	float: right;
	margin-top: 4px;
}

nav.main-menu ul li .expand span {
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

nav.main-menu ul li .expand .vertical {
	width: 2px;
	height: 100%;
	display: block;
	margin: 0 auto;
	background-color: #7e876d;
}

nav.main-menu ul li .expand .horizontal {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 2px;
	display: block;
	margin: auto;
	background-color: #7e876d;
}

nav.main-menu ul li .expand.open .vertical {
	opacity: 0;
}

.no-touchevents nav.main-menu ul li .expand:hover span {
	background-color: #fff;
}

/* Contact info */
.menu-wrap .contact-info {
	position: absolute;
	bottom: 30px;
	left: 0;
	width: 100%;
	text-align: center;
	color: #fff;
	/*padding: 0 30px;*/
}

.menu-wrap .contact-info p {
	font-size: 1.125em;
	line-height: 1.611;
	color: #fff;
	display: inline-block;
}

.contact-info a {
	text-decoration: none;
	color: #fff;
}

.no-touchevents .contact-info a:hover {
	color: #7e876d;
}


.contact-info .login-register a,
.contact-info a.healcode-login-register-text-link {
	font: 500 0.875rem/1 'Montserrat';
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.contact-info .login-register ul li {
    display: inline-block;
    margin-right: 20px;
}

.contact-info .login-register ul li:last-child {
    margin-right: 0px;
}

.ie9 .contact-info a.healcode-login-register-text-link,
.ie10 .contact-info a.healcode-login-register-text-link {
	font-weight: 500;
	font-size: 0.875rem;
	font-family: 'Montserrat', sans-serif;
}

.contact-info .login-register a:after,
.contact-info a.healcode-login-register-text-link:after {
	content: "";
	width: 32%;
	height: 3px;
	display: block;
	margin: 24px auto 12px;
	background-color: #7e876d;
}

.slideout-menu .menu-toggle {
	position: relative;
	width: 85px;
	height: 100%;
	float: left;
	cursor: pointer;
	padding: 43px 0 30px;
	background-color: #fff;
}

.hamburger {
	width: 35px;
	margin: 0 auto;
}

.hamburger .line {
	position: relative;
	top: 0;
	width: 100%;
	height: 4px;
	display: block;
	margin-bottom: 6px;
	background-color: #7e876d;
	-webkit-transition: -webkit-transform 0.4s ease-in-out, opacity 0.3s ease-in-out 0.4s, top 0.4s ease-in-out 0.45s;
	   -moz-transition:    -moz-transform 0.4s ease-in-out, opacity 0.3s ease-in-out 0.4s, top 0.4s ease-in-out 0.45s;
	     -o-transition: 	 -o-transform 0.4s ease-in-out, opacity 0.3s ease-in-out 0.4s, top 0.4s ease-in-out 0.45s;
		-ms-transition: 	-ms-transform 0.4s ease-in-out, opacity 0.3s ease-in-out 0.4s, top 0.4s ease-in-out 0.45s;
			transition: 		transform 0.4s ease-in-out, opacity 0.3s ease-in-out 0.4s, top 0.4s ease-in-out 0.45s;
}

.hamburger .line.bottom {
	margin-bottom: 0;
}


.hamburger.open .line {
	-webkit-transition: top 0.4s ease-in-out, opacity 0.3s ease-in-out 0.4s, -webkit-transform 0.4s ease-in-out 0.45s;
	   -moz-transition: top 0.4s ease-in-out, opacity 0.3s ease-in-out 0.4s,    -moz-transform 0.4s ease-in-out 0.45s;
	     -o-transition: top 0.4s ease-in-out, opacity 0.3s ease-in-out 0.4s, 	  -o-transform 0.4s ease-in-out 0.45s;
		-ms-transition: top 0.4s ease-in-out, opacity 0.3s ease-in-out 0.4s, 	 -ms-transform 0.4s ease-in-out 0.45s;
			transition: top 0.4s ease-in-out, opacity 0.3s ease-in-out 0.4s, 		 transform 0.4s ease-in-out 0.45s;
}

.hamburger.open .line.top {
	top: 10px;
	-webkit-transform: rotate(45deg);
	   -moz-transform: rotate(45deg);
	     -o-transform: rotate(45deg);
		-ms-transform: rotate(45deg);
			transform: rotate(45deg);
}

.hamburger.open .line.middle {
	opacity: 0;
}

.hamburger.open .line.bottom {
	top: -10px;
	-webkit-transform: rotate(-45deg);
	   -moz-transform: rotate(-45deg);
	     -o-transform: rotate(-45deg);
		-ms-transform: rotate(-45deg);
			transform: rotate(-45deg);
}

/* Mobile menu */
.hamburger.mobile {
	position: fixed;
	top: 10px;
	left: -webkit-calc(100%);
	left:	 -moz-calc(100%);
	left:		  calc(100%);
	width: 50px;
	height: 50px;
	cursor: pointer;
	z-index: 110;
	padding-top: 14px;
	background-color: #7e876d;
	-webkit-transition: all 0.5s ease-in-out;
	   -moz-transition: all 0.5s ease-in-out;
		 -o-transition: all 0.5s ease-in-out;
			transition: all 0.5s ease-in-out;
}

.no-touchevents .hamburger.mobile:hover {
	background-color: #99a384;
}

.hamburger.mobile.open {
	left: 0;
}

.ie8 .hamburger.mobile {
	left: 100%;
}

.hamburger.mobile .line {
	width: 25px;
	height: 3px;
	margin-right: auto;
	margin-left: auto;
	background-color: #fff;
}

.hamburger.mobile.open .line.top {
	top: 9px;
}

.hamburger.mobile.open .line.bottom {
	top: -9px;
}

.slideout-menu.mobile {
	left: auto;
	width: 91.3%;
	width: -webkit-calc(100% - 50px);
	width:	  -moz-calc(100% - 50px);
	width:		   calc(100% - 50px);
	right: -100%;
	z-index: 110;
}

.slideout-menu.mobile.open {
	right: 0;
}

.slideout-menu.mobile .menu-wrap {
	width: 100%;
	float: none;
}

.logo-mark {
	width: 100%;
	max-width: 60px;
	margin: inherit;
	left: auto;
	right: 13px;
	-webkit-transition: all 0.5s ease-in-out;
	   -moz-transition: all 0.5s ease-in-out;
		 -o-transition: all 0.5s ease-in-out;
			transition: all 0.5s ease-in-out;
}

.logo-mark.hidden {
	opacity: 0;
}

.logo-mark img {
	width: 100%;
}

.menu-social {
	position: absolute;
	bottom: 12px;
	left: 0;
	width: 100%;
	z-index: -1;
	opacity: 0;
	-webkit-transition: all 0.5s ease-in-out;
	   -moz-transition: all 0.5s ease-in-out;
		 -o-transition: all 0.5s ease-in-out;
			transition: all 0.5s ease-in-out;
}

.menu-social.open {
	z-index: 1;
	opacity: 1;
}

.menu-social ul li {
	width: 100%;
	text-align: center;
	display: inline-block;
}

.menu-social ul li a {
	text-decoration: none;
	color: #7e876d;
	display: block;
	padding-bottom: 18px;
}

.no-touchevents .menu-social ul li a:hover {
	color: #30373d;
}

.menu-social ul li a i._mi {
	font-size: 1.7em !important;
	margin: 0;
}

.menu-social ul li a span {
	display: none;
}

/* Mobile menu */
.slideout-menu.mobile .mobile-hide {
	display: none;
}

.slideout-menu.mobile .contact-info a.healcode-login-register-text-link:after {
	content: "";
	display: none;
	margin: 0;
}

.slideout-menu.mobile .menu-social {
	position: static;
	text-align: center;
	z-index: 1;
	opacity: 1;
}

.slideout-menu.mobile .menu-social ul li {
	width: auto;
	margin-right: 25px;
}

.slideout-menu.mobile .menu-social ul li:last-child {
	margin-right: 0;
}

.no-touchevents .slideout-menu.mobile .menu-social ul li a:hover {
	color: #99a384;
}

.slideout-menu.mobile .menu-social ul li a i._mi {
	font-size: 2em !important;
}

.mask {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	background-color: rgba(48,55,61, 0.9);
	opacity: 0;
	-webkit-transition: opacity 0.5s ease-in-out, z-index 0.05s ease-in-out 0.5s;
	   -moz-transition: opacity 0.5s ease-in-out, z-index 0.05s ease-in-out 0.5s;
		 -o-transition: opacity 0.5s ease-in-out, z-index 0.05s ease-in-out 0.5s;
			transition: opacity 0.5s ease-in-out, z-index 0.05s ease-in-out 0.5s;
}

.mask.open {
	z-index: 5;
	opacity: 1;
	-webkit-transition: z-index 0.05s ease-in-out, opacity 0.5s ease-in-out 0.05s;
	   -moz-transition: z-index 0.05s ease-in-out, opacity 0.5s ease-in-out 0.05s;
		 -o-transition: z-index 0.05s ease-in-out, opacity 0.5s ease-in-out 0.05s;
			transition: z-index 0.05s ease-in-out, opacity 0.5s ease-in-out 0.05s;
}

/*
==================
 4.3. Banner area
==================
*/

.banner {
	position: relative;
	width: 100%;
	min-height: 500px;
	margin-bottom: 10px;
	background-color: #30373d;
}

.banner.carousel,
.banner.static.has-image {
	min-height: 80vh;
}

.banner.carousel .carousel-slide {
	min-height: 80vh;
}

.banner-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	background-color: #000;
	opacity: 0.35;
}

.ie8 .banner-overlay {
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=35)";
}

.banner-text {
	width: 100%;
	max-width: 770px;
	text-align: center;
	color: #fff;
	z-index: 2;
	opacity: 0;
}

.ie8 .banner-text {
	top: 30%;
}

.banner-text p {
	color: #fff;
}

.banner-text p .read-more {
	margin-top: 0;
}

.banner.carousel .banner-text {
	max-width: 830px;
}

.banner-text .underline {
	font-size: 1.75em;
	letter-spacing: 0.01em;
	color: #fff;
}
.banner-text .underline:after {
	margin: 20px auto 16px;
}

.banner-text .logo-wrap {
	display: inline-block;
}

.banner-text .logo-wrap:after {
	margin: 26px auto 25px;
}

.ie .banner-text .logo-wrap img {
	width: 198px;
	height: 36px;
}

p.banner-heading {
	font: 500 2.188em/1.714 'Montserrat';
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: #fff;
}

/*.banner-text .read-more {
	margin-top: 40px;
}*/

.owl-nav div {
	position: absolute;
	top: 0;
	bottom: 0;
	width: 50px;
	height: 50px;
	font-size: 1.9em;
	text-align: center;
	color: #fff;
	z-index: 2;
	margin: auto;
	padding: 6px 0;
	border: 2px solid #fff;
	-webkit-border-radius: 50%;
	   -moz-border-radius: 50%;
			border-radius: 50%;
	-webkit-transition: all 0.25s ease-in-out;
	   -moz-transition: all 0.25s ease-in-out;
		 -o-transition: all 0.25s ease-in-out;
			transition: all 0.25s ease-in-out;
}

.owl-nav div.owl-prev {
	left: 50px;
	padding-right: 4px;
}

.no-touchevents .owl-nav div.owl-prev:hover {
	left: 47px;
}

.owl-nav div.owl-next {
	right: 50px;
	padding-left: 4px;
}

.no-touchevents .owl-nav div.owl-next:hover {
	right: 47px;
}

.owl-carousel .animated {
	animation-duration: 1800ms;
 }

/* Pink CTA buttons */
.cta-buttons {
	position: absolute;
	top: 20px;
	right: 20px;
	float: right;
	z-index: 100;
}

.cta-buttons .cta-button {
	float: left;
}

.cta-buttons .read-more {
	margin-top: 0;
}

.cta-buttons .fixed {
	position: fixed;
	top: 20px;
	right: 20px;
}

.tel-wrap {
	padding-left: 70px;
}

.tel-icon {
	width: 59px;
	height: 59px;
	text-align: center;
	text-decoration: none;
	color: #fff;
	padding: 17px 0 0;
}

.no-touchevents .tel-icon {
	cursor: default;
}

.tel-icon:before {
	content: "\f095";
	font: 400 1.8em/1 "FontAwesome";
	color: #fff;
}

.tel-icon:after {
	content: attr(title);
	position: absolute;
	top: 53px;
	right: 0;
	width: 200px;
	height: 62px;
	font: 600 1.125rem/1.222 'Montserrat';
	color: #30373d;
	padding-top: 25px;
	background: url(../img/tel-cta-arrow.svg) 90% 2px no-repeat,    -moz-linear-gradient(top, transparent 0%, transparent 12px, #ffffff 12px, #ffffff 100%); /* FF3.6-15 */
	background: url(../img/tel-cta-arrow.svg) 90% 2px no-repeat,        -webkit-gradient(linear, left top, left bottom, color-stop(0%, transparent), color-stop(12px, tranparent), color-stop(12px, #ffffff), color-stop(100%, #ffffff)); /* Chrome4-9,Safari4-5 */
	background: url(../img/tel-cta-arrow.svg) 90% 2px no-repeat, -webkit-linear-gradient(top, transparent 0%, transparent 12px, #ffffff 12px, #ffffff 100%); /* Chrome10-25,Safari5.1-6 */
	background: url(../img/tel-cta-arrow.svg) 90% 2px no-repeat,      -o-linear-gradient(top, transparent 0%, transparent 12px, #ffffff 12px, #ffffff 100%); /* Opera 11.10-11.50 */
	background: url(../img/tel-cta-arrow.svg) 90% 2px no-repeat,     -ms-linear-gradient(top, transparent 0%, transparent 12px, #ffffff 12px, #ffffff 100%); /* IE10 preview */
	background: url(../img/tel-cta-arrow.svg) 90% 2px no-repeat,         linear-gradient(to bottom, transparent 0%, transparent 12px, #ffffff 12px, #ffffff 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	opacity: 0;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.ie9 .tel-icon:after,
.ie10 .tel-icon:after {
	font-weight: 600;
	font-size: 1.125rem;
	font-family: 'Montserrat', sans-serif;
	line-height: 1.222;
}

.no-svg .tel-icon:after {
	background: url(../img/tel-cta-arrow.png) 90% 2px no-repeat,    -moz-linear-gradient(top, transparent 0%, transparent 12px, #ffffff 12px, #ffffff 100%);
	background: url(../img/tel-cta-arrow.png) 90% 2px no-repeat,        -webkit-gradient(linear, left top, left bottom, color-stop(0%, transparent), color-stop(12px, tranparent), color-stop(12px, #ffffff), color-stop(100%, #ffffff));
	background: url(../img/tel-cta-arrow.png) 90% 2px no-repeat, -webkit-linear-gradient(top, transparent 0%, transparent 12px, #ffffff 12px, #ffffff 100%);
	background: url(../img/tel-cta-arrow.png) 90% 2px no-repeat,      -o-linear-gradient(top, transparent 0%, transparent 12px, #ffffff 12px, #ffffff 100%);
	background: url(../img/tel-cta-arrow.png) 90% 2px no-repeat,     -ms-linear-gradient(top, transparent 0%, transparent 12px, #ffffff 12px, #ffffff 100%);
	background: url(../img/tel-cta-arrow.png) 90% 2px no-repeat,         linear-gradient(to bottom, transparent 0%, transparent 12px, #ffffff 12px, #ffffff 100%);
}

.no-multiplebgs .tel-icon:after,
.ie9 .tel-icon:after,
.ie8 .tel-icon:after {
	background: url(../img/tel-cta-bg-fallback.png) center no-repeat;
}

.no-touchevents .tel-icon:hover:after {
	opacity: 1;
}

/*
===========================
 4.4. Regular content area
===========================
*/

.regular-content {
	margin-bottom: 10px;
	padding-top: 90px;
	padding-bottom: 90px;
	position: relative;
}

/*
===============================
 4.5. Full-height content area
===============================
*/

.full-height-content,
.full-screen-carousel {
	margin-bottom: 10px;
}

.full-height .content-wrap {
	width: 100%;
	max-width: 480px;
	text-align: left;
	margin: 0 auto;
}

.ie8 .full-height .content-wrap {
	top: 10%;
}

/*
==========================
 4.6. Tabbed content area
==========================
*/

.tabbed-content {
	margin-bottom: 10px;
}

.tabs .tab {
	position: relative;
	min-height: 235px;
	text-align: center;
	cursor: pointer;
	padding-top: 23px;
	border-bottom: 10px solid #f3f2f2;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.no-touchevents .tabs .tab:not(.active):hover {
	background-color: #99a384;
}

.tabs .tab.active {
	border-color: #ddd6c6;
	background-color: #ddd6c6;
}

.tabs .tab p {
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.tabs .tab:not(.active) p {
	color: #fff;
}

.tabs .tab .underline {
	font-size: 5em;
	line-height: 1;
	margin-bottom: 0;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.tabs .tab .underline:after {
	margin: 20px auto 30px;
}

.tabs .tab:not(.active) .underline:after {
	background-color: #fff;
}

.tab-contents {
	min-height: 500px;
}

.tab-content {
	position: relative;
	min-height: 500px;
	text-align: center;
	display: none;
}

.tab-content.active {
	display: block;
}

.tab-content .content-wrap {
	width: 100%;
	max-width: 550px;
	margin: 0 auto;
}

.tab-content .underline:after {
	margin: 14px auto 25px;
}

/*
==================
 4.7. Link blocks
==================
*/

.link-blocks .link-block {
	width: 100%;
	margin-bottom: 10px;
}

.link-blocks .half {
	position: relative;
	min-height: 550px;
}

.link-blocks .link-block {
	-webkit-transition: all 0.5s ease-in-out;
	   -moz-transition: all 0.5s ease-in-out;
		 -o-transition: all 0.5s ease-in-out;
			transition: all 0.5s ease-in-out;
}

.no-touchevents .link-blocks:hover > .link-block {
	opacity: 0.75;
}

.no-touchevents .link-blocks:hover > .link-block:hover {
	opacity: 1;
}

/*.link-blocks a {
	width: 100%;
	height: 100%;
	text-decoration: none;
	display: block;
	position: absolute;
}*/

.link-block-content .content-wrap {
	width: 100%;
	max-width: 480px;
	margin: 0 auto;
}

.link-block-content .content-wrap h2,
.link-block-content .content-wrap h3 {
	color: #ffffff;
}

.link-block-content {
	text-align: center;
	color: #fff;
}

.link-block-content .underline,
.pricing-box .underline {
	color: #fff;
}

.link-block-content .underline:after,
.pricing-box .underline:after {
	margin-right: auto;
	margin-bottom: 20px;
	margin-left: auto;
}

.link-block-content p {
	line-height: 1.833;
	color: #fff;
}

.link-block-image {
	position: relative;
}

#posts .post-item .image-half .block-button,
.link-block-image .block-button {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	max-height: 60px;
	z-index: 0;
	margin: auto;
}

.link-block-image .block-button:before {
	content: "";
	display: none;
}

.link-block.image-left .link-block-image .block-button {
	left: auto;
	right: 0;
}

/*
==================
 4.8. CTA banners
==================
*/

.cta-banner {
	position: relative;
	text-align: center;
	color: #fff;
	margin-bottom: 10px;
	padding: 100px 0;
}

.cta-banner .half {
	text-align: left;
}

.cta-banner .right-col-content {
	padding-top: 75px;
}

.cta-banner .right-col-content p a.read-more {
	margin-top: 0;
}

.cta-banner .underline,
.cta-banner h2,
.cta-banner h3,
.cta-banner p {
	color: #fff;
}

.cta-banner p + h3:last-of-type, 
.cta-banner p + h2:last-of-type {
	margin-bottom: 0;
}

/*
====================
 4.9. Pricing boxes
====================
*/

.pricing-boxes {
	display: -webkit-box; 
	display: -moz-box;
	display: -ms-flexbox;
	display: -webkit-flex; 
	display: flex;
	margin-bottom: 10px;
}

.pricing-box {
	min-height: 300px;
	text-align: center;
	color: #30373d;
	padding: 40px 2%;
}

.pricing-box.half.box-1,
.pricing-box.half.box-2 {
	margin-top: 0;
}

.pricing-box.one-third.box-1,
.pricing-box.one-third.box-2,
.pricing-box.one-third.box-3 {
	margin-top: 0;
}

.pricing-box .underline,
.pricing-box p {
	color: #30373d;
}

.pricing-box p {
	font-size: 1em;
	line-height: 1.625;
	margin-bottom: 0;
}

/*.pricing-box .read-more {
	margin-top: 30px;
}*/

.price {
	margin: 7px 0 0 0;
}

.price p {
	font-weight: 700;
	font-size: 1rem;
	line-height: 1.625;
	margin-bottom: 0;
}

.price p:first-of-type {
	font: 500 4.375rem/1 'Montserrat';
	margin-bottom: 7px;
}

.ie9 .price p:first-of-type,
.ie10 .price p:first-of-type {
	font-weight: 500;
	font-size: 4.375rem;
	font-family: 'Montserrat', sans-serif;
	line-height: 1;
}

/*
======================
 4.10. Schedule table
======================
*/
/* Any !important tags below are purely for overriding inline styles added by MINDBODY! */

/*
.healcode.schedule {
	position: relative;
	z-index: 1;
	margin-top: -150px;
	overflow: auto;
}

.healcode.schedule .header a.action_icon {
	width: 50px;
	height: 50px;
	text-align: center;
	text-decoration: none;
	color: #7e876d;
	display: inline-block;
	float: right;
	margin-right: 16px;
	padding-top: 10px;
	background-color: #f3f2f2;
}

 .healcode.schedule .header a.action_icon.cart_version:before {
 	content: "\f07a";
 	font: 400 1.8em/1 "FontAwesome";
 	color: #7e876d;
 }

.healcode.schedule .header a.action_icon.print_version {
	margin-right: 0;
}

.healcode.schedule .header a.action_icon.print_version:before {
	content: "\f02f";
	font: 400 1.8em/1 "FontAwesome";
	color: #7e876d;
}

.healcode.schedule .header a.action_icon.my_account_version,
.healcode.schedule .header a.action_icon img {
	display: none;
}

.healcode.schedule .date_links {
	clear: both;
	padding-top: 20px;
}

.healcode.schedule .week_links span {
	width: 100%;
	max-width: 180px;
	height: 60px;
	overflow: hidden;
	float: left;
	margin-right: 20px;
}

.healcode.schedule .week_links span.healcode-next {
	margin-right: 0;
}

div.healcode.schedule .week_links span a,
.healcode.enrollments .week_links span a {
	position: relative;
	width: 100%;
	height: 100%;
	font: 500 0.938em/1 'Montserrat';
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-align: center;
	text-decoration: none;
	color: #fff;
	display: block;
	padding: 23px 0;
	background: #7e876d;
	-webkit-transform: rotate(0deg);
	   -moz-transform: rotate(0deg);
		 -o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
			transform: rotate(0deg);
}

div.healcode.enrollments .healcode-date-links-area span.healcode-next a,
div.healcode.enrollments .healcode-date-links-area span.healcode-previous a {
    -moz-border-radius-topleft: 0px;
     -webkit-border-top-left-radius: 0px; 
    -o-border-top-left-radius: 0px;
    -ms-border-top-left-radius: 0px;
    -khtml-border-top-left-radius: 0px;
     border-top-left-radius: 0px; 
    -moz-border-radius-bottomleft: 0px;
     -webkit-border-bottom-left-radius: 0px; 
    -o-border-bottom-left-radius: 0px;
    -ms-border-bottom-left-radius: 0px;
    -khtml-border-bottom-left-radius: 0px;
     border-bottom-left-radius: 0px; 
}

.healcode.schedule .week_links span a:before,
.healcode.enrollments .week_links span a:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 0%;
	height: 100%;
	z-index: -1;
	background-color: #99a384;
	-webkit-transition: width 0.4s ease-in-out;
	   -moz-transition: width 0.4s ease-in-out;
		 -o-transition: width 0.4s ease-in-out;
			transition: width 0.4s ease-in-out;
}

.no-touchevents .healcode.schedule .week_links span a:hover:before,
.no-touchevents .healcode.enrollments .week_links span a:hover:before {
	width: 100%;
}

.healcode.schedule .week_links span.healcode-jump-to-date,
div.healcode.enrollments .header .healcode-date-links-area .healcode-jump-to-date {
	position: relative;
	width: 100%;
	max-width: 320px;
	height: 60px;
	float: right;
	margin-right: 0;
	border-radius: 0;
	background: none;
    background-color: transparent;
}

div.healcode.enrollments .header input[type="text"] {
	-webkit-border-radius: 0;
    -moz-border-radius: 0;
    -o-border-radius: 0;
    border-radius: 0;
}

.healcode.enrollments .week_links span.healcode-jump-to-date:before,
.healcode.schedule .week_links span.healcode-jump-to-date:before {
	content: "\f133";
	position: absolute;
	top: 15px;
	left: 20px;
	font: 400 1.8em/1 "FontAwesome";
	color: #7e876d;
	z-index: -1;
}


.healcode.schedule .week_links span.healcode-jump-to-date input,
div.healcode.enrollments .header .healcode-date-links-area .healcode-jump-to-date input {
	width: 100%;
	height: 100%;
	font: 500 0.938em/1 'Montserrat';
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: #7e876d;
	padding-left: 65px;
	border: 3px solid #7e876d;
	background-color: transparent;
}

.healcode.schedule .week_links span.healcode-jump-to-date img {
	display: none;
}

.healcode.schedule table,
.healcode.enrollments table.enrollments {
	font: 500 0.938em/1 'Montserrat';
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin-top: 65px;
}

.healcode.schedule table a,
.healcode.enrollments table.enrollments a {
	text-decoration: none;
	color: #fff;
}

.no-touchevents .healcode table a:hover {
	color: #b37776;
}

.healcode.schedule table a.hc-button,
.healcode.enrollments table.enrollments a.hc-button {
	position: relative;
	width: 170px;
	height: 78px;
	text-align: center;
	display: block;
	font-size: 16px;
	padding-top: 30px;
	background-color: #ab1a5c;
	-webkit-border-radius: 0;
    -moz-border-radius: 0;
    -o-border-radius: 0;
    border-radius: 0;
	-webkit-transform: rotate(0deg);
	   -moz-transform: rotate(0deg);
		 -o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
			transform: rotate(0deg);
}

.healcode.enrollments table.enrollments a.hc-button {
	height: 80px;
    padding: 36px 0;
    height: 100%;
    max-width: 145px;
}

.no-touchevents .healcode.schedule table a.hc-button:hover {
	color: #fff;
}

.healcode.schedule table a.hc-button:before,
.healcode.enrollments table.enrollments a.hc-button:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 0%;
	height: 100%;
	z-index: -1;
	background-color: #b37776;
	-webkit-transition: width 0.4s ease-in-out;
	   -moz-transition: width 0.4s ease-in-out;
		 -o-transition: width 0.4s ease-in-out;
			transition: width 0.4s ease-in-out;
}

.no-touchevents .healcode.enrollments table.enrollments a.hc-button:hover:before,
.no-touchevents .healcode.schedule table a.hc-button:hover:before {
	width: 100%;
}

.healcode.schedule table tr,
div.healcode.enrollments table.enrollments tr {
	border-bottom: 5px solid #f3f2f2;
}

.healcode.schedule table tr th,
.healcode.schedule table tr td,
div.healcode.enrollments table.enrollments tr th,
div.healcode.enrollments table.enrollments tr td {
	line-height: 1.4em;
}

div.healcode.enrollments table.enrollments tr th,
div.healcode.enrollments table.enrollments tr td,
div.healcode.enrollments table.enrollments tr tr {
	font-size: 16px;
}

.healcode.schedule table tr th,
div.healcode.enrollments table.enrollments tr th  {
	color: #30373d;
	padding: 40px 20px 24px;
	border: 0;
	background-color: transparent;
}

.healcode.schedule table tr td,
div.healcode.enrollments table.enrollments tr td {
	color: #fff;
	padding: 0;
	border: 0;
	background-color: #30373d;
}

.healcode table tr td:first-child {
	min-width: 180px;
}

.healcode.enrollments table.enrollments tr td:first-child {
	min-width: 280px;
}

.healcode.enrollments table.enrollments tr td.healcode-time-field {
	min-width: 205px;
}

div.healcode.enrollments table.enrollments tr.odd td {
	background-color: #30373d;
}

.healcode.schedule table tr td:first-child,
.healcode.schedule table tr td[class],
div.healcode.enrollments table.enrollments tr td:first-child,
div.healcode.enrollments table.enrollments tr td[class] {
	padding: 18px;
	vertical-align: inherit;
}

.healcode.schedule table tr th.resource,
.healcode.schedule table tr td.resource,
.healcode.schedule table tr th.class_level,
.healcode.schedule table tr td.class_level,
div.healcode.enrollments table.enrollments tr th.resource,
div.healcode.enrollments table.enrollments tr td.resource,
div.healcode.enrollments table.enrollments tr th.class_level,
div.healcode.enrollments table.enrollments tr td.class_level {
	text-align: center;
}

.healcode.schedule table tr td span.hc_waitlist,
.healcode.enrollments table.enrollments tr td span.hc_waitlist  {
    text-align: center;
    display: block;
    padding: 10px;
    background-color: #7e876d;
}

.healcode.schedule .header h1,
.healcode.schedule .header .filters,
.healcode.schedule .hc_footer,
.healcode.enrollments .header h1,
.healcode.enrollments .header .filters,
.healcode.enrollments .hc_footer  {
	display: none !important;
}

div.healcode.enrollments table.enrollments tr td.healcode-button-field {
	padding-top: 0;
	padding-bottom: 0;
	padding: 0!important;
}

*/

/*
=============================
 4.10 Schedule table (new)
=============================
*/
/* Any !important tags below are purely for overriding inline styles added by MINDBODY! */

/*

div#bw-widget__schedules-57852,
div#bw-widget__schedules-212855,
div#bw-widget__schedules-218795 {
	font-weight: 500;
    font-family: 'Montserrat', sans-serif;
}

div#bw-widget__schedules-57852 .bw-calendar-container,
div#bw-widget__schedules-212855 .bw-calendar-container,
div#bw-widget__schedules-218795 .bw-calendar-container {
	background-color: #30373d;
	padding: 30px;
}

div#bw-widget__schedules-57852 .bw-calendar__day--current > span,
div#bw-widget__schedules-212855 .bw-calendar__day--current > span,
div#bw-widget__schedules-218795 .bw-calendar__day--current > span {
	background-color: #7e876d;
}

div#bw-widget__schedules-57852 .bw-calendar__day--today:not(.bw-calendar__day--current) > span,
div#bw-widget__schedules-212855 .bw-calendar__day--today:not(.bw-calendar__day--current) > span,
div#bw-widget__schedules-218795 .bw-calendar__day--today:not(.bw-calendar__day--current) > span {
	color: #ffffff !important;
}

div#bw-widget__schedules-57852 .bw-widget__header,
div#bw-widget__schedules-212855 .bw-widget__header,
div#bw-widget__schedules-218795 .bw-widget__header {
	background-color: #f3f2f2;
	padding: 20px 20px 15px 20px;
}

div#bw-widget__schedules-57852 .bw-widget__header span.bw-header__title,
div#bw-widget__schedules-212855 .bw-widget__header span.bw-header__title,
div#bw-widget__schedules-218795 .bw-widget__header span.bw-header__title {
	text-transform: uppercase;
	color: #30373d;
	font-size: 14px;
	letter-spacing: 0.15em;
}

div#bw-widget__schedules-57852 button.bw-widget__cta,
div#bw-widget__schedules-212855 button.bw-widget__cta,
div#bw-widget__schedules-218795 button.bw-widget__cta,
div#bw-widget__schedules-57852 .bw-widget__header button.bw-header__account-link,
div#bw-widget__schedules-212855 .bw-widget__header button.bw-header__account-link,
div#bw-widget__schedules-218795 .bw-widget__header button.bw-header__account-link {
	display: none;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-widget__cart_button button.bw-widget__cta,
div#bw-widget__schedules-212855 .bw-widget__day .bw-widget__cart_button button.bw-widget__cta,
div#bw-widget__schedules-218795 .bw-widget__day .bw-widget__cart_button button.bw-widget__cta {
	background-color: #ab1a5c;
    font-size: 16px;
	padding: 12px 20px;
    font-weight: 600;
    letter-spacing: 0.15em;
    font-family: 'Montserrat', sans-serif;
    text-transform: uppercase;
    text-align: center;
    color: #ffffff !important;
    display: inline-block;
    margin: 0;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    cursor: pointer;
    -webkit-transition: width 0.4s ease-in-out;
    -moz-transition: width 0.4s ease-in-out;
    -o-transition: width 0.4s ease-in-out;
    transition: width 0.4s ease-in-out;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-widget__cart_button button.bw-widget__cta:hover,
div#bw-widget__schedules-212855 .bw-widget__day .bw-widget__cart_button button.bw-widget__cta:hover,
div#bw-widget__schedules-218795 .bw-widget__day .bw-widget__cart_button button.bw-widget__cta:hover {
	background-color: #b37776;
    color: #ffffff;
	text-decoration: none;
}

div#bw-widget__schedules-57852 .bw-calendar-container button.bw-fullcal-button,
div#bw-widget__schedules-212855 .bw-calendar-container button.bw-fullcal-button,
div#bw-widget__schedules-218795 .bw-calendar-container button.bw-fullcal-button {
	border: 2px solid #7e876d;
	color: #7e876d;
	text-decoration: none;
	text-transform: uppercase;
	padding: 10px 40px;
	font-weight: 600;
	letter-spacing: 0.15em;
}

.no-touchevents div#bw-widget__schedules-57852 .bw-calendar-container button.bw-fullcal-button:hover,
.no-touchevents div#bw-widget__schedules-212855 .bw-calendar-container button.bw-fullcal-button:hover,
.no-touchevents div#bw-widget__schedules-218795 .bw-calendar-container button.bw-fullcal-button:hover {
	background-color: #7e876d;
	color: #ffffff !important;
}

div#bw-widget__schedules-57852 .bw-widget__header svg.bw-widget__filter-icon,
div#bw-widget__schedules-212855 .bw-widget__header svg.bw-widget__filter-icon,
div#bw-widget__schedules-218795 .bw-widget__header svg.bw-widget__filter-icon {
    color: #7e876d;
}

div#bw-widget__schedules-57852 .bw-widget__header button.bw-header__filter-link,
div#bw-widget__schedules-212855 .bw-widget__header button.bw-header__filter-link,
div#bw-widget__schedules-218795 .bw-widget__header button.bw-header__filter-link {
	margin-right: 0;
	padding-right: 0;
	border-right: none;
	cursor: pointer;
}

div#bw-widget__schedules-57852 .bw-widget__header button.bw-header__filter-link:before,
div#bw-widget__schedules-212855 .bw-widget__header button.bw-header__filter-link:before,
div#bw-widget__schedules-218795 .bw-widget__header button.bw-header__filter-link:before {
	content: 'Filter';
	padding-right: 10px;
	text-transform: uppercase;
	font-weight: 600;
	color: #30373d;
	letter-spacing: 0.15em;
}

div#bw-widget__schedules-57852 th.bw-calendar__heading,
div#bw-widget__schedules-212855 th.bw-calendar__heading,
div#bw-widget__schedules-218795 th.bw-calendar__heading {
	color: #ffffff;
	font-weight: 600;
}

div#bw-widget__schedules-57852 .bw-widget td.bw-calendar__day,
div#bw-widget__schedules-212855 .bw-widget td.bw-calendar__day,
div#bw-widget__schedules-218795 .bw-widget td.bw-calendar__day {
	color: #ffffff;
	font-weight: 600;
}

div#bw-widget__schedules-57852 .bw-widget td.bw-calendar__day.bw-calendar__day--past,
div#bw-widget__schedules-212855 .bw-widget td.bw-calendar__day.bw-calendar__day--past,
div#bw-widget__schedules-218795 .bw-widget td.bw-calendar__day.bw-calendar__day--past {
	opacity: 0.4;
}

div#bw-widget__schedules-57852 button.bw-empty__clear,
div#bw-widget__schedules-212855 button.bw-empty__clear,
div#bw-widget__schedules-218795 button.bw-empty__clear {
	border: 2px solid #7e876d;
	color: #7e876d !important;
	text-decoration: none;
	text-transform: uppercase;
	padding: 10px 40px;
	font-weight: 600;
	letter-spacing: 0.15em;
	cursor: pointer;
}

.no-touchevents div#bw-widget__schedules-57852 button.bw-empty__clear:hover,
.no-touchevents div#bw-widget__schedules-212855 button.bw-empty__clear:hover,
.no-touchevents div#bw-widget__schedules-218795 button.bw-empty__clear:hover {
	background-color: #7e876d;
	color: #ffffff !important;
}

div#bw-widget__schedules-57852 .bw-widget__footer,
div#bw-widget__schedules-212855 .bw-widget__footer,
div#bw-widget__schedules-218795 .bw-widget__footer {
	display: none;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-widget__date,
div#bw-widget__schedules-212855 .bw-widget__day .bw-widget__date,
div#bw-widget__schedules-218795 .bw-widget__day .bw-widget__date {
	padding: 20px;
	background-color: #f3f2f2;
	border-bottom: none;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-session,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session {
	padding: 20px;
	background-color: #30373d;
	color: #ffffff;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__time,
div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__name,
div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__staff,
div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__full-title,
div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__description,
div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__description div,
div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__description p,
div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-address__line1,
div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-address__line2,
div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-phone__title,
div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-phone__number {
	color: #ffffff !important;
}

div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__time,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__name,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__staff,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__full-title,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__description,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__description div,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__description p,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-address__line1,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-address__line2,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-phone__title,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-phone__number {
	color: #ffffff !important;
}

div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__time,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__name,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__staff,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__full-title,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__description,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__description div,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__description p,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-address__line1,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-address__line2,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-phone__title,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-phone__number {
	color: #ffffff !important;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__staff,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__staff,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__staff {
	margin-top: 0;
	font-family: 'Montserrat', sans-serif;
	text-transform: uppercase;
    letter-spacing: 0.15em;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__staff span.bw-session__sub,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__staff span.bw-session__sub,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__staff span.bw-session__sub {
	display: none;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__description,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__description,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__description {
	font-family: 'freight-text-pro', Arial, 'Helvetica Neue', Helvetica, sans-serif !important;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__full-title,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__full-title,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__full-title,
div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__name,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__name,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__name {
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-size: 20px;
	line-height: 26px;
	margin-bottom: 0;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__time,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__time,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__time {
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-size: 12px;
}

div#bw-widget__schedules-57852 .bw-widget--medium .bw-session__level,
div#bw-widget__schedules-212855 .bw-widget--medium .bw-session__level,
div#bw-widget__schedules-218795 .bw-widget--medium .bw-session__level {
    display: none;
}

div#bw-widget__schedules-57852 .bw-widget--medium .bw-session__contact,
div#bw-widget__schedules-212855 .bw-widget--medium .bw-session__contact,
div#bw-widget__schedules-218795 .bw-widget--medium .bw-session__contact {
	border-color: rgba(255, 255, 255, 0.2);
}

div#bw-widget__schedules-57852 .bw-widget--medium .bw-session__address,
div#bw-widget__schedules-212855 .bw-widget--medium .bw-session__address,
div#bw-widget__schedules-218795 .bw-widget--medium .bw-session__address {
	border-right: none;
}

div#bw-widget__schedules-57852 .bw-widget--medium .bw-session__instructor-name,
div#bw-widget__schedules-212855 .bw-widget--medium .bw-session__instructor-name,
div#bw-widget__schedules-218795 .bw-widget--medium .bw-session__instructor-name {
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-size: 20px;
	line-height: 26px;
}

div#bw-widget__schedules-57852 .bw-widget--medium .bw-session__instructor-name,
div#bw-widget__schedules-57852 .bw-widget--medium .bw-session__bio,
div#bw-widget__schedules-57852 .bw-widget--medium .bw-session__bio p {
	color: #ffffff;
}

div#bw-widget__schedules-212855 .bw-widget--medium .bw-session__instructor-name,
div#bw-widget__schedules-212855 .bw-widget--medium .bw-session__bio,
div#bw-widget__schedules-212855 .bw-widget--medium .bw-session__bio p {
	color: #ffffff;
}

div#bw-widget__schedules-218795 .bw-widget--medium .bw-session__instructor-name,
div#bw-widget__schedules-218795 .bw-widget--medium .bw-session__bio,
div#bw-widget__schedules-218795 .bw-widget--medium .bw-session__bio p {
	color: #ffffff;
}

div#bw-widget__schedules-57852 .bw-widget--medium .bw-session__bio,
div#bw-widget__schedules-212855 .bw-widget--medium .bw-session__bio,
div#bw-widget__schedules-218795 .bw-widget--medium .bw-session__bio {
    font-family: 'freight-text-pro', Arial, 'Helvetica Neue', Helvetica, sans-serif !important;
}

div#bw-widget__schedules-57852 .bw-widget--medium div.bw-session__availability span.hc_waitlist:not(:empty),
div#bw-widget__schedules-212855 .bw-widget--medium div.bw-session__availability span.hc_waitlist:not(:empty),
div#bw-widget__schedules-218795 .bw-widget--medium div.bw-session__availability span.hc_waitlist:not(:empty) {
	color: #ffffff;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-size: 14px;
	line-height: 24px;
	display: block;
}

div#bw-widget__schedules-57852 button.bw-session__detail-link,
div#bw-widget__schedules-212855 button.bw-session__detail-link,
div#bw-widget__schedules-218795 button.bw-session__detail-link {
	border: none;
	color: #7e876d !important;
	text-decoration: none;
	text-transform: uppercase;
	padding: 0;
	font-weight: 600;
	letter-spacing: 0.15em;
	cursor: pointer;
	min-width: 150px;
	margin-top: 0;
}

div#bw-widget__schedules-57852 .bw-session.bw-session--empty,
div#bw-widget__schedules-212855 .bw-session.bw-session--empty,
div#bw-widget__schedules-218795 .bw-session.bw-session--empty {
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-size: 20px;
	line-height: 26px;
}

.hc-pignose-calendar-bw {
	font-weight: 500;
    font-family: 'Montserrat', sans-serif !important;
}

.hc-pignose-calendar-wrapper .hc-pignose-calendar.hc-pignose-calendar-bw.hc-pignose-calendar-57852 .hc-pignose-calendar-button-group .hc-pignose-calendar-button-cancel {
	color: #696C74 !important;
}

.hc-pignose-calendar-wrapper .hc-pignose-calendar.hc-pignose-calendar-57852 .hc-pignose-calendar-button-group .hc-pignose-calendar-button-apply,
.hc-pignose-calendar-bw.hc-pignose-calendar-57852 .hc-pignose-calendar-body .hc-pignose-calendar-row .hc-pignose-calendar-unit.hc-pignose-calendar-unit-active a {
	background-color: #7e876d !important;
}

div#bw-widget__schedules-57852 .bw-session__info,
div#bw-widget__schedules-57852 .bw-session__group1,
div#bw-widget__schedules-57852 .bw-session__group2 {
    display: -webkit-box; 
	display: -moz-box;
	display: -ms-flexbox;
	display: -webkit-flex; 
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}

div#bw-widget__schedules-212855 .bw-session__info,
div#bw-widget__schedules-212855 .bw-session__group1,
div#bw-widget__schedules-212855 .bw-session__group2 {
    display: -webkit-box; 
	display: -moz-box;
	display: -ms-flexbox;
	display: -webkit-flex; 
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}

div#bw-widget__schedules-218795 .bw-session__info,
div#bw-widget__schedules-218795 .bw-session__group1,
div#bw-widget__schedules-218795 .bw-session__group2 {
    display: -webkit-box; 
	display: -moz-box;
	display: -ms-flexbox;
	display: -webkit-flex; 
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}

div#bw-widget__schedules-57852 .bw-widget--medium .bw-session__time,
div#bw-widget__schedules-212855 .bw-widget--medium .bw-session__time,
div#bw-widget__schedules-218795 .bw-widget--medium .bw-session__time {
	margin-right: 0;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__time,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__time,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__time {
	font-size: 14px;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__name,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__name,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__name {
    font-size: 14px;
}

div#bw-widget__schedules-57852 .bw-widget__day .bw-session .bw-session__full-title,
div#bw-widget__schedules-212855 .bw-widget__day .bw-session .bw-session__full-title,
div#bw-widget__schedules-218795 .bw-widget__day .bw-session .bw-session__full-title {
    margin-bottom: 8px;
}

/*

/*
==============================
 4.10.1 Membership Calculator
==============================
*/

div.membership-calculator {
	margin: 2em 0;
}

div.membership-calculator {
	margin: 2em 0;
}

div.membership-calculator form.membership-calculator__form div.row-wrapper {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-direction: row;
	flex-direction: row;
	gap: 20px;
}

div.membership-calculator form.membership-calculator__form div.select-wrapper {
	width: 100%;
}

div.membership-calculator form.membership-calculator__form div.select-wrapper select {
	padding: 15px 43px 15px 15px;
    border: 2px solid;
    color: #30373d;
    background-color: transparent;
    background-image: url(../img/select-arrow.svg);
    background-repeat: no-repeat;
    background-size: 15px;
    background-position-y: 19px;
    background-position-x: calc(100% - 15px);
    text-overflow: ellipsis;
    width: 100%;
}

div.membership-calculator form.membership-calculator__form div.select-wrapper select.error {
	background-image: url(../img/select-arrow-error.svg);
	color: #d8000c;
    border-color: #d8000c;
    background-color: #ffbaba;
}

div.membership-calculator form.membership-calculator__form span.ajax-loader {
    width: 22px;
    height: 22px;
    clear: both;
    display: inline-block;
    margin: 0 0 0 15px;
    text-indent: -9999em;
    border-top: 4px solid rgba(243, 242, 242, 0.2);
    border-right: 4px solid rgba(243, 242, 242, 0.2);
    border-bottom: 4px solid rgba(243, 242, 242, 0.2);
    border-left: 4px solid #ab1a5c;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    border-radius: 50%;
    vertical-align: middle;
    -webkit-animation: loading 1s infinite linear;
    animation: loading 1s infinite linear;
}

div.membership-calculator form.membership-calculator__form div.result {
	background-color: #30373d;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin-top: 20px;
	padding: 10px;
	width: 100%;
    max-width: 466px;
}

div.membership-calculator form.membership-calculator__form div.result span.monthly-price {
	border-right: 1px solid #ffffff;
}

div.membership-calculator form.membership-calculator__form div.result span.monthly-price,
div.membership-calculator form.membership-calculator__form div.result span.per-class-price {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	text-align: center;
	font-family: 'Montserrat', sans-serif;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-size: 14px;
    font-weight: 700;
    color: #ffffff;
    padding: 0px 20px; 
}

div.membership-calculator form.membership-calculator__form div.result span.monthly-price__title,
div.membership-calculator form.membership-calculator__form div.result span.per-class-price__title {
	display: block;	
}

div.membership-calculator form.membership-calculator__form div.result span.monthly-price__cost,
div.membership-calculator form.membership-calculator__form div.result span.per-class-price__cost {
	display: block;
	margin-top: 5px;	
}

div.membership-calculator form.membership-calculator__form div.result a.read-more {
	margin: 0;
}

/*
============================
 4.10.1.1 Schedule (Manual)
============================
*/

section.flexible-schedule {
	position: relative;
    margin-bottom: 10px;
    padding: 100px 0;
}

section.flexible-schedule div.intro-text {
	max-width: 800px;
	margin: 0 auto 70px auto;
}

section.flexible-schedule div.intro-text p:first-of-type {
	margin-bottom: 0;
}

section.flexible-schedule div.intro-text h2 {
	margin-top: 0;
}

section.flexible-schedule div.intro-text span.underline:after {
	margin: 14px 15% 25px 15%;
}

section.flexible-schedule div.schedule-tables h3.schedule-table__date {
	font-size: 0.875em;
	font-weight: 600;
	color: #30373d;
	margin-left: 36px;
	margin-bottom: 24px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

section.flexible-schedule div.schedule-tables div.schedule-table {
	margin-top: 24px;
}

section.flexible-schedule div.schedule-tables div.schedule-table:first-of-type {
	margin-top: 0;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row {
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
	background-color: #30373d;
	margin-bottom: 10px;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row:last-of-type {
	margin-bottom: 0;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column {
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
	width: 30%;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column.book-link {
	width: 10%;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column span {
	display: block;
	font-family: 'Montserrat', sans-serif;
	font-size: 0.875em;
	line-height: 1.4em;
	font-weight: 600;
	color: #ffffff;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column span.class-title {
	display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    padding: 0;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column span {
	display: block;
	padding: 36px 0;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column span.time,
section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column span.teacher {
	display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    padding: 36px;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column a.description-link {
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
	font-family: 'Montserrat', sans-serif;
	font-size: 0.875em;
	line-height: 1.4em;
	font-weight: 600;
	color: #ffffff;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	text-decoration: none;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column a.description-link span.text {
	width: calc(100% - 18px);
	padding: 0;
	font-size: 1em;
	display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
	-webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column a.description-link svg {
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-item-align: start;
    align-self: flex-start;
	width: 18px;
	height: 18px;
	margin-right: 8px;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column a.description-link svg path {
	fill: #ffffff;
	-webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
}

.no-touchevents section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column a.description-link:hover,
.no-touchevents section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column a.description-link:hover span.text {
	color: #b37776;
}

.no-touchevents section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column a.description-link:hover svg path {
	fill: #b37776;
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column a.book-link {
	position: relative;
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    justify-content: center;
	height: 100%;
	background-color: #ab1a5c;
	color: #ffffff;
	font-family: 'Montserrat', sans-serif;
	font-size: 0.875em;
	line-height: 1.4em;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	text-decoration: none;
	padding: 36px 28px;
	min-width: 114px;
	-webkit-transition: width 0.4s ease-in-out;
    -moz-transition: width 0.4s ease-in-out;
    -o-transition: width 0.4s ease-in-out;
    transition: width 0.4s ease-in-out;
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform: rotate(0deg);
}

section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column a.book-link:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0%;
    height: 100%;
    z-index: -1;
    background-color: #b37776;
    -webkit-transition: width 0.4s ease-in-out;
    -moz-transition: width 0.4s ease-in-out;
    -o-transition: width 0.4s ease-in-out;
    transition: width 0.4s ease-in-out;
}

.no-touchevents section.flexible-schedule div.schedule-tables div.schedule-table div.schedule-table__table div.table-row div.table-row__column a.book-link:hover:before {
    width: 100%;
}

/*
=====================================
 4.10.1.2 Training Schedule (Manual)
=====================================
*/

section.flexible-training-schedule {
	position: relative;
    padding: 100px 0;
}

section.flexible-training-schedule div.intro-text {
	max-width: 800px;
	margin: 0 auto 70px auto;
}

section.flexible-training-schedule div.intro-text p:first-of-type {
	margin-bottom: 0;
}

section.flexible-training-schedule div.intro-text h2 {
	margin-top: 0;
}

section.flexible-training-schedule div.intro-text span.underline:after {
	margin: 14px 15% 25px 15%;
}

section.flexible-training-schedule div.training-schedule div.table-row {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-direction: row;
	flex-direction: row;
	background-color: #30373d;
	color: #ffffff;
	padding: 36px;
	margin-bottom: 10px;
}

section.flexible-training-schedule div.training-schedule div.table-row:last-of-type {
	margin-bottom: 0;
}

section.flexible-training-schedule div.training-schedule div.table-row div.table-row__column {
	width: 33.3333333%;
	padding-right: 36px;
}

section.flexible-training-schedule div.training-schedule div.table-row div.table-row__column.column-three {
	text-align: right;
	padding-right: 0;
}

section.flexible-training-schedule div.training-schedule div.table-row div.table-row__column span {
	display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
	font-family: 'Montserrat', sans-serif;
	font-size: 0.875em;
	line-height: 1.4em;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/*
===============
 4.10.1.3 FAQs 
===============
*/

section.flexible-faqs {
	position: relative;
    padding: 100px 0;
}

section.flexible-faqs div.intro-text {
	max-width: 800px;
	margin: 0 auto 70px auto;
}

section.flexible-faqs div.intro-text p:first-of-type {
	margin-bottom: 0;
}

section.flexible-faqs div.intro-text h2 {
	margin-top: 0;
}

section.flexible-faqs div.intro-text span.underline:after {
	margin: 14px 15% 25px 15%;
}

section.flexible-faqs div.faq-list.faqs-1 {
	border-bottom: 2px solid #DFDFDF;
}

section.flexible-faqs div.faq-list div.faq {
	padding: 1em 10px;
	border-bottom: 2px solid #DFDFDF;
	cursor: pointer;
}

section.flexible-faqs div.faq-list div.faq:last-of-type {
	border-bottom: none;
}

section.flexible-faqs div.faq-list div.faq.open div.faq-heading span.plus-icon span.horizontal {
    transform: rotate(90deg);
}

section.flexible-faqs div.faq-list div.faq.open div.faq-heading span.plus-icon span.vertical {
    opacity: 0;
}	

section.flexible-faqs div.faq-list div.faq div.faq-heading span.plus-icon {
	position: relative;
	display: block;
    width: 18px;
    height: 18px;
}

section.flexible-faqs div.faq-list div.faq div.faq-heading span.plus-icon span {
	position: absolute;
	background-color: #7E876D;
	transition: all 0.3s ease-in-out;
	transform: rotate(-90deg);
}

section.flexible-faqs div.faq-list div.faq div.faq-heading span.plus-icon span.horizontal {
    width: 3px;
    height: 18px;
    left: 50%;
    top: 50%;
    margin-top: -8px;
    margin-left: -1px;
}

section.flexible-faqs div.faq-list div.faq div.faq-heading span.plus-icon span.vertical {
    width: 18px;
    height: 3px;
    left: 50%;
    top: 50%;
    margin-top: -1px;
    margin-left: -8px;
    opacity: 1;
}

section.flexible-faqs div.faq-list div.faq div.faq-heading {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}

section.flexible-faqs div.faq-list div.faq div.faq-heading span.plus-icon {
	position: absolute;
	top: 6px;
	left: 0;
}

section.flexible-faqs div.faq-list div.faq div.faq-heading h3 {
	margin-left: 35px;
	margin-bottom: 0;
	font-family: 'Bara Grande', sans-serif;
	font-weight: 800;
    font-size: 1.8em;
    line-height: 1.2em;
    color: #7E876D;
    text-transform: none;
    letter-spacing: 0;
}

section.flexible-faqs div.faq-list div.faq div.hidden-content {
	display: none;
	padding-left: 35px;
}

section.flexible-faqs div.faq-list div.faq div.hidden-content {
	margin-top: 0.5em;
}

/*
==============================
 4.10.1.4 Image & Text Blocks 
==============================
*/

section.flexible-image-text-blocks {
	position: relative;
    padding: 100px 0;
}

section.flexible-image-text-blocks div.intro-text {
	max-width: 800px;
	margin: 0 auto 70px auto;
}

section.flexible-image-text-blocks div.intro-text p:first-of-type {
	margin-bottom: 0;
}

section.flexible-image-text-blocks div.intro-text h2 {
	margin-top: 0;
}

section.flexible-image-text-blocks div.intro-text span.underline:after {
	margin: 14px 15% 25px 15%;
}

section.flexible-image-text-blocks div.blocks div.block {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-direction: row;
	flex-direction: row;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
    margin-bottom: 4em;
}

section.flexible-image-text-blocks div.blocks div.block:last-of-type {
    margin-bottom: 0;
}

section.flexible-image-text-blocks div.blocks div.block.block--left div.block__image {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
}

section.flexible-image-text-blocks div.blocks div.block.block--left div.block__content {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    padding-right: 4em;
}

section.flexible-image-text-blocks div.blocks div.block.block--right div.block__image {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
}

section.flexible-image-text-blocks div.blocks div.block.block--right div.block__content {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    padding-left: 4em;
}

section.flexible-image-text-blocks div.blocks div.block div.block__image,
section.flexible-image-text-blocks div.blocks div.block div.block__content {
    float: left;
    width: 50%;
}

section.flexible-image-text-blocks div.blocks div.block div.block__content {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-flow: column;
	flex-flow: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

section.flexible-image-text-blocks div.blocks div.block div.block__content h3 {
	color: #30373d;
	font-size: 1.8em;
}

section.flexible-image-text-blocks div.blocks div.block div.block__content p .read-more {
	margin-top: 0;
}

/*
======================
 4.10.1.5 Webinar CTA 
======================
*/

section.flexible-webinar-cta {
	position: relative;
    padding: 100px 0;
    background-color: #ddd6c6;
}

section.flexible-webinar-cta div.intro-text {
	max-width: 800px;
	margin: 0 auto 70px auto;
}

section.flexible-webinar-cta div.intro-text p:first-of-type {
	margin-bottom: 0;
}

section.flexible-webinar-cta div.intro-text h2 {
	margin-top: 0;
}

section.flexible-webinar-cta div.intro-text span.underline:after {
	margin: 14px 15% 25px 15%;
}

section.flexible-webinar-cta div.image-wrapper {
	position: relative;
	overflow: hidden;
}

section.flexible-webinar-cta div.image-wrapper button,
section.flexible-webinar-cta div.image-wrapper a {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 100%;
	max-width: 214px;
	margin: 0;
}

/*
====================
 4.10.1.6 Video CTA 
====================
*/

section.flexible-video-cta {
	position: relative;
    padding: 100px 0;
    background-color: #ddd6c6;
}

section.flexible-video-cta div.intro-text {
	max-width: 800px;
	margin: 0 auto 70px auto;
}

section.flexible-video-cta div.intro-text p:first-of-type {
	margin-bottom: 0;
}

section.flexible-video-cta div.intro-text h2 {
	margin-top: 0;
}

section.flexible-video-cta div.intro-text span.underline:after {
	margin: 14px 15% 25px 15%;
}

/*
================
 4.10.2 Reviews
================
*/
/* Any !important tags below are purely for overriding inline styles added by MINDBODY! */

div.mb-review-widget iframe {
    min-height: 250px !important;
    height: unset !important;
}

div.mb-review-widget .frederick-widget-reviews hr {
	border-top: 1px solid #e9e9e9 !important;
}

/*
======================
 4.10.1 Workshops list
======================
*/
/* Any !important tags below are purely for overriding inline styles added by MINDBODY! */

/*

.healcode.enrollments {
	position: relative;
	z-index: 1;
	margin-top: -150px;
	overflow: auto;
}

.healcode.enrollments a.action_icon {
	width: 50px;
	height: 50px;
	text-align: center;
	text-decoration: none;
	color: #7e876d;
	display: inline-block;
	float: right;
	margin-right: 16px;
	padding-top: 10px;
	background-color: #f3f2f2;
}

 .healcode.enrollments a.action_icon.cart_version:before {
 	content: "\f07a";
 	font: 400 1.8em/1 "FontAwesome";
 	color: #7e876d;
 }

.healcode.enrollments a.action_icon.print_version {
	margin-right: 0;
}

.healcode.enrollments a.action_icon.print_version:before {
	content: "\f02f";
	font: 400 1.8em/1 "FontAwesome";
	color: #7e876d;
}

.healcode.enrollments a.action_icon.my_account_version,
.healcode.enrollments a.action_icon img {
	display: none;
}

.healcode.enrollments .date_links {
	clear: both;
	padding-top: 20px;
}

.healcode.enrollments .week_links span {
	width: 100%;
	max-width: 195px;
	height: 60px;
	overflow: hidden;
	float: left;
	margin-right: 20px;
}

.healcode.enrollments .week_links span.healcode-next {
	margin-right: 0;
}

.healcode.enrollments .week_links span a {
	position: relative;
	width: 100%;
	height: 100%;
	font: 500 0.938em/1 'Montserrat'!important;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-align: center;
	font-size: 16px!important;
	text-decoration: none!important;
	color: #fff;
	display: block;
	padding: 23px 0;
	background-color: #7e876d !important;
	-webkit-transform: rotate(0deg);
	   -moz-transform: rotate(0deg);
		 -o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
			transform: rotate(0deg);
}

.healcode.enrollments .week_links span a:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 0%;
	height: 100%;
	z-index: -1;
	background-color: #99a384;
	-webkit-transition: width 0.4s ease-in-out;
	   -moz-transition: width 0.4s ease-in-out;
		 -o-transition: width 0.4s ease-in-out;
			transition: width 0.4s ease-in-out;
}

.no-touchevents .healcode.enrollments .week_links span a:hover:before {
	width: 100%;
}

.healcode.enrollments .week_links span.healcode-jump-to-date {
	position: relative;
	width: 100%;
	max-width: 410px;
	height: 60px;
	float: right;
	overflow: visible;
	margin-right: 0;
}

.healcode.enrollments .week_links span.healcode-jump-to-date input {
	width: 100%;
	height: 100%;
	font: 500 0.938em/1 'Montserrat';
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: #7e876d;
	padding-left: 65px;
	border: 3px solid #7e876d;
	background-color: transparent;
}

.healcode.enrollments .week_links span.healcode-jump-to-date img {
	display: none;
}

.healcode.enrollments .filtered_collection {
    font: 500 0.938em/1 'Montserrat';
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-top: 65px;
}

.healcode.enrollments .filtered_collection .enrollment {
	padding: 30px;
	background-color: #ddd6c6;
	margin-bottom: 10px;
}

.healcode.enrollments .filtered_collection .enrollment:last-child {
	margin-bottom: 0px;
}

.healcode.enrollments .filtered_collection .enrollment .healcode-image-area {
	display: inline-block;
	float: left;
	width: 20%;
	padding-right: 30px;
}

.healcode.enrollments .filtered_collection .enrollment h2.healcode-enrollment-name,
.healcode.enrollments .filtered_collection .enrollment .healcode-date-area {
	display: inline-block;
	float: left;
	width: 80%;
}

.healcode.enrollments .filtered_collection .enrollment .healcode-description-area,
.healcode.enrollments .filtered_collection .enrollment .healcode-button {
	display: block;
	float: left;
	margin-left: 20%;
}

.healcode.enrollments .filtered_collection .enrollment .healcode-date-area span.healcode-active-days:before {
    content: 'Day: ';
}

.healcode.enrollments .filtered_collection .enrollment .healcode-date-area span.healcode-date-value {
	margin-left: 10px;
	margin-right: 10px;
}

.healcode.enrollments .filtered_collection .enrollment h2.healcode-enrollment-name,
.healcode.enrollments .filtered_collection .enrollment span.healcode-trainer-name {
	font-size: 24px;
}

.healcode.enrollments .filtered_collection .enrollment h2.healcode-enrollment-name {
	margin-bottom: 10px;
}

.healcode.enrollments .filtered_collection .enrollment h2.healcode-enrollment-name a {
	text-decoration: none;
	color: #30373d;
}

.healcode.enrollments .filtered_collection .enrollment .healcode-date-area {
    font-size: 1.313em;
    line-height: 1.4em;
    color: #99a384;
}

.healcode.enrollments .filtered_collection .enrollment .healcode-date-area:after {
    content: "";
    width: 20%;
    height: 3px;
    display: block;
    margin: 10px 0px 0px;
    background-color: #7e876d;
}

.healcode.enrollments .filtered_collection .enrollment .healcode-description-area {
	margin-top: 30px;
    margin-bottom: 30px;
}

.healcode.enrollments .filtered_collection .enrollment .healcode-description-area p,
.healcode.enrollments .filtered_collection .enrollment .healcode-description-area ul {
	font: normal 400 1em/1 "freight-text-pro", Arial, 'Helvetica Neue', Helvetica, sans-serif;
    font-size: 1.125em;
    line-height: 1.444em;
    color: #30373d;
    text-transform: none;
}

.healcode.enrollments .filtered_collection .enrollment .healcode-description-area ul li {
    font-size: inherit;
    line-height: inherit;
}

.healcode.enrollments .filtered_collection .enrollment .healcode-description-area ul li:before {
    top: 0px;
}

.healcode.enrollments .filtered_collection .enrollment a.hc-button {
	position: relative;
	width: 150px;
	height: 60px;
	text-align: center;
	display: block;
	padding-top: 23px;
	background-color: #ab1a5c;
	color: #ffffff;
	text-decoration: none;
	-webkit-transform: rotate(0deg);
	   -moz-transform: rotate(0deg);
		 -o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
			transform: rotate(0deg);
}

.healcode.enrollments .filtered_collection .enrollment a.hc-button:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 0%;
	height: 100%;
	z-index: -1;
	background-color: #b37776;
	-webkit-transition: width 0.4s ease-in-out;
	   -moz-transition: width 0.4s ease-in-out;
		 -o-transition: width 0.4s ease-in-out;
			transition: width 0.4s ease-in-out;
}

.no-touchevents .healcode.enrollments .filtered_collection .enrollment a.hc-button:hover:before {
	width: 100%;
}

.healcode.enrollments .header h1,
.healcode.enrollments .header .filters,
.healcode.enrollments .hc_footer {
	display: none !important;
}


div.healcode.enrollments .header .healcode-date-links-area .healcode-jump-to-date input {
    background: none;
    font-size: 16px;
    height: 60px;
}

 div.healcode.enrollments .healcode-date-links-area span.healcode-next  {
 	height: 60px;
 }

div.healcode.enrollments .week_links span.next_week a, 
div.healcode.enrollments .healcode-date-links-area span.healcode-next a {
    -moz-border-radius-topright: 0;
    -webkit-border-top-right-radius: 0;
    -o-border-top-right-radius: 50;
    -ms-border-top-right-radius: 0;
    -khtml-border-top-right-radius: 0;
    border-top-right-radius: 0;
    -moz-border-radius-bottomright: 0;
     -webkit-border-bottom-right-radius: 0; 
    -o-border-bottom-right-radius: 0;
    -ms-border-bottom-right-radius: 0;
    -khtml-border-bottom-right-radius: 0;
     border-bottom-right-radius: 0; 
     padding-bottom: 23px;
     height: 60px;
}

div.healcode.enrollments .header .healcode-date-links-area {
    border-top: none;
}

*/

/*
==========================
 4.10.2 Registration form
==========================
*/
/* Any !important tags below are purely for overriding inline styles added by MINDBODY! */

div.healcode.registration {
	position: relative;
	margin: 0 auto;
    display: block;
    max-width: 800px;
}

div.healcode.registration h1 {
	color: #30373d;
	font-size: 2.2em;
}

div.healcode.registration div.hc-label,
div.healcode.registration label,
div.healcode.registration div.hc-birth-date > label {
	font-size: 2.2em;
    font-family: 'Bara Grande', sans-serif;
    color: #30373d;
    margin-bottom: 0;
    display: inline-block;
}

div.healcode.registration div.hc-label:after,
div.healcode.registration div.hc-birth-date > label:after {
    content: "";
    width: 70%;
    height: 3px;
    display: block;
    margin: 8px 0 25px;
    background-color: #7e876d;
}

div.healcode.registration div.hc-birth-date > label {
	margin-top: 1em;
}

div.healcode.registration div.hc-birth-date > label,
div.healcode.registration div#hc-liability-release > label {
	margin-bottom: 0;
}

div.healcode.registration label {
	font-size: 100%;
}

div.healcode.registration input::-webkit-input-placeholder { /* Chrome/Opera/Safari */
	color: #30373d;
	letter-spacing: 0.15em;
	text-transform: uppercase;
}

div.healcode.registration input::-moz-placeholder { /* Firefox 19+ */
	color: #30373d;
	letter-spacing: 0.15em;
	text-transform: uppercase;
}

div.healcode.registration input:-ms-input-placeholder { /* IE 10+ */
	color: #30373d;
	letter-spacing: 0.15em;
	text-transform: uppercase;
}

div.healcode.registration input:-moz-placeholder { /* Firefox 18- */
	color: #30373d;
	letter-spacing: 0.15em;
	text-transform: uppercase;
}

div.healcode.registration textarea::-webkit-input-placeholder { /* Chrome/Opera/Safari */
	color: #30373d;
	letter-spacing: 0.15em;
	text-transform: uppercase;
}

div.healcode.registration textarea::-moz-placeholder { /* Firefox 19+ */
	color: #30373d;
	letter-spacing: 0.15em;
	text-transform: uppercase;
}

div.healcode.registration textarea:-ms-input-placeholder { /* IE 10+ */
	color: #30373d;
	letter-spacing: 0.15em;
	text-transform: uppercase;
}

div.healcode.registration textarea:-moz-placeholder { /* Firefox 18- */
	color: #30373d;
	letter-spacing: 0.15em;
	text-transform: uppercase;
}

div.healcode.registration input[type="text"],
div.healcode.registration input[type="email"],
div.healcode.registration input[type="password"],
div.healcode.registration textarea,
div.healcode.registration select {
	background-color: transparent;
	border: 2px solid #30373d;
	font-size: 1.5em;
	font-weight: 500;
    font-family: 'Montserrat', sans-serif;
	padding: 10px;
	color: #30373d;
}

div.healcode.registration input[type="text"],
div.healcode.registration input[type="email"],
div.healcode.registration input[type="password"],
div.healcode.registration textarea {
	width: 100%;
}

div.healcode.registration select {
	width: 100%;
	padding: 10px;
    border: 2px solid;
    color: #30373d;
    background-color: transparent;
    background-image: url(../img/select-arrow.svg);
    background-repeat: no-repeat;
    background-size: 15px;
    background-position-y: 16px;
    background-position-x: calc(100% - 15px);
    text-overflow: ellipsis;
}

div.healcode.registration div.hc-birth-date select {
	max-width: 150px;
}

div.healcode.registration div.hc-registration-field {
	margin-bottom: 1.5em;
}

div.healcode.registration ul.parsley-errors-list li {
	list-style-type: none;
    margin: 0.5em 0 0 0;
    padding: 0;
    font-style: italic;
    font-size: 1em;
    font-weight: 400;
    color: #d8000c;
}

div.healcode.registration ul.parsley-errors-list li:before {
	content: '';
}

div.healcode.registration div.hc-prospect-comment textarea {
	margin-bottom: 1em;
}

div.healcode.registration div {
	font-size: 1em;
	margin: 1em 0;
    font-family: 'Montserrat', sans-serif;
}

div.healcode.registration div.hc-password div.note {
	margin-top: 1em;
	margin-bottom: 0;
	font-size: 1em;
	color: #30373d;
}

div.healcode.registration div#hc-liability-release {
	margin-bottom: 0;
}

div.healcode.registration div.liability {
	background-color: #ffffff;
	width: 100%;
    max-width: 800px;
    min-height: 300px;
    font-size: 12px;
	line-height: 1.444;
	color: #30373d;
}

div.healcode.registration div.liability p {
    font-size: 12px;
    line-height: 1.444;
    color: #30373d;
    margin-bottom: 18px;
}

div.healcode.registration div.hc-liability {
	margin-bottom: 2em;
}

div.healcode.registration input.hc-button {
	background-color: #ab1a5c;
    font-size: 1.3em;
	font-weight: 500;
    font-family: 'Montserrat', sans-serif;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-align: center;
    color: #ffffff;
    display: inline-block;
    margin: 0;
    padding: 20px 30px;
	-webkit-border-radius: 0; 
	-moz-border-radius: 0; 
	border-radius: 0; 
    cursor: pointer;
    -webkit-transition: width 0.4s ease-in-out;
    -moz-transition: width 0.4s ease-in-out;
    -o-transition: width 0.4s ease-in-out;
    transition: width 0.4s ease-in-out;
}

div.healcode.registration input.hc-button:hover {
    background-color: #b37776;
    color: #ffffff;
}

.no-touchevents div.healcode.registration div.hc-privacy-footer img {
	display: none;
}

/*
=========================================
 4.10.3 One to one (appointments widget)
=========================================
*/
/* Any !important tags below are purely for overriding inline styles added by MINDBODY! */

./*

div.healcode .ui-widget-header .ui-icon {
    background-image: url(../img/ui-icons_ffffff_256x240.png);
}

div.healcode.appointments {
	position: relative;
	margin-top: -160px;
	background-color: transparent !important;
}

div.healcode.appointments .header h1 span.healcode-title-text {
	display: none;
}

div.healcode.appointments .header h1 {
	border-bottom: none;
}

div.healcode.appointments div.pre-filters {
	margin-top: 100px;
}

div.healcode.appointments a.action_icon {
	width: 50px;
	height: 50px;
	text-align: center;
	text-decoration: none;
	color: #7e876d;
	display: inline-block;
	float: right;
	margin-right: 16px;
	padding-top: 10px;
	background-color: #f3f2f2;
	font-size: 1.3em;
}

div.healcode.appointments a.action_icon.cart_version img {
 	display: none;
}

div.healcode.appointments a.action_icon.cart_version {
	margin-right: 0;
	margin-left: 0;
}

div.healcode.appointments a.action_icon.cart_version:before {
 	content: "\f007";
 	font: 400 1.8em/1 "FontAwesome";
 	color: #7e876d;
}

div.healcode.appointments a.action_icon.my_account_version span {
	display: none;
}

div.healcode.appointments a.action_icon.my_account_version:before {
	content: "\f07a";
	font: 400 1.8em/1 "FontAwesome";
	color: #7e876d;
}

div.healcode.appointments ul.parsley-errors-list li {
	border-top: none;
	list-style-type: none;
    margin: 0;
    padding: 0;
    font-style: italic;
    font-size: 1.3em;
    font-weight: 400;
    color: #d8000c;
}

div.healcode.appointments ul.parsley-errors-list li:before {
	content: '';
}

div.healcode.appointments select {
	font-size: 1.5em;
	width: 100%;
	padding: 10px;
    border: 2px solid;
    color: #7e876d;
    background-color: transparent;
    background-image: url(../img/select-arrow-green.svg);
    background-repeat: no-repeat;
    background-size: 15px;
    background-position-y: 16px;
    background-position-x: calc(100% - 15px);
    text-overflow: ellipsis;
}

div.healcode.appointments div.ui-datepicker {
	width: 100%;
	padding: 0;
	margin-top: 50px;
	-webkit-border-radius: 0; 
	-moz-border-radius: 0; 
	border-radius: 0; 
}

div.healcode.appointments div.ui-datepicker .ui-widget-header {
	border: none;
	background: #30373d;
	color: #ffffff;
	-webkit-border-radius: 0; 
	-moz-border-radius: 0; 
	border-radius: 0; 
}

div.healcode.appointments div.ui-datepicker .ui-widget-header .ui-datepicker-title {
	line-height: 4em;
	font-size: 2em;
    font-family: 'Bara Grande', sans-serif;
}

div.healcode.appointments .ui-widget-header .ui-datepicker-prev,
div.healcode.appointments .ui-widget-header .ui-datepicker-next {
    top: 45px;
}

div.healcode.appointments .ui-widget-header .ui-datepicker-prev {
    left: 10px;
}

div.healcode.appointments .ui-widget-header .ui-datepicker-next {
    right: 10px;
}

div.healcode.appointments .ui-widget-content {
	border: none;
}

div.healcode.appointments div.ui-datepicker table tr td:first-child {
	min-width: unset !important;
}

div.healcode.appointments div.ui-datepicker table tr th {
	background: #30373d;
    color: #ffffff;
    font-size: 1.2em;
    font-family: 'Bara Grande', sans-serif;
}

div.healcode.appointments div.ui-datepicker table tr td a,
div.healcode.appointments div.ui-datepicker table tr td span {
	background: #e6e6e6;
    height: 50px;
}

div.healcode.appointments div.ui-datepicker table tr td a.ui-state-highlight {
	background: #e6e6e6;
	border: 1px solid #d3d3d3;
}

div.healcode.appointments div.ui-datepicker table tr td a.ui-state-active,
div.healcode.appointments div.ui-datepicker table tr td a.ui-state-hover {
	background-color: #ab1a5c;
	border-color: #ab1a5c;
	color: #ffffff;
}

div.healcode.appointments a.hc-button {
	margin-top: 1em !important;
	background-color: #ab1a5c;
    font-size: 1.3em;
	font-weight: 500;
    font-family: 'Montserrat', sans-serif;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-align: center;
    color: #ffffff;
    display: inline-block;
    margin: 0;
    padding: 20px 30px;
	-webkit-border-radius: 0; 
	-moz-border-radius: 0; 
	border-radius: 0; 
    cursor: pointer;
    -webkit-transition: width 0.4s ease-in-out;
    -moz-transition: width 0.4s ease-in-out;
    -o-transition: width 0.4s ease-in-out;
    transition: width 0.4s ease-in-out;
}

div.healcode.appointments a.hc-button:hover {
    background-color: #b37776;
    color: #ffffff;
}

.no-touchevents div.healcode.appointments div.hc_footer img {
	display: none;
}

div.healcode.appointments div#appointment_results div.healcode-appointments div.appointment-date-block {
    padding-bottom: 25px;
}

div.healcode.appointments div#appointment_results div.healcode-appointments div.appointment-date-block h1.healcode-date-label {
	background-color: #30373d;
    color: #ffffff !important;
    padding: 10px 20px;
}

div.healcode.appointments div#appointment_results div.healcode-appointments div.appointment-date-block div.trainer-label {
	margin-bottom: 1em;
	margin-top: 1em;
}

div.healcode.appointments div#appointment_results div.healcode-appointments div.appointment-date-block div.trainer-label a {
	color: #30373d;
	text-decoration: none;
	font-size: 1.5em;
	display: inline-block;
}

div.healcode.appointments div#appointment_results div.healcode-appointments div.appointment-date-block div.trainer-label a:after {
    content: "";
    width: 70%;
    height: 3px;
    display: block;
    margin: 8px 0 25px;
    background-color: #7e876d;
}

div.healcode.appointments div#appointment_results div.healcode-appointments div.appointment-date-block h1.healcode-date-label {
	color: #30373d;
	border-bottom: 1px solid #30373d;
	font-weight: 500;
}

*/

.footer-main .widget.login-register ul li {
	display: inline-block;
}

.footer-main .widget.login-register ul li:before {
	content: none;
}

.footer-main .widget.login-register ul li:first-child:after {
	content: '|';
	display: inline-block;
	color: #ffffff;
    position: relative;
    top: -5px;
    right: -7px;
}

.footer-main .widget.login-register a {
	font-size: 1.625em;
    line-height: 1.275;
    letter-spacing: 0.1em;
	font-weight: 700;
    color: #fff;
    margin-bottom: 0;
}

.no-touchevents .footer-main .widget.login-register a:hover {
	color: #7e876d;
}

/*
============
 4.11. Blog
============
*/

/* Pagination */
.blog-pagination {
	margin-bottom: 10px;
}

.pagination-box {
	color: #fff;
	background-color: #ab1a5c;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.no-touchevents .pagination-box:hover {
	background-color: #b37776;
}

.prev-post {
	float: left;
	background-color: #b37776;
}

.no-touchevents .prev-post:hover {
	background-color: #ab1a5c;
}

.next-post {
	float: right;
}

.pagination-box a {
	width: 100%;
	min-height: 400px;
	text-decoration: none;
	color: #fff;
	display: block;
	padding: 60px 100px;
}

.pagination-box .underline {
	color: #fff;
	margin-bottom: 24px;
}

.pagination-box .underline:after {
	display: none;
}

.pagination-box h2 {
	color: #fff;
}

/*
=======================
 4.12. Contact details
=======================
*/

.contact-form .content-wrap {
	width: 100%;
	max-width: 75%;
	text-align: center;
}

.wpcf7 form {
	position: relative;
	text-align: left;
}

.wpcf7 form p {
	position: relative;
	font-size: 1em;
	line-height: 1;
	margin-bottom: 24px;
	border-bottom: 2px solid #7e876d;
	-webkit-transition: all 0.3s ease-in-out;
	   -moz-transition: all 0.3s ease-in-out;
		 -o-transition: all 0.3s ease-in-out;
			transition: all 0.3s ease-in-out;
}

.wpcf7 form p:last-of-type,
.wpcf7 form p:last-child {
	border: 0;
}

.wpcf7 form p:nth-last-child(2) {
	border: 0;
}

.wpcf7 form p:nth-last-child(3) {
	margin-bottom: 45px;
}

.wpcf7 form p.focused {
	border-color: #99a384;
}

.wpcf7 label {
	position: absolute;
	bottom: 12px;
	left: 0;
	font: normal 800 1.563em/1 "Bara Grande";
	color: #7e876d;
	-webkit-transition: all 0.3s ease-in-out 0.35s;
	   -moz-transition: all 0.3s ease-in-out 0.35s;
		 -o-transition: all 0.3s ease-in-out 0.35s;
			transition: all 0.3s ease-in-out 0.35s;
}

.wpcf7 label[for="your-message"] {
	position: static;
	display: block;
	margin-top: 48px;
}

.wpcf7 form p.focused label {
	bottom: 40px;
	font-size: 1.125rem;
	color: #99a384;
	-webkit-transition: all 0.3s ease-in-out;
	   -moz-transition: all 0.3s ease-in-out;
		 -o-transition: all 0.3s ease-in-out;
			transition: all 0.3s ease-in-out;
}

.wpcf7 input:not([type="checkbox"]),
.wpcf7 textarea {
	width: 100%;
	font: normal 400 1.125em/1 "freight-text-pro";
	color: #7e876d;
	opacity: 0;
	background-color: transparent;
	-webkit-transition: all 0.3s ease-in-out;
	   -moz-transition: all 0.3s ease-in-out;
		 -o-transition: all 0.3s ease-in-out;
			transition: all 0.3s ease-in-out;
}

.wpcf7 input:not([type="checkbox"]) {
	height: 44px;
}

.wpcf7 input::-webkit-input-placeholder { /* Chrome/Opera/Safari */
	color: #7e876d;
	opacity: 1;
}

.wpcf7 input::-moz-placeholder { /* Firefox 19+ */
	color: #7e876d;
	opacity: 1;
}

.wpcf7 input:-ms-input-placeholder { /* IE 10+ */
	color: #7e876d;
	opacity: 1;
}

.wpcf7 input:-moz-placeholder { /* Firefox 18- */
	color: #7e876d;
	opacity: 1;
}

.wpcf7 form p.focused input {
	opacity: 1;
	-webkit-transition: all 0.3s ease-in-out 0.3s;
	   -moz-transition: all 0.3s ease-in-out 0.3s;
		 -o-transition: all 0.3s ease-in-out 0.3s;
			transition: all 0.3s ease-in-out 0.3s;
}

.wpcf7 textarea {
	height: 130px;
	min-width: 100%;
	max-width: 100%;
	line-height: 1.5;
	margin-top: 20px;
	margin-bottom: 0;
	/*background: url(../img/textarea-bg.png) repeat scroll;*/
	opacity: 1;
}

.wpcf7 input.wpcf7-submit {
	width: auto;
	height: auto;
	font: 500 0.938em 'Montserrat';
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-align: center;
	color: #fff;
	display: inline-block;
	cursor: pointer;
	margin: 48px auto 0;
	padding: 20px 30px;
	border: 0;
	background-color: #ab1a5c;
	opacity: 1;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
	-webkit-transform: rotate(0deg);
	   -moz-transform: rotate(0deg);
		 -o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
			transform: rotate(0deg); /* This is needed for the hover effect! */
}

.no-touchevents .wpcf7 input.wpcf7-submit:hover {
	background-color: #b37776;
}

div.wpcf7 .ajax-loader {
	width: 40px !important;
	height: 40px !important;
	margin-left: 8px !important;
	background-image: url(../img/contact-loading.svg) !important;
}

.no-svg div.wpcf7 .ajax-loader,
.ie div.wpcf7 .ajax-loader {
	background-image: url(../img/contact-loading.gif) !important;
}

span.wpcf7-not-valid-tip {
	position: absolute;
	bottom: -32px;
	font-size: 0.75em !important;
	color: #d8000c !important;
}

div.wpcf7 div.wpcf7-response-output {
	width: 100%;
	font-weight: 400;
	font-size: 1.125em;
	line-height: 1.444;
	margin: 0 0 20px;
	padding: 10px;
}

div.wpcf7 .wpcf7-response-output.wpcf7-validation-errors,
div.wpcf7 .wpcf7-response-output.wpcf7-mail-sent-ng {
	color: #d8000c;
	border: 1px solid #d8000c;
    background-color: #ffbaba;
}

div.wpcf7 .wpcf7-response-output.wpcf7-mail-sent-ok {
	color: #4f8a10;
	border: 1px solid #4f8a10;
	background-color: #dff2bf;
}

/* GDPR CHECKBOX - 13-4-18 */

.checkbox {
	clear: both;
}

.newsletter-sign-up .checkbox {
	padding: 20px 0 10px 0;
}

.checkbox label {
	color: #7e876d;
	position: static;
}

.checkbox.options {
    margin-top: 48px;
    margin-bottom: 24px;
}

.checkbox.options .wpcf7-checkbox {
	display: flex;
    flex-direction: column;
    gap: 5px;
	margin-top: 20px;
}

.checkbox.options .wpcf7-checkbox label {
	font-size: 0.850rem;
}

.checkbox.gdpr-terms label {
	font-size: 0.750rem;
}

.checkbox label a {
	display: inline-block;
	color: #7e876d;
}

.no-touchevents .checkbox label a:hover {
	color: #ffffff;
}

.checkbox input[type="checkbox"] {
	margin: 0px 5px 0px 0px;
	position: relative;
	top: 2px;
	cursor: pointer;
	display: inline;
	opacity: 1;
	-webkit-appearance: checkbox;
	appearance: checkbox;
}

.checkbox .wpcf7-list-item {
	margin: 0;
}

.checkbox .wpcf7-list-item-label {
	display: inline;
}

.checkbox span.wpcf7-not-valid-tip {
	bottom: -25px;
}

.contact-map {
	position: relative;
	width: 100%;
	height: 500px;
	margin-bottom: 10px;
	background-color: #ccc;
}

.contact-map .read-more {
	position: absolute;
	bottom: 0;
	right: 0;
	left: 0;
	width: 100%;
	max-width: 300px;
	margin: auto;
}

/*
================================
 4.12.1 Generate Video's (Form)
================================
*/

form#generate-videos {
    max-width: 800px;
    margin: 0 auto;
}

form#generate-videos fieldset#step-1,
form#generate-videos fieldset#step-2 {
	margin-bottom: 2em;
}

form#generate-videos fieldset#step-2,
form#generate-videos fieldset#step-3 {
	opacity: 1;
	transition: opacity 0.4s ease-in-out;
   	-moz-transition: opacity 0.4s ease-in-out;
   	-webkit-transition: opacity 0.4s ease-in-out;
}

form#generate-videos fieldset#step-2.hidden,
form#generate-videos fieldset#step-3.hidden {
	opacity: 0.1;
	pointer-events: none;
}

form#generate-videos input[type='text'], 
form#generate-videos input[type='number'],
form#generate-videos input[type='email'],
form#generate-videos select {
	-moz-appearance: none;
    -webkit-appearance: none;
    border: none;
    width: 100%;
}

form#generate-videos label {
	color: #30373d;
	display: block;
	width: 100%;
	margin-bottom: 10px;
	font-family: 'Montserrat', sans-serif;
	font-weight: 500;
	letter-spacing: 0.15em;
    text-transform: uppercase;
}

form#generate-videos input[type='text'], 
form#generate-videos input[type='number'],
form#generate-videos input[type='email'] {
    color: #30373d;
    padding: 15px;
    border: 2px solid;
    background-color: transparent;
    margin-bottom: 1.5em;
    font-size: 1em;
    font-family: 'Montserrat', sans-serif;
}

form#generate-videos input.error,
form#generate-videos select.error {
	color: #d8000c;
    border-color: #d8000c;
    background-color: #ffbaba;
    margin-bottom: 0;
}

form#generate-videos select.error {
	background-image: url(../img/select-arrow-error.svg);
}

form#generate-videos div.error {
	font-size: 0.85em;
	color: #d8000c;
    margin-top: 0.5em;
    margin-bottom: 1.5em;
    font-style: italic;
}

form#generate-videos div#video-links-error,
form#generate-videos div#expiration-period-error,
form#generate-videos fieldset#step-1 div.error {
    margin-bottom: 0;
}

form#generate-videos select {
	padding: 15px 43px 15px 15px;
    border: 2px solid;
    color: #30373d;
    background-color: transparent;
    background-image: url(../img/select-arrow.svg);
    background-repeat: no-repeat;
    background-size: 15px;
    background-position-y: 19px;
    background-position-x: calc(100% - 15px);
    text-overflow: ellipsis;
}

form#generate-videos select.loading {
    background-image: url(../img/loading-arrow.svg);
    background-size: 20px;
    background-position-y: 14px;
}

form#generate-videos div.video-preview.loaded {
	margin-top: 1.5em;
	overflow: hidden;
	padding-top: 45.445445445%; /* Height / Width * 100% */
	position: relative;		
}

form#generate-videos div.video-preview.loaded iframe {
	border: 0;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

form#generate-videos div.alert {
    margin-top: 2em;
    padding: 20px;
    -moz-border-radius: 0px;
    -webkit-border-radius: 0px;
    border-radius: 0px;
    border: 2px solid;
}

form#generate-videos div.alert.red {
    background-color: #ffbaba;
    border-color: #d8000c;
    color: #d8000c;
}

form#generate-videos div.alert.red p {
    color: #d8000c;
}

form#generate-videos div.alert.green {
    background-color: #dff2bf;
    border-color: #4f8a10;
    color: #4f8a10;
}

form#generate-videos div.alert.green p {
    color: #4f8a10;
}

form#generate-videos span.ajax-loader {
    width: 22px;
    height: 22px;
    clear: both;
    display: inline-block;
    margin: 0 0 0 15px;
    text-indent: -9999em;
    border-top: 4px solid rgba(243, 242, 242, 0.2);
    border-right: 4px solid rgba(243, 242, 242, 0.2);
    border-bottom: 4px solid rgba(243, 242, 242, 0.2);
    border-left: 4px solid #ab1a5c;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    border-radius: 50%;
    vertical-align: middle;
    -webkit-animation: loading 1s infinite linear;
    animation: loading 1s infinite linear;
}

@-webkit-keyframes loading {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg)
    }
}

@keyframes loading {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg)
    }
}

/*
================================
 4.12.1 Password Protection (Form)
================================
*/

form#password-protection {
    max-width: 800px;
    margin: 0 auto;
    padding-left: 10%;
    padding-right: 10%;
}

form#password-protection label {
	color: #30373d;
	display: block;
	width: 100%;
	margin-bottom: 10px;
	font-family: 'Montserrat', sans-serif;
	font-weight: 500;
	letter-spacing: 0.15em;
    text-transform: uppercase;
}

form#password-protection input[type='password'] {
	-moz-appearance: none;
    -webkit-appearance: none;
    border: none;
    width: 100%;
    color: #30373d;
    padding: 15px;
    border: 2px solid;
    background-color: transparent;
    margin-bottom: 1.5em;
    font-size: 1em;
    font-family: 'Montserrat', sans-serif;
}

form#password-protection button.read-more {
    margin: 0;
}

/*
==========================
 4.13. Lightbox pop-up(s)
==========================
*/

.pop-up-gallery {
	margin-top: 50px;
}

.pop-up-gallery a {
	width: 100%;
	max-width: 385px;
	display: block;
	text-decoration: none;
}

.pop-up-gallery a.preview-thumb {
	position: relative;
}

.pop-up-gallery a.preview-thumb:after {
	content: "\002B";
	position: absolute;
	right: 0;
	bottom: 0;
	font-size: 2.65em;
	line-height: 1;
	width: 50px;
	height: 50px;
	text-align: center;
	color: #fff;
	cursor: pointer;
	background-color: #7e876d;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.no-touchevents .pop-up-gallery a.preview-thumb:hover:after {
	background-color: #99a384;
}

.lightboxOverlay {
	background-color: #30373d;
	opacity: 0.9;
}

.lb-outerContainer {
	-webkit-border-radius: 0;
	   -moz-border-radius: 0;
			border-radius: 0;
}

.lightbox .lb-image {
	border: 10px solid #fff;
	-webkit-border-radius: 0;
	   -moz-border-radius: 0;
			border-radius: 0;
}

.lb-nav a.lb-prev,
.lb-nav a.lb-next {
	position: relative;
	width: 10%;
	text-decoration: none;
	background: none;
	opacity: 1;
}

.lb-nav a.lb-prev:after,
.lb-nav a.lb-next:after {
	content: "";
	position: absolute;
	top: 43%;
	right: 20px;
	font: 400 4em/1 "FontAwesome";
	color: #fff;
	display: block;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.lb-nav a.lb-prev:after {
	content: "\f104";
	right: auto;
	left: 20px;
}

.no-touchevents .lb-nav a.lb-prev:hover:after {
	left: 17px;
}

.lb-nav a.lb-next:after {
	content: "\f105";
}

.no-touchevents .lb-nav a.lb-next:hover:after {
	right: 17px;
}

.lb-data .lb-close {
	position: relative;
	top: 60px;
	right: 6px;
	width: 50px;
	height: 50px;
	text-align: center;
	z-index: 100;
	background: none #7e876d;
	opacity: 1;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.no-touchevents .lb-data .lb-close:hover {
	background-color: #99a384;
}

.lb-data .lb-close:after {
	content: "\00D7";
	position: absolute;
	right: 0;
	left: 2px;
	font-size: 2.65em;
	line-height: 1;
	color: #fff;
	margin: auto;
}

/*
=================
 4.* Footer area
=================
*/

/*
=====================
 4.*.1. Social media
=====================
*/

.footer-social-media {
	margin-bottom: 10px;
}

.footer-social-media ul li {
	font: 500 2.188em/1.571 'Montserrat';
	width: -webkit-calc(33.333% - 6.666px);
	width:	  -moz-calc(33.333% - 6.666px);
	width:		   calc(33.333% - 6.666px);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	text-align: center;
	color: #fff;
	float: left;
	margin-right: 10px;
}

.footer-social-media ul li:last-of-type {
	margin-right: 0;
}

.ie8 .footer-social-media ul li {
	width: 33.333%;
	margin-right: 0;
}

.footer-social-media ul li a {
	height: 275px;
	text-decoration: none;
	color: #fff;
	display: block;
	padding: 95px 0;
	background-color: #7e876d;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.footer-social-media ul li a i._mi {
	display: block;
	margin: 0;
}

.footer-social-media ul li a span {
	opacity: 0;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.no-touchevents .footer-social-media ul li a:hover {
	padding-top: 75px;
	background-color: #99a384;
}

.no-touchevents .footer-social-media ul li a:hover span {
	opacity: 1;
}

/*
===========================
 4.*.2. Newsletter sign-up
===========================
*/

.newsletter-sign-up {
	width: 100%;
	min-height: 275px;
	text-align: center;
	margin-bottom: 10px;
	padding: 45px 30px;
	background-color: #ddd6c6;
}

.newsletter-sign-up h2 {
	margin-bottom: 10px;
}

.newsletter-sign-up .wpcf7 form {
	width: 100%;
	max-width: 700px;
	margin: 0 auto;
}

.newsletter-sign-up .wpcf7 form p {
	margin-bottom: 0;
	border: 0;
}

.newsletter-sign-up .wpcf7 input[type="text"],
.newsletter-sign-up .wpcf7 input[type="email"] {
	width: 100%;
	max-width: 500px;
	height: 60px;
	font-weight: 800;
	font-size: 1.563em;
	color: #30373d;
	margin-right: 20px;
	padding: 0 5px;
	border-bottom: 2px solid #30373d;
	opacity: 1;
	-webkit-transition: all 0.4s ease-in-out;
	   -moz-transition: all 0.4s ease-in-out;
		 -o-transition: all 0.4s ease-in-out;
			transition: all 0.4s ease-in-out;
}

.ie9 .newsletter-sign-up .wpcf7 input[type="text"],
.ie9 .newsletter-sign-up .wpcf7 input[type="email"] {
	height: 61px;
}

.newsletter-sign-up .wpcf7 input[type="text"].wpcf7-not-valid,
.newsletter-sign-up .wpcf7 input[type="email"].wpcf7-not-valid {
	background-color: #ffbaba;
}

.newsletter-sign-up .wpcf7 form input::-webkit-input-placeholder {
	color: #30373d;
}

.newsletter-sign-up .wpcf7 form input:-moz-placeholder {
	color: #30373d;
}

.newsletter-sign-up .wpcf7 form input::-moz-placeholder {
	color: #30373d;
}

.newsletter-sign-up .wpcf7 form input:-ms-input-placeholder {
	color: #30373d;
}

.newsletter-sign-up .wpcf7 form input::-ms-input-placeholder {
	color: #30373d;
}

.newsletter-sign-up .wpcf7 input.wpcf7-submit {
	margin: 0;
}

.newsletter-sign-up .your-email span.wpcf7-not-valid-tip {
	display: none !important;
}

.newsletter-sign-up div.wpcf7 div.wpcf7-response-output {
	margin-bottom: 40px;
}

/*
================================================
 4.*.2.1 Newsletter sign-up (Healcode Prospect)
================================================
*/

div.healcode.prospect {
	max-width: 600px;
}

div.healcode.prospect div.hc-prospect-field {
	margin-bottom: 20px;
}

div.healcode.prospect div.hc-prospect-field input {
	font-family: 'freight-text-pro', sans-serif;
	font-weight: 400;
	width: 100%;
	padding: 10px;
    font-weight: 800;
    font-size: 2em;
    color: #30373d;
    border-bottom: 2px solid #30373d;
    background-color: transparent;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
}

div.healcode.prospect div.hc-prospect-field input::-webkit-input-placeholder { /* Chrome/Opera/Safari */
	color: #30373d;
	opacity: 1;
}
div.healcode.prospect div.hc-prospect-field input::-moz-placeholder { /* Firefox 19+ */
	color: #30373d;
	opacity: 1;
}
div.healcode.prospect div.hc-prospect-field input:-ms-input-placeholder { /* IE 10+ */
	color: #30373d;
	opacity: 1;
}
div.healcode.prospect div.hc-prospect-field input:-moz-placeholder { /* Firefox 18- */
	color: #30373d;
	opacity: 1;
}

div.healcode.prospect div.hc-prospect-field input.parsley-error {
	background-color: #ffbaba;
}

div.healcode.prospect div.hc-actions input.submit {
	font-family: 'Montserrat', sans-serif;
	font-weight: 500;
	font-size: 1.3em;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-align: center;
    color: #fff;
    display: inline-block;
    cursor: pointer;
    margin: 15px auto 0;
    padding: 20px 30px;
    border: 0;
    width: 100%;
    max-width: 250px;
    background-color: #ab1a5c;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
}

div.healcode.prospect div.hc-actions input.submit:hover {
	background-color: #b37776;
}

div.healcode.prospect ul.parsley-errors-list {
	margin: 0.5em 0 0 0;
	padding: 0;
}

div.healcode.prospect ul.parsley-errors-list li {
	list-style-type: none;
	padding: 0;
	font-size: 1.4em;
	font-style: italic;
	font-weight: normal;
}

div.healcode.prospect ul.parsley-errors-list li:before {
	content: '';
}

div.healcode.prospect div.hc_prospect div {
	font-family: 'Bara Grande', sans-serif;
	font-weight: 800;
}

div.healcode.prospect div.hc_prospect div > div {
	margin-bottom: 0.5em;
}

div.healcode.prospect div.hc_prospect div div:first-child {
	font-size: 1.1em;
}

div.healcode.prospect div.hc_prospect div.hc-actions {
	margin: 0 auto;
	display: block;
	text-align: center;
}

div.healcode.prospect div.hc-privacy-footer {
	display: none;
}

/*
====================
 4.*.3. Main footer
====================
*/

footer {
	width: 100%;
	min-height: 275px;
	text-align: center;
	padding: 90px 0 75px;
	background-color: #30373d;
}

footer a {
	font-weight: 400;
	text-decoration: none;
	color: #fff;
}

footer p a:after {
	content: "";
	display: none;
}

footer .award {
	width: 170px;
	margin: 60px auto 0;
}

footer .footer-main {
	margin: 75px 0 150px;
}

footer .one-third:last-of-type {
	margin-right: 0;
}

footer .underline {
	font-size: 2.188em;
	color: #fff;
	margin-right: auto;
	margin-left: auto;
}

footer .underline:after {
	margin-right: auto;
	margin-bottom: 38px;
	margin-left: auto;
}

footer .footer-main p {
	font-size: 1.625em;
	line-height: 1.275;
	letter-spacing: 0.1em;
	color: #fff;
	margin-bottom: 0;
}

footer .footer-main p a {
	color: #fff;
}

.no-touchevents footer .footer-main p a:hover {
	color: #7e876d;
}

footer.main-content ul,
footer.main-content ol {
	margin-bottom: 0;
}

.app-disclaimer ul li,
footer .widget_nav_menu ul li {
	display: inline-block;
	margin-right: 6px;
	margin-bottom: 0;
	padding: 0;
}

footer .widget_nav_menu ul li:last-of-type {
	margin-right: 0;
}

.app-disclaimer ul li a,
footer .widget_nav_menu a,
footer.main-content .widget_nav_menu ul li a {
	position: relative;
	width: 60px;
	height: 60px;
	text-align: center;
	color: #fff;
	display: inline-block;
	padding: 12px 0;
	background-color: #7e876d;
	-webkit-transform: rotate(0deg);
	   -moz-transform: rotate(0deg);
		 -o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
			transform: rotate(0deg); /* This is needed for the hover effect! */
}

.no-touchevents .app-disclaimer ul li a:hover,
.no-touchevents footer.main-content .widget_nav_menu ul li a:hover {
	color: #fff;
}

.app-disclaimer ul li a:before,
footer .widget_nav_menu a:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 0%;
	height: 100%;
	z-index: -1;
	background-color: #99a384;
	-webkit-transition: width 0.4s ease-in-out;
	   -moz-transition: width 0.4s ease-in-out;
		 -o-transition: width 0.4s ease-in-out;
			transition: width 0.4s ease-in-out;
}

.no-touchevents .app-disclaimer ul li a:hover:before,
.no-touchevents footer .widget_nav_menu a:hover:before {
	width: 100%;
}

footer .widget_nav_menu a i._mi {
	margin-top: 0;
}

footer .footer-legal nav {
	margin-bottom: 20px;
}

footer .footer-legal ul li {
	font: 400 0.875em/1 'Montserrat';
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #7e876d;
	display: inline;
	margin: 0;
	padding: 0;
}

footer .footer-legal ul li:after {
	content: "\2022";
	position: relative;
	top: -1px;
	font-size: 1em;
	display: inline-block;
	margin: 0 10px 0 13px;
}

footer .footer-legal ul li:last-of-type:after {
	content: "";
	display: none;
	margin-right: 0;
}

footer .footer-legal ul li a {
	color: #7e876d;
}

.no-touchevents footer .footer-legal ul li a:hover,
.no-touchevents footer p.sign-off a:hover  {
	color: #99a384;
}

footer p.sign-off {
	line-height: 1.666;
	color: #fff;
}

/*
==============
 4.*.4. Popup
==============
*/

div.popup {
	visibility: hidden;
    opacity: 0;
    width: 100%;
    max-width: 600px;
    background: #ddd6c6;
    position: fixed;
    left: 50%;
    top: 50%;
    -moz-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    padding: 4em 3em 3em 3em;
    text-align: center;
    margin-left: 35px;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    z-index: 999;
}

div.popup:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.5);
    width: 100%;
    height: 100%;
    z-index: -1;
}

div.popup.active {
	visibility: visible;
    opacity: 1;
}

div.popup p {
    font-size: 1.125em;
    line-height: 1.444;
    color: #ffffff;
    margin-bottom: 26px;
}

div.popup p.underline {
	margin-bottom: 0;
}

div.popup p.underline:after {
    margin: 26px auto 25px;
}

div.popup p.banner-heading {
    font-size: 2.188em;
    line-height: 1.428;
}

div.popup p:nth-last-of-type(2) {
    margin-bottom: 0;
}

div.popup p > a {
	text-decoration: none;
    color: #ab1a5c;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    -webkit-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
}

.no-touchevents div.popup p > a:hover {
    color: #b37776;
}

span.close-btn {
	position: absolute;
    top: 25px;
    right: 30px;
    cursor: pointer;
}

span.close-btn i {
	font-size: 1.5em;
    color: #ffffff;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    -webkit-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
}

.no-touchevents span.close-btn:hover i {
	color: #b37776;
}

div.popup-overlay {
	display: none;
	position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0,0,0,0.4);
    z-index: 998;
    cursor: pointer;
}

div.popup-overlay.active {
	display: inherit;
}

/*
==============================================================================================================
 5. Legacy browser bar
==============================================================================================================

 * Styling for a conditional bar that will appear only in Internet Explorer 8 and below
 * Provides a warning to <=IE8 users that the website may not look and/or function as intended
*/

.legacy-browser-notice {
	position: fixed;
	bottom: 0px;
	z-index: 9999;
	width: 100%;
	max-width: 1000px;
	font-size: 16px;
	font-family: Segoe UI, Frutiger, Frutiger Linotype, Dejavu Sans, Helvetica Neue, Arial, sans-serif;
	line-height: 1.6;
	text-align: center;
	color: #ffffff;
	padding: 20px 10px 26px;
	background: url(../img/legacy-browser-logo.jpg) no-repeat 30px center #00a1f1;
}

.legacy-browser-notice .notice {
	font-size: 26px;
	text-transform: uppercase;
	margin-bottom: 10px;
}

.legacy-browser-notice strong {
	font-weight: bold;
}
	
.legacy-browser-notice a {
	font-weight: bold;
	color: #fff;
}

/*
==============================================================================================================
 6. Brads Stylings
==============================================================================================================
Updates to website phase 2
30/08/2017
*/

#posts .post-item {
	height: 500px;
	position: relative;
	margin-bottom: 10px;
	color: #fff;
	text-align: center;
	-webkit-transition: all 0.5s ease-in-out;
    -moz-transition: all 0.5s ease-in-out;
    -o-transition: all 0.5s ease-in-out;
    transition: all 0.5s ease-in-out;
}

.no-touchevents #posts:hover > .post-item {
	opacity: 0.75;
}

.no-touchevents #posts:hover > .post-item:hover {
	opacity: 1;
}

#posts .post-item .half {
	position: relative;
	height: 100%;
	background-color: #30373D;
}

#posts .post-item .half.image-half a {
	width: 100%;
    height: 100%;
    text-decoration: none;
    display: block;
}

#posts .post-item:nth-child(even) > .half.content-half {
	float: right;
}

#posts .post-item:nth-child(even) .image-half a .block-button {
	right: 0;
	left: inherit;
}

#posts .post-item:nth-child(even) .half:last-of-type, 
#posts .post-item:nth-child(even) .half:nth-child(2n+2) {
    margin-right: 10px;
}

#posts .post-item:nth-child(even) .half:first-of-type {
    margin-right: 0;
}

#posts .post-item p.underline {
    color: #fff;
}

#posts .post-item p.underline:after {
    margin: 0 auto;
    margin-top: 14px;
    margin-bottom: 25px;
}

#posts .post-item h2 {
	color: #fff;
}

#posts .post-item .vertical-centre {
	width: 100%;
	max-width: 570px;
	padding: 0 20px;
}

.cover { 
  background-repeat:  no-repeat ; 
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}

.select-wrap.faq-select,
.select-wrap {
	display: inline-block;
	background-color: #7e876d;
	margin: 0 auto;
	position: relative;
	overflow: hidden;
}

.select-wrap.faq-select {
	background-color: transparent;
	border-bottom: 2px solid #fff;
	text-align: left;
	margin-bottom: 15px;
	width: 100%;
}

.faq-wrapper {
	width: 100%;
	max-width: 700px;
	padding: 0 20px;
	margin: 0 auto;
}

.banner-text p.filter-text {
    text-align: left;
}

.select-wrap:before {
	content: url(../img/down-arrow.svg);
	display: block;
    width: 13px;
    height: 8px;
    position: absolute;
    right: 28px;
    top: 21px;
}

.select-wrap.faq-select:before {
	content: url(../img/big-down-arrow.svg);
    width: 25px;
    height: 16px;
    right: 28px;
    top: 25px;
}

select {
	font: 500 2.188em/1.714 'Montserrat';
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    text-indent: 1px;
    text-overflow: '';
    background-color: transparent;
    font-size: 0.938em;
    color: #fff;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    line-height: 1.266;
    padding: 20px 50px 20px 30px;
    position: relative;
}

select::-ms-expand {
    display: none;
}

.select-wrap.faq-select select {
	font-size: 1.500em;
    line-height: 1.2;
    letter-spacing: 0.15em;
    padding: 15px 15px 15px 15px;
    width: 100%;
}

select option {
    background: #7e876d;
    color: #fff;
}

.select-wrap.faq-select select option {
	font-size: 0.938em;
}

/*CSS Loader*/
@keyframes ball-scale {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0); 
	 }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 0; 
    } 
}

.ball-scale > div {
	background-color: #7e876d;
	width: 15px;
	height: 15px;
	border-radius: 100%;
	margin: 2px;
	-webkit-animation-fill-mode: both;
	      animation-fill-mode: both;
	display: inline-block;
	height: 60px;
	width: 60px;
	margin: 0 auto;
	margin-top: 20px;
	margin-bottom: 50px;
	display: block;
	-webkit-animation: ball-scale 1s 0s ease-in-out infinite;
	      animation: ball-scale 1s 0s ease-in-out infinite; 
}

.ie9 .ball-scale > div {
	background-color: transparent;
	background-image: url(../img/contact-loading.svg) !important;
	background-repeat: no-repeat;
}

/*
==============================================================================================================
 6.1 Video banner
==============================================================================================================
*/
.video-banner {
	position: relative;
	min-height: 400px;
	height: 100vh;
	overflow: hidden;
	margin-bottom: 10px;
}

.dark-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #000;
	opacity: 0.25;
}

#myVideo {
  position: absolute;
  top: -9999px;
  bottom: -9999px;
  left: -9999px;
  right: -9999px;
  margin: auto;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
}

.touchevents #myVideo {
    display: none;
}

/*
==============================================================================================================
 6.2 Social Sharing
==============================================================================================================
*/
.mobile-wrap {
	display: none;
}

.desktop-social-sharing {
	position: absolute;
	right: 29px;
	top: 60px;
}

.mobile-wrap .social-sharing {
	display: block;
	margin: 0 auto;
	text-align: center;
}

.social-sharing .share {
	color: #30373D;
	font: 800 1.5em/1 "Bara Grande";
	margin-bottom: 5px;
}

.desktop-wrap .social-sharing .share {
	text-align: right;
}

.main-content .social-sharing ul {
	display: inline-block;
	margin: 0;
}

.desktop-wrap .social-sharing ul li {
	display: block;
	margin-bottom: 10px;
	padding-left: 0;
}

.mobile-wrap .social-sharing ul li {
	display: inline-block;
	margin-right: 10px;
	padding-left: 0;
}

.mobile-wrap .social-sharing ul li:last-of-type {
	margin-right: 0;
}

.main-content .social-sharing ul li:before {
	content:'';
}

.social-sharing ul li a {
	display: inline-block;
	background-color: #7e876d;
	color: #fff;
	font-size: 25px;
	width: 50px;
	height: 50px;
	line-height: 50px;
	text-align: center;
	opacity: 0.75;
}

.no-touchevents .social-sharing ul li:hover a {
	opacity: 1;
	color: #fff;
}

/*
==============================================================================================================
 6.3 Schedule
==============================================================================================================
*/

.app-disclaimer {
	margin-top: 20px;
	display: none;
}

.app-disclaimer ul li a {
	line-height: 40px;
}

.app-disclaimer p.disclaimer {
	font: 500 1em/1.5 'Montserrat';
    letter-spacing: 0.15em;
    text-transform: uppercase;
    margin-bottom: 14px;
    color: #30373d;
}

.healcode.schedule h3 {
    color: inherit;
}

/*
==============================================================================================================
 6.4 FAQs section
==============================================================================================================
*/
.faqs-section {
	padding: 60px 0 10px 0;
}

.faqs-section .container {
	max-width: 700px;
}

.faqs-section .faq-item h2 {
	color: #7e876d;
	font: 800 1.75em/1 "Bara Grande";
	font-size: 1.563em;
	margin-bottom: 15px;
}

.faqs-section .faq-item p {
	line-height: 1.833;
}

.faqs-section .faq-item a {
	text-decoration: none;
}

.faqs-section hr {
	width: 100%;
	background-color: #DFDFDF;
	height: 3px;
	margin-top: 50px;
	margin-bottom: 50px;
}

.popout-text {
	max-width: 100%;
	max-width: 800px;
	padding: 20px;
	background-color: transparent;
	color: #30373D;
}

.popout-text h2,
.popout-text h3 {
	color: #7e876d;
	font: 800 1.75em/1 "Bara Grande";
	font-size: 1.563em;
	margin-bottom: 15px;
	text-transform: none;
}

.popout-text .wrapper {
	background-color: #fff;
	padding: 40px;
}

.fancybox-bg {
    background: #30373D;
}

select:after::-webkit-focus-inner,
select:after::-moz-focus-inner,
button:after::-webkit-focus-inner,
button:after::-moz-focus-inner {
  border: 0;
  outline: none;
}

.fancybox-close-small {
    top: 20px;
    right: 20px;
}

.fancybox-close-small:after {
	content: url(../img/close-button.svg);
    top: 0px;
    right: 0px;
    width: 50px;
    height: 50px;
    padding: 15px 35px 35px 15px;
    font: normal 400 1.125em/1 "freight-text-pro";
    color: #30373D;
    font-weight: 400;
    text-align: left;
    border-radius: 0;
    background: #7e876d;
    outline: none;
	outline: 0;
	border: 0;
}

.fancybox-close-small:hover:after {
    color: inherit;
    background: #99a384;
    outline: none;
}

.fancybox-close-small:active:after {
	outline: 0;
	outline: none;
	border: 0;
}

.fancybox-close-small:visited:after, 
.fancybox-close-small:focus:after, 
.fancybox-close-small:active:after, 
.fancybox-close-small:hover:after{
    outline:0 none !important;
}

/*.cta-banner.blue-bg .underline:after {
    margin: 25px auto 25px;
}*/

.page-id-13 .cta-banner .container {
    max-width: 600px;
}

/* Schedule (Manual) */
.fancybox-stage .fancybox-slide div.description-popup {
	margin: 0;
	max-width: 600px;
	padding: 90px 20px 20px 20px;
	background-color: #ddd6c6;
}

.fancybox-stage .fancybox-slide div.description-popup__content {
	max-height: 60%;
	max-height: 60vh;
	overflow-y: auto;
	padding-right: 20px;
}

.fancybox-stage .fancybox-slide div.description-popup__content::-webkit-scrollbar {
	width: 5px;
}
 
.fancybox-stage .fancybox-slide div.description-popup__content::-webkit-scrollbar-track {
	background-color: rgba(0, 0, 0, 0.1);
}
 
.fancybox-stage .fancybox-slide div.description-popup__content::-webkit-scrollbar-thumb {
	background-color: #7e876d;
	outline: none;
}

.fancybox-stage .fancybox-slide div.description-popup div.description-popup__content h3 {
	font-size: 1.6em;
	line-height: 1.4em;
	color: #30373d;
	margin-bottom: 12px;
}

/*
==============================================================================================================
 6.5 Team Members
==============================================================================================================
*/

.team-member-list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-ms-flex-direction: row;
	flex-direction: row;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.team-member.one-third {
	margin-bottom: 10px;
	background-color: #DDD6C6;
}

.team-member .team-member-content {
	padding: 15px 30px 30px 30px;
}

.team-member .team-member-content .underline {
	font-size: 1.313em;
	color: #99a384;
}

.team-member .team-member-content h2 {
	margin-bottom: 12px;
}

.team-member .team-member-content .underline:after {
	width: 62px;
}

.read-more {
    margin: 30px 10px 0 0;
}

.banner-text .team-filter .read-more {
    background-color: transparent;
    border: 3px solid #7e876d;
    color: #7e876d;
}

.banner-text .team-filter .read-more.active {
    background-color: #7e876d;
    color: #fff;
}

.no-touchevents .banner-text .team-filter .read-more:hover {
    border: 3px solid #99a384;
    color: #fff;
}

.team-member-section .class-type {
	font: 800 1.313em/1 "Bara Grande";
	color: #7E8763;
	margin-bottom: 50px;
	display: block;
}

.main-content ul.social-media li:before {
    content: none;
}

.main-content ul.social-media li {
	padding-left: 0;
}

.no-touchevents .main-content ul.social-media li a:hover,
.main-content ul.social-media li a {
	color: #fff;
}

.main-content ul.social-media li:first-of-type a.read-more {
	margin-top: 40px;
}

.main-content ul.social-media li a.read-more {
	padding-top: 12px;
	margin-top: 0;
}

.main-content ul.social-media li a span .fa{
	margin-right: 15px;
    font-size: 1.875em;
    position: relative;
    top: 5px;
}

.team-member-section.full-height-content h1, 
.team-member-section.full-height-content h2 {
    margin-bottom: 15px;
}

.team-member-section .full-height.text {
    overflow: auto;
}

.one-fourth {
	width: -webkit-calc(25% - 7.5px);
	width:	  -moz-calc(25% - 7.5px);
	width:		   calc(25% - 7.5px);
	float: left;
	margin-right: 10px;
	margin-bottom: 10px;
	position: relative;
}

.one-fourth:nth-of-type(4n+4) {
	margin-right: 0;
}

.no-touchevents .one-fourth.no-image {
	-webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
}

.no-touchevents .one-fourth.no-image:hover {
	background-color: #99a384;
}

.one-fourth.no-image,
.one-fourth.no-image a,
.gallery-section .one-fourth.no-image h2  {
	color: #fff;
	text-decoration: none;
}

.one-fourth.no-image .vertical-centre {
	padding: 20px;
}

.no-touchevents .one-fourth.no-image .text-wrap {
	width: 100%;
	max-width: 200px;
	margin: 0 auto;
}

.gallery-section .one-fourth img {
	width: 100%;
}

.gallery-section .one-fourth .underline {
	color: #fff;
}

.gallery-section .one-fourth .underline:after {
	background-color: #fff;
	margin: 0 auto;
	margin-top: 15px;
	margin-bottom: 30px;
}

.gallery-section .one-fourth h2 {
	font-size: 2em;
	margin-bottom: 0;
}

/*
==============================================================================================================
 6.6 Top Banner Animation
==============================================================================================================
*/
.animated {
  animation-duration: 1s;
  animation-fill-mode: both;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    top: 60%;
  }

  to {
    opacity: 1;
    top: 50%;
  }
}

.fadeInUp {
  animation-name: fadeInUp;
}

/*
==============================================================================================================
 6.7 Browser Fixes
==============================================================================================================
*/
.ie9 .banner-text {
	opacity: 1;
	top: 50%;
}

/*
==============================================================================================================
 Brad 31/07/18
==============================================================================================================
*/
.lightboxcontainer {
  	width:100%;
  	text-align:left;
}

.lightboxleft {
  	width: 40%;
  	float:left;
}

.lightboxright {
  	width: 60%;
  	float:left;
}

.lightboxright iframe {
  	min-height: 390px;
}

.divtext {
  	margin: 36px;
}

.link-block .play-btn {
  	width: 100px;
}

#html5-close {
	margin-top: -18px!important;
  	margin-right: -9px!important;
}

#html5-close img {
	width: 40px;
}

.iframe-wrapper {
	overflow: hidden;
	padding-top: 56.25%;
	position: relative;
}

.iframe-wrapper iframe {
	border: 0;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.full-height-iframe iframe {
    width: 100%;
    height: 100%;
}

.owl-prev i,
.owl-next i {
    position: relative;
    top: 2px;
}