/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */
@import url("https://fast.fonts.net/lt/1.css?apiType=css&c=66dc4af4-6897-43fd-846c-30008d2a73c7&fontids=1564315,1564351");
button, hr, input {
  overflow: visible; }

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

progress, sub, sup {
  vertical-align: baseline; }

[type=checkbox], [type=radio], legend {
  box-sizing: border-box;
  padding: 0; }

html {
  line-height: 1.15;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%; }

body {
  margin: 0; }

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

h1 {
  font-size: 2em;
  margin: .67em 0; }

figure {
  margin: 1em 40px; }

hr {
  box-sizing: content-box;
  height: 0; }

code, kbd, pre, samp {
  font-family: monospace,monospace;
  font-size: 1em; }

a {
  background-color: transparent;
  -webkit-text-decoration-skip: objects; }

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted; }

b, strong {
  font-weight: bolder; }

dfn {
  font-style: italic; }

mark {
  background-color: #ff0;
  color: #000; }

small {
  font-size: 80%; }

sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative; }

sub {
  bottom: -.25em; }

sup {
  top: -.5em; }

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

img {
  border-style: none; }

svg:not(:root) {
  overflow: hidden; }

button, input, optgroup, select, textarea {
  font-family: sans-serif;
  font-size: 100%;
  line-height: 1.15;
  margin: 0; }

button, select {
  text-transform: none; }

[type=reset], [type=submit], button, html [type=button] {
  -webkit-appearance: button; }

[type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner, button::-moz-focus-inner {
  border-style: none;
  padding: 0; }

[type=button]:-moz-focusring, [type=reset]:-moz-focusring, [type=submit]:-moz-focusring, button:-moz-focusring {
  outline: ButtonText dotted 1px; }

fieldset {
  padding: .35em .75em .625em; }

legend {
  color: inherit;
  display: table;
  max-width: 100%;
  white-space: normal; }

textarea {
  overflow: auto; }

[type=number]::-webkit-inner-spin-button, [type=number]::-webkit-outer-spin-button {
  height: auto; }

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px; }

[type=search]::-webkit-search-cancel-button, [type=search]::-webkit-search-decoration {
  -webkit-appearance: none; }

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit; }

summary {
  display: list-item; }

[hidden], template {
  display: none; }

@font-face {
  font-family: "ITC Avant Garde Gothic W04 Bk";
  src: url("../webfonts/28fe8312-61c6-495a-99a7-7076964d3a0a.eot?#iefix");
  src: url("../webfonts/28fe8312-61c6-495a-99a7-7076964d3a0a.eot?#iefix") format("eot"), url("../webfonts/f4935529-9256-45ed-b492-68175b05634e.woff2") format("woff2"), url("../webfonts/536ca58d-8cc1-420d-a857-f0129065d22e.woff") format("woff"), url("../webfonts/a1d76b37-6e92-4b0a-9827-fc436b674a2b.ttf") format("truetype"); }
@font-face {
  font-family: "ITC Avant Garde Gothic W04 Bd";
  src: url("../webfonts/164e8060-5596-4d5a-97fa-9dd2d530bc8a.eot?#iefix");
  src: url("../webfonts/164e8060-5596-4d5a-97fa-9dd2d530bc8a.eot?#iefix") format("eot"), url("../webfonts/d4cc2493-a895-4aee-8384-9f12698e2bb6.woff2") format("woff2"), url("../webfonts/725537f2-fc68-40c2-b3e1-90504a042d38.woff") format("woff"), url("../webfonts/a50a427b-334a-4da2-a238-6aa52409830d.ttf") format("truetype"); }
@font-face {
  font-family: 'King_Cool_KC_Pro';
  src: url("../webfonts/King_Cool_KC_Pro-webfont.woff2") format("woff2"), url("../webfonts/King_Cool_KC_Pro-webfont.woff") format("woff");
  font-weight: normal;
  font-style: normal; }
/**
 * Z-INDEX MANAGEMENT
 * z-index: index($layers, hamburger);
 */
.show-for-xsmall-down, .show-for-xsmall-only, .show-for-xsmall-up, .show-for-small-down, .show-for-small-only, .show-for-small-up, .show-for-medium-down, .show-for-medium-only, .show-for-medium-up, .show-for-large-down, .show-for-large-only, .show-for-large-up, .show-for-xlarge-down, .show-for-xlarge-only, .show-for-xlarge-up {
  display: none; }

@media (max-width: 319px) {
  .show-for-xsmall-down {
    display: block; } }

@media (max-width: 319px) {
  .show-for-xsmall-only {
    display: block; } }

.show-for-xsmall-up {
  display: block; }

