@charset "UTF-8";
/* BACKGROUND COLOR OPACITY */
/* general opacity */
/* css filters */
/* TEXT SHADOW */
/* Border radius */
/* Reset/Adjust styles of <button> elements */
/* open-sans-300 - latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 300;
  src: local(""), url("fonts/open-sans-v34-latin-300.woff2") format("woff2"), url("fonts/open-sans-v34-latin-300.woff") format("woff");
  /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */ }

/* open-sans-regular - latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  src: local(""), url("fonts/open-sans-v34-latin-regular.woff2") format("woff2"), url("fonts/open-sans-v34-latin-regular.woff") format("woff");
  /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */ }

/* open-sans-700 - latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  src: local(""), url("fonts/open-sans-v34-latin-700.woff2") format("woff2"), url("fonts/open-sans-v34-latin-700.woff") format("woff");
  /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */ }

/* open-sans-800 - latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  src: local(""), url("fonts/open-sans-v34-latin-800.woff2") format("woff2"), url("fonts/open-sans-v34-latin-800.woff") format("woff");
  /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */ }

/* montserrat-300 - latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  src: local(""), url("fonts/montserrat-v25-latin-300.woff2") format("woff2"), url("fonts/montserrat-v25-latin-300.woff") format("woff");
  /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */ }

/* montserrat-regular - latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  src: local(""), url("fonts/montserrat-v25-latin-regular.woff2") format("woff2"), url("fonts/montserrat-v25-latin-regular.woff") format("woff");
  /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */ }

/* montserrat-800 - latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  src: local(""), url("fonts/montserrat-v25-latin-800.woff2") format("woff2"), url("fonts/montserrat-v25-latin-800.woff") format("woff");
  /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */ }

#headerBackground.header_1 {
  background-image: url("../_images/header/header_1_mobile.jpg");
  /* @include tint(260deg); */ }

#headerBackground.header_2 {
  background-image: url("../_images/header/header_2_mobile.jpg"); }

#headerBackground.header_3 {
  background-image: url("../_images/header/header_3_mobile.jpg"); }

#headerBackground.header_4 {
  background-image: url("../_images/header/header_4_mobile.jpg"); }

#headerBackground.header_5 {
  background-image: url("../_images/header/header_5_mobile.jpg"); }

#headerBackground.header_6 {
  background-image: url("../_images/header/header_6_mobile.jpg"); }

#headerBackground.header_7 {
  background-image: url("../_images/header/header_7_mobile.jpg"); }

#headerBackground.header_8 {
  background-image: url("../_images/header/header_8_mobile.jpg"); }

#headerBackground.header_9 {
  background-image: url("../_images/header/header_9_mobile.jpg"); }

#headerBackground.header_10 {
  background-image: url("../_images/header/header_10_mobile.jpg"); }

#headerBackground.header_11 {
  background-image: url("../_images/header/header_11_mobile.jpg"); }

#headerBackground.header_12 {
  background-image: url("../_images/header/header_12_mobile.jpg"); }

#headerBackground.header_13 {
  background-image: url("../_images/header/header_13_mobile.jpg"); }

#headerBackground.header_14 {
  background-image: url("../_images/header/header_14_mobile.jpg"); }

#headerBackground.header_15 {
  background-image: url("../_images/header/header_15_mobile.jpg"); }

#headerBackground.header_16 {
  background-image: url("../_images/header/header_16_mobile.jpg"); }

#headerBackground.header_17 {
  background-image: url("../_images/header/header_17_mobile.jpg"); }

#headerBackground.header_18 {
  background-image: url("../_images/header/header_18_mobile.jpg");
  /* @include filter(7px, 0.9); */ }

#headerBackground.header_19 {
  background-image: url("../_images/header/header_19_mobile.jpg"); }

#headerBackground.header_20 {
  background-image: url("../_images/header/header_20_mobile.jpg"); }

#headerBackground.landing_1 {
  background-image: url("../_images/header/landing_1.jpg"); }

#headerBackground.landing_2 {
  background-image: url("../_images/header/landing_2.jpg"); }

#headerBackground.landing_3 {
  background-image: url("../_images/header/landing_3.jpg"); }

#headerBackground.landing_4 {
  background-image: url("../_images/header/landing_4.jpg"); }

#headerBackground.landing_5 {
  background-image: url("../_images/header/landing_5.jpg"); }

#headerBackground.landing_6 {
  background-image: url("../_images/header/landing_6.jpg"); }

#headerBackground.landing_7 {
  background-image: url("../_images/header/landing_7.jpg"); }

#headerBackground.landing_8 {
  background-image: url("../_images/header/landing_8.jpg"); }

#headerBackground.landing_9 {
  background-image: url("../_images/header/landing_9.jpg"); }

#headerBackground.landing_10 {
  background-image: url("../_images/header/landing_10.jpg"); }

#headerBackground.landing_11 {
  background-image: url("../_images/header/landing_11.jpg"); }

#headerBackground.landing_12 {
  background-image: url("../_images/header/landing_12.jpg"); }

@media only screen and (min-width: 768px) {
  #headerBackground.header_1 {
    background-image: url("../_images/header/header_1.jpg"); }
  #headerBackground.header_2 {
    background-image: url("../_images/header/header_2.jpg"); }
  #headerBackground.header_3 {
    background-image: url("../_images/header/header_3.jpg"); }
  #headerBackground.header_4 {
    background-image: url("../_images/header/header_4.jpg"); }
  #headerBackground.header_5 {
    background-image: url("../_images/header/header_5.jpg"); }
  #headerBackground.header_6 {
    background-image: url("../_images/header/header_6.jpg"); }
  #headerBackground.header_7 {
    background-image: url("../_images/header/header_7.jpg"); }
  #headerBackground.header_8 {
    background-image: url("../_images/header/header_8.jpg"); }
  #headerBackground.header_9 {
    background-image: url("../_images/header/header_9.jpg"); }
  #headerBackground.header_10 {
    background-image: url("../_images/header/header_10.jpg"); }
  #headerBackground.header_11 {
    background-image: url("../_images/header/header_11.jpg"); }
  #headerBackground.header_12 {
    background-image: url("../_images/header/header_12.jpg"); }
  #headerBackground.header_13 {
    background-image: url("../_images/header/header_13.jpg"); }
  #headerBackground.header_14 {
    background-image: url("../_images/header/header_14.jpg"); }
  #headerBackground.header_15 {
    background-image: url("../_images/header/header_15.jpg"); }
  #headerBackground.header_16 {
    background-image: url("../_images/header/header_16.jpg"); }
  #headerBackground.header_17 {
    background-image: url("../_images/header/header_17.jpg"); }
  #headerBackground.header_18 {
    background-image: url("../_images/header/header_18.jpg"); }
  #headerBackground.header_19 {
    background-image: url("../_images/header/header_19.jpg"); }
  #headerBackground.header_20 {
    background-image: url("../_images/header/header_20.jpg"); } }

@media only screen and (min-width: 1100px) {
  #headerBackground.header_1 {
    background-image: url("../_images/header/header_1_retina.jpg"); }
  #headerBackground.header_2 {
    background-image: url("../_images/header/header_2_retina.jpg"); }
  #headerBackground.header_3 {
    background-image: url("../_images/header/header_3_retina.jpg"); }
  #headerBackground.header_4 {
    background-image: url("../_images/header/header_4_retina.jpg"); }
  #headerBackground.header_5 {
    background-image: url("../_images/header/header_5_retina.jpg"); }
  #headerBackground.header_6 {
    background-image: url("../_images/header/header_6_retina.jpg"); }
  #headerBackground.header_7 {
    background-image: url("../_images/header/header_7_retina.jpg"); }
  #headerBackground.header_8 {
    background-image: url("../_images/header/header_8_retina.jpg"); }
  #headerBackground.header_9 {
    background-image: url("../_images/header/header_9_retina.jpg"); }
  #headerBackground.header_10 {
    background-image: url("../_images/header/header_10_retina.jpg"); }
  #headerBackground.header_11 {
    background-image: url("../_images/header/header_11_retina.jpg"); }
  #headerBackground.header_12 {
    background-image: url("../_images/header/header_12_retina.jpg"); }
  #headerBackground.header_13 {
    background-image: url("../_images/header/header_13_retina.jpg"); }
  #headerBackground.header_14 {
    background-image: url("../_images/header/header_14_retina.jpg"); }
  #headerBackground.header_15 {
    background-image: url("../_images/header/header_15_retina.jpg"); }
  #headerBackground.header_16 {
    background-image: url("../_images/header/header_16_retina.jpg"); }
  #headerBackground.header_17 {
    background-image: url("../_images/header/header_17_retina.jpg"); }
  #headerBackground.header_18 {
    background-image: url("../_images/header/header_18_retina.jpg"); }
  #headerBackground.header_19 {
    background-image: url("../_images/header/header_19_retina.jpg"); }
  #headerBackground.header_20 {
    background-image: url("../_images/header/header_20_retina.jpg"); } }

