/*
Theme Name: HIIT House
Theme URI: https://www.theodagency.com
Description: HIIT House 2019 Theme
Author URI: https://www.theodagency.com
Version: 1.0.0v
*/

:root{
  --wf-dark:  #033b2b;  /* Dark Green */
  --wf-teal:  #558e87;  /* Teal */
  --wf-blue:  #c5dbd8;  /* Light Blue */
  --wf-cream: #f5e2c6;  /* Cream */
  --wf-beige: #e0be90;  /* Beige */
  --wf-brown: #c2795a;  /* Brown */
  --wf-white: #ffffff;
  --wf-black: #000000;
}

/* BACKGROUND VIDEO */

#fullVideo {
	max-width: 100%;
}

.video-container{
  width: 100vw;
  height: 100vh;
}
    
.video-container iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100vw;
  height: 100vh;
  transform: translate(-50%, -50%);
}
@media (min-aspect-ratio: 16/9) {
  .video-container iframe {
    /* height = 100 * (9 / 16) = 56.25 */
    height: 56.25vw;
  }
}
    
@media (max-aspect-ratio: 16/9) {
  .video-container iframe {
    /* width = 100 / (9 / 16) = 177.777777 */
    width: 177.78vh;
  }
}

.vimeo-wrapper {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100vh;
   z-index: -1;
   pointer-events: none;
   overflow: hidden;
}
.vimeo-wrapper iframe {
   width: 100vw;
   height: 56.25vw; /* Given a 16:9 aspect ratio, 9/16*100 = 56.25 */
   min-height: 100vh;
   min-width: 177.77vh; /* Given a 16:9 aspect ratio, 16/9*100 = 177.77 */
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
}


/* VIDEOWRAPPER */

.videoWrapper {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
}
.videoWrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* MODAL */

#appModal {
    background: rgba(256,256,256,0.9);
}

.modal-content {
	border-radius:0;
}

.modal-dialog {
    max-width: 500px;
    margin: 0 auto;
}

.modal-header {
    border: none;
    padding-bottom: 0;
}

.modal-header button.close {
    position: absolute;
    top: 10px;
    right: 15px;
}

.modal-header .icon-icon {
    margin: 0 auto!important;
    width: 100%;
    font-size: 3em;
    margin-left: -.25em!important;
}

/* MBO */

/** TIMETABLE **/
.dayCol {
	list-style: none;
	padding-left:0;
	width: calc(100%/7);
	float: left;
}
.dayName {
    font-family: 'Montserrat', sans-serif;
    font-weight: 800;
    text-transform: uppercase;
    font-size: 2.25em;
}
.classTime {
	padding: 10px;
	border: 3px solid #fff;
	background: #eee;
}	
.classTime span {
	display:block;
}
span.class {
    font-size: 1em;
    font-weight: 600;
}
span.trainer {
    color: #aaa;
}	
span.trainer a {
    font-size: 0.8em;
    color: #aaa;
}	
@media screen and (min-width:992px) {
.tooltip, .tooltip .tooltip-inner {
	max-width:40em;
  width: 40em;
  white-space: normal;
}
.classTime {
	padding: 10px;
	background: #eee;
	height: 160px;
}		
.classTime:hover {
	transform:scale(1.2);
	background: #000;
	color: #fff;
}	
.classTime:hover > .class a {
	color: #fff!important;
}	
}

@media screen and (max-width:992px) {
.classTime span {
    display: inline-block!important;
    margin: 0 10px 0 0!important;
}
.dayCol {
	width: calc(100%);
}	
}

/** REGISTER **/

.healcode.registration input[type=text], .healcode.registration input[type=email], .healcode.registration input[type=password], .healcode.registration textarea {
    width: 100%;
    padding: 0.5em 1em;
    font-size: 1.25em;
}
.hc-label {
    font-size: 1.5em!important;
    margin-bottom: 10px;
}	
.hc-prospect-comment {
    display: none;
}
#hc-other-information {
    display: none;
}	
.hc-liability, .hc-actions {
    float: left!important;
    width: 100%!important;
	margin-top: 10px;
}	
.healcode .hc_registration .liability {
	max-width: 100%!important;
	height: 200px!important;
}	
.healcode.registration {
    float: left;
	margin-bottom: 40px;
}
.hc_registration div div {
    float: left;
    width: 100%;
    font-size: 1.5em;
    font-weight: 600;
    margin: 10px 0;
    line-height: 1.25em;
}
div.healcode input.hc-button, .bw-widget__cart_button button {
	background: #1a1a1a!important;
   	border-color: #1a1a1a!important;
   	border-radius: 0!important;
   	color: #fff!important;
   	font-family: 'Montserrat'!important;
   	text-transform: uppercase;
   	letter-spacing: 0.2em!important;
   	font-size: 0.9em!important;
   	padding: 0.75em 1.2em!important;
}	
.hc-privacy-footer {
	display: none;
    float: left;
    width: 100%;
    margin: 20px 0;
}	
@media screen and (min-width: 992px) {
.hc-registration-field {
    float: left;
    width: 49%;
	margin-right: 1%;
}
}	
@media screen and (max-width: 992px) {
.hc-registration-field {
    float: left;
    width: 100%;
	margin-right: 0%;
}
}	