@media (max-width: 599px) {
  .show-for-small-down {
    display: block; } }

@media (min-width: 320px) and (max-width: 599px) {
  .show-for-small-only {
    display: block; } }

@media (min-width: 320px) {
  .show-for-small-up {
    display: block; } }

@media (max-width: 1023px) {
  .show-for-medium-down {
    display: block; } }

@media (min-width: 600px) and (max-width: 1023px) {
  .show-for-medium-only {
    display: block; } }

@media (min-width: 600px) {
  .show-for-medium-up {
    display: block; } }

@media (max-width: 1199px) {
  .show-for-large-down {
    display: block; } }

@media (min-width: 1024px) and (max-width: 1199px) {
  .show-for-large-only {
    display: block; } }

@media (min-width: 1024px) {
  .show-for-large-up {
    display: block; } }

.show-for-xlarge-down {
  display: block; }

@media (min-width: 1200px) {
  .show-for-xlarge-only {
    display: block; } }

@media (min-width: 1200px) {
  .show-for-xlarge-up {
    display: block; } }

@media (max-width: 319px) {
  .hide-for-xsmall-down {
    display: none; } }

@media (max-width: 319px) {
  .hide-for-xsmall-only {
    display: none; } }

.hide-for-xsmall-up {
  display: none; }

@media (max-width: 599px) {
  .hide-for-small-down {
    display: none; } }

@media (min-width: 320px) and (max-width: 599px) {
  .hide-for-small-only {
    display: none; } }

@media (min-width: 320px) {
  .hide-for-small-up {
    display: none; } }

@media (max-width: 1023px) {
  .hide-for-medium-down {
    display: none; } }

@media (min-width: 600px) and (max-width: 1023px) {
  .hide-for-medium-only {
    display: none; } }

@media (min-width: 600px) {
  .hide-for-medium-up {
    display: none; } }

@media (max-width: 1199px) {
  .hide-for-large-down {
    display: none; } }

@media (min-width: 1024px) and (max-width: 1199px) {
  .hide-for-large-only {
    display: none; } }

@media (min-width: 1024px) {
  .hide-for-large-up {
    display: none; } }

.hide-for-xlarge-down {
  display: none; }

@media (min-width: 1200px) {
  .hide-for-xlarge-only {
    display: none; } }

@media (min-width: 1200px) {
  .hide-for-xlarge-up {
    display: none; } }