a,
a:active,
a:visited {
  color: #25292d;
  text-decoration: none;
  outline: none;
  cursor: pointer;
  -webkit-transition: all 0.2s ease-out;
  -moz-transition: all 0.2s ease-out;
  -ms-transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out; }
  a:hover,
  a:active:hover,
  a:visited:hover {
    color: #e5004b; }
  a img,
  a:active img,
  a:visited img {
    border: 0; }
  a.textlink,
  a:active.textlink,
  a:visited.textlink {
    border-bottom: 1.5px solid #25292d;
    font-weight: 700;
    white-space: nowrap; }
    a.textlink-arrow::after,
    a:active.textlink-arrow::after,
    a:visited.textlink-arrow::after {
      margin-left: 4px;
      font-family: "FontAwesome";
      content: "\f061"; }
    a.textlink:hover,
    a:active.textlink:hover,
    a:visited.textlink:hover {
      border-color: #e5004b; }
  a.btn, a.btn-primary,
  a:active.btn,
  a:active.btn-primary,
  a:visited.btn,
  a:visited.btn-primary {
    box-sizing: border-box;
    display: inline-block;
    white-space: nowrap;
    padding: 0.8em 1.4em;
    margin-top: 10px;
    text-transform: uppercase;
    border: 1px solid #e5004b;
    border-radius: 4px;
    font-weight: 700;
    font-size: 0.9em;
    line-height: 1.5em; }
  a.btn,
  a:active.btn,
  a:visited.btn {
    color: #e5004b; }
    a.btn:hover,
    a:active.btn:hover,
    a:visited.btn:hover {
      color: #e5004b; }
  a.btn-primary,
  a:active.btn-primary,
  a:visited.btn-primary {
    background-color: #e5004b;
    color: #fff; }
    a.btn-primary:hover,
    a:active.btn-primary:hover,
    a:visited.btn-primary:hover {
      color: #fff; }
  a.btn-text,
  a:active.btn-text,
  a:visited.btn-text {
    border: 1px solid transparent; }
    a.btn-text:hover,
    a:active.btn-text:hover,
    a:visited.btn-text:hover {
      background-color: none;
      border: 1px solid #e5004b; }
  a.btn-success,
  a:active.btn-success,
  a:visited.btn-success {
    color: #00e0a1;
    border-color: #00e0a1; }
    a.btn-success:hover,
    a:active.btn-success:hover,
    a:visited.btn-success:hover {
      color: #00e0a1; }
    a.btn-success::before,
    a:active.btn-success::before,
    a:visited.btn-success::before {
      margin-right: 7px;
      font-family: "FontAwesome";
      content: " \f00c"; }
  a.btn-arrow-right::after,
  a:active.btn-arrow-right::after,
  a:visited.btn-arrow-right::after {
    margin-left: 7px;
    font-family: "FontAwesome";
    content: " \f105"; }
  a.btn-arrow-left::before,
  a:active.btn-arrow-left::before,
  a:visited.btn-arrow-left::before {
    margin-right: 11px;
    font-family: "FontAwesome";
    content: "\f104 "; }
  a.btn-heart-o::before,
  a:active.btn-heart-o::before,
  a:visited.btn-heart-o::before {
    margin-right: 11px;
    font-family: "Font Awesome 5 Free";
    font-weight: 200;
    content: "\f004"; }
  a.btn-heart::before,
  a:active.btn-heart::before,
  a:visited.btn-heart::before {
    margin-right: 11px;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f004"; }
  a.colorMagenta,
  a:active.colorMagenta,
  a:visited.colorMagenta {
    color: #e5004b;
    -webkit-transition: all 0.7s ease-out;
    -moz-transition: all 0.7s ease-out;
    -ms-transition: all 0.7s ease-out;
    -o-transition: all 0.7s ease-out;
    transition: all 0.7s ease-out; }
    a.colorMagenta:hover,
    a:active.colorMagenta:hover,
    a:visited.colorMagenta:hover {
      color: #00e0a1; }

textarea,
input[type="email"],
input[type="password"],
input[type="text"] {
  -webkit-appearance: none;
  box-sizing: border-box;
  background-clip: padding-box;
  border: 1px solid #999;
  border-radius: 0.25em;
  color: #25292d;
  outline: 0;
  margin: 0.5em 0px;
  padding: 0.8em;
  text-align: left;
  font-size: 1em;
  font-weight: 300;
  font-family: Open Sans, Arial, Helvetica, sans-serif;
  vertical-align: middle;
  width: 100%; }
  textarea.halfWidth,
  input[type="email"].halfWidth,
  input[type="password"].halfWidth,
  input[type="text"].halfWidth {
    width: 49%; }
  textarea.autoWidth,
  input[type="email"].autoWidth,
  input[type="password"].autoWidth,
  input[type="text"].autoWidth {
    width: auto; }
  textarea.minWidth,
  input[type="email"].minWidth,
  input[type="password"].minWidth,
  input[type="text"].minWidth {
    width: 40px; }

select {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-background-clip: padding;
  -moz-background-clip: padding;
  background-clip: padding-box;
  background-color: #fff;
  color: #25292d;
  outline: 0;
  margin: 3px 0px;
  padding: 0.4em;
  text-align: left;
  font-size: 1em;
  font-weight: 300;
  font-family: Open Sans, Arial, Helvetica, sans-serif;
  vertical-align: middle;
  border: 1px solid #999;
  -webkit-border-radius: 0px;
  -moz-border-radius: 0px;
  -ms-border-radius: 0px;
  -o-border-radius: 0px;
  border-radius: 0px; }
  select.fullWidth {
    width: 100%; }

/*** custom checkboxes ***/
label {
  cursor: pointer; }

input[type="checkbox"] {
  display: none; }

label input[type="checkbox"] {
  display: inline-block; }

input[type="checkbox"] + label:before {
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  -ms-border-radius: 2px;
  -o-border-radius: 2px;
  border-radius: 2px;
  font-family: FontAwesome;
  box-sizing: border-box;
  font-size: 1em;
  position: relative;
  width: 1em;
  height: 1em;
  border: 1px solid #999;
  margin-right: 0.5em;
  padding: 0.1em;
  content: "\f00c";
  color: transparent; }

input[type="checkbox"]:checked + label:before {
  content: "\f00c";
  background-color: #25292d;
  border: 1px solid #25292d;
  color: #fff; }

button,
button[type="submit"],
button[type="reset"],
input[type="button"],
input[type="submit"],
input[type="reset"] {
  margin: 0;
  border: 0;
  padding: 0;
  font: inherit;
  background-color: transparent;
  cursor: pointer;
  overflow: visible;
  /* Removes extra side padding in IE */
  outline: none;
  padding: 0.8em 1.4em;
  border: 0;
  border-radius: 5px;
  color: #fff;
  background-color: #e5004b;
  font-family: "FontAwesome", "Open Sans", Arial, Helvetica, sans-serif;
  text-transform: uppercase;
  font-weight: 700;
  font-size: .9em; }
  button:active,
  button[type="submit"]:active,
  button[type="reset"]:active,
  input[type="button"]:active,
  input[type="submit"]:active,
  input[type="reset"]:active {
    outline: none; }
  button::-moz-focus-inner,
  button[type="submit"]::-moz-focus-inner,
  button[type="reset"]::-moz-focus-inner,
  input[type="button"]::-moz-focus-inner,
  input[type="submit"]::-moz-focus-inner,
  input[type="reset"]::-moz-focus-inner {
    border: 0;
    padding: 0; }
  button::after,
  button[type="submit"]::after,
  button[type="reset"]::after,
  input[type="button"]::after,
  input[type="submit"]::after,
  input[type="reset"]::after {
    margin-left: 7px;
    font-family: "FontAwesome";
    content: " \f105"; }
  button:disabled,
  button[type="submit"]:disabled,
  button[type="reset"]:disabled,
  input[type="button"]:disabled,
  input[type="submit"]:disabled,
  input[type="reset"]:disabled {
    border-color: #999;
    color: #999; }

.columns {
  margin: 0 20px;
  column-gap: 40px; }
  .columns p {
    margin-top: 0; }
  .columns-2 {
    column-count: 2; }
    @media (max-width: 767px) {
      .columns-2 {
        column-count: 1; } }
  .columns-3 {
    column-count: 3; }
    @media (max-width: 767px) {
      .columns-3 {
        column-count: 1; } }

.badge {
  display: inline-block;
  margin: .5em;
  padding: 0 1.3em;
  border-radius: 15px;
  border: 1px solid #25292d;
  text-transform: uppercase;
  font-size: 0.8em;
  font-weight: 700;
  letter-spacing: 1px;
  line-height: 2em; }
  .badge-dark {
    background-color: #25292d;
    color: #fff; }
  .badge-red {
    background-color: #e5004b;
    color: #fff;
    border-color: #e5004b; }
  .badge-small {
    font-size: 0.6em; }

.taSizeSmall {
  font-size: 0.8em; }

.taSizeSmaller {
  font-size: 0.5em; }

.taSizeLarge {
  font-size: 1.5em; }

.taSizeLarger {
  font-size: 2em; }

.taShadow {
  text-shadow: 0px 0px 5px rgba(0, 0, 0, 0.8); }

.taShadow--2p {
  text-shadow: 0px 0px 2px rgba(0, 0, 0, 0.9); }

.taColorMagenta,
.taColorRaspberry {
  color: #e5004b !important; }

.taColorOrange {
  color: #ffbc0a !important; }

.taColorIndigo {
  color: #4502da !important; }

.taColorWhite {
  color: #fff !important; }

.taColorGreen {
  color: #00e0a1 !important; }

.taColorGrey {
  color: #999 !important; }

.taColorDarkGrey {
  color: #25292d !important; }

.taBgColorGrey {
  background: #999 !important;
  background: rgba(153, 153, 153, 0.5) !important; }

.taBgColorMagenta {
  background: #e5004b !important;
  background: rgba(229, 0, 75, 0.5) !important; }

.taDisplayInlineBlock {
  display: inline-block !important; }

.taCenter {
  text-align: center; }

.taRight {
  text-align: right; }

.taLeft {
  text-align: left; }

.taWeightBold {
  font-weight: bold !important; }

.taUppercase {
  text-transform: uppercase; }

.taNarrow {
  letter-spacing: -0.05em; }

.taItalic {
  font-style: italic; }

h1,
h2,
h3 {
  margin: 0; }

h1,
.h1 {
  color: #000;
  text-transform: uppercase;
  padding-top: 20px;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-weight: 800;
  letter-spacing: -1px;
  font-size: 1.8em;
  line-height: 1.2em; }

h2,
h3,
.h2,
.h3 {
  color: #25292d;
  padding-top: 5px;
  font-size: 1.1em;
  font-weight: 400;
  font-family: "Montserrat", Arial, Helvetica, sans-serif; }

.header {
  box-sizing: border-box;
  width: 100%;
  height: 80px;
  background-color: #fff;
  border-bottom: 1px solid #ececec; }
  .header .pageWrap {
    display: flex;
    justify-content: space-between;
    align-items: center; }

.header_navigation {
  display: flex;
  justify-content: space-between;
  align-items: center; }

.header_logo {
  width: 150px;
  height: auto; }
  .header_logo img {
    width: 100%; }

.header_meta {
  margin-right: 20px;
  color: #999; }
  .header_meta .header-cart-icon--active {
    color: #e5004b; }
  .header_meta .header-user-icon--active {
    color: #e5004b; }

.header_burger_menu {
  cursor: pointer;
  box-sizing: border-box;
  padding-left: 20px;
  border-left: 1px solid #999;
  text-transform: uppercase;
  font-weight: 400; }
  .header_burger_menu .header_burger_menu--label {
    margin-left: 5px; }

@media (max-width: 767px) {
  .header .pageWrap {
    padding: 0 20px; }
  .header_logo {
    width: 125px; }
  .header_burger_menu .header_burger_menu--label {
    display: none; } }

.body--fixed {
  position: fixed;
  overflow: hidden;
  width: 100%; }

.overlay {
  display: none;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9998;
  background-color: #00000077; }

.overlay--active {
  display: block; }

.side-menu {
  display: none;
  position: fixed;
  box-sizing: border-box;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  background-color: #fff;
  overflow: hidden;
  animation: slide-out 0.3s ease-in forwards; }

.side-menu--active {
  display: flex;
  flex-flow: column nowrap;
  justify-content: space-between;
  animation: slide-in 0.3s ease-in forwards; }

.side-menu--header {
  display: flex;
  justify-content: space-between;
  flex-flow: row-reverse;
  align-items: center;
  height: 80px;
  min-height: 80px;
  box-sizing: border-box;
  padding: 0 20px;
  border-bottom: 1px solid #ececec; }
  .side-menu--header .side-menu--header__logo {
    width: 125px;
    height: auto; }
    .side-menu--header .side-menu--header__logo img {
      width: 100%; }
  .side-menu--header .side-menu--header__close {
    cursor: pointer;
    color: #000;
    text-align: right;
    padding-left: 20px;
    border-left: 1px solid #999; }

.side-menu--nav {
  display: flex;
  flex-flow: column nowrap;
  justify-content: space-between;
  height: 100%; }

.side-menu--myaviva {
  background-color: #f3f3f3;
  font-weight: 700;
  padding: 0 20px; }
  .side-menu--myaviva__header {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-flow: row nowrap;
    -webkit-flex-flow: row nowrap;
    -moz-flex-flow: row nowrap;
    -ms-flex-flow: row nowrap;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    -ms-justify-content: space-between;
    align-items: stretch;
    -webkit-align-items: stretch;
    -moz-align-items: stretch;
    -ms-align-items: stretch;
    margin: 10px 0;
    padding-bottom: 5px;
    border-bottom: 1px solid #25292d; }
  .side-menu--myaviva .myaviva-login__input:-webkit-autofill,
  .side-menu--myaviva .myaviva-login__input:-webkit-autofill:hover,
  .side-menu--myaviva .myaviva-login__input:-webkit-autofill:focus,
  .side-menu--myaviva .myaviva-login__input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 30px #f3f3f3 inset !important; }
  .side-menu--myaviva__name {
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -1.25px;
    text-transform: uppercase; }
  .side-menu--myaviva .side-menu--myaviva__nav {
    list-style: none;
    margin: 0;
    margin-bottom: 10px;
    padding: 0;
    display: flex;
    justify-content: flex-start;
    flex-flow: row wrap;
    text-transform: uppercase; }
    .side-menu--myaviva .side-menu--myaviva__nav li {
      box-sizing: border-box;
      flex-basis: 25%;
      max-width: 25%;
      overflow: hidden;
      padding: 5px;
      margin: 0;
      font-size: 9px;
      font-weight: 400;
      text-align: center; }
      .side-menu--myaviva .side-menu--myaviva__nav li a {
        display: block; }
      .side-menu--myaviva .side-menu--myaviva__nav li i {
        display: block;
        margin: 0 auto;
        padding: 10px 0;
        font-size: 20px; }

.side-menu--main {
  padding: 20px;
  position: relative; }
  .side-menu--main ul {
    list-style: none;
    margin: 0;
    padding: 0;
    font-weight: 800;
    text-transform: uppercase;
    font-size: 35px;
    line-height: 1.3em;
    letter-spacing: -0.05em; }
    .side-menu--main ul li {
      padding: 0; }
      .side-menu--main ul li .side-menu--main__root {
        cursor: pointer; }
      .side-menu--main ul li .side-menu--main__sub {
        position: absolute;
        z-index: 10000;
        top: 0;
        left: 0;
        padding-top: 20px;
        padding-left: 20px;
        width: 100%;
        height: 100%;
        box-sizing: border-box;
        background-color: #fff;
        font-size: 25px;
        line-height: 1.3em; }
        .side-menu--main ul li .side-menu--main__sub .side-menu--main__sub-back {
          cursor: pointer;
          font-size: 20px;
          font-weight: 400;
          color: #999;
          padding-bottom: 5px; }
      .side-menu--main ul li .side-menu--main__sub-active {
        animation: slide-in 0.3s ease-in; }
      .side-menu--main ul li .side-menu--main__sub-inactive {
        transform: translateX(120%);
        animation: slide-out 0.1s ease-out; }

@keyframes slide-in {
  0% {
    transform: translateX(100%); }
  100% {
    transform: translateX(0); } }

@keyframes slide-out {
  0% {
    transform: translateX(0); }
  100% {
    transform: translateX(100%); } }

@media (min-width: 768px) {
  .side-menu {
    width: 40%; }
  .side-menu--header__logo {
    display: none; } }

@media (min-width: 1100px) {
  .side-menu {
    width: 33%; }
  .side-menu--header__logo {
    display: none; } }

@media (max-width: 374px) {
  .side-menu--main ul {
    font-size: 30px; }
    .side-menu--main ul li .side-menu--main__sub {
      font-size: 20px; }
  .side-menu--myaviva .side-menu--myaviva__name {
    font-size: 20px; } }

.breadcrumb {
  margin: 0;
  padding: 1em 20px;
  font-weight: 400;
  font-size: 0.8em; }
  @media (min-width: 768px) {
    .breadcrumb {
      padding: 1.5em 0; } }
  .breadcrumb ul {
    list-style: none;
    margin: 0;
    padding: 0; }
    .breadcrumb ul li {
      display: inline-block; }
      .breadcrumb ul li:not(:first-child)::before {
        margin: 0 0.8em;
        font-family: "FontAwesome";
        content: "\f105";
        color: #999; }

.statusbar {
  padding: 0.75em;
  background-color: #4502da;
  color: #fff;
  font-size: 0.85em; }
  .statusbar__highlight {
    font-weight: 700; }
  .statusbar a,
  .statusbar a:hover,
  .statusbar a:visited,
  a:active .statusbar__link {
    margin: 0 1.5em;
    font-weight: 800;
    color: #fff; }

.myaviva-login-box {
  padding: 20px;
  border: 1px solid #25292d;
  border-radius: 3px; }

.myaviva-login {
  padding: 10px 0; }
  .myaviva-login__row {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-flow: row nowrap;
    -webkit-flex-flow: row nowrap;
    -moz-flex-flow: row nowrap;
    -ms-flex-flow: row nowrap;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    -ms-justify-content: space-between;
    align-items: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    -ms-align-items: center;
    height: 2.5rem;
    margin-top: 0.5rem;
    border-bottom: 1px solid #25292d; }
  .myaviva-login__label {
    margin-right: 10px;
    color: #25292d; }
  .myaviva-login__input:-webkit-autofill, .myaviva-login__input:-webkit-autofill:hover, .myaviva-login__input:-webkit-autofill:focus, .myaviva-login__input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 30px #fff inset !important; }
  .myaviva-login__input {
    display: inline-block;
    border: 0 !important;
    outline: 0;
    height: 100%;
    background: transparent;
    padding: 1rem;
    padding-left: 1.5rem;
    font-size: 1.5rem;
    font-weight: 400 !important;
    color: #25292d !important; }
  .myaviva-login__options, .myaviva-login__actions {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-flow: row nowrap;
    -webkit-flex-flow: row nowrap;
    -moz-flex-flow: row nowrap;
    -ms-flex-flow: row nowrap;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    -ms-justify-content: space-between;
    align-items: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    -ms-align-items: center;
    margin-top: 20px; }
  .myaviva-login__options {
    font-size: 0.9em; }
    .myaviva-login__options-permalogin {
      font-size: 0.9em;
      font-weight: 700; }
  .myaviva-login__actions-submit {
    width: 100%;
    background-color: #e5004b !important;
    color: #fff !important;
    font-size: 0.8em !important; }
  .myaviva-login__register {
    margin-top: 15px;
    text-align: center;
    font-size: 0.9em; }
    .myaviva-login__register-link {
      margin-left: 10px; }

.base-form textarea,
.base-form input[type="email"],
.base-form input[type="password"],
.base-form input[type="text"] {
  -webkit-appearance: none;
  box-sizing: border-box;
  background-clip: padding-box;
  border: 1px solid #999;
  border-radius: 0.25em;
  color: #25292d;
  outline: 0;
  margin: 0.5em 0px;
  padding: 0.8em;
  text-align: left;
  font-size: 1em;
  font-weight: 300;
  font-family: Open Sans, Arial, Helvetica, sans-serif;
  vertical-align: middle;
  width: 100%; }

.base-form select {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-background-clip: padding;
  -moz-background-clip: padding;
  background-clip: padding-box;
  background-color: #fff;
  color: #25292d;
  outline: 0;
  margin: 3px 0px;
  padding: 0.4em;
  text-align: left;
  font-size: 1em;
  font-weight: 300;
  font-family: Open Sans, Arial, Helvetica, sans-serif;
  vertical-align: middle;
  border: 1px solid #999;
  -webkit-border-radius: 0px;
  -moz-border-radius: 0px;
  -ms-border-radius: 0px;
  -o-border-radius: 0px;
  border-radius: 0px; }
  .base-form select.fullWidth {
    width: 100%; }

.base-form label {
  text-transform: uppercase;
  color: #999;
  font-size: 0.9em;
  font-weight: 700;
  display: block; }

.base-form p {
  margin-bottom: 20px; }

.title-stage {
  margin: 0;
  padding: 30px 0;
  background-color: #fff; }
  .title-stage__wrapper {
    padding: 0 20px; }
  .title-stage__headline, .title-stage__subheadline {
    margin: 0;
    padding: 0; }
  .title-stage__headline {
    text-transform: uppercase;
    color: #000;
    font-size: 3rem;
    font-weight: 800;
    line-height: 3rem;
    letter-spacing: -0.2rem;
    overflow-wrap: break-word; }
  .title-stage__subheadline {
    margin-top: 1rem;
    color: #25292d;
    font-size: 1.25rem;
    font-family: "Montserrat", Arial, Helvetica, sans-serif;
    font-weight: 400;
    letter-spacing: -0.075rem; }

@media (min-width: 768px) {
  .title-stage__wrapper {
    padding: 0; }
  .title-stage__headline {
    font-size: 6rem;
    line-height: 6rem;
    letter-spacing: -0.4rem; }
  .title-stage__subheadline {
    font-size: 1.75rem; } }

.color-box {
  padding: 20px;
  color: #fff; }
  .color-box p,
  .color-box h1,
  .color-box .h1,
  .color-box h2,
  .color-box .h2 {
    margin: 0;
    padding: 0;
    padding-bottom: 0.5rem;
    color: #fff; }
  .color-box a,
  .color-box a:hover,
  .color-box a:active,
  .color-box a:visited {
    color: #fff; }
    .color-box a:hover,
    .color-box a:hover:hover,
    .color-box a:active:hover,
    .color-box a:visited:hover {
      color: #fff; }
    .color-box a.btn, .color-box a.btn-primary,
    .color-box a:hover.btn,
    .color-box a:hover.btn-primary,
    .color-box a:active.btn,
    .color-box a:active.btn-primary,
    .color-box a:visited.btn,
    .color-box a:visited.btn-primary {
      margin-right: 10px;
      color: #fff;
      background-color: transparent;
      border: 1px solid #fff;
      font-weight: 700;
      box-sizing: border-box;
      font-size: 0.9em; }
      .color-box a.btn:hover, .color-box a.btn-primary:hover,
      .color-box a:hover.btn:hover,
      .color-box a:hover.btn-primary:hover,
      .color-box a:active.btn:hover,
      .color-box a:active.btn-primary:hover,
      .color-box a:visited.btn:hover,
      .color-box a:visited.btn-primary:hover {
        color: #fff; }
  .color-box__indigo {
    background-color: #4502da; }
  .color-box__raspberry {
    background-color: #e5004b; }
  .color-box__dark {
    background-color: #25292d; }

.classes-next-up {
  font-size: 0.9em; }
  .classes-next-up .left .title {
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: -0.5px; }
  .classes-next-up .right {
    text-align: right; }
    .classes-next-up .right .day {
      display: inline-block;
      min-width: 3ch;
      padding: 0.25em 0.5em;
      margin-right: 5px;
      font-size: 0.7em;
      font-weight: 700;
      text-transform: uppercase;
      text-align: center;
      color: #25292d;
      background-color: #fff;
      border-radius: 1em; }

.class-dates__headline {
  display: block;
  margin-bottom: 5px;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: -1px; }

.class-dates__booking-info {
  background-color: #25292d;
  padding: 15px;
  margin: 30px 0;
  text-align: center;
  color: #fff; }
  .class-dates__booking-info-headline {
    display: block;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 0.9em; }
  .class-dates__booking-info-copy {
    font-size: 0.8em; }
  .class-dates__booking-info-options {
    display: flex;
    flex-flow: row nowrap;
    justify-content: center;
    margin-top: 15px; }
  .class-dates__booking-info-option {
    flex-basis: 50%;
    padding: 5px 0;
    color: #fff;
    text-align: center; }
    .class-dates__booking-info-option-icon {
      margin-right: 5px; }
    .class-dates__booking-info-option-text {
      font-size: 0.8em;
      text-transform: uppercase;
      font-weight: 700; }
    .class-dates__booking-info-option:first-of-type {
      border-right: 1px solid #fff; }

.class-dates__list {
  list-style: none;
  margin: 0;
  padding: 10px 0; }
  .class-dates__list-item {
    min-height: 55px;
    padding: 5px;
    box-sizing: border-box;
    border-radius: 3px;
    margin-bottom: 10px;
    font-size: 0.9em;
    background-color: #f3f3f3;
    display: grid;
    grid-template-columns: repeat(3, 1fr) 90px;
    grid-gap: 10px;
    align-items: center; }
    .class-dates__list-item-actions, .class-dates__list-item-response {
      display: flex;
      flex-flow: row nowrap;
      gap: 5px;
      justify-content: center;
      align-items: center; }
    .class-dates__list-item-selected {
      outline: 2px solid #ddd;
      outline-style: auto;
      outline-offset: 2px; }
    .class-dates__list-item-full {
      border-left: 5px solid #ffbc0a; }
    .class-dates__list-item-available {
      border-left: 5px solid #00e0a1; }
    .class-dates__list-item-status {
      display: flex;
      flex-flow: row wrap;
      justify-content: center;
      align-items: center; }
      .class-dates__list-item-status-icon {
        font-size: 1.6em;
        margin-right: 5px; }
      .class-dates__list-item-status-undo {
        display: block;
        margin-top: 5px;
        text-align: center;
        font-size: 0.8em;
        cursor: pointer; }
        .class-dates__list-item-status-undo .icon {
          margin-right: 3px;
          text-decoration: none;
          font-size: 0.8em; }
        .class-dates__list-item-status-undo .label {
          text-decoration: underline;
          font-weight: 600; }
    .class-dates__list-item-cta {
      display: inline-block;
      width: 40px;
      height: 40px;
      background-color: #fff;
      border-radius: 50%;
      cursor: pointer;
      text-align: center;
      vertical-align: middle;
      line-height: 40px; }
      .class-dates__list-item-cta:hover {
        background-color: #25292d; }
        .class-dates__list-item-cta:hover i {
          color: #fff; }
    .class-dates__list-item-date {
      font-weight: 700;
      margin-left: 5px; }
    .class-dates__list-item-time .from {
      font-weight: 700; }
    .class-dates__list-item-time .until {
      font-size: 0.9em; }
    .class-dates__list-item-instructor {
      font-size: 0.9em; }
  .class-dates__list-item-confirmed, .class-dates__list-item-waiting, .class-dates__list-item-succeeded, .class-dates__list-item-error {
    color: #fff; }
  .class-dates__list-item-confirmed, .class-dates__list-item-succeeded {
    background-color: #00e0a1; }
  .class-dates__list-item-waiting {
    background-color: #ffbc0a; }
  .class-dates__list-item-error {
    background-color: #e5004b; }

.class-dates__cta {
  margin-top: 5px;
  text-align: center; }

.class-bookings__list {
  list-style: none;
  margin: 0;
  padding: 0; }
  .class-bookings__list-month {
    position: sticky;
    top: 0;
    padding: 0.5em 0;
    background-color: #fff;
    font-size: 1.75em;
    font-weight: 800;
    text-transform: uppercase; }
  .class-bookings__list-item {
    min-height: 60px;
    padding: 15px;
    margin-bottom: 15px;
    box-sizing: border-box;
    border-radius: 3px;
    font-size: 0.9em;
    background-color: #f3f3f3;
    display: grid;
    grid-template-columns: 40px 0.5fr 2fr;
    grid-gap: 20px 15px;
    align-items: center; }
    @media (min-width: 768px) {
      .class-bookings__list-item {
        grid-template-columns: 40px 0.75fr 2fr 0.75fr;
        grid-gap: 10px 20px;
        padding: 20px; } }
    .class-bookings__list-item-day span {
      display: block;
      text-transform: uppercase;
      font-size: 0.9em;
      text-align: center; }
    .class-bookings__list-item-day span:first-child {
      font-size: 1.6em;
      font-weight: 800; }
    .class-bookings__list-item-time .start {
      display: block;
      font-weight: 700; }
    .class-bookings__list-item-time .until {
      display: none; }
    .class-bookings__list-item-time .end {
      font-size: 0.9em; }
    @media (min-width: 768px) {
      .class-bookings__list-item-time {
        text-align: center; }
        .class-bookings__list-item-time .start {
          display: inline;
          font-size: 1.2em; }
        .class-bookings__list-item-time .until {
          display: inline; } }
    .class-bookings__list-item-title .instructor,
    .class-bookings__list-item-title .title {
      display: block; }
    .class-bookings__list-item-title .instructor {
      font-size: 0.9em; }
    .class-bookings__list-item-title .title {
      text-transform: uppercase;
      font-weight: 800; }
    @media (min-width: 768px) {
      .class-bookings__list-item-title .title {
        font-size: 1.2em; } }
    .class-bookings__list-item-status {
      display: flex;
      flex-flow: row nowrap;
      justify-content: center;
      align-items: center;
      grid-column: 1 / span 3;
      grid-row: 2;
      padding-top: 20px;
      border-top: 1px solid #ddd;
      line-height: 1.5em; }
      .class-bookings__list-item-status .status,
      .class-bookings__list-item-status .position,
      .class-bookings__list-item-status .type {
        display: flex;
        flex-flow: row nowrap;
        justify-content: center;
        align-items: center;
        margin: 0 8px; }
      @media (min-width: 768px) {
        .class-bookings__list-item-status {
          grid-column: 1 / span 4;
          padding-top: 15px; } }
    .class-bookings__list-item-status-icon {
      margin-right: 5px;
      font-size: 1.4em; }
      .class-bookings__list-item-status-icon .confirmed,
      .class-bookings__list-item-status-icon .succeeded {
        color: #00e0a1; }
      .class-bookings__list-item-status-icon .waiting {
        color: #ffbc0a; }
    .class-bookings__list-item-status-text, .class-bookings__list-item-status-position {
      padding: 0 6px;
      border-radius: 3px;
      border: 1px solid #25292d;
      text-transform: uppercase;
      font-size: 0.6em;
      font-weight: 700;
      letter-spacing: 1px;
      line-height: 20px; }
    .class-bookings__list-item-status-position {
      font-size: 0.8em; }
    .class-bookings__list-item-actions {
      grid-column: 1 / span 3;
      grid-row: 3;
      text-align: center; }
      @media (min-width: 768px) {
        .class-bookings__list-item-actions {
          grid-column: 4;
          grid-row: 1;
          text-align: right; } }
    .class-bookings__list-item-cta {
      display: inline-block;
      width: 40px;
      height: 40px;
      background-color: #fff;
      border-radius: 50%;
      cursor: pointer;
      text-align: center;
      vertical-align: middle;
      line-height: 40px; }
      .class-bookings__list-item-cta:last-child {
        margin-left: 10px; }
      .class-bookings__list-item-cta:hover {
        background-color: #25292d; }
        .class-bookings__list-item-cta:hover i {
          color: #fff; }
      .class-bookings__list-item-cta-primary {
        background-color: #e5004b;
        color: #fff; }
    .class-bookings__list-item-date {
      font-weight: 700; }
    .class-bookings__list-item-instructor {
      font-size: 0.9em;
      text-align: right; }

.class-participants__list {
  list-style: none;
  margin: 0;
  padding: 10px 0; }
  .class-participants__list-day {
    position: sticky;
    top: 0;
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    align-items: center;
    padding: 0.75em 0;
    background-color: #fff; }
    .class-participants__list-day .weekday {
      font-size: 1.75em;
      font-weight: 800;
      text-transform: uppercase; }
    .class-participants__list-day .date {
      padding: 0.25em 1em;
      border-radius: 1em;
      text-align: right;
      font-weight: 700;
      font-size: 0.9em;
      color: #fff;
      background-color: #4502da; }
  .class-participants__list-item {
    min-height: 60px;
    padding: 15px;
    margin-bottom: 15px;
    box-sizing: border-box;
    border-radius: 3px;
    font-size: 0.9em;
    background-color: #f3f3f3;
    display: grid;
    grid-template-columns: 1fr 1.75fr 0.75fr 1fr 0.75fr 40px;
    grid-gap: 0 15px;
    align-items: center;
    cursor: pointer; }
    .class-participants__list-item:hover {
      box-shadow: 0 0 15px #ececec; }
    .class-participants__list-item-cancelled {
      color: #999;
      border-left: 5px solid #e5004b; }
      .class-participants__list-item-cancelled-text {
        padding: 0 6px;
        margin-left: 10px;
        border-radius: 3px;
        border: 1px solid #e5004b;
        color: #e5004b;
        text-transform: uppercase;
        font-size: 0.6em;
        font-weight: 700;
        letter-spacing: 1px;
        line-height: 20px; }
    .class-participants__list-item-full {
      border-left: 5px solid #ffbc0a; }
    .class-participants__list-item-free {
      border-left: 5px solid #00e0a1; }
    .class-participants__list-item .time .start {
      font-size: 1.3em;
      font-weight: 700; }
    .class-participants__list-item .title {
      font-size: 1.3em;
      font-weight: 800;
      text-transform: uppercase; }
    .class-participants__list-item .participation {
      font-size: 1.3em; }
      .class-participants__list-item .participation-item {
        margin-right: 15px;
        font-weight: 700; }
        .class-participants__list-item .participation-item .max-occupancy {
          font-weight: 400;
          font-size: 0.8em; }
    .class-participants__list-item .participants {
      display: none;
      grid-column: 2 / 4; }
      .class-participants__list-item .participants__list {
        list-style: none;
        margin: 0;
        padding: 0;
        padding-top: 15px; }
        .class-participants__list-item .participants__list-item {
          margin-bottom: 1em;
          box-sizing: border-box;
          display: grid;
          grid-template-columns: 20px 20px 1fr 1fr;
          grid-gap: 0 10px;
          align-items: center; }
          .class-participants__list-item .participants__list-item .status {
            font-size: 1.25em; }
          .class-participants__list-item .participants__list-item .name .last-name {
            font-weight: 700; }
    .class-participants__list-item .actions {
      text-align: right; }
      .class-participants__list-item .actions-cta {
        display: inline-block;
        width: 40px;
        height: 40px;
        background-color: #fff;
        border-radius: 50%;
        cursor: pointer;
        text-align: center;
        vertical-align: middle;
        line-height: 40px; }
        .class-participants__list-item .actions-cta:last-child {
          margin-left: 10px; }
        .class-participants__list-item .actions-cta:hover {
          background-color: #25292d; }
          .class-participants__list-item .actions-cta:hover i {
            color: #fff; }
        .class-participants__list-item .actions-cta-primary {
          background-color: #e5004b;
          color: #fff; }
          .class-participants__list-item .actions-cta-primary a {
            color: #fff; }
    .class-participants__list-item .toggle {
      text-align: center;
      font-size: 1.25em; }

.image-teaser {
  max-width: 100%;
  box-sizing: border-box; }
  .image-teaser img {
    width: 100%;
    height: 100%;
    object-fit: cover; }

.color-box-teaser {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-flow: row wrap;
  -webkit-flex-flow: row wrap;
  -moz-flex-flow: row wrap;
  -ms-flex-flow: row wrap;
  justify-content: space-between;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  align-items: stretch;
  -webkit-align-items: stretch;
  -moz-align-items: stretch;
  -ms-align-items: stretch; }
  .color-box-teaser .color-box {
    margin: 10px 0;
    flex-basis: 100%;
    width: 100%; }
  .color-box-teaser .image-teaser {
    margin: 10px 0;
    flex-basis: 100%;
    width: 100%;
    overflow: hidden; }

@media (min-width: 768px) {
  .color-box-teaser {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-flow: row nowrap;
    -webkit-flex-flow: row nowrap;
    -moz-flex-flow: row nowrap;
    -ms-flex-flow: row nowrap;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    -ms-justify-content: space-between;
    align-items: stretch;
    -webkit-align-items: stretch;
    -moz-align-items: stretch;
    -ms-align-items: stretch;
    margin: 0; }
    .color-box-teaser .color-box {
      flex-basis: 33%;
      width: 33%; }
    .color-box-teaser .image-teaser {
      flex-basis: 60%;
      width: 60%; } }

.price-teaser {
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-flow: row wrap; }
  .price-teaser__box {
    width: 100%;
    flex-basis: 100%;
    box-sizing: border-box;
    padding: 25px;
    margin: 20px;
    background-color: #ececec;
    text-align: center; }
  .price-teaser__title {
    font-weight: 700;
    font-size: 1.25em;
    text-transform: uppercase; }
  .price-teaser__promo-title {
    display: block;
    padding-bottom: 5px;
    font-weight: 700;
    color: #e5004b; }
  .price-teaser__promo-conditions {
    display: block;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid #999;
    font-size: 0.8em; }
  .price-teaser__price {
    margin: 10px 0; }
    .price-teaser__price-from {
      margin-right: 5px;
      color: #999; }
    .price-teaser__price-amount {
      font-size: 4.5em;
      font-weight: 800;
      color: #4502da; }
    .price-teaser__price-old {
      font-size: 0.3em;
      font-weight: 700;
      color: #25292d;
      text-decoration: line-through; }
    .price-teaser__price-sup {
      font-size: 0.5em;
      vertical-align: super; }
    .price-teaser__price-info {
      text-transform: uppercase;
      color: #999;
      display: block; }
  .price-teaser__benefits {
    list-style: "✓ ";
    text-align: left; }
  .price-teaser__cta {
    margin: 30px 0; }
    .price-teaser__cta-link {
      display: block;
      padding: 10px 5px;
      background-color: #e5004b;
      color: #fff !important;
      text-transform: uppercase;
      font-weight: 800; }
  .price-teaser__info {
    font-size: 0.9em;
    color: #999; }
    .price-teaser__info-title {
      color: #4502da;
      display: block;
      margin-bottom: 5px; }
    .price-teaser__info-legal {
      display: block;
      margin-top: 10px; }

@media (min-width: 768px) {
  .price-teaser {
    flex-flow: row nowrap; }
    .price-teaser__box {
      width: 33%;
      flex-basis: 33%;
      padding: 50px; } }

.abo-checkout-summary table td {
  padding: 10px 0; }

.abo-checkout-summary table td:first-child {
  text-transform: uppercase;
  color: #999;
  font-size: 0.9em;
  font-weight: 700;
  padding-right: 30px; }

.abo-checkout-summary table td:last-child {
  text-align: right; }

.abo-checkout-summary__info {
  font-size: 0.9em;
  color: #999; }
  .abo-checkout-summary__info-title {
    color: #4502da;
    display: block;
    margin-bottom: 5px; }

.abo-checkout-form label {
  text-transform: uppercase;
  color: #999;
  font-size: 0.9em;
  font-weight: 700;
  display: block; }

.abo-checkout-form p {
  margin-bottom: 20px; }

.cards {
  display: grid;
  grid-template-columns: 100%; }
  @media (min-width: 768px) {
    .cards {
      grid-template-columns: 1fr 1fr;
      grid-gap: 40px; }
      .cards__single {
        grid-template-columns: 100%; }
      .cards__double {
        grid-template-columns: 1fr 1fr; } }
  @media (min-width: 1100px) {
    .cards {
      grid-template-columns: repeat(3, 1fr);
      grid-gap: 40px; }
      .cards__single {
        grid-template-columns: 100%; }
      .cards__double {
        grid-template-columns: 1fr 1fr; } }
  .cards .card {
    box-sizing: border-box;
    position: relative;
    border: 1px solid #ececec;
    border-radius: 3px;
    display: flex;
    flex-flow: column;
    justify-content: space-between;
    background-color: #fff;
    overflow: hidden; }
    @media (max-width: 767px) {
      .cards .card {
        margin: 20px; } }
    .cards .card:hover {
      box-shadow: 0 0 15px #ececec; }
    .cards .card p {
      margin: 15px 0; }
    .cards .card hr {
      border: 1px solid #ececec; }
    .cards .card.flex-start {
      justify-content: flex-start; }
    .cards .card.max-height-300 {
      max-height: 400px; }
    .cards .card.scroll {
      overflow: scroll; }
    .cards .card__date {
      position: absolute;
      left: 25px;
      top: 0;
      min-width: 60px;
      background-color: #4502da;
      color: #fff;
      text-align: center; }
      .cards .card__date-day {
        display: block;
        padding-top: 10px;
        font-weight: 800;
        letter-spacing: -1px;
        font-size: 1.8em;
        line-height: .8em; }
      .cards .card__date-month {
        display: block;
        padding-bottom: 5px;
        font-size: .9em;
        text-transform: uppercase; }
    .cards .card__image img {
      max-width: 100%; }
    .cards .card__body, .cards .card__actions {
      margin: 25px; }
      .cards .card__body.no-margin, .cards .card__actions.no-margin {
        margin: 0; }
    .cards .card__body {
      margin-bottom: 20px; }
      .cards .card__body.card__date-body {
        padding-top: 50px; }
    .cards .card__title {
      font-weight: 800;
      font-size: 1.75em;
      line-height: 1.1em;
      letter-spacing: -1px;
      text-transform: uppercase; }
      .cards .card__title-medium {
        font-size: 1.5em; }
    .cards .card__subtitle {
      margin-top: 5px;
      font-family: "Montserrat", Arial, Helvetica, sans-serif;
      color: #999;
      font-size: 1.1em; }
    .cards .card__collapse-toggle {
      font-size: .8em;
      font-weight: 700;
      text-transform: uppercase; }
    .cards .card__actions {
      margin-top: 0; }
    .cards .card__columns {
      display: grid;
      grid-template-columns: 40% 60%;
      row-gap: 0.3em;
      margin-bottom: 1em;
      word-break: break-word;
      line-height: 1.4em; }
      .cards .card__columns-title {
        font-size: 0.8em;
        line-height: 1.8em;
        color: #999;
        text-transform: uppercase; }
      .cards .card__columns-ellipsis {
        word-break: normal;
        overflow: hidden;
        text-overflow: ellipsis; }
      .cards .card__columns-auto {
        grid-template-columns: max-content auto;
        column-gap: 0.75em; }
    .cards .card__rows-item {
      display: grid;
      padding: 20px 25px;
      border-bottom: 1px solid #ececec; }

.popup {
  padding: 20px; }
  .popup hr {
    border: 1px solid #ececec; }
  .popup__close {
    text-align: right; }
  .popup__headline,
  .popup .h1 {
    padding: 0; }
  .popup__action {
    font-size: 0.8em;
    text-transform: uppercase;
    font-weight: 600; }
  .popup__info-text {
    margin: 10px 0;
    font-size: 0.9em; }
  .popup__login-info {
    background-color: #25292d;
    padding: 15px;
    margin: 30px 0;
    text-align: center;
    color: #fff; }
    .popup__login-info a {
      color: #fff !important;
      text-decoration: underline; }
  .popup__availability {
    margin: 20px 0; }
  .popup__details {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 20px;
    list-style: none;
    padding: 0;
    margin: 20px 0; }
    .popup__details li {
      font-size: 0.9em; }
      .popup__details li .title {
        display: block;
        margin-bottom: 5px;
        text-transform: uppercase;
        font-weight: 700;
        letter-spacing: -1px; }
      .popup__details li.col-full {
        grid-column: 1 / -1; }
  .popup__class-dates {
    list-style: none;
    padding: 0;
    margin: 15px 0; }
    .popup__class-dates li {
      padding: 3px 0; }

.schedule {
  margin: 20px 0; }
  @media (min-width: 768px) {
    .schedule {
      display: flex;
      flex-flow: row nowrap;
      justify-content: space-between; } }
  .schedule__controls {
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between; }
    .schedule__controls-prev, .schedule__controls-next {
      font-size: 0.9em;
      font-weight: 700;
      text-transform: uppercase; }
      @media (max-width: 767px) {
        .schedule__controls-prev, .schedule__controls-next {
          font-size: 0.75em;
          padding: 0 20px; } }
  .schedule__day {
    display: flex;
    flex-direction: column;
    width: 100%;
    padding: 0 20px;
    box-sizing: border-box; }
    @media (min-width: 768px) {
      .schedule__day {
        padding: 0;
        padding-right: 20px;
        width: 20%; }
        .schedule__day:last-child {
          padding: 0; } }
    .schedule__day-info {
      position: sticky;
      top: 0;
      display: flex;
      flex-flow: row nowrap;
      justify-content: space-between;
      align-items: center;
      padding: 10px 0;
      background-color: #fff; }
    .schedule__day-name {
      display: block;
      text-transform: uppercase;
      font-weight: 800;
      letter-spacing: -1px;
      font-size: 1.5em; }
      @media (min-width: 768px) {
        .schedule__day-name {
          font-size: 1em;
          letter-spacing: -0.5px; } }
    .schedule__day-date {
      display: block;
      padding: 4px 8px;
      border-radius: 20px;
      background-color: #4502da;
      color: #fff;
      font-weight: 700;
      font-size: 0.75em; }
      .schedule__day-date-today {
        background-color: #00e0a1; }
    .schedule__day-empty {
      display: flex;
      flex-flow: column;
      justify-content: center;
      margin: 10px 0;
      padding: 20px 0;
      height: 100%;
      border: 1px solid #ddd;
      border-radius: 3px; }
      .schedule__day-empty-info {
        text-align: center;
        font-size: 0.8em;
        color: #25292d;
        text-transform: uppercase; }
  .schedule__classes {
    list-style: none;
    padding: 0;
    margin: 10px 0; }
  .schedule__class {
    display: grid;
    grid-template-columns: 70% 30%;
    padding: 10px;
    border: 1px solid #ddd;
    border-radius: 3px;
    margin-bottom: 15px;
    margin-top: 0;
    background-color: #f3f3f3;
    cursor: pointer; }
    @media (min-width: 768px) {
      .schedule__class:hover {
        box-shadow: 0 0 15px #ddd; } }
    .schedule__class:last-child {
      margin-bottom: 0; }
    .schedule__class-info {
      padding-right: 5px;
      box-sizing: border-box;
      word-wrap: break-word; }
      @media (min-width: 768px) {
        .schedule__class-info {
          font-size: 0.8em; } }
      @media (min-width: 1100px) {
        .schedule__class-info {
          font-size: 1em; } }
    .schedule__class-times {
      text-align: right;
      grid-row: 1 / 3; }
      @media (min-width: 768px) {
        .schedule__class-times {
          grid-row: 2 / 3;
          grid-column: 2 / 3; } }
    .schedule__class-time {
      display: block;
      font-weight: 800; }
      @media (min-width: 768px) {
        .schedule__class-time {
          font-size: 0.8em; } }
      @media (min-width: 1100px) {
        .schedule__class-time {
          font-size: 1em; } }
    .schedule__class-duration {
      display: block;
      font-size: 0.8em;
      color: #999; }
      @media (min-width: 768px) {
        .schedule__class-duration {
          font-size: 0.7em;
          text-align: right; } }
      @media (min-width: 1100px) {
        .schedule__class-duration {
          font-size: 0.8em; } }
    .schedule__class-title {
      display: block;
      grid-row: 1 / 2;
      grid-column: 1 / 2;
      margin-bottom: 5px;
      text-transform: uppercase;
      font-weight: 700;
      letter-spacing: -0.7px;
      hyphens: auto; }
      @media (min-width: 768px) {
        .schedule__class-title {
          grid-column: 1 / 3; } }
    .schedule__class-join {
      margin: 0.75em 0;
      grid-column: 1 / 3;
      grid-row: 3; }
      .schedule__class-join a {
        display: block;
        color: #fff;
        font-size: 0.75em;
        text-transform: uppercase;
        text-align: center;
        font-weight: 700;
        background-color: #e5004b;
        padding: 0.5em 0.75em;
        border-radius: 0.25em; }
        .schedule__class-join a:hover {
          color: #fff;
          background-color: #25292d; }

.errorBox {
  background-color: #ffd6e2;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-flow: row wrap;
  -webkit-flex-flow: row wrap;
  -moz-flex-flow: row wrap;
  -ms-flex-flow: row wrap;
  justify-content: flex-start;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  align-items: stretch;
  -webkit-align-items: stretch;
  -moz-align-items: stretch;
  -ms-align-items: stretch;
  border-left: 5px solid #e5004b; }
  .errorBox .errorBox__icon {
    flex-basis: 100%;
    text-align: center;
    color: #e5004b;
    padding: 25px 0;
    box-sizing: border-box; }
  .errorBox .errorBox__content {
    padding: 20px;
    padding-top: 0; }
  .errorBox .errorBox__headline {
    margin-bottom: 10px;
    font-weight: 700;
    color: #e5004b;
    display: block;
    font-size: 1.75em;
    line-height: 1.2em; }

@media (min-width: 768px) {
  .errorBox {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-flow: row nowrap;
    -webkit-flex-flow: row nowrap;
    -moz-flex-flow: row nowrap;
    -ms-flex-flow: row nowrap;
    justify-content: flex-start;
    -webkit-justify-content: flex-start;
    -moz-justify-content: flex-start;
    -ms-justify-content: flex-start;
    align-items: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    -ms-align-items: center; }
    .errorBox .errorBox__icon {
      flex: 0 1 auto;
      padding: 0 35px; }
    .errorBox .errorBox__content {
      padding-top: 20px;
      padding-left: 0; } }

.infoBox {
  background-color: #00e0a125;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-flow: row wrap;
  -webkit-flex-flow: row wrap;
  -moz-flex-flow: row wrap;
  -ms-flex-flow: row wrap;
  justify-content: flex-start;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  align-items: stretch;
  -webkit-align-items: stretch;
  -moz-align-items: stretch;
  -ms-align-items: stretch;
  border-left: 5px solid #00e0a1; }
  .infoBox-grey {
    background-color: #f3f3f3;
    border-left: 5px solid #999; }
  .infoBox-dark {
    background-color: #25292d;
    border-left: 5px solid #00e0a1;
    color: #fff; }
  .infoBox .infoBox__icon {
    flex-basis: 100%;
    text-align: center;
    color: #00e0a1;
    padding: 25px 0;
    box-sizing: border-box; }
  .infoBox .infoBox__content {
    padding: 20px; }
  .infoBox .infoBox__headline {
    margin-bottom: 10px;
    font-weight: 700;
    display: block;
    font-size: 1.5em;
    line-height: 1.2em; }
  .infoBox .infoBox__price {
    padding: 0 35px;
    margin-bottom: 35px;
    font-size: 1.75em;
    font-weight: 700; }

@media (min-width: 768px) {
  .infoBox {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-flow: row nowrap;
    -webkit-flex-flow: row nowrap;
    -moz-flex-flow: row nowrap;
    -ms-flex-flow: row nowrap;
    justify-content: flex-start;
    -webkit-justify-content: flex-start;
    -moz-justify-content: flex-start;
    -ms-justify-content: flex-start;
    align-items: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    -ms-align-items: center; }
    .infoBox .infoBox__icon {
      flex: 0 1 auto;
      padding: 0 35px; }
    .infoBox .infoBox__price {
      margin-bottom: 0; } }

.list {
  margin: 0;
  padding: 0; }
  .list-unordered {
    list-style: none; }
    .list-unordered li {
      position: relative;
      margin: 0;
      padding: 0.25em 0;
      padding-left: 20px; }
      .list-unordered li::before {
        content: "/";
        position: absolute;
        left: 0;
        color: #e5004b;
        font-weight: bold; }

.ul {
  list-style: none;
  padding: 0;
  margin: 0; }
  .ul li {
    margin: 0;
    padding: 0.15em 0; }
  .ul__classFavs li {
    margin: 0.25em 0;
    padding: 0.25em 0;
    border-bottom: 1px solid #ececec;
    font-size: 0.9em;
    cursor: pointer; }

.container-xs, .container-s, .container-m, .container-l, .container-xl {
  box-sizing: border-box;
  margin: auto;
  padding: 20px;
  width: 100%; }

@media (min-width: 768px) {
  .container-xs {
    width: 25%; }
  .container-s {
    width: 35%; }
  .container-m {
    width: 50%; }
  .container-l {
    width: 65%; }
  .container-xl {
    width: 80%; } }

.container-nopadding {
  padding: 0; }

.container__flex {
  display: flex; }
  .container__flex-between {
    flex-flow: row nowrap;
    justify-content: space-between; }
  .container__flex-align-center {
    align-items: center; }

.spacer-xs {
  padding: 2px 0; }

.spacer-s {
  padding: 4px 0; }

.spacer-m {
  padding: 8px 0; }

.spacer-l {
  padding: 16px 0; }

.spacer-xl {
  padding: 32px 0; }

.spacer-divider {
  border-bottom: 1px solid #ececec; }

@media (min-width: 768px) {
  .spacer-xs {
    padding: 2px 0; }
  .spacer-s {
    padding: 4px 0; }
  .spacer-m {
    padding: 8px 0; }
  .spacer-l {
    padding: 16px 0; }
  .spacer-xl {
    padding: 32px 0; } }

.landing-stage {
  margin: 0;
  padding: 3rem 0;
  background-color: #fff; }
  .landing-stage__headline, .landing-stage__subheadline {
    margin: 0;
    padding: 0; }
  .landing-stage__headline {
    text-transform: uppercase;
    color: #000;
    font-size: 2.5rem;
    font-weight: 800;
    line-height: 2.5rem;
    letter-spacing: -0.2rem;
    overflow-wrap: break-word; }
    .landing-stage__headline-centered {
      text-align: center; }
  .landing-stage__subheadline {
    margin-top: 1.5rem;
    color: #25292d;
    font-size: 1.25rem;
    font-family: "Montserrat", Arial, Helvetica, sans-serif;
    font-weight: 400;
    letter-spacing: -0.05rem; }
    .landing-stage__subheadline-centered {
      text-align: center; }

@media (min-width: 768px) {
  .landing-stage {
    padding: 5rem 0; }
    .landing-stage__headline {
      font-size: 4rem;
      line-height: 4rem;
      letter-spacing: -0.2rem; }
    .landing-stage__subheadline {
      font-size: 1.5rem; } }

.adventDoor {
  box-sizing: border-box; }
  .adventDoor .adventDoorContent {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 2em;
    font-size: 2em;
    background-color: #ececec;
    margin: auto;
    text-align: center;
    font-weight: 900;
    -webkit-transition: all 0.5s ease-out;
    -moz-transition: all 0.5s ease-out;
    -ms-transition: all 0.5s ease-out;
    -o-transition: all 0.5s ease-out;
    transition: all 0.5s ease-out; }
    .adventDoor .adventDoorContent:hover {
      box-shadow: 0 0 15px #999;
      background-color: #e5004b;
      color: #fff; }

progress[value] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  color: #4502da; }

progress::-webkit-progress-bar {
  background-color: #ececec;
  border-radius: 7px;
  border: 0.5px solid #999; }

progress::-webkit-progress-value {
  background-color: #4502da;
  border-top-left-radius: 7px;
  border-bottom-left-radius: 7px; }

progress::-moz-progress-bar {
  background-color: #4502da; }

.progressbar {
  width: 100%;
  height: 7px; }

.flexbox {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-flow: row wrap;
  -webkit-flex-flow: row wrap;
  -moz-flex-flow: row wrap;
  -ms-flex-flow: row wrap;
  justify-content: flex-start;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  -ms-justify-content: flex-start;
  align-items: stretch;
  -webkit-align-items: stretch;
  -moz-align-items: stretch;
  -ms-align-items: stretch;
  margin-top: 0px; }
  .flexbox.flex-between {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-flow: row nowrap;
    -webkit-flex-flow: row nowrap;
    -moz-flex-flow: row nowrap;
    -ms-flex-flow: row nowrap;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    -ms-justify-content: space-between;
    align-items: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    -ms-align-items: center; }
  .flexbox.flex-center {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-flow: row wrap;
    -webkit-flex-flow: row wrap;
    -moz-flex-flow: row wrap;
    -ms-flex-flow: row wrap;
    justify-content: center;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    -ms-justify-content: center;
    align-items: stretch;
    -webkit-align-items: stretch;
    -moz-align-items: stretch;
    -ms-align-items: stretch; }
  .flexbox .flex6 {
    -webkit-box-flex: 0 1 auto;
    -moz-box-flex: 0 1 auto;
    -webkit-flex: 0 1 auto;
    -ms-flex: 0 1 auto;
    flex: 0 1 auto;
    padding: 0px 20px;
    padding-bottom: 20px;
    box-sizing: border-box;
    width: 33.33%;
    flex-basis: 33.33%; }
  .flexbox .flex4,
  .flexbox .flex33,
  .flexbox .flex50 {
    -webkit-box-flex: 0 1 auto;
    -moz-box-flex: 0 1 auto;
    -webkit-flex: 0 1 auto;
    -ms-flex: 0 1 auto;
    flex: 0 1 auto;
    padding: 20px;
    box-sizing: border-box;
    width: 100%; }
    .flexbox .flex4 img,
    .flexbox .flex33 img,
    .flexbox .flex50 img {
      max-width: 100%; }
  @media (max-width: 767px) {
    .flexbox .firstItem {
      order: 0; }
    .flexbox .secondItem {
      order: 1; } }

table {
  width: 100%;
  font-size: 0.8em; }
  table thead {
    text-align: left; }
    table thead th {
      font-weight: 300;
      font-size: 0.9em;
      padding: 0 0.25em;
      height: 3em;
      color: #999; }
      table thead th:first-child {
        padding-left: 0; }
      table thead th:last-child {
        padding-right: 0; }
      table thead th a,
      table thead th a:visited,
      table thead th a:active {
        color: #999; }
  table tbody td {
    border-bottom: 1px solid #ececec;
    height: 2.5em;
    padding: 0 0.25em; }
    table tbody td:first-child {
      padding-left: 0; }
    table tbody td:last-child {
      padding-right: 0; }

html,
body {
  margin: 0px;
  padding: 0px;
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-weight: 400;
  color: #25292d;
  scroll-behavior: smooth; }

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

code {
  border-left: 2px solid #999;
  background-color: #ececec;
  padding: 0.4em 0.8em; }

.courseType {
  display: inline-block;
  padding-right: 4px;
  min-width: 12px;
  height: 12px;
  outline: 0;
  background-color: transparent; }
  .courseType.green, .courseType.magenta, .courseType.grey, .courseType.health, .courseType.special, .courseType.premium, .courseType.live, .courseType.wellbeing, .courseType.strength, .courseType.cardio, .courseType.sale {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: 50% 50%;
    font-size: 0.9em;
    font-family: "FontAwesome"; }
  .courseType.live {
    width: 35px;
    height: 15px;
    margin-bottom: -2px; }
  .courseType.green::after, .courseType.wellbeing::after {
    content: " \f6ad";
    color: #00e0a1; }
  .courseType.magenta::after, .courseType.strength::after {
    content: " \f44b";
    color: #e5004b; }
  .courseType.grey::after, .courseType.cardio::after {
    content: " \f21e";
    color: #25292d; }
  .courseType.health::after {
    content: " \f0fe";
    color: #00e0a1; }
  .courseType.special::after {
    content: " \f005";
    color: #4502da; }
  .courseType.premium::after {
    content: " \f288";
    color: #25292d; }
  .courseType.live {
    background-image: url("../_images/layout/icon_live.png"); }
  .courseType.sale::after {
    content: " \f541";
    color: #4502da; }

.assistiveText {
  display: none; }

.rotate-180 {
  -webkit-transform: rotate(180deg);
  -moz-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  -o-transform: rotate(180deg);
  transform: rotate(180deg); }

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

.display--inline {
  display: inline !important; }

.display--block {
  display: block !important; }

.border--white {
  border: 1px solid #fff; }

.pageWrap {
  height: 100%; }

.cursorPointer {
  cursor: pointer; }

header,
article,
footer {
  width: 100%; }

header #printHeader {
  position: relative;
  width: 100%;
  height: 150px;
  background-color: #fff; }

header #printLogo {
  margin: 50px 0px;
  width: 100%;
  text-align: right; }
  header #printLogo img {
    width: 25%; }

header #titlePrint h1,
header #titlePrint h2 {
  margin: 0px;
  margin-left: 20px;
  margin-right: 20px;
  color: #25292d; }

header #titlePrint h1 {
  font-size: 2.5em;
  font-weight: 700;
  letter-spacing: -2px; }

header #titlePrint h2 {
  font-size: 1.3em;
  font-weight: 400; }

.lightBack {
  background-color: #f3f3f3; }

.ulClean ul {
  list-style: none;
  padding: 0;
  margin: 0; }
  .ulClean ul li {
    margin: 0;
    padding: 0; }
    .ulClean ul li h1 {
      font-size: 1.2em; }
    .ulClean ul li p {
      font-size: 0.9em; }

p {
  margin: 10px 0;
  font-size: 1em;
  line-height: 1.6em;
  font-weight: 400; }

section {
  padding-bottom: 15px;
  margin: 0;
  margin-top: 15px; }
  section.divider {
    border-bottom: 1px solid #ececec; }
  section ul {
    line-height: 1.5em; }
    section ul.ulErrors {
      color: #e5004b;
      font-size: 0.9em;
      padding-left: 20px; }
    section ul li {
      margin: 5px 0px; }
    section ul.ulCheck {
      list-style: none; }
      section ul.ulCheck li:before {
        content: "\2714\0020";
        margin-left: -1.2em;
        margin-right: 0.1em;
        color: #e5004b;
        font-size: 1.25em; }
      section ul.ulCheck li {
        margin-left: 0.1em; }
    section ul.myClasses {
      display: -webkit-box;
      display: -moz-box;
      display: -ms-flexbox;
      display: -webkit-flex;
      display: flex;
      flex-flow: row wrap;
      -webkit-flex-flow: row wrap;
      -moz-flex-flow: row wrap;
      -ms-flex-flow: row wrap;
      justify-content: flex-start;
      -webkit-justify-content: flex-start;
      -moz-justify-content: flex-start;
      -ms-justify-content: flex-start;
      align-items: stretch;
      -webkit-align-items: stretch;
      -moz-align-items: stretch;
      -ms-align-items: stretch;
      list-style: none;
      margin: 0;
      padding: 0; }
      section ul.myClasses li {
        flex: 0 1 auto;
        flex-basis: 95%;
        padding: 0 2%;
        margin: 0 auto;
        margin-bottom: 25px;
        box-sizing: border-box; }
        section ul.myClasses li span {
          display: block;
          padding: 15px;
          height: 100%;
          box-sizing: border-box;
          background-color: #f3f3f3;
          border: 1px solid #ddd;
          border-radius: 3px; }
          section ul.myClasses li span .myClassTitle {
            display: inline;
            font-weight: 700;
            letter-spacing: -0.5px;
            text-transform: uppercase; }
          section ul.myClasses li span .myClassTime {
            font-weight: 800; }
          section ul.myClasses li span h1,
          section ul.myClasses li span h2 {
            padding: 0;
            margin: 0;
            margin-bottom: 15px;
            display: inline-block;
            width: 48%; }
          section ul.myClasses li span h1 {
            font-size: 1.5em;
            text-align: right; }
          section ul.myClasses li span div.myClassesToday {
            display: -webkit-box;
            display: -moz-box;
            display: -ms-flexbox;
            display: -webkit-flex;
            display: flex;
            flex-flow: row nowrap;
            -webkit-flex-flow: row nowrap;
            -moz-flex-flow: row nowrap;
            -ms-flex-flow: row nowrap;
            justify-content: flex-start;
            -webkit-justify-content: flex-start;
            -moz-justify-content: flex-start;
            -ms-justify-content: flex-start;
            align-items: stretch;
            -webkit-align-items: stretch;
            -moz-align-items: stretch;
            -ms-align-items: stretch;
            margin: 0;
            margin-top: 20px; }
            section ul.myClasses li span div.myClassesToday div.myClassItem {
              -webkit-box-flex: 1 1 auto;
              -moz-box-flex: 1 1 auto;
              -webkit-flex: 1 1 auto;
              -ms-flex: 1 1 auto;
              flex: 1 1 auto;
              cursor: pointer; }
              section ul.myClasses li span div.myClassesToday div.myClassItem i {
                margin-right: 4px; }
          section ul.myClasses li span:hover {
            box-shadow: 0 0 15px #ddd; }
  section .tableWrap {
    margin: 0 20px; }
  section.lightBack {
    background-color: #f3f3f3; }
  section.turqBack {
    background-color: #438d7c;
    color: #fff; }
  section.greyBack {
    background-color: #00e0a1;
    color: #fff; }
    section.greyBack h2 {
      color: #25292d; }
    section.greyBack a {
      color: #25292d;
      border-bottom: 1px solid; }

.g-recaptcha {
  margin: 10px 20px; }

.colorbox {
  background-color: #ececec; }

.colorBorderMagenta {
  border: 2px solid #e5004b; }

.colorBorderGrey {
  border: 2px solid #999; }

.creditPrice {
  background-color: #e5004b;
  color: #fff;
  font-weight: bold;
  font-size: 0.65em;
  padding: 4px 8px;
  border-radius: 30px; }

.part33,
.part66,
.part50 {
  display: inline-block;
  vertical-align: top;
  width: 100%;
  padding: 0 20px;
  box-sizing: border-box; }
  .part33 img,
  .part66 img,
  .part50 img {
    max-width: 100%; }

.circleImg {
  width: 150px;
  height: 150px;
  display: inline-block;
  -webkit-border-radius: 75px;
  -moz-border-radius: 75px;
  -ms-border-radius: 75px;
  -o-border-radius: 75px;
  border-radius: 75px;
  overflow: hidden;
  text-align: center; }
  .circleImg img {
    width: 100%;
    max-width: 100%; }

.squareImg {
  width: 100px;
  height: 100px;
  display: inline-block;
  overflow: hidden;
  text-align: center; }
  .squareImg img {
    width: 100%;
    max-width: 100%; }

.chartImg {
  height: 150px;
  display: inline-block;
  overflow: hidden;
  text-align: center; }
  .chartImg img {
    height: 100%; }

.contentTeaser {
  background-color: #ececec; }
  .contentTeaser img {
    width: 100%;
    overflow: hidden; }
  .contentTeaser h1,
  .contentTeaser h2 {
    font-size: 1.8em;
    font-weight: 700;
    letter-spacing: -1px;
    line-height: 1em;
    padding: 1em 0;
    color: #25292d; }

.contentHint {
  border-left: 7px solid #e5004b;
  padding: 0 20px; }
  .contentHint p {
    color: #25292d; }
  .contentHint p.contentHint--headline {
    font-weight: 700;
    font-size: 1.1em;
    color: #e5004b; }
  .contentHint p.contentHint--subline {
    color: #25292d; }

dl.faq dt {
  padding: 12px;
  margin-bottom: 10px;
  color: #25292d;
  background-color: #ececec;
  font-weight: 700;
  position: relative;
  cursor: pointer; }
  dl.faq dt:after {
    content: "+";
    font-size: 2em;
    color: #e5004b;
    position: absolute;
    right: 10px;
    top: 0px;
    transition: transform 0.7s;
    -webkit-transition: transform 0.7s; }
  dl.faq dt.rotate:after {
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    transform: rotate(45deg); }

dl.faq dd {
  margin-left: 0;
  display: block;
  height: 0px;
  overflow: hidden;
  transition: height 0.7s;
  -webkit-transition: height 0.7s; }
  dl.faq dd p {
    margin: 0;
    padding: 25px 12px;
    padding-top: 15px; }
    dl.faq dd p ul {
      display: inline;
      margin-left: 0; }

.video-container {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 0;
  height: 0;
  overflow: hidden; }

.video-container iframe,
.video-container object,
.video-container embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; }

#popupOverlay {
  -webkit-transform: scale(0.8);
  -moz-transform: scale(0.8);
  -ms-transform: scale(0.8);
  transform: scale(0.8);
  background-color: #fff;
  width: 95%;
  border-radius: 10px;
  box-shadow: 5px 5px 15px #555; }

@media (min-width: 768px) {
  #popupOverlay {
    width: 450px; } }

.popup_visible #popupOverlay {
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1); }

footer {
  padding-top: 20px;
  padding-bottom: 40px;
  background-color: #25292d; }
  footer section a,
  footer section a:active,
  footer section a:visited {
    color: #fff; }
  footer section h1,
  footer section h2 {
    margin: 0px 20px; }
  footer section h1 {
    color: #fff;
    padding-top: 20px;
    font-weight: 800;
    font-size: 1.3em;
    line-height: 1.1em;
    text-transform: uppercase; }
  footer section p {
    color: #fff;
    margin: 10px 20px;
    font-size: 0.9em;
    line-height: 1.5em;
    font-weight: 300; }
  footer section input[type="button"] {
    border: 2px solid #95a9b0;
    color: #fff; }
  footer section table {
    width: 90%;
    margin: 0px 20px;
    font-size: 0.9em;
    color: #fff;
    font-weight: 300; }
    footer section table tbody td {
      border: 0;
      height: 2em; }
  footer .socialLinks {
    text-align: center;
    margin-top: 15px; }
    footer .socialLinks p {
      font-size: 0.8em; }
      footer .socialLinks p a {
        margin: 0px 5px; }

@media (max-width: 767px) {
  .noMobiles {
    display: none; }
  header #title a.btn {
    border: 0;
    background: #25292d !important;
    background: rgba(37, 41, 45, 0) !important;
    text-transform: none;
    padding: 0;
    font-size: 0.9em; }
    header #title a.btn i {
      font-size: 2em;
      color: #fff; }
  article section {
    padding-bottom: 10px;
    margin-top: 10px; } }

@media (min-width: 768px) {
  .onlyMobiles {
    display: none; }
  .pageWrap {
    width: 97%;
    margin: auto; }
  .pageWrapPrint {
    width: 60%;
    margin: auto; }
  .padL25x {
    padding-left: 25%; }
  .padV50p {
    padding: 50px 0px; }
  img.imgGreyscale {
    filter: grayscale(100%);
    -webkit-filter: grayscale(100%);
    -moz-filter: grayscale(100%);
    -ms-filter: grayscale(100%);
    -o-filter: grayscale(100%);
    filter: url("desaturate.svg#greyscale");
    filter: gray;
    -webkit-filter: grayscale(1);
    -webkit-transition: all 1.5s ease-out;
    -moz-transition: all 1.5s ease-out;
    -ms-transition: all 1.5s ease-out;
    -o-transition: all 1.5s ease-out;
    transition: all 1.5s ease-out; }
    img.imgGreyscale:hover {
      filter: grayscale(0%);
      -webkit-filter: grayscale(0%);
      -moz-filter: grayscale(0%);
      -ms-filter: grayscale(0%);
      -o-filter: grayscale(0%);
      filter: none; }
  header.landingPage {
    padding-bottom: 150px; }
  header #fixHeader {
    position: fixed;
    z-index: 9999;
    width: 100%;
    height: 150px;
    background-color: #fff;
    border-bottom: 1px solid #f3f3f3; }
  header #logo {
    display: inline-block;
    margin: 10px 0px;
    width: 100%; }
    header #logo img {
      width: 25%; }
  article section {
    margin: 0;
    margin-top: 30px;
    border: 0; }
    article section ul.myClasses {
      margin: 0 -2%; }
      article section ul.myClasses li {
        flex-basis: 33.33%;
        margin: 0;
        margin-bottom: 30px; }
    article section table {
      font-size: 1em; }
      article section table tbody td.checkoutImg {
        width: 6em; }
        article section table tbody td.checkoutImg img {
          width: 5em; }
  article .flexbox .flex6 {
    width: 33.33%;
    flex-basis: 33.33%; }
  article .flexbox .flex4 {
    width: 33.33%;
    flex-basis: 33.33%; }
  article .flexbox .flex33 {
    width: 50%;
    flex-basis: 50%; }
  article .flexbox .flex50 {
    width: 50%;
    flex-basis: 50%; }
  article .part33 img.img50,
  article .part66 img.img50,
  article .part50 img.img50 {
    width: 50%; }
  article .part33 img.imgH75p,
  article .part66 img.imgH75p,
  article .part50 img.imgH75p {
    height: 75px; }
  article .part66 {
    width: 66.66%; }
  article .part33 {
    width: 33.33%; }
  article .part50 {
    width: 50%; }
  article .shopProduct .shopProduct__body {
    margin: 20px; }
  footer section {
    display: inline-block;
    width: 33.33%;
    vertical-align: top; }
  footer .socialLinks {
    text-align: left; } }

@media (min-width: 992px) {
  .pageWrap {
    width: 90%;
    margin: auto; }
  header #fixHeader {
    height: 90px; }
  header #logo {
    margin: 10px 0px;
    margin-right: 20px;
    width: 170px;
    vertical-align: 10px; }
    header #logo img {
      width: 100%; } }

@media (min-width: 1280px) {
  .pageWrap {
    width: 80%;
    margin: auto; }
  article {
    min-height: 700px; }
    article .flexbox .flex6 {
      width: 16.66%;
      flex-basis: 16.66%; }
    article .flexbox .flex33 {
      width: 33.33%;
      flex-basis: 33.33%; }
    article .flexbox .flex50 {
      width: 50%;
      flex-basis: 50%; }
    article .adventDoor .adventDoorContent {
      width: 85%;
      height: 2.5em;
      font-size: 2.5em; } }

@media (min-width: 1280px) {
  header #logo {
    margin-right: 20px; }
  .pageWrap {
    width: 80%;
    margin: auto; }
  article .flexbox .flex4 {
    width: 25%;
    flex-basis: 25%; } }

@media (min-width: 1500px) {
  .pageWrap {
    width: 75%;
    margin: auto; } }