/** BOOK A CLASS **/

.bw-widget__header, .bw-widget__date {
    background-color: rgb(230, 230, 230);
}

.bw-header__title, .bw-header__account-link {
	font-family: 'Montserrat', sans-serif!important;
    text-transform: uppercase;
}

.bw-widget--medium .bw-widget__header {
	padding: 8px 32px!Important;
}

.bw-widget__footer {
    display: none!important;
}

.alert-danger {
    color: #F44336;
    background-color: #fff;
    border: 2px solid #F44336;
}

.alert-danger a {
    color: #F44336!important;
	text-decoration: underline;
}

.alert-primary {
    color: #000;
    background-color: #fff;
    border: 2px solid #000;
}

.alert-primary a {
    color: #000!important;
	text-decoration: underline;
}


/* PACKAGES */

.package ul {
    list-style: none;
    padding-left: 0;
}

.package h5 {
	min-height: 72px;
	font-size: 1em
}

/*
.package .intro {
	min-height: 120px;
} */

/* FONTS */

@font-face { 
      font-family: 'hiithouse';
	  font-display: swap;
      src: url('font/hh3.eot?96651468');
      src: url('font/hh3.eot?96651468#iefix') format('embedded-opentype'),
           url('font/hh3.woff?96651468') format('woff'),
           url('font/hh3.ttf?96651468') format('truetype'),
           url('font/hh3.svg?96651468#fontello') format('svg');
      font-weight: normal;
      font-style: normal;
    }
     
     
    .icon
    {
      font-family: "hiithouse";
      font-style: normal;
      font-weight: normal;
      speak: none;
      font-display: swap;
      display: inline-block;
      text-decoration: inherit;
      width: 1em;
      margin-right: .2em;
      text-align: center;
      /* opacity: .8; */
     
      /* For safety - reset parent styles, that can break glyph codes*/
      font-variant: normal;
      text-transform: none;
     
      /* fix buttons height, for twitter bootstrap */
      line-height: 1em;
     
      /* Animation center compensation - margins should be symmetric */
      /* remove if not needed */
      margin-left: .2em;
     
      /* You can be more comfortable with increased icons size */
      /* font-size: 120%; */
     
      /* Font smoothing. That was taken from TWBS */
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
     
      /* Uncomment for 3D effect */
      /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */
    }

.icon-martial-arts:before {
	content: "\E801";
}

.icon-trx-icon:before {
	content: "\E802";
}

.main .container-fluid {
	max-width:1440px;
}

::selection {
	background: #98A3A5;
	color: #fff;
}

::-moz-selection {
	background: #98A3A5;
	color: #fff;
}

/*** GENERAL ***/

h1, h2, h3, h4, h5, h6 {
	font-weight: 800;
	font-family: 'Montserrat', sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.2em;
}

h4 {
    text-transform: none;
    letter-spacing: 0;
}

h6 {
	font-size:0.8em;
	margin:0;
}

body {
	margin-top:165px;
	font-family: 'Lato', sans-serif;
}

a, a:hover, a:active, a:visited {
	color: #000;
}

.bg-light {
    background-color: #e6e6e6!important;
}

.bg-dark {
    background-color: #000!important;
}

.opacity-90 {
    background-color: rgba(256,256,256,0.9)!important;
}

.opacity-80 {
    background-color: rgba(256,256,256,0.8)!important;
}

img {
	max-width:100%;
	height: auto;
}

.bookClass, .viewProf {
	text-transform:uppercase;
	font-family:'Montserrat', sans-serif;
	letter-spacing: 0.2em;
	padding-right: 15px;
	font-size:0.9em;
	text-decoration:none!important;
}

.viewProf {
	font-size: 0.75em;
	padding-right: 20px;
}

.bookClass:after, .viewProf:after {
	content: '\f178';
	font-family: 'Font Awesome 5 Pro';
	font-display: swap;
	position: absolute;
	right: 5px;
	font-size: 1em;
	top:3px;
}

.viewProf:after {
	top: 5px;
}

.bookClass:hover:after {
	right: 0;
}

.viewProf:hover:after {
	right: 0;
}

button:focus {
	outline:0;
}

.btn {
	margin-bottom:15px;
	outline: none!important;
}

.btn-outline-primary, .healcode-contract-text-link, .healcode-pricing-option-text-link {
    border-radius: 0;
    color: #1a1a1a;
    font-family: 'Montserrat';
    text-transform: uppercase;
    letter-spacing: 0.2em;
    font-size: 0.9em;
    border: 2px solid #1a1a1a;
    padding: 0.75em 1.2em;
}

.btn-outline-primary:hover, .healcode-contract-text-link:hover, .healcode-pricing-option-text-link:hover {
    background: #1a1a1a;
    border-color: #1a1a1a;
	color: #fff;
	text-decoration: none;
}

.healcode-link.healcode-contract-text-link, .healcode-link.healcode-pricing-option-text-link {
    display: inline-block;
    margin-bottom: 20px;
}