.section {
  text-align: center;
  padding: 40px 0;
  background: white;
  color: #575757; }
  @media (max-width: 1023px) {
    .section {
      padding: 30px 0; } }
  @media (max-width: 599px) {
    .section {
      padding: 20px 0; } }
  .section.blue {
    background: #009beb;
    color: white; }
  .section.less-wide .section-inner {
    max-width: 900px;
    width: calc( 90% - 60px ); }
    @media (max-width: 599px) {
      .section.less-wide .section-inner {
        width: calc(100% - 40px); } }
  .section .section-inner {
    display: inline-block;
    max-width: 1000px;
    width: calc( 100% - 60px );
    text-align: left;
    position: relative;
    padding: 0 30px; }
    @media (max-width: 1023px) {
      .section .section-inner {
        width: calc( 100% - 40px );
        padding: 0 20px; } }
    @media (max-width: 599px) {
      .section .section-inner {
        width: calc( 100% - 30px );
        padding: 0 15px; } }

.content-format h1, .content-format h2, .content-format h3, .content-format h4, .content-format h5, .content-format h6 {
  font-weight: 400; }
.content-format h1, .content-format h2 {
  font-size: 2.35em;
  color: #009beb;
  text-transform: uppercase;
  font-family: "King_Cool_KC_Pro", sans;
  margin-bottom: 30px; }
  .content-format h1 + h3, .content-format h2 + h3 {
    margin-top: -30px; }
.content-format h3 {
  font-size: 1.7em;
  color: #575757;
  text-transform: uppercase;
  font-family: "King_Cool_KC_Pro", sans; }
.content-format h4 {
  margin-top: 50px;
  font-size: 1em;
  color: #575757;
  text-decoration: underline;
  font-family: "ITC Avant Garde Gothic W04 Bd", sans; }
.content-format img {
  margin-bottom: 30px; }
.content-format strong {
  font-weight: 400;
  font-family: "ITC Avant Garde Gothic W04 Bd", sans; }
.content-format a {
  color: #575757;
  text-decoration: none; }
  .content-format a:hover {
    text-decoration: underline; }
  .content-format a.button {
    display: inline-block;
    background: #009beb;
    color: white;
    text-decoration: none;
    padding: 10px 50px;
    font-family: "King_Cool_KC_Pro", sans;
    font-size: 1.5em;
    text-transform: uppercase; }
    @media (min-width: 600px) {
      .content-format a.button:hover {
        text-decoration: none;
        transform: scale(1.2) rotate(5deg); } }
.content-format ul {
  margin-left: 0;
  padding-left: 20px; }
.content-format p {
  margin-top: 0;
  margin-bottom: 25px; }
  .content-format p.small {
    font-size: .8em; }
  .content-format p.teasertext {
    font-size: 3.33em;
    text-align: center;
    font-family: "King_Cool_KC_Pro", sans;
    text-transform: uppercase; }
    @media (min-width: 600px) and (max-width: 1023px) {
      .content-format p.teasertext {
        font-size: 5.3vw; } }
    @media (max-width: 599px) {
      .content-format p.teasertext {
        font-size: 2em; } }
    @media (max-width: 599px) {
      .content-format p.teasertext br {
        display: none; } }
.content-format p + h1, .content-format p + h2 {
  margin-top: 100px; }
  @media (max-width: 599px) {
    .content-format p + h1, .content-format p + h2 {
      margin-top: 40px; } }
.content-format .frame {
  border: 3px solid #009beb;
  padding: 50px 25px;
  position: relative;
  margin-bottom: 70px;
  margin-top: 70px; }
  @media (max-width: 599px) {
    .content-format .frame {
      margin-top: 30px;
      margin-bottom: 60px;
      padding: 30px 15px; } }
  .content-format .frame .frame-label {
    display: inline-block;
    position: absolute;
    left: 50%;
    top: 0;
    transform: translate(-50%, -50%);
    background: #009beb;
    color: white;
    text-decoration: none;
    padding: 10px 15px;
    font-family: "King_Cool_KC_Pro", sans;
    font-size: 1.5em;
    text-transform: uppercase; }
  .content-format .frame .frame-label + .frame-inner {
    padding-top: 40px; }
  .content-format .frame .frame-inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }
    .content-format .frame .frame-inner .block {
      display: block;
      width: 47%;
      margin-bottom: 70px;
      position: relative; }
      @media (min-width: 600px) {
        .content-format .frame .frame-inner .block:nth-last-child(1), .content-format .frame .frame-inner .block:nth-last-child(2) {
          margin-bottom: 20px; } }
      .content-format .frame .frame-inner .block.full-width {
        width: 100%;
        margin-bottom: 40px; }
      @media (max-width: 599px) {
        .content-format .frame .frame-inner .block {
          width: 100%;
          margin-bottom: 30px; } }
      .content-format .frame .frame-inner .block .text {
        padding-top: 10px; }
        .content-format .frame .frame-inner .block .text.small {
          font-size: .8em; }
      .content-format .frame .frame-inner .block .title {
        color: #009beb;
        text-decoration: underline;
        margin-bottom: 10px;
        font-weight: bold; }
        .content-format .frame .frame-inner .block .title.large {
          color: #009beb;
          font-family: "King_Cool_KC_Pro", sans;
          font-size: 1.6em;
          text-transform: uppercase;
          text-decoration: none;
          font-weight: normal; }
      .content-format .frame .frame-inner .block .price {
        font-size: 1.6em;
        text-transform: uppercase;
        position: absolute;
        right: 0;
        top: 0;
        color: #009beb;
        font-family: "King_Cool_KC_Pro", sans; }
        .content-format .frame .frame-inner .block .price.small {
          font-size: 1em;
          font-family: "ITC Avant Garde Gothic W04 Bk", sans;
          text-transform: none;
          color: #575757; }
  .content-format .frame .frame-button {
    position: absolute;
    left: 0;
    bottom: -5px;
    width: 100%;
    height: 40px;
    text-align: center; }
    @media (max-width: 1023px) {
      .content-format .frame .frame-button {
        bottom: -13px; } }
    .content-format .frame .frame-button a {
      display: inline-block;
      background: #009beb;
      color: white;
      text-decoration: none;
      padding: 10px 15px;
      font-family: "King_Cool_KC_Pro", sans;
      font-size: 1.5em;
      text-transform: uppercase; }
      .content-format .frame .frame-button a:hover {
        transform: scale(1.2) rotate(5deg); }
.content-format .align-left {
  text-align: left; }
.content-format .align-center {
  text-align: center; }
.content-format .align-right {
  text-align: right; }
.content-format > *:last-child {
  margin-bottom: 0; }

a {
  transition: color ease 0.25s, transform ease 0.25s; }

body, html {
  display: block;
  background-color: white;
  margin: 0;
  padding: 0;
  width: 100%;
  font-family: "ITC Avant Garde Gothic W04 Bk", sans;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

body {
  font-size: 17px;
  line-height: 1.46;
  padding-top: 135px; }
  @media (max-width: 1023px) {
    body {
      padding-top: 120px;
      font-size: 16px; } }
  @media (max-width: 599px) {
    body {
      font-size: 14px;
      padding-top: 70px; } }

@media (max-width: 599px) {
  .spacer.spacer-small-20 {
    height: 20px; }
  .spacer.spacer-small-40 {
    height: 40px; }
  .spacer.spacer-small-60 {
    height: 60px; }
  .spacer.spacer-small-80 {
    height: 80px; }
  .spacer.spacer-small-100 {
    height: 100px; }
  .spacer.spacer-small-130 {
    height: 130px; }
  .spacer.spacer-small-160 {
    height: 160px; } }
@media (min-width: 600px) and (max-width: 1023px) {
  .spacer.spacer-medium-20 {
    height: 20px; }
  .spacer.spacer-medium-40 {
    height: 40px; }
  .spacer.spacer-medium-60 {
    height: 60px; }
  .spacer.spacer-medium-80 {
    height: 80px; }
  .spacer.spacer-medium-100 {
    height: 100px; }
  .spacer.spacer-medium-130 {
    height: 130px; }
  .spacer.spacer-medium-160 {
    height: 160px; } }
@media (min-width: 1024px) {
  .spacer.spacer-large-20 {
    height: 20px; }
  .spacer.spacer-large-40 {
    height: 40px; }
  .spacer.spacer-large-60 {
    height: 60px; }
  .spacer.spacer-large-80 {
    height: 80px; }
  .spacer.spacer-large-100 {
    height: 100px; }
  .spacer.spacer-large-130 {
    height: 130px; }
  .spacer.spacer-large-160 {
    height: 160px; } }

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

.header {
  text-align: center;
  padding: 15px 0;
  background: white;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 115px;
  z-index: 4;
  transition: all ease 0.25s; }
  @media (max-width: 1023px) {
    .header {
      height: 80px; } }
  @media (max-width: 599px) {
    .header {
      padding: 10px 0;
      height: 50px; } }
  .header .header-inner {
    display: inline-block;
    max-width: 1000px;
    width: 100%;
    text-align: left;
    position: relative; }
    .header .header-inner .mobile-navigation-toggle {
      display: inline-block;
      position: absolute;
      right: 20px;
      top: 0;
      display: none;
      color: #009beb;
      text-decoration: none; }
      @media (max-width: 599px) {
        .header .header-inner .mobile-navigation-toggle {
          display: block; } }
    .header .header-inner .logo {
      position: absolute;
      left: 0;
      top: -20px;
      transition: all ease 0.25s; }
      @media (max-width: 1199px) {
        .header .header-inner .logo {
          left: 20px; } }
      .header .header-inner .logo.default, .header .header-inner .logo.nosub {
        width: 330px; }
        @media (max-width: 1023px) {
          .header .header-inner .logo.default, .header .header-inner .logo.nosub {
            width: 230px; } }
      .header .header-inner .logo.nosub {
        opacity: 0; }
      .header .header-inner .logo.small {
        display: none; }
      @media (max-width: 599px) {
        .header .header-inner .logo {
          top: -14px; }
          .header .header-inner .logo.default {
            opacity: 0; }
          .header .header-inner .logo.nosub {
            opacity: 0; }
          .header .header-inner .logo.small {
            display: block;
            height: 50px;
            width: auto;
            left: 15px; } }
    .header .header-inner .main-navigation {
      position: absolute;
      right: 0;
      top: 20px;
      list-style: none;
      margin: 0;
      padding: 0; }
      @media (max-width: 1199px) {
        .header .header-inner .main-navigation {
          right: 20px; } }
      @media (max-width: 599px) {
        .header .header-inner .main-navigation {
          display: none; } }
      .header .header-inner .main-navigation li {
        display: inline-block;
        margin: 0 0 0 45px;
        padding: 0;
        position: relative; }
        @media (max-width: 1023px) {
          .header .header-inner .main-navigation li {
            margin-left: 20px; } }
        .header .header-inner .main-navigation li a {
          color: #575757;
          text-decoration: none; }
          .header .header-inner .main-navigation li a.active, .header .header-inner .main-navigation li a:hover {
            color: #009beb; }
        .header .header-inner .main-navigation li ul {
          background: white;
          display: block;
          position: absolute;
          padding: 20px;
          margin: 0;
          text-align: center;
          left: 50%;
          transform: translateX(-60%);
          visibility: hidden;
          opacity: 0;
          transition: transform ease 0.25s, opacity ease 0.25s, visibility ease 0s 0.25s; }
          .header .header-inner .main-navigation li ul li {
            display: block;
            margin: 15px 0 0 0;
            padding: 0; }
            .header .header-inner .main-navigation li ul li a.active, .header .header-inner .main-navigation li ul li a:hover {
              color: #009beb;
              text-decoration: underline; }
        .header .header-inner .main-navigation li:hover ul {
          visibility: visible;
          transform: translateX(-50%);
          opacity: 1;
          transition: all ease 0.25s; }
  @media (min-width: 600px) {
    .header.scrolled {
      padding: 5px 0 8px 0;
      height: 80px; } }
  @media (min-width: 600px) and (max-width: 1023px) {
    .header.scrolled {
      height: 60px; } }
  @media (min-width: 600px) {
      .header.scrolled .header-inner .logo.default {
        opacity: 0;
        width: 260px; } }
    @media (min-width: 600px) and (max-width: 1023px) {
      .header.scrolled .header-inner .logo.default {
        width: 200px; } }
  @media (min-width: 600px) {
      .header.scrolled .header-inner .logo.nosub {
        opacity: 1;
        width: 260px; } }
    @media (min-width: 600px) and (max-width: 1023px) {
      .header.scrolled .header-inner .logo.nosub {
        width: 200px; } }
  @media (min-width: 600px) {
      .header.scrolled .header-inner .logo.small {
        display: none; }
      .header.scrolled .header-inner .main-navigation {
        top: 10px; } }

.mobile-navigation-overlay {
  display: none;
  width: 100%;
  height: 100%;
  position: fixed;
  left: 0;
  top: 0;
  background: #009beb;
  z-index: 5; }
  @media (max-width: 599px) {
    .mobile-navigation-overlay {
      display: block;
      visibility: hidden;
      opacity: 0;
      transition: opacity ease 0.25s 0s, visibility ease 0.25s 0.25s; }
      .mobile-navigation-overlay.visible {
        opacity: 1;
        visibility: visible;
        transition: opacity ease 0.25s 0s, visibility ease 0.25s 0s; } }
  .mobile-navigation-overlay .mobile-navigation-toggle {
    position: absolute;
    right: 20px;
    top: 25px;
    color: white;
    text-decoration: none; }
  .mobile-navigation-overlay .main-navigation-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    height: 100%; }
  .mobile-navigation-overlay .main-navigation {
    display: block;
    text-align: center;
    margin: 0;
    padding: 0;
    list-style: none;
    font-size: 2em; }
    .mobile-navigation-overlay .main-navigation li {
      margin: 0 0 20px 0;
      padding: 0; }
      .mobile-navigation-overlay .main-navigation li a {
        color: white;
        text-decoration: none; }

.booking-overlay {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.8);
  z-index: 6;
  text-align: center;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  transition: visibility ease 0s 0.25s, opacity ease 0.25s 0s; }
  .booking-overlay.visible {
    visibility: visible;
    opacity: 1;
    transition: visibility ease 0s 0s, opacity ease 0.25s 0s; }
  .booking-overlay .booking-overlay-inner {
    display: inline-block;
    text-align: left;
    margin: 10% 0;
    padding: 30px 50px;
    background: #009beb;
    width: calc(100% - 100px);
    max-width: 800px;
    color: white;
    position: relative; }
    @media (max-width: 599px) {
      .booking-overlay .booking-overlay-inner {
        padding: 60px 20px 30px 20px;
        background: #009beb;
        width: calc(100% - 40px);
        margin: 0; } }
    .booking-overlay .booking-overlay-inner a.close {
      position: absolute;
      right: 25px;
      top: 15px;
      color: white;
      transform-origin: center center;
      font-size: 1.5em;
      transition: all ease 0.25s;
      text-decoration: none; }
      .booking-overlay .booking-overlay-inner a.close:hover {
        transform: scale(1.5) rotate(5deg); }
    .booking-overlay .booking-overlay-inner h2 {
      display: block;
      color: white;
      font-size: 1.55em;
      font-family: "King_Cool_KC_Pro", sans;
      text-transform: uppercase;
      text-align: center;
      margin-bottom: 50px; }
      .booking-overlay .booking-overlay-inner h2 span {
        border-bottom: 2px solid white;
        padding: 5px 20px; }

.footer {
  text-align: center;
  padding: 40px 0 80px 0;
  background: #009beb;
  color: white; }
  .footer .footer-inner {
    display: inline-block;
    max-width: 1000px;
    width: calc( 100% - 60px );
    text-align: left;
    position: relative;
    padding: 0 30px; }
    @media (max-width: 1023px) {
      .footer .footer-inner {
        width: calc( 100% - 40px );
        padding: 0 20px; } }
    .footer .footer-inner h2, .footer .footer-inner h3, .footer .footer-inner a, .footer .footer-inner p, .footer .footer-inner ul {
      color: white; }
    .footer .footer-inner h3 {
      margin-bottom: 0; }
    .footer .footer-inner ul {
      margin: 0 0 50px 0;
      padding: 0;
      list-style: none; }
      .footer .footer-inner ul li {
        margin-bottom: 6px; }
        .footer .footer-inner ul li a {
          display: inline-block;
          color: white;
          font-family: "ITC Avant Garde Gothic W04 Bd", sans;
          text-decoration: none; }
          .footer .footer-inner ul li a:hover {
            transform: rotate(5deg); }
    .footer .footer-inner a.facebook,
    .footer .footer-inner a.instagram {
      display: inline-block;
      color: white;
      font-family: "ITC Avant Garde Gothic W04 Bd", sans;
      text-decoration: none;
      padding-left: 55px;
      line-height: 40px;
      margin-bottom: 1.4em; }
      .footer .footer-inner a.facebook:hover,
      .footer .footer-inner a.instagram:hover {
        transform: rotate(5deg); }
    .footer .footer-inner a.facebook {
      background: url("../images/facebook.png") no-repeat left center/40px auto; }
    .footer .footer-inner a.instagram {
      background: url("../images/instagram.png") no-repeat left center/40px auto; }
    .footer .footer-inner .footer-columns {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; }
      .footer .footer-inner .footer-columns .footer-left {
        width: 60%; }
        @media (max-width: 599px) {
          .footer .footer-inner .footer-columns .footer-left {
            width: 100%; } }
      .footer .footer-inner .footer-columns .footer-right {
        width: 40%; }
        @media (max-width: 599px) {
          .footer .footer-inner .footer-columns .footer-right {
            width: 100%; } }

.slider {
  font-size: 0px;
  line-height: 0px;
  margin: 0 0 -1px 0; }
  .slider .slick-dots {
    display: block;
    position: absolute;
    bottom: 40px;
    left: 0;
    width: 100%;
    margin: 0;
    padding: 0;
    text-align: center; }
    @media (max-width: 599px) {
      .slider .slick-dots {
        bottom: 15px; } }
    .slider .slick-dots li {
      margin: 0 5px;
      padding: 0;
      display: inline-block; }
      .slider .slick-dots li button {
        display: block;
        width: 8px;
        height: 8px;
        overflow: hidden;
        white-space: no-wrap;
        text-indent: 999em;
        border-radius: 50%;
        background: white;
        padding: 0;
        margin: 0;
        opacity: .4;
        outline: 0;
        cursor: pointer;
        transition: opacity ease 0.25s; }
        .slider .slick-dots li button:hover {
          opacity: .9; }
      .slider .slick-dots li.slick-active button {
        opacity: 1; }
  .slider .slide img {
    margin: 0;
    width: 100%; }

.error {
  display: none;
  font-size: 1.4em;
  padding: 15px 30px;
  background: #f00;
  color: white; }

.success {
  display: none;
  font-size: 1.4em; }

.no-dates {
  font-size: 1.4em; }

button {
  outline: none;
  transition: all ease 0.25s;
  display: inline-block;
  background: #009beb;
  color: white;
  text-decoration: none;
  padding: 10px 50px;
  font-family: "King_Cool_KC_Pro", sans;
  font-size: 1.5em;
  text-transform: uppercase;
  cursor: pointer;
  border: 2px solid white; }
  button[disabled] {
    opacity: .3;
    cursor: default; }
    button[disabled]:hover {
      text-decoration: none;
      transform: none; }
  @media (min-width: 600px) {
    button:hover {
      text-decoration: none;
      transform: scale(1.2) rotate(5deg); } }

.button-wrapper {
  display: block;
  text-align: center;
  padding-top: 20px;
  padding-bottom: 20px; }

input::-moz-focus-inner {
  border: 0; }

input[type=text] {
  border-radius: 0;
  color: white;
  border: 2px solid white;
  background: transparent;
  display: block;
  width: calc(100% - 30px);
  padding: 10px 15px;
  -webkit-appearance: none;
  -moz-appearance: none; }

select {
  border: 0;
  border-radius: 0;
  background: white url("../images/select-arrow.png") no-repeat right 10px center/auto 20px;
  color: #009beb;
  padding: 10px 15px;
  width: 100%;
  text-indent: 1px;
  text-overflow: '';
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none; }

label {
  display: block;
  color: white;
  margin-top: 6px;
  font-style: italic; }

input[type=radio],
input[type=checkbox] {
  height: 1px;
  overflow: hidden;
  opacity: 0; }

input[type=radio] + label,
input[type=checkbox] + label {
  margin-top: -30px;
  padding-top: 50px;
  background: url("../images/checkbox0.png") no-repeat left top/43px auto;
  cursor: pointer; }

input[type=radio]:checked + label,
input[type=checkbox]:checked + label {
  background-image: url("../images/checkbox1.png"); }

.field-wrapper {
  display: block;
  margin-bottom: 20px; }
  .field-wrapper.inline {
    display: inline-block;
    margin-right: 20px;
    width: 30%; }

.two-columns {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between; }
  .two-columns .column {
    display: block;
    width: 47%; }
    @media (max-width: 599px) {
      .two-columns .column {
        width: 100%; } }

.agb.marginTop {
  margin-top: 80px; }
  @media (max-width: 599px) {
    .agb.marginTop {
      margin-top: 40px; } }
.agb a {
  color: white; }
.agb input[type=checkbox] + label {
  padding-top: 5px;
  min-height: 50px;
  padding-left: 60px;
  margin-top: 0; }

.tiles {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 40px 0; }
  .tiles .tile {
    background: url("../images/tile.png") no-repeat left top/100% 100%;
    display: block;
    float: left;
    width: 29.333%;
    height: 20vw;
    margin-bottom: 5vw; }
    @media (max-width: 1023px) {
      .tiles .tile {
        width: 47%;
        height: 35vw;
        margin-bottom: 6vw; } }
    @media (max-width: 599px) {
      .tiles .tile {
        width: 100%;
        height: 80vw;
        margin-bottom: 30px; } }
    @media (min-width: 1200px) {
      .tiles .tile {
        height: 240px;
        margin-bottom: 60px; } }
    .tiles .tile.active {
      z-index: 3; }
      .tiles .tile.active .tile-inner {
        overflow: visible; }
        .tiles .tile.active .tile-inner .tile-overlay {
          margin-top: 0;
          background: #009beb;
          height: calc(200% + 60px);
          opacity: 1;
          visibility: visible; }
          @media (max-width: 1023px) {
            .tiles .tile.active .tile-inner .tile-overlay {
              height: calc(200% + 6vw); } }
          @media (max-width: 599px) {
            .tiles .tile.active .tile-inner .tile-overlay {
              height: calc(200% + 30px); } }
          .tiles .tile.active .tile-inner .tile-overlay a.more {
            display: none; }
          .tiles .tile.active .tile-inner .tile-overlay a.book {
            display: inline-block; }
          .tiles .tile.active .tile-inner .tile-overlay a.close {
            opacity: 1; }
          .tiles .tile.active .tile-inner .tile-overlay .text {
            max-height: 600px; }
      @media (max-width: 599px) {
        .tiles .tile.active:nth-child(6) .tile-inner .tile-overlay {
          margin-top: calc(-76vw - 30px); } }
      @media (min-width: 600px) and (max-width: 1023px) {
        .tiles .tile.active:nth-child(5) .tile-inner .tile-overlay, .tiles .tile.active:nth-child(6) .tile-inner .tile-overlay {
          margin-top: -41vw; } }
      @media (min-width: 1024px) {
        .tiles .tile.active:nth-child(4) .tile-inner .tile-overlay, .tiles .tile.active:nth-child(5) .tile-inner .tile-overlay, .tiles .tile.active:nth-child(6) .tile-inner .tile-overlay {
          margin-top: -25vw; } }
      @media (min-width: 1200px) {
        .tiles .tile.active:nth-child(4) .tile-inner .tile-overlay, .tiles .tile.active:nth-child(5) .tile-inner .tile-overlay, .tiles .tile.active:nth-child(6) .tile-inner .tile-overlay {
          margin-top: -300px; } }
    .tiles .tile .tile-inner {
      width: 100%;
      height: 100%;
      position: relative;
      overflow: hidden; }
      .tiles .tile .tile-inner h3 {
        display: block;
        text-align: center;
        width: 100%;
        font-family: "King_Cool_KC_Pro", sans;
        text-transform: uppercase;
        font-size: 1.45em;
        line-height: 1.3;
        font-weight: 400; }
      .tiles .tile .tile-inner .tile-icon {
        width: 100%;
        height: 100%;
        background-size: 100% auto;
        background-position: center top;
        background-repeat: no-repeat;
        position: relative; }
        .tiles .tile .tile-inner .tile-icon .title-wrapper {
          position: absolute;
          bottom: 10px;
          left: 0;
          text-align: center;
          width: 100%; }
          .tiles .tile .tile-inner .tile-icon .title-wrapper h3 {
            font-size: 2.25vw;
            color: #009beb;
            margin: 0 0 14px 0; }
            @media (max-width: 1023px) {
              .tiles .tile .tile-inner .tile-icon .title-wrapper h3 {
                font-size: 3.37vw; } }
            @media (max-width: 599px) {
              .tiles .tile .tile-inner .tile-icon .title-wrapper h3 {
                margin-bottom: 10px;
                font-size: 7.4vw; } }
            @media (min-width: 1200px) {
              .tiles .tile .tile-inner .tile-icon .title-wrapper h3 {
                font-size: 1.6em; } }
          .tiles .tile .tile-inner .tile-icon .title-wrapper a.small-more {
            display: none;
            background: transparent;
            color: #009beb;
            border: 2px solid #009beb;
            padding: 5px 15px;
            margin-bottom: 10px; }
            @media (max-width: 599px) {
              .tiles .tile .tile-inner .tile-icon .title-wrapper a.small-more {
                display: inline-block; } }
      .tiles .tile .tile-inner .tile-overlay {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background: rgba(0, 155, 235, 0.8);
        margin-top: 120%;
        transition: all ease 0.25s;
        text-align: center; }
        @media (max-width: 599px) {
          .tiles .tile .tile-inner .tile-overlay {
            opacity: 0;
            visibility: hidden; } }
        .tiles .tile .tile-inner .tile-overlay h3 {
          margin-top: 15%;
          display: block;
          color: white;
          font-size: 1.55em;
          line-height: 1;
          margin-bottom: 15px; }
          @media (min-width: 1024px) and (max-width: 1199px) {
            .tiles .tile .tile-inner .tile-overlay h3 {
              margin-top: 12%; } }
          .tiles .tile .tile-inner .tile-overlay h3 span {
            border-bottom: 2px solid white;
            padding: 5px 20px; }
        .tiles .tile .tile-inner .tile-overlay .text {
          max-height: 0;
          overflow: hidden;
          transition: max-height ease 0.25s;
          padding: 0 30px;
          color: white;
          font-size: .9em;
          margin: 0; }
        .tiles .tile .tile-inner .tile-overlay a.more {
          margin-top: 10px;
          display: block;
          color: white;
          text-align: center;
          text-decoration: none;
          padding-bottom: 65px;
          font-family: "ITC Avant Garde Gothic W04 Bd", sans;
          background: url("../images/arrow.png") no-repeat center bottom 4px/50px auto; }
        .tiles .tile .tile-inner .tile-overlay a.close {
          position: absolute;
          right: 25px;
          top: 15px;
          color: white;
          transform-origin: center center;
          font-size: 1.5em;
          opacity: 0;
          transition: all ease 0.25s; }
          .tiles .tile .tile-inner .tile-overlay a.close:hover {
            text-decoration: none;
            transform: scale(1.5) rotate(5deg); }
        .tiles .tile .tile-inner .tile-overlay a.book {
          display: none;
          border: 2px solid white;
          color: white;
          background: none;
          padding: 10px 15px;
          margin-top: 50px;
          width: calc( 70% - 34px );
          white-space: nowrap; }
          @media (min-width: 1024px) and (max-width: 1199px) {
            .tiles .tile .tile-inner .tile-overlay a.book {
              margin-top: 30px; } }
          @media (max-width: 599px) {
            .tiles .tile .tile-inner .tile-overlay a.book {
              margin-bottom: 50px; } }
      .tiles .tile .tile-inner:hover .tile-overlay {
        margin-top: 0; }

.cookie-bar {
  display: block;
  position: fixed;
  left: 0;
  bottom: 0;
  width: calc(100% - 60px);
  background: #fff;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.15);
  padding: 15px 30px;
  text-align: center;
  z-index: 999999; }

.cookie-bar .cookie-bar-inner {
  display: inline-block; }

.cookie-bar .cookie-bar-inner .cookie-bar-text {
  font-size: 15px;
  line-height: 22px;
  color: #000;
  display: inline-block;
  margin-right: 30px; }

.cookie-bar .cookie-bar-inner .cookie-bar-text a {
  color: #000;
  text-decoration: underline; }

@media screen and (max-width: 880px) {
  .cookie-bar .cookie-bar-inner .cookie-bar-text {
    margin-right: 0;
    display: block;
    margin-bottom: 10px; } }
.cookie-bar .cookie-bar-inner button {
  display: inline-block;
  background: #009beb;
  color: #fff;
  font-size: 20px;
  text-transform: uppercase;
  font-family: "King_Cool_KC_Pro", sans;
  padding: 10px 25px;
  border: 0;
  border-radius: 0px;
  outline: none; }

/*# sourceMappingURL=app.css.map */