.btn-primary {
    background: #1a1a1a;
    border-color: #1a1a1a;
    border-radius: 0;
    color: #fff!important;
    font-family: 'Montserrat';
    text-transform: uppercase;
    letter-spacing: 0.2em;
    font-size: 0.9em;
    padding: 0.75em 1.2em;
}

.btn-primary:hover {
    background: #808080;
    border-color: #808080;
}

.btn-outline-primary:not(:disabled):not(.disabled).active, .btn-outline-primary:not(:disabled):not(.disabled):active, .show>.btn-outline-primary.dropdown-toggle, .btn-primary:not(:disabled):not(.disabled).active, .btn-primary:not(:disabled):not(.disabled):active, .show>.btn-primary.dropdown-toggle {
	background:#000!important;
}

.btn-outline-primary.focus, .btn-outline-primary:focus, .btn-primary:not(:disabled):not(.disabled).active:focus, .btn-primary:not(:disabled):not(.disabled):active:focus, .show>.btn-primary.dropdown-toggle:focus, .btn-primary.focus, .btn-primary:focus {
	box-shadow:none!important;
}

.btn-outline-primary:not(:disabled):not(.disabled).active, .btn-outline-primary:not(:disabled):not(.disabled):active, .show>.btn-outline-primary.dropdown-toggle, .btn-primary:not(:disabled):not(.disabled).active, .btn-primary:not(:disabled):not(.disabled):active, .show>.btn-primary.dropdown-toggle {
	border-color:#000!important;
}

.btn-outline-light {
    color: #fff!Important;
    padding: 25px 35px;
    text-transform: uppercase;
    border-radius: 0;
    font-family: 'Montserrat';
    letter-spacing: 0.2em;
}
.btn-outline-light:hover {
    color: #000!Important;
}
.rotate90 {
	transform: rotate(-90deg);
	-webkit-transform: rotate(-90deg);
	-moz-transform: rotate(-90deg);
	-ms-transform: rotate(-90deg);
	-o-transform: rotate(-90deg);
	filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=3);
}

/*** OVERLAY ***/

.overlay{
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: rgba(256, 256, 256, 0.95);
	z-index: 999;
}

.overlay-bg {
    position: absolute;
    background: rgba(0,0,0,0.3);
    width: 100%;
    height: 100%;
    left: 0px;
    right: 0px;
    bottom: 0px;
    top: 0px;
    z-index: 999;
	padding: 10px 30px;
}

.ourwork:hover > .overlay {
	background: rgba(0,0,0,0.6);
}

.overlay nav {
	text-align: center;
	position: relative;
	top: 50%;
	top: 15% \9;
	font-size: 24px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	text-align: left;
}

.overlay ul {
	list-style: none;
	padding: 0;
	margin: 0 auto;
	display: inline-block;
	height: 100%;
	position: relative;
}

.overlay ul li {
	display: block;
	height: calc(100% / 5);
	margin: 15px 0;
}

.overlay ul li a {
	display: block;
	color: #000;
  	text-decoration:none;
	-webkit-transition: color 0.2s;
	transition: color 0.2s;
  	text-transform:uppercase;
	line-height: 1.5em;
	font-family: 'Montserrat', sans-serif;
	letter-spacing: 0.2em;
}

.overlay ul li a:hover,
.overlay ul li a:focus,
.overlay ul li a:active {
	color: #98A3A5;
}

.overlay ul li a:hover {
    margin-left: 10px;
}

.menu-collapsed .overlay-hh {
	opacity: 0;
	visibility: hidden;
	-webkit-transition: opacity 0.5s, visibility 0s 0.5s;
	transition: opacity 0.5s, visibility 0s 0.5s;
}

.menu-expanded .overlay-hh {
	opacity: 1;
	visibility: visible;
	-webkit-transition: opacity 0.5s;
	transition: opacity 0.5s;
}

.overlay-hh nav ul {

	-webkit-transition: -webkit-transform 0.5s, opacity 0.5s;
	transition: transform 0.5s, opacity 0.5s;
}

.overlay .disTop h2:after { 
	font-family: 'hiithouse';
    content: '\e804';
    display: block;
    font-size: 1.5em;
    margin-top: 15px;
    margin-left: -0.75em;
    position: absolute;
    bottom: 40px;
    left: 50%;	
}


.icon-icon {
    margin-left: -0.5em!important;
}

/*** SLIDERS ***/

#testCarousel .carousel-item {
	display: none!important;	
}

#testCarousel .carousel-item.active {
	display: block!important;	
}

#carouselBook .carousel-item {
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	min-height: 200px;
}

/*** TRANSITIONS ***/

#nav-icon3 span, .bookClass:after, .overlay, .onTop, .disTop, .btn-primary, .btn-outline-primary, .viewProf:after, .overlay ul li a, .classTime, header {
		-webkit-transition: all 0.5s;
		-moz-transition: all 0.5s;
		-ms-transition: all 0.5s;
		-o-transition: all 0.5s;
		transition: all 0.5s;
}

/*** HEADER ***/

#optin {
     position:relative;
	top:0;
	margin-top:0;
 }

.smaller #optin {
	margin-top: -77px;
	z-index: -1;
}
 #optin-close {
	  position: absolute;
      display:inline-block;
      right:8px;
      top:0px;
      font-size:2em;
      z-index:999;
      color:#fff; 
      padding-left:10px;
	  cursor:pointer;
 }
  #optin-close:hover {
	  cursor:pointer;
 }

.login {
    text-transform: uppercase;
    font-size: 0.65em;
    font-weight: 800;
    letter-spacing: 0.2em;
    padding-right: 15px;
}

.login a:before {
	content: '\f2bd';
    font-family: 'Font Awesome 5 Pro';
	font-display: swap;
    padding-right: 10px;
    font-size: 1.5em;
    font-weight: 100;
    position: absolute;
    margin-left: -25px;
    margin-top: -3px;
}

.memberSign h6 {
	color: #808080;
}

header {
	background:#fff;
}

.home header {
	background: rgba(256,256,256,0);
}

.home header.headroom--not-top {
	background: rgba(256,256,256,1);
}

.navbar-light {
	border-bottom:1px solid #e6e6e6;
}

.navbar-toggler {
	border: none;
	position: absolute;
	z-index:99999;
	margin-top: -15px;
	width:40px;
	height:40px;
}

a.navbar-brand {
    margin: 0;
}

a.navbar-brand i {
    width: auto;
    font-size: 3.5em;
}

/* Icon 3 */

#nav-icon3 {
  width: 40px;
  height: 30px;
  position: relative;
  margin: 0 auto;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .5s ease-in-out;
  -moz-transition: .5s ease-in-out;
  -o-transition: .5s ease-in-out;
  transition: .5s ease-in-out;
  cursor: pointer;
}

#nav-icon3 span {
  display: block;
  position: absolute;
  height: 1px;
  width: 100%;
  background: #000;
  border-radius: 0;
  opacity: 1;
  left: 0;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .25s ease-in-out;
  -moz-transition: .25s ease-in-out;
  -o-transition: .25s ease-in-out;
  transition: .25s ease-in-out;
}

.collapsed #nav-icon3 span:nth-child(1) {
  top: 0px;
}

.navbar-toggler.collapsed:hover > #nav-icon3 span:nth-child(1), .navbar-toggler.collapsed:hover > #nav-icon3 span:nth-child(4) {
  left: 5px;
}

.collapsed #nav-icon3 span:nth-child(2), .collapsed #nav-icon3 span:nth-child(3) {
  top: 10px;
	left: 10px;
}

.navbar-toggler.collapsed:hover > #nav-icon3 span:nth-child(2), .navbar-toggler.collapsed:hover > #nav-icon3 span:nth-child(3) {
	left: 5px;
}

#nav-icon3 span:nth-child(4) {
  top: 20px;
}

.collapsed #nav-icon3.open span:nth-child(1) {
  top: 18px;
  width: 0%;
  left: 50%;
}

#nav-icon3 span:nth-child(1) {
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
	top:20px;
}

#nav-icon3 span:nth-child(4) {
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  transform: rotate(-45deg);
	top:20px;
}

.collapsed #nav-icon3 span:nth-child(1) {
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
	top:0px;
}

.collapsed #nav-icon3 span:nth-child(4) {
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
	top:20px;
}

.collapsed #nav-icon3.open span:nth-child(4) {
  top: 18px;
  width: 0%;
  left: 50%;
}

/*** FITMETRIX ***/

#sf-frame {
	width: 100%;
}

/***HOME***/

.vid{
    transform: scale(1.5);
}

.vidFrame {
    width: 100%;
    height: 380px;
    overflow: hidden;
}

.sq .vid{
    transform: scale(2);
}

/* PACKAGES */

.package {
    box-shadow: 0px 10px 20px rgba(0,0,0,0.25);
}

.price {
	font-weight: 800;
	font-size: 1.5em;
}

/***TESTIMONIAL CAROUSEL***/

#testimonials .carousel-item {
    min-height: 150px;
}

#testimonials .carousel-control-prev {
    left: -100px;
}

#testimonials .carousel-control-next {
    right: -100px;
}
.testimonial p {
    font-size: 1.5em;
    font-style: italic;
    font-family: 'Lato',sans-serif;
    font-weight: 600;
	line-height: 1.4em;
}

.strike {
	position: relative;
	width: auto;
	display: inline-block;
}

.strike:before {
	width: 110%;
	position: absolute;
	content: '';
	background: #e2e2e2;
	height:4px;
	margin-left: -6%;
	top: calc(50% - 2px);
	z-index:-1;
}

/*** INSTRUCTORS ***/
span.intro {
	font-size: 12px;
}

.leftA {
    bottom: 10px;
	left: 0;
    position: absolute;
}
.skills h6, .attributes h6 {
    margin-bottom: 70px;
}
.skills h6:after, .attributes h6:after {
    content: '';
    width: 30px;
    border-bottom: thin solid #B0A2AA;
    position: absolute;
    top: 50%;
    left: -40px;
}
.skills ul, .attributes ul {
    display: block;
    text-align: center;
}

.skills ul li, .attributes ul li {
	margin:5px 0;
	font-size: 1.5em;
}
.topA {
    top: 20px;
	right: 20px;
    position: absolute;
}
.baseA {
    bottom: 20px;
	right: 20px;
    position: absolute;
	width: 70%;
	text-align: right;
	line-height:1em;
}

/* MULTICAROUSEL */
#instructorCarousel {
	background: rgb(242,242,242);
	background: -moz-linear-gradient(top,  rgba(242,242,242,1) 0%, rgba(242,242,242,1) 50%, rgba(204,204,204,1) 50%, rgba(204,204,204,1) 100%);
	background: -webkit-linear-gradient(top,  rgba(242,242,242,1) 0%,rgba(242,242,242,1) 50%,rgba(204,204,204,1) 50%,rgba(204,204,204,1) 100%);
	background: linear-gradient(to bottom,  rgba(242,242,242,1) 0%,rgba(242,242,242,1) 50%,rgba(204,204,204,1) 50%,rgba(204,204,204,1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f2f2f2', endColorstr='#cccccc',GradientType=0 );
}
.carousel-control-prev, .carousel-control-next {
    font-size: 36px;
    color: #000;
}

#instrCarousel {
	width: 100%;
}

#instrCarousel .carousel-inner .carousel-item.active,
#instrCarousel .carousel-inner .carousel-item-next,
#instrCarousel .carousel-inner .carousel-item-prev {
  display: flex;
}

#instrCarousel .carousel-inner .carousel-item-right.active, #instrCarousel .carousel-inner .carousel-item-next {
  transform: translateX(33.3333%);
}

#instrCarousel .carousel-inner .carousel-item-left.active, #instrCarousel .carousel-inner .carousel-item-prev {
  transform: translateX(-33.3333%);
}

#instrCarousel .carousel-inner .carousel-item-right, #instrCarousel .carousel-inner .carousel-item-left {
  transform: translateX(0);
}

#instrCarousel .carousel-control-next, #instrCarousel .carousel-control-prev {
	width: 5%;
}

#instrCarousel .carousel-control-next-icon, #instrCarousel .carousel-control-prev-icon {
	margin-top: -75%;
}

#instrCarousel .carousel-control-prev {
	left: 30.7%;
		z-index:999;
}

#instrCarousel .carousel-control-next {
	right: 30.7%;
		z-index:999;
}

#instrCarousel .d-block {
	padding: 0 30px 30px;
}	



#profileDetails ul {
	padding-left: 0;
	list-style: none;
}

#profileDetails ul li {
	padding: 8px 0;
}

ul.skills, ul.attributes {
	margin-top:20px;
}	
ul.skills li, ul.attributes li {
	text-transform: uppercase;
	font-weight: 800;
	font-size: 0.8em;
	letter-spacing: 0.2em;
	padding-left: 55px!Important;
}	

ul.attributes li {
	padding-left:0px!important;
}
ul.skills i, ul.attributes i {
	width: 40px;
	text-align: left;
	padding:0;
	margin:-3px 5px 0 -50px;
	font-size: 2em;
	display: inline-block;
	position: absolute;
}

ul.qualifications li {
	border-top: thin solid #ccc;
}

/* GIFT CARDS */

#giftCards healcode-widget {
    border: thin solid #000;
    padding: 15px 30px;
    display: block;
    text-align: center;
}

/*** HOVER EFFECTS ***/
.disTop {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow: hidden;
    width: 100%;
    height: 100%;
	z-index: 999;
}
.disTop a, .disTop a:focus, .disTop a:active {
	color: #fff;
}
.view {
    position: relative;
    overflow: hidden;
    cursor: default;
}
.zoom img, .zoom video {
    transition: all .2s linear;
	transform: scale(1.05);
}
.view img, .view video {
    position: relative;
    display: block;
}

.desat, .desat img {
	-webkit-filter: grayscale(100%); /* Safari 6.0 - 9.0 */
	filter: grayscale(100%);
}
.overlay .mask {
    opacity: 0;
    transition: all .4s ease-in-out;
}
.view .mask, .onTop {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow: hidden;
    width: 100%;
    height: 100%;
    background-attachment: fixed;
}
.flex-center {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
}
.zoom:hover img, .zoom:hover video, .zoom:active video, .zoom:focus img, .zoom:focus video, .zoom:active video {
    transform: scale(1.1);
}
.overlay .mask:hover, .overlay .mask:focus, .overlay .mask:active {
    opacity: 1;
}

.zoom:hover > .disTop, .zoom:focus > .disTop, .zoom:active > .disTop {
	opacity:0;
}

.zoom:hover > .onTop, .zoom:focus > .onTop, .zoom:active > .onTop {
	background-color: rgba(256,256,256,0.8);
	z-index: 999;
}

.onTop {
    display: flex;
    justify-content: center;
    align-items: center;
}

/*** CPT ***/

#coaches .col-sm-3:hover > .coach, #instructors .col-md-4:hover > .coach, #instructorCarousel .col-sm-4:hover > .coach,
#coaches .col-sm-3:focus > .coach, #instructors .col-md-4:focus > .coach, #instructorCarousel .col-sm-4:focus > .coach,
#coaches .col-sm-3:active > .coach, #instructors .col-md-4:active > .coach, #instructorCarousel .col-sm-4:active > .coach {
  transform: scale(1.05);
}

.coach {
  box-shadow: 0px 10px 10px rgba(0,0,0,0.25);
}

.largePad {
	padding: 80px 40px;
}

/*** CONTACT ***/

.acf-map {
	width: 100%;
	height: 450px;
}
.acf-map img {
	max-width: inherit!important;
}

.times span {
    width: 70px;
    display: inline-block;
    font-weight: 800;
	text-align: left;
}

/*** FOOTER ***/

footer .textwidget {
    font-size: .9em;
}

footer .icon {
	width: auto;
	font-size: 2.5em;    
	margin: 5px 10px 15px 0;
}
/*
footer .introTxt {
	font-weight: 800;
	font-family: 'Montserrat', sans-serif;
}
*/

footer h5, footer ul li, footer {
    font-size: 0.9em;
}

footer ul, ul.social {
    padding: 15px 0;
    list-style: none;
}

footer ul li {
    margin:10px 0;
}

.social i{
	width: 30px;
}

#copyright {
	font-size: 0.8em;
}

@media screen and (max-width:768px) {
	li#menu-item-474 {
    	display: none;
	}
}

@media screen and (min-width:575px) and (max-width:960px) {
	.skills ul li {
	    margin: 2px 0;
	    font-size: 1em;
	}	
	.skills h6 {
		font-size: 0.5em;
	}
	.baseA h5 {
		font-size: 1em;
	}
	span.intro {
	    font-size: 10px;
	    line-height: 0.8em;
	}	
	.topA {
	    font-size: 0.8em;		
	}
	.overlay ul {
		margin-top: 65px;
	}
}

@media screen and (max-width:767px) {
	a.navbar-brand i {
	    width: auto;
	    font-size: 2em;
	}
	.bookClass:before {
		content: 'Book';
    	font-family: 'Montserrat', sans-serif;
    	padding-right: 10px;
    	font-weight: 100;
    	margin-left: -25px;
    	margin-top: -3px;
		font-size: 1em;
		float: right;
		padding: 0;
	}	
	.login a:before {
		font-size: 1.5em;
		margin-top: -3px;
	}
	.memberSign h6 {
	    color: #808080;
	    font-size: 0.7em;
	}
	.bookClass span, .login span, .bookClass:after {
		display: none;
	}
	.navbar-toggler {
		padding: 5px 0;
	}
	h1 {
		font-size: 2em;
	}
	.proImg {
		height:400px;
	}
#testimonials .carousel-control-prev {
    left: 0;
}

#testimonials .carousel-control-next {
    right: 0;
}	
	.overlay ul {
		margin-top:100px;
	}
	.largePad {
		padding:0;
	}
	#instrCarousel .carousel-control-prev {
		left: 2%;
	}
	#instrCarousel .carousel-control-next {
		right: 2%;
	}	
	.carousel-item {
		opacity:0;
	}
	.carousel-item.active {
		opacity:1;
	}	
	#instrCarousel .carousel-inner .carousel-item-right.active, #instrCarousel .carousel-inner .carousel-item-next {
	  transform: translateX(0%);
	}
	#instrCarousel .carousel-inner .carousel-item-left.active, #instrCarousel .carousel-inner .carousel-item-prev {
	  transform: translateX(0%);
	}
	.classType .zoom img {
    	min-height: 100%;
    	width: auto;
		max-width: none;
		position: absolute;
		right:0;
	}
	.classType .zoom .bgleft img {
		left: 0;
	}
	.col-sm-6.classType .bgleft img {
		left: -45%;
	}	
	
	.classType.wide .zoom img {	
	    margin-left: -50%;
	}
	.classType {
		height: 380px;
	}
	.baseA {
		line-height: 0.9em;
	}
	#instrCarousel .d-block {
		padding: 0 10px 20px;
	}	
}

@media screen and (max-width:575px) {
	#instrCarousel .d-block {
		padding: 0 50px 30px;
	}
}

@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) and (orientation : portrait) {
	.vidFrame {
		height:280px;
	}	
	h2 {
		font-size: 1.6em;
	}
	.onTop h2 {
		font-size: 1.2em;
	}
	.onTop p, .onTop .btn {
		font-size: 0.5em;
	}
	footer h5 {
		font-size:0.8em;
	}
	.testimonial p {
		font-size: 1.25em;
	}
}
/* =========================
   WEFORM COLOUR OVERRIDES
   Paste at bottom of style.css
   ========================= */

body { color: var(--wf-dark); }
a, a:hover, a:active, a:visited { color: var(--wf-dark); }

::selection, ::-moz-selection {
  background: var(--wf-teal);
  color: var(--wf-white);
}

.bg-light { background-color: var(--wf-blue)!important; }
.bg-dark  { background-color: var(--wf-dark)!important; }

.navbar-light { border-bottom: 1px solid rgba(3,59,43,0.12); }
#nav-icon3 span { background: var(--wf-dark); }

.btn-primary{
  background: var(--wf-dark);
  border-color: var(--wf-dark);
  color: var(--wf-white)!important;
}
.btn-primary:hover{
  background: var(--wf-teal);
  border-color: var(--wf-teal);
}

.btn-outline-primary,
.healcode-contract-text-link,
.healcode-pricing-option-text-link{
  color: var(--wf-dark);
  border-color: var(--wf-dark);
}
.btn-outline-primary:hover,
.healcode-contract-text-link:hover,
.healcode-pricing-option-text-link:hover{
  background: var(--wf-dark);
  border-color: var(--wf-dark);
  color: var(--wf-white);
}

.package{
  box-shadow: 0px 10px 20px rgba(3,59,43,0.18);
}
.package h5.bg-dark{
  background-color: var(--wf-dark)!important;
}

@media screen and (min-width:992px) {
  .classTime:hover{
    background: var(--wf-dark);
    color: var(--wf-white);
  }
  .classTime:hover > .class a { color: var(--wf-white)!important; }
}

.overlay ul li a:hover,
.overlay ul li a:focus,
.overlay ul li a:active{
  color: var(--wf-teal);
}

span.trainer,
span.trainer a,
.memberSign h6{
  color: rgba(3,59,43,0.55);
}

.alert-primary{
  color: var(--wf-dark);
  border-color: var(--wf-dark);
}
.alert-primary a{ color: var(--wf-dark)!important; }

.alert-danger{
  border-color: var(--wf-brown);
  color: var(--wf-brown);
}
.alert-danger a{ color: var(--wf-brown)!important; }

/* Site-wide default background */
html, body {
  background-color: var(--wf-cream);
}
/* If theme wrapper has its own background */
.main,
#page,
.site,
.site-content,
.content-area {
  background-color: var(--wf-cream);
}
/* Don't allow white text on light sections */
.text-white { color: var(--wf-white)!important; }

/* Allow white text where it makes sense */
.bg-dark .text-white,
.bg-dark h1, .bg-dark h2, .bg-dark h3, .bg-dark p,
footer .text-white{
  color: var(--wf-white)!important;
}
/* FIX: keep homepage video ABOVE the site background */
#fullVideo{
  position: relative;
  height: 100vh;
  overflow: hidden;
  z-index: 0;
}

.vimeo-wrapper{
  z-index: 0;           /* was -1 */
}
/* ===============================
   HERO TILE – CENTERED O LOGO
   Bigger • Lower • Animated
   =============================== */

/* Ensure tile is positioning context */
.hero-tile{
	position: relative;
}

/* Base logo */
.hero-tile::after{
	content: "";
	position: absolute;
	left: 50%;
	top: 72%;                    /* ⬅️ lower half of tile */
	transform: translate(-50%, 0) scale(1);
	width: 90px;                 /* ⬅️ bigger */
	height: 90px;
	background: url("https://simsondigital-bpasu.wpcomstaging.com/wp-content/uploads/2026/01/WeForm-O-Logo-Transparent-.png")
		no-repeat center;
	background-size: contain;
	opacity: 0.95;
	pointer-events: none;
	z-index: 3;

	transition:
		transform 0.45s ease,
		opacity 0.45s ease;
}

/* Hover animation */
.hero-tile:hover::after{
	transform: translate(-50%, -10px) scale(1.1);
	opacity: 1;
}
/* REMOVE old icon-font logo on hero tiles */
.hero-tile .disTop h2:after,
.hero-tile .mask h2:after{
	content: none !important;
	display: none !important;
	background: none !important;
}
/* CLASSES: make the hover text box light blue (no page background changes) */
.classType .onTop{
	background-color: var(--wf-blue) !important; /* light blue */
}

/* Text inside the light-blue box */
.classType .onTop h2,
.classType .onTop h2 a,
.classType .onTop p{
	color: var(--wf-dark) !important; /* dark green text for contrast */
}

/* Buttons inside the light-blue box */
.classType .onTop .btn-outline-primary{
	border-color: var(--wf-dark) !important;
	color: var(--wf-dark) !important;
}

.classType .onTop .btn-outline-primary:hover{
	background: var(--wf-dark) !important;
	color: var(--wf-white) !important;
}

/* Keep primary button consistent */
.classType .onTop .btn-primary{
	background: var(--wf-dark) !important;
	border-color: var(--wf-dark) !important;
	color: var(--wf-white) !important;
}

.classType .onTop .btn-primary:hover{
	background: var(--wf-teal) !important;
	border-color: var(--wf-teal) !important;
}
/* =========================================
   CLASS CONCEPTS – FORCE LIGHT BLUE BACKGROUND
   (covers div.main AND any inner wrapper panels)
   ========================================= */

:root{
  --wf-light-blue:#cfe5df; /* your light blue */
}

/* Apply to Class Concepts pages only */
body[class*="class-concepts"] div.main,
body[class*="class_concepts"] div.main,
body[class*="class-concepts"] div.main * ,
body[class*="class_concepts"] div.main * {
  background-color: var(--wf-light-blue) !important;
}
/* =========================================
   CLASS CONCEPTS – LEFT TEXT PANEL (bg-light/opacity-80) → LIGHT BLUE
   Paste at VERY BOTTOM of style.css
   ========================================= */

/* You already have --wf-blue in :root, use that */
body.single-class-concepts .bg-light,
body.single-class-concepts .opacity-80{
  background-color: var(--wf-blue) !important;
}

/* If any class concepts pages are using inline background images, remove them */
body.single-class-concepts [style*="background:url"]{
  background-image: none !important;
  background: var(--wf-blue) !important;
}
/* =========================================
   CLASS CONCEPTS – FIX GREY PANEL (bg-light + opacity-80)
   Paste at VERY BOTTOM of style.css
   ========================================= */

/* Covers both body class naming styles */
body.single-class-concepts .col-lg-6.bg-light.opacity-80,
body.single-class_concepts .col-lg-6.bg-light.opacity-80,
body[class*="class-concepts"] .col-lg-6.bg-light.opacity-80,
body[class*="class_concepts"] .col-lg-6.bg-light.opacity-80{
  background: var(--wf-blue) !important;       /* this kills background-image too */
  background-image: none !important;
}

/* Belt + braces: override the utility classes on those pages */
body.single-class-concepts .bg-light,
body.single-class_concepts .bg-light,
body[class*="class-concepts"] .bg-light,
body[class*="class_concepts"] .bg-light{
  background-color: var(--wf-blue) !important;
}

body.single-class-concepts .opacity-80,
body.single-class_concepts .opacity-80,
body[class*="class-concepts"] .opacity-80,
body[class*="class_concepts"] .opacity-80{
  background-color: var(--wf-blue) !important;
}
/* =========================================
   CLASS CONCEPTS – FIX GREY PANEL (bg-light + opacity-80)
   Paste at VERY BOTTOM of style.css
   ========================================= */

/* Covers both body class naming styles */
body.single-class-concepts .col-lg-6.bg-light.opacity-80,
body.single-class_concepts .col-lg-6.bg-light.opacity-80,
body[class*="class-concepts"] .col-lg-6.bg-light.opacity-80,
body[class*="class_concepts"] .col-lg-6.bg-light.opacity-80{
  background: var(--wf-blue) !important;       /* this kills background-image too */
  background-image: none !important;
}

/* Belt + braces: override the utility classes on those pages */
body.single-class-concepts .bg-light,
body.single-class_concepts .bg-light,
body[class*="class-concepts"] .bg-light,
body[class*="class_concepts"] .bg-light{
  background-color: var(--wf-blue) !important;
}

body.single-class-concepts .opacity-80,
body.single-class_concepts .opacity-80,
body[class*="class-concepts"] .opacity-80,
body[class*="class_concepts"] .opacity-80{
  background-color: var(--wf-blue) !important;
}
/* =========================================
   INDIVIDUAL CLASS PAGES – FORCE LIGHT BLUE BOXES
   Paste at VERY BOTTOM of style.css
   ========================================= */

/* Use your existing light blue variable */
body.single-class-concepts .bg-light,
body.single-class_concepts .bg-light,
body.single-class-concepts .opacity-80,
body.single-class_concepts .opacity-80,
body.single-class-concepts .opacity-90,
body.single-class_concepts .opacity-90,
body.single-class-concepts .col-lg-6.bg-light,
body.single-class_concepts .col-lg-6.bg-light,
body.single-class-concepts .col-lg-6.bg-light.opacity-80,
body.single-class_concepts .col-lg-6.bg-light.opacity-80,
body.single-class-concepts .col-lg-6.bg-light.opacity-90,
body.single-class_concepts .col-lg-6.bg-light.opacity-90{
  background: var(--wf-blue) !important;        /* kills gradients + images */
  background-image: none !important;
}

/* If the grey is coming from inline styles, force override */
body.single-class-concepts [style*="background"],
body.single-class_concepts [style*="background"]{
  background-color: var(--wf-blue) !important;
  background-image: none !important;
}

/* Book-a-class widget header/date (if used on these pages) */
body.single-class-concepts .bw-widget__header,
body.single-class_concepts .bw-widget__header,
body.single-class-concepts .bw-widget__date,
body.single-class_concepts .bw-widget__date{
  background-color: var(--wf-blue) !important;
}

/* Timetable class boxes, if they appear on these pages */
body.single-class-concepts .classTime,
body.single-class_concepts .classTime{
  background: var(--wf-blue) !important;
  border-color: var(--wf-white) !important;
}

/* Make sure text stays readable on light blue */
body.single-class-concepts .bg-light,
body.single-class_concepts .bg-light,
body.single-class-concepts .opacity-80,
body.single-class_concepts .opacity-80{
  color: var(--wf-dark) !important;
}
/* =========================================
   CLASS TEMPLATE – FORCE LEFT PANEL LIGHT BLUE
   (does NOT affect the section background image)
   ========================================= */

section.desat .class-panel{
  background-color: rgba(197, 219, 216, 0.90) !important; /* light blue overlay */
  background-image: none !important;
}

/* If something inside is still painting grey/white, neutralize it */
section.desat .class-panel *{
  background-color: transparent;
}

/* Restore the panel background after wiping inner backgrounds */
section.desat .class-panel{
  background-color: rgba(197, 219, 216, 0.90) !important;
}
