/**
 * selectize.default.css (v0.12.3) - Default Theme
 * Copyright (c) 2013–2015 Brian Reavis & contributors
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this
 * file except in compliance with the License. You may obtain a copy of the License at:
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software distributed under
 * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
 * ANY KIND, either express or implied. See the License for the specific language
 * governing permissions and limitations under the License.
 *
 * @author Brian Reavis <brian@thirdroute.com>
 */
/*! Swipebox v1.3.0 | Constantin Saguin csag.co | MIT License | github.com/brutaldesign/swipebox */
/*!
 * animate.css -http://daneden.me/animate
 * Version - 3.6.0
 * Licensed under the MIT license - http://opensource.org/licenses/MIT
 *
 * Copyright (c) 2018 Daniel Eden
 */
@charset "UTF-8";
article, aside, details, figcaption, figure, footer, header, main, menu, nav, section {
  display: block; }

html, body {
  height: 100%;
  padding: 0;
  margin: 0; }

input, select, textarea, button {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  border-radius: none; }

button, [type="submit"] {
  cursor: pointer;
  padding: 0;
  font-size: inherit;
  font-family: inherit;
  border: none;
  background: none; }

p {
  padding: 0;
  margin: 0 0 1em; }

ul {
  padding: 0;
  margin: 0;
  list-style: none; }

a img {
  border: none; }

@font-face {
  font-family: Roboto;
  src: url('/res/fonts/Roboto/Roboto-Regular.eot');
  src: url('/res/fonts/Roboto/Roboto-Regular.eot?#iefix') format('embedded-opentype'), url('/res/fonts/Roboto/Roboto-Regular.woff2') format('woff2'), url('/res/fonts/Roboto/Roboto-Regular.woff') format('woff'), url('/res/fonts/Roboto/Roboto-Regular.ttf') format('truetype'), url('/res/fonts/Roboto/Roboto-Regular.svg#Roboto-Regular') format('svg');
  font-weight: 400;
  font-style: normal; }

@font-face {
  font-family: Roboto;
  src: url('/res/fonts/Roboto/Roboto-Italic.eot');
  src: url('/res/fonts/Roboto/Roboto-Italic.eot?#iefix') format('embedded-opentype'), url('/res/fonts/Roboto/Roboto-Italic.woff2') format('woff2'), url('/res/fonts/Roboto/Roboto-Italic.woff') format('woff'), url('/res/fonts/Roboto/Roboto-Italic.ttf') format('truetype'), url('/res/fonts/Roboto/Roboto-Italic.svg#Roboto-Italic') format('svg');
  font-weight: 400;
  font-style: italic; }

@font-face {
  font-family: Roboto;
  src: url('/res/fonts/Roboto/Roboto-Light.eot');
  src: url('/res/fonts/Roboto/Roboto-Light.eot?#iefix') format('embedded-opentype'), url('/res/fonts/Roboto/Roboto-Light.woff2') format('woff2'), url('/res/fonts/Roboto/Roboto-Light.woff') format('woff'), url('/res/fonts/Roboto/Roboto-Light.ttf') format('truetype'), url('/res/fonts/Roboto/Roboto-Light.svg#Roboto-Light') format('svg');
  font-weight: 300;
  font-style: normal; }

@font-face {
  font-family: Roboto;
  src: url('/res/fonts/Roboto/Roboto-LightItalic.eot');
  src: url('/res/fonts/Roboto/Roboto-LightItalic.eot?#iefix') format('embedded-opentype'), url('/res/fonts/Roboto/Roboto-LightItalic.woff2') format('woff2'), url('/res/fonts/Roboto/Roboto-LightItalic.woff') format('woff'), url('/res/fonts/Roboto/Roboto-LightItalic.ttf') format('truetype'), url('/res/fonts/Roboto/Roboto-LightItalic.svg#Roboto-LightItalic') format('svg');
  font-weight: 300;
  font-style: italic; }

@font-face {
  font-family: Roboto;
  src: url('/res/fonts/Roboto/Roboto-Bold.eot');
  src: url('/res/fonts/Roboto/Roboto-Bold.eot?#iefix') format('embedded-opentype'), url('/res/fonts/Roboto/Roboto-Bold.woff2') format('woff2'), url('/res/fonts/Roboto/Roboto-Bold.woff') format('woff'), url('/res/fonts/Roboto/Roboto-Bold.ttf') format('truetype'), url('/res/fonts/Roboto/Roboto-Bold.svg#Roboto-Bold') format('svg');
  font-weight: 800;
  font-style: normal; }

@font-face {
  font-family: Roboto;
  src: url('/res/fonts/Roboto/Roboto-BoldItalic.eot');
  src: url('/res/fonts/Roboto/Roboto-BoldItalic.eot?#iefix') format('embedded-opentype'), url('/res/fonts/Roboto/Roboto-BoldItalic.woff2') format('woff2'), url('/res/fonts/Roboto/Roboto-BoldItalic.woff') format('woff'), url('/res/fonts/Roboto/Roboto-BoldItalic.ttf') format('truetype'), url('/res/fonts/Roboto/Roboto-BoldItalic.svg#Roboto-BoldItalic') format('svg');
  font-weight: 800;
  font-style: italic; }

@font-face {
  font-family: PoliceStudioVedette;
  src: url('/res/fonts/PoliceStudioVedette/POLICESTUDIOVedette-Dark.eot');
  src: url('/res/fonts/PoliceStudioVedette/POLICESTUDIOVedette-Dark.eot?#iefix') format('embedded-opentype'), url('/res/fonts/PoliceStudioVedette/POLICESTUDIOVedette-Dark.woff2') format('woff2'), url('/res/fonts/PoliceStudioVedette/POLICESTUDIOVedette-Dark.woff') format('woff'), url('/res/fonts/PoliceStudioVedette/POLICESTUDIOVedette-Dark.ttf') format('truetype'), url('/res/fonts/PoliceStudioVedette/POLICESTUDIOVedette-Dark.svg#POLICESTUDIOVedette-Dark') format('svg');
  font-weight: 900;
  font-style: normal; }

@font-face {
  font-family: LeGrandQuartierCafe;
  src: url('/res/fonts/LeGrandQuartierCafe/LEGRANDQUARTIER-Cafe.eot');
  src: url('/res/fonts/LeGrandQuartierCafe/LEGRANDQUARTIER-Cafe.eot?#iefix') format('embedded-opentype'), url('/res/fonts/LeGrandQuartierCafe/LEGRANDQUARTIER-Cafe.woff2') format('woff2'), url('/res/fonts/LeGrandQuartierCafe/LEGRANDQUARTIER-Cafe.woff') format('woff'), url('/res/fonts/LeGrandQuartierCafe/LEGRANDQUARTIER-Cafe.ttf') format('truetype'), url('/res/fonts/LeGrandQuartierCafe/LEGRANDQUARTIER-Cafe.svg#LEGRANDQUARTIER-Cafe') format('svg');
  font-weight: 400;
  font-style: normal; }

@font-face {
  font-family: LeGrandQuartierHotel;
  src: url('/res/fonts/LeGrandQuartierHotel/LEGRANDQUARTIER-Hotel.eot');
  src: url('/res/fonts/LeGrandQuartierHotel/LEGRANDQUARTIER-Hotel.eot?#iefix') format('embedded-opentype'), url('/res/fonts/LeGrandQuartierHotel/LEGRANDQUARTIER-Hotel.woff2') format('woff2'), url('/res/fonts/LeGrandQuartierHotel/LEGRANDQUARTIER-Hotel.woff') format('woff'), url('/res/fonts/LeGrandQuartierHotel/LEGRANDQUARTIER-Hotel.ttf') format('truetype'), url('/res/fonts/LeGrandQuartierHotel/LEGRANDQUARTIER-Hotel.svg#LEGRANDQUARTIER-Hotel') format('svg');
  font-weight: 400;
  font-style: normal; }

@font-face {
  font-family: LeGrandQuartierStudio;
  src: url('/res/fonts/LeGrandQuartierStudio/LEGRANDQUARTIER-Studio.eot');
  src: url('/res/fonts/LeGrandQuartierStudio/LEGRANDQUARTIER-Studio.eot?#iefix') format('embedded-opentype'), url('/res/fonts/LeGrandQuartierStudio/LEGRANDQUARTIER-Studio.woff2') format('woff2'), url('/res/fonts/LeGrandQuartierStudio/LEGRANDQUARTIER-Studio.woff') format('woff'), url('/res/fonts/LeGrandQuartierStudio/LEGRANDQUARTIER-Studio.ttf') format('truetype'), url('/res/fonts/LeGrandQuartierStudio/LEGRANDQUARTIER-Studio.svg#LEGRANDQUARTIER-Studio') format('svg');
  font-weight: 400;
  font-style: normal; }

@font-face {
  font-family: LeGrandQuartierShop;
  src: url('/res/fonts/LeGrandQuartierShop/LEGRANDQUARTIER-Shop.eot');
  src: url('/res/fonts/LeGrandQuartierShop/LEGRANDQUARTIER-Shop.eot?#iefix') format('embedded-opentype'), url('/res/fonts/LeGrandQuartierShop/LEGRANDQUARTIER-Shop.woff2') format('woff2'), url('/res/fonts/LeGrandQuartierShop/LEGRANDQUARTIER-Shop.woff') format('woff'), url('/res/fonts/LeGrandQuartierShop/LEGRANDQUARTIER-Shop.ttf') format('truetype'), url('/res/fonts/LeGrandQuartierShop/LEGRANDQUARTIER-Shop.svg#LEGRANDQUARTIER-Shop') format('svg');
  font-weight: 400;
  font-style: normal; }

::-moz-selection {
  color: #fff;
  background: #468bce; }

::selection {
  color: #fff;
  background: #468bce; }

* {
  box-sizing: border-box; }

body {
  padding-top: 133px;
  color: #000;
  font-family: 'Roboto', Arial, sans-serif;
  background-color: #fff; }

a {
  cursor: pointer;
  color: #f08372;
  text-decoration: none; }

.lazy {
  background: none !important;
  opacity: 0;
  transition: opacity 1s; }
  .lazy * {
    background: none !important;
    opacity: 0;
    transition: opacity 1s; }

.availpro-container {
  position: absolute;
  top: 140px;
  right: 50px;
  height: 130px;
  overflow: hidden;
  z-index: 92; }
  .availpro-container > div {
    background: #fff;
    padding: 0 10px; }

.slideshow-item {
  display: none;
  width: 100%;
  height: 100%;
  background-size: cover; }
  .slideshow-item:first-child {
    display: block; }

.hidden {
  display: none; }

.rel {
  position: relative; }

.left {
  text-align: left; }

.right {
  text-align: right; }

.justify {
  text-align: justify; }

.center {
  text-align: center; }

.splash {
  height: calc(100% - 62px - 2rem); }

.h100 {
  height: 100%; }

.ovh {
  overflow: hidden; }

.cover, .btn-img, .big-slideshow-item {
  background-position: center;
  background-size: cover; }

.label-hidden {
  position: absolute;
  clip: rect(0, 0, 0, 0); }

.btn {
  display: inline-block;
  padding: 0.3em 1.5em;
  color: #fff;
  font-size: 1rem;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  text-transform: uppercase;
  background: #87cdc8;
  transition: color 0.2s, background 0.2s; }
  .btn:hover, .btn:focus {
    background: #142e52;
    transition: color 0.2s, background 0.2s; }

.btn-red {
  background: #f08372; }

.btn-orange {
  background: #f7ab59; }

.btn-blue {
  background: #468bce; }

.btn-yellow {
  color: #000;
  background: #fee834; }
  .btn-yellow:hover, .btn-yellow:focus {
    color: #fff;
    transition: color 0.2s, background 0.2s; }

.btn-with-arrow {
  display: inline-block;
  color: #000;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  text-transform: uppercase; }
  .btn-with-arrow svg {
    width: 33px;
    height: 10px;
    margin: 0 0 0 5px;
    fill: #87cdc8;
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); }
  .btn-with-arrow:hover svg, .btn-with-arrow:focus svg {
    transform: translateX(5px);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); }

.btn-with-arrow-red svg {
  fill: #f08372; }

.btn-with-arrow-orange svg {
  fill: #f7ab59; }

.btn-narrow {
  padding-left: 0.5em;
  padding-right: 0.5em; }

.btn-border {
  color: #000;
  background: #fff;
  border: #87cdc8 solid 3px;
  transition: color 0.2s, background 0.2s, border 0.2s; }
  .btn-border:hover, .btn-border:focus {
    color: #fff;
    background: #87cdc8;
    transition: color 0.2s, background 0.2s, border 0.2s; }

.btn-img {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 600px; }
  .btn-img div {
    padding: 0.7em;
    color: #f7ab59;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 1.1rem;
    text-transform: uppercase;
    background: #fff;
    transition: transform 0.3s; }
  .btn-img span {
    color: #000; }
  .btn-img:hover div, .btn-img:focus div {
    transform: scale(1.2);
    transition: transform 0.3s; }

.block-content {
  max-width: 1370px;
  margin: 62px auto;
  padding: 0 62px; }

.block-content-mt {
  margin-top: 32px; }

.block-content-nomargin {
  margin-top: 0;
  margin-bottom: 0; }

.text {
  font-size: 0.95rem;
  line-height: 1.5em; }

h1, h2.h1 {
  margin: 0 0 1em;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-size: 2.2rem;
  line-height: 1em; }
  h1 em, h2.h1 em {
    color: #808080;
    font-family: 'Roboto', Arial, sans-serif;
    font-size: 1.5rem;
    font-weight: 300; }

div.h1 h2 {
  margin: 0 0 1em;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-size: 1.6rem;
  line-height: 1em; }
  div.h1 h2 em {
    color: #808080;
    font-family: 'Roboto', Arial, sans-serif;
    font-size: 1.2rem;
    font-weight: 300; }

div.h1-big h2 {
  font-size: 2.2rem; }

.h1-reversed {
  margin: 0 0 1em;
  color: #808080;
  font-family: 'Roboto', Arial, sans-serif;
  font-size: 1.5rem;
  font-weight: 300;
  font-style: italic; }
  .h1-reversed em {
    color: #000;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 2.2rem;
    font-style: normal;
    line-height: 1em; }

.h1-h3 h3 {
  margin: 0 0 1em;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-size: 1.6rem;
  line-height: 1em; }
  .h1-h3 h3 em {
    color: #808080;
    font-family: 'Roboto', Arial, sans-serif;
    font-size: 1.2rem;
    font-weight: 300; }

.quote {
  margin-bottom: 0;
  color: #808080;
  font-size: 1.4rem;
  font-weight: 300;
  font-style: italic;
  line-height: 1.6em; }

.subtitle {
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
  color: #808080;
  font-size: 1.4rem;
  font-weight: 300;
  font-style: italic;
  line-height: 1.4em; }

.has-bg {
  background: #fcfbfb; }

img.w100 {
  display: block;
  width: 100%;
  height: auto; }

img.mw100 {
  display: block;
  max-width: 100%;
  height: auto; }

.f {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between; }

.f-row-reverse {
  flex-direction: row-reverse; }

.f-align-center {
  align-items: center; }

.f-align-bottom {
  align-items: flex-end; }

.f3 {
  flex-basis: calc(30% - 15px); }

.f4 {
  flex-basis: calc(40% - 15px); }

.f5 {
  flex-basis: calc(50% - 15px); }

.f6 {
  flex-basis: calc(60% - 15px); }

.f7 {
  flex-basis: calc(70% - 15px); }

.mts {
  margin-top: 2em; }

.mtm {
  margin-top: 3em; }

.mtl {
  margin-top: 5em; }

.mtxl {
  margin-top: 7em; }

.mbs {
  margin-bottom: 2em; }

.flex-col {
  flex-direction: column; }

.gap-1 {
  gap: 10px; }

.gap-2 {
  gap: 20px; }

.items-start {
  align-items: flex-start; }

.items-center {
  align-items: center;
  /* pages */ }

.menu-page {
  position: absolute;
  width: 385px;
  left: 0;
  top: 0;
  bottom: 0;
  padding: 100px 45px 45px;
  background: #fff; }
  .menu-page h1 {
    margin-bottom: 1.5em;
    font-family: 'LeGrandQuartierHotel', Arial, sans-serif;
    font-size: 3.2rem;
    font-weight: normal; }
  .menu-page ul {
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 1.6rem; }
  .menu-page li {
    display: block;
    border-bottom: #ccc solid 1px; }
  .menu-page li:first-child {
    border-top: #ccc solid 1px; }
  .menu-page li a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: #000;
    padding: 1.1em 0;
    transition: color 0.2s; }
    .menu-page li a.has-arrow svg {
      opacity: 1;
      transform: translateX(0);
      transition: transform 0.2s, opacity 0.2s; }
    .menu-page li a:active {
      color: #f7ab59; }
    .menu-page li a:hover, .menu-page li a:focus {
      color: #808080;
      transition: color 0.2s; }
  .menu-page li svg {
    opacity: 0;
    width: 33px;
    height: 10px;
    fill: #f7ab59;
    transform: translateX(-10px);
    transition: transform 0.2s, opacity 0.2s; }
  .menu-page .font-title {
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 2.2rem; }
  .menu-page .font-cafe {
    font-family: 'LeGrandQuartierCafe', Arial, sans-serif; }
  .menu-page .font-studios {
    font-family: 'LeGrandQuartierStudio', Arial, sans-serif; }

.menu-page-has-details h1 {
  margin-bottom: 0.5em; }

.menu-page-mosa {
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-weight: bold; }
  .menu-page-mosa ul {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    height: 100%; }
  .menu-page-mosa li {
    flex-basis: calc(25% - 8px); }
  .menu-page-mosa li:nth-child(1), .menu-page-mosa li:nth-child(2), .menu-page-mosa li:nth-child(3), .menu-page-mosa li:nth-child(4) {
    flex-basis: calc(25% - 8px);
    margin-bottom: 8px; }
  .menu-page-mosa a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    color: #000;
    text-transform: uppercase;
    background-size: cover;
    background-position: center;
    min-height: 386px; }
  .menu-page-mosa a:hover span, .menu-page-mosa a:focus span {
    transform: scale(1.2);
    transition: transform 0.2s; }
  .menu-page-mosa span {
    padding: 1em;
    background: #fff;
    transition: transform 0.2s; }
  .menu-page-mosa span:after {
    content: ' +';
    color: #f7ab59; }

.menu-page-mosa-rooms li {
  flex-basis: calc(33% - 32px); }

.menu-page-mosa-studios li {
  flex-basis: calc(50% - 32px); }
  .menu-page-mosa-studios li:nth-child(1), .menu-page-mosa-studios li:nth-child(2), .menu-page-mosa-studios li:nth-child(3) {
    flex-basis: calc(33% - 32px); }

.btn-back {
  display: inline-block;
  padding: 0.5em 1em;
  margin: 0 0 2em;
  color: #fff;
  font-size: 1.1rem;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  text-transform: uppercase;
  background: #f7ab59;
  transition: background 0.2s; }
  .btn-back:hover, .btn-back:focus {
    background: #468bce;
    transition: background 0.2s; }

.menu-page-detail {
  display: inline-flex;
  justify-content: center;
  margin-bottom: 1em;
  font-size: 0.85rem; }
  .menu-page-detail > div:first-child {
    padding-right: 0.5em; }
  .menu-page-detail svg {
    width: 20px;
    height: 20px;
    fill: #87cdc8; }

.home-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: #000; }

.home-main-slideshow {
  height: 100%; }
  .home-main-slideshow .slideshow-item {
    background-position: center; }
  .home-main-slideshow .slideshow-item picture {
    position: absolute;
    top: 0;
    left: 0; }
  .home-main-slideshow .slideshow-prev, .home-main-slideshow .slideshow-next {
    top: auto;
    bottom: 16px; }
  .home-main-slideshow .slideshow-prev {
    left: calc(50% - 75px); }
  .home-main-slideshow .slideshow-next {
    right: calc(50% - 75px); }

.slideshow-controls {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 200; }
  .slideshow-controls svg {
    fill: #fff;
    width: 42px; }

.sc-prev {
  left: 1rem; }

.sc-next {
  right: 1rem;
  /* step */ }

.steps-line {
  position: relative;
  display: inline-flex;
  align-items: center; }
  .steps-line:before {
    content: '';
    position: absolute;
    width: 100%;
    height: 4px;
    left: 0;
    top: calc(50% - 2px);
    background: #f7ab59; }

.steps-line-spaced .steps-item {
  margin-left: 40px;
  margin-right: 40px; }

.steps-line-full {
  display: flex;
  justify-content: space-between;
  margin-bottom: 3em; }

.steps-line-green:before {
  background: #87cdc8; }
  .steps-line-green .steps-line-title {
    background: #87cdc8; }
  .steps-line-green .steps-item {
    color: #87cdc8; }

.steps-line-title {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-basis: 130px;
  height: 110px;
  padding: 0 1em;
  color: #fff;
  font-size: 1.1rem;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  background: #f7ab59; }

.steps-item {
  position: relative;
  width: 170px;
  margin: 0 5px;
  color: #f7ab59;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  text-align: center; }
  .steps-item div {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    min-height: 80px;
    margin: 0 auto 1em; }
  .steps-item img {
    max-width: 80px;
    max-height: 80px;
    padding: 3px;
    background: #fcfbfb; }

div.sub-green h2 em, div.sub-green h3 em {
  color: #87cdc8; }

div.sub-orange h2 em, div.sub-orange h3 em {
  color: #f7ab59; }

div.sub-blue h2 em, div.sub-blue h3 em {
  color: #468bce; }

div.sub-red {
  /* global */ }
  div.sub-red h2 em, div.sub-red h3 em {
    color: #f08372; }

.block-text-img {
  margin-bottom: 50px; }
  .block-text-img .text {
    padding-top: 60px;
    padding-bottom: 0; }
  .block-text-img.nopadding .text {
    padding-top: 0;
    padding-bottom: 0; }

.stupid-overlaping-block {
  margin-top: -350px; }

.stupid-overlaping-block-less-stupid {
  margin-top: -250px;
  /* menu hotel */ }

.menu-hotel ul {
  display: flex;
  justify-content: space-between;
  font-size: 3rem; }
  .menu-hotel li {
    flex-basis: calc(33.3% - 6px); }
  .menu-hotel li:first-child {
    font-family: 'LeGrandQuartierShop', Arial, sans-serif; }
  .menu-hotel li:nth-child(2) {
    font-family: 'LeGrandQuartierCafe', Arial, sans-serif; }
  .menu-hotel li:nth-child(3) {
    font-family: 'LeGrandQuartierStudio', Arial, sans-serif; }
  .menu-hotel a {
    position: relative;
    display: block;
    height: 430px;
    color: #fff;
    background-position: center;
    background-size: cover; }
  .menu-hotel a:hover div, .menu-hotel a:focus div {
    background: rgba(0, 0, 0, 0.85);
    transition: background 0.3s; }
    .menu-hotel a:hover span, .menu-hotel a:focus span {
      transform: scale(1.2);
      transition: transform 0.3s; }
  .menu-hotel div {
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.45);
    transition: background 0.3s; }
  .menu-hotel span {
    display: block;
    transition: transform 0.3s; }

.menu-hotel-title {
  color: #808080;
  font-size: 1.8rem;
  font-weight: 300;
  font-style: italic;
  text-align: center;
  /* slideshow */ }

.slideshow-prev, .slideshow-next {
  z-index: 200;
  position: absolute;
  height: 48px;
  top: calc(50% - 24px);
  padding: 0 1em;
  background: #fff; }
  .slideshow-prev svg, .slideshow-next svg {
    width: 33px;
    height: 10px;
    fill: #87cdc8;
    transition: transform 0.3s; }

.slideshow-prev {
  left: 0; }
  .slideshow-prev:hover svg, .slideshow-prev:focus svg {
    transform: translateX(-5px);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); }

.slideshow-next {
  right: 0; }
  .slideshow-next:hover svg, .slideshow-next:focus svg {
    transform: translateX(5px);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); }

.btn-fullscreen {
  z-index: 200;
  position: absolute;
  right: 0;
  bottom: 0;
  padding: 10px;
  background: #fff; }
  .btn-fullscreen svg {
    width: 30px;
    height: 30px;
    fill: #000;
    transition: transform 0.2s; }
  .btn-fullscreen:hover svg, .btn-fullscreen:focus svg {
    transform: scale(1.2);
    transition: transform 0.2s; }

.ss-imgs-list {
  display: none;
  /* meeting */ }

.book-meeting {
  width: 100%;
  height: 100%;
  border: none; }

#bubble {
  background: #fff; }

._3fQbteJd3oQu4il3LpMKkX.avcHn2VQJenBvoR5hilPG ._2ChX4GFAl1-UBiWknYZyEQ, .avcHn2VQJenBvoR5hilPG ._2ChX4GFAl1-UBiWknYZyEQ {
  bottom: 50px !important; }

picture {
  width: 100%;
  height: 100%; }
  picture img {
    width: 100%;
    height: 100%;
    object-fit: cover; }

.book-bistrot-btns {
  position: fixed;
  left: 0;
  bottom: 2rem;
  z-index: 400;
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: flex-start; }
  .book-bistrot-btns .btn {
    padding: 10px 20px;
    position: relative;
    color: #142e52; }
  .book-bistrot-btns .btn:hover, .book-bistrot-btns .btn:focus {
    color: #fff; }
    .book-bistrot-btns .btn:hover .open-icon, .book-bistrot-btns .btn:focus .open-icon {
      background: #142e52; }
    .book-bistrot-btns .btn:hover svg, .book-bistrot-btns .btn:focus svg {
      fill: #fff; }
  .book-bistrot-btns .btn.btn-orange .open-icon {
    background: #f7ab59; }
    .book-bistrot-btns .btn.btn-orange:hover .open-icon, .book-bistrot-btns .btn.btn-orange:focus .open-icon {
      background: #142e52; }

.open-icon {
  padding: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100%;
  width: 30px;
  height: 30px;
  position: absolute;
  left: calc(100% - 15px);
  bottom: calc(100% - 15px);
  background: #fee834; }
  .open-icon svg {
    fill: #142e52;
    transform: rotate(180deg); }

.full-img {
  height: 490px; }

.picto {
  display: none;
  position: absolute;
  bottom: 100%; }
  .picto img {
    width: 60px;
    object-fit: contain;
    animation: tilt-n-move-shaking 2s infinite; }
  .picto.picto-right {
    right: 0; }
  .picto.picto-left {
    left: 0; }
  .picto.picto-center {
    bottom: auto;
    top: 20px;
    right: 50px; }
  .picto.picto-center img {
    width: 80px; }

.min-340 img {
  height: 340px;
  object-fit: cover; }

.min-605 img {
  height: 605px;
  object-fit: cover; }

@media all and (min-width: 768px) {
  .picto {
    display: block; } }

@keyframes tilt-n-move-shaking {
  0% {
    transform: translate(0, 0) rotate(0deg); }

  25% {
    transform: translate(5px, 5px) rotate(5deg); }

  50% {
    transform: translate(0, 0) rotate(0eg); }

  75% {
    transform: translate(-5px, 5px) rotate(-5deg); }

  100% {
    transform: translate(0, 0) rotate(0deg); } }

.header {
  z-index: 500;
  position: fixed;
  width: 100%;
  min-height: 133px;
  left: 0;
  top: 0;
  background: #fff;
  box-shadow: rgba(0, 0, 0, 0.15) 0 0 6px; }

.header-content {
  display: grid;
  grid-template-columns: 1fr max-content 1fr;
  padding: 15px 0 0; }
  .header-content > div {
    flex-basis: 210px; }
  .header-content > div:first-child {
    flex-basis: 155px;
    display: flex;
    align-items: center;
    padding-left: 20px; }
  .header-content > div:nth-child(2) {
    flex-basis: calc(100% - 550px);
    display: flex;
    justify-content: center;
    padding-right: 20px; }

.header-buttons {
  justify-content: flex-end;
  width: 100%;
  display: flex;
  gap: 16px;
  /*.btn-menu {
	outline: none;
	display: flex;
	align-items: center;
	width: 100%;
	height: 100%;
	color: $green;
	font-size: 1.1rem;
	font-family: $fontAlt;

	&:hover, &:focus {
		.btn-menu-icon {
			&:after {
				width: 29px;
				left: 16px;
				transition: width .3s, left .3s, top .3s, transform .3s;
			}
		}
	}

	&.active {
		.btn-menu-icon {
			&:before {
				top: 50%;
				transform: rotate(-45deg);
				transition: all .3s;
			}

			span {
				opacity: 0;
				transition: all .3s;
			}

			&:after {
				width: 29px;
				left: 16px;
				top: 50%;
				transform: rotate(45deg);
				transition: all .3s;
			}
		}
	}
}

.btn-menu-icon {
	position: relative;
	width: 58px;
	height: 62px;
	margin: 0 20px 0 0;
	background: $green;

	&:before {
		content: '';
		position: absolute;
		width: 29px;
		height: 2px;
		left: 16px;
		top: 23px;
		background: $light;
		transition: all .3s;
	}

	span {
		position: absolute;
		width: 29px;
		height: 2px;
		left: 16px;
		top: 31px;
		background: $light;
		transition: all .3s;
	}

	&:after {
		content: '';
		position: absolute;
		width: 20px;
		height: 2px;
		left: 25px;
		top: 39px;
		background: $light;
		transition: all .3s;
	}
}*/ }

.logo {
  display: flex;
  align-items: center;
  height: 100%; }
  .logo img {
    width: 580px;
    height: 50px; }

.menu-contact {
  z-index: 200;
  position: fixed;
  right: 0;
  top: 140px; }
  .menu-contact li {
    position: relative;
    display: block;
    margin: 0 0 5px; }

.menu-contact-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 42px;
  height: 42px;
  background: #fff;
  box-shadow: rgba(0, 0, 0, 0.5) 0 0 3px; }
  .menu-contact-btn svg {
    width: 21px;
    height: 21px;
    fill: #142e52;
    transition: transform 0.3s, fill 0.3s; }
  .menu-contact-btn:hover svg, .menu-contact-btn:focus svg {
    fill: #f7ab59;
    transform: scale(1.2);
    transition: transform 0.3s, fill 0.3s; }

.btn-faq svg {
  width: 26px;
  height: 26px; }
  .btn-faq:hover .faq, .btn-faq:focus .faq {
    display: block; }

.btn-mail:hover .mailbox, .btn-mail:focus .mailbox {
  display: block; }

.faq, .mailbox {
  z-index: 201;
  position: absolute;
  display: none;
  width: 230px;
  padding: 0 4px 0 0;
  right: 42px;
  top: 0; }
  .faq > div, .mailbox > div {
    padding: 12px;
    background: #fff; }

.faq-intro, .mailbox-intro {
  font-size: 0.8rem;
  text-align: center; }
  .faq-intro strong, .mailbox-intro strong {
    font-size: 1.1rem;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    line-height: 1.5em; }
  .faq-intro em, .mailbox-intro em {
    color: #87cdc8;
    font-size: 2.5rem;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    line-height: 1.5em; }

.form-callback {
  padding: 12px;
  background: #f6f4f3; }
  .form-callback label {
    display: block;
    margin: 0 0 0.5em; }
  .form-callback input, .form-callback textarea {
    display: block;
    width: 100%;
    padding: 0.5em 0.3em;
    font-family: inherit;
    font-size: 0.8rem;
    font-weight: bold;
    font-style: italic;
    text-align: center;
    background: transparent;
    border: #000 solid 1px;
    transition: background 0.2s; }
  .form-callback input:focus, .form-callback textarea:focus {
    background: #fff;
    transition: background 0.2s; }

.form-callback-title {
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  text-align: center;
  text-transform: uppercase; }
  .form-callback-title strong {
    font-size: 1.2rem; }

#recaptcha-2, #recaptcha-3 {
  transform-origin: 0 0;
  transform: scale(0.55); }

.btn-gift {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  padding: 5px 24px;
  color: #000;
  font-size: 1.1rem;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  text-align: center;
  background: #fae85d;
  transition: opacity 0.2s; }

.btn-book {
  width: 210px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  padding: 5px;
  color: #000;
  font-size: 1.1rem;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  text-align: center;
  background: #87cdc8;
  transition: opacity 0.2s;
  /* menu */ }
  .btn-book.w-auto {
    width: auto; }
  .btn-book svg {
    margin: 0 10px;
    width: 16px;
    height: 16px;
    fill: #000; }
  .btn-book span {
    position: relative;
    flex-basis: calc(100% - 16px); }
  .btn-book span span:last-child {
    display: none; }
  .btn-book:hover, .btn-book:focus {
    opacity: 0.7;
    transition: opacity 0.2s; }
  .btn-book:hover > span:before, .btn-book:focus > span:before {
    transform: scaleX(0);
    transition: transform 0.4s cubic-bezier(0.6, 0.04, 0.98, 0.335); }
  .btn-book:hover span span:first-child, .btn-book:focus span span:first-child {
    display: none; }
    .btn-book:hover span span:last-child, .btn-book:focus span span:last-child {
      display: block; }

.menu-container {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 17px 32px 12px; }

.opening {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 102px;
  height: 102px;
  left: 10px;
  top: -50px;
  padding: 5px;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  text-align: center;
  background: #fee834;
  border-radius: 50%; }

.trip-certificat {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  left: 10px;
  top: -50px;
  padding: 5px; }
  .trip-certificat a {
    display: block;
    height: 102px;
    width: 102px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: #fae85c; }
  .trip-certificat img {
    width: 95px;
    transition: all 0.3s ease-in-out; }
  .trip-certificat:hover img {
    transform: scale(1.2); }

.menu {
  display: flex;
  justify-content: center;
  font-size: 1.1rem;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  text-transform: uppercase;
  /* newsletter */ }
  .menu li {
    padding: 0 20px; }
  .menu a {
    display: block;
    padding: 0.25em 0;
    color: #000;
    transition: color 0.2s; }
  .menu a:after {
    content: '';
    display: block;
    width: 90%;
    height: 3px;
    margin: 5px auto 0;
    background: #87cdc8;
    transform-origin: 50% 0;
    transform: scaleX(0);
    transition: transform 0.2s; }
  .menu a:hover:after, .menu a:focus:after, .menu a.active:after {
    transform: scaleX(1);
    transition: transform 0.2s; }

.form-newsletter input {
  width: 180px;
  padding: 0.3em;
  margin: 0 15px 0 0;
  font-size: 1rem;
  font-family: inherit;
  border: #142e52 solid 1px;
  transition: background 0.2s; }
  .form-newsletter input:focus {
    background: #e6e6e6;
    transition: background 0.2s; }

.newsletter-form-title {
  display: block;
  margin: 0 0 0.7em;
  color: #000;
  font-size: 1.2rem;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  text-transform: uppercase; }

.form-newsletter-content {
  display: flex;
  justify-content: space-between; }

.small-form-success {
  display: none;
  padding: 0.5em 1em;
  margin: 1em 0 0;
  color: #fff;
  font-size: 0.85rem;
  text-align: center;
  background: #f7ab59; }
  .small-form-success p:last-child {
    margin-bottom: 0; }

.btn-book-meeting {
  z-index: 200;
  position: fixed;
  width: 250px;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.3em 5px;
  color: #000;
  font-size: 1rem;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  text-align: center;
  background: #87cdc8;
  transition: opacity 0.2s; }
  .btn-book-meeting svg {
    margin: 0 10px;
    width: 16px;
    height: 16px;
    fill: #000; }
  .btn-book-meeting span {
    position: relative;
    flex-basis: calc(100% - 16px); }
  .btn-book-meeting span span:last-child {
    display: none; }
  .btn-book-meeting:hover, .btn-book-meeting:focus {
    opacity: 0.7;
    transition: opacity 0.2s; }
  .btn-book-meeting:hover span span:first-child, .btn-book-meeting:focus span span:first-child {
    display: none; }
    .btn-book-meeting:hover span span:last-child, .btn-book-meeting:focus span span:last-child {
      display: block; }

.btn-book-meeting-new {
  display: none; }

.no-meeting .btn-book-meeting {
  display: none; }

.menu-langs-header {
  font-family: 'PoliceStudioVedette', Arial, sans-serif; }
  .menu-langs-header ul {
    display: flex;
    align-items: center; }
  .menu-langs-header a {
    color: #000; }
  .menu-langs-header a:hover, .menu-langs-header a:focus {
    text-decoration: underline; }
  .menu-langs-header span.active {
    color: #000;
    text-decoration: underline; }

.gds {
  padding-top: 10px;
  font-size: 14px; }
  .gds span {
    display: block;
    line-height: 28px; }

.footer {
  padding: 35px 0;
  color: #808080;
  background: #f6f4f3; }
  .footer a {
    color: #808080;
    transition: color 0.2s; }
  .footer a:hover, .footer a:focus {
    color: #000;
    transition: color 0.2s; }

.footer-content {
  max-width: 1370px;
  margin: 0 auto;
  padding: 0 62px; }

.footer-socials {
  padding-top: 1em; }
  .footer-socials ul {
    display: flex;
    align-items: center;
    gap: 10px; }
  .footer-socials ul a {
    display: flex;
    justify-content: center;
    align-items: center; }
    .footer-socials ul a svg {
      width: 28px;
      height: 28px;
      fill: #142e52;
      transition: transform 0.3s, fill 0.3s; }
    .footer-socials ul a:hover svg, .footer-socials ul a:focus svg {
      fill: #f7ab59;
      transform: scale(1.2);
      transition: transform 0.3s, fill 0.3s; }

.footer-logo img {
  display: block;
  width: 230px;
  height: 192px; }

.menu-langs {
  margin-bottom: 1em;
  font-family: 'PoliceStudioVedette', Arial, sans-serif; }
  .menu-langs li {
    display: inline-block; }
  .menu-langs li:not(:last-child):after {
    content: ' / '; }
  .menu-langs a {
    color: #000; }
  .menu-langs a:hover, .menu-langs a:focus, .menu-langs a.active {
    text-decoration: underline; }

.footer-top {
  display: flex;
  justify-content: space-between;
  padding: 0 0 30px;
  border-bottom: #b3b3b3 solid 1px; }
  .footer-top > div {
    flex-basis: 33.3%;
    padding: 0 50px;
    border-right: #b3b3b3 solid 1px; }
  .footer-top > div:first-child {
    padding-left: 0; }
  .footer-top > div:last-child {
    padding-right: 0;
    border-right: none; }

.footer-title {
  margin: 0 0 0.5em;
  color: #000;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-size: 1.2rem; }

.form-newsletter-footer {
  margin-bottom: 2em; }
  .form-newsletter-footer input {
    background-color: transparent; }
  .form-newsletter-footer input:focus {
    background: #fff; }

.org {
  display: block;
  margin-bottom: 0.5em;
  color: #000;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-size: 1rem; }

.footer-address {
  display: flex;
  margin: 0.25em 0;
  font-size: 0.85rem; }
  .footer-address > div:first-child {
    flex-basis: 30px; }
  .footer-address > div:last-child {
    flex-basis: calc(100% - 30px); }
  .footer-address svg {
    width: 12px;
    height: 18px;
    fill: #808080; }

.menu-footer {
  font-size: 0.95rem;
  line-height: 1.5em; }

.btn-modify-booking {
  display: block;
  margin-top: 1.5em;
  font-size: 0.95rem; }
  .btn-modify-booking span {
    text-decoration: underline; }

.copyright {
  margin: 1em 0 0;
  font-size: 0.85rem;
  text-align: center; }

.logo-paris-love {
  display: block;
  margin: 20px auto 0; }

.home-plan {
  overflow: hidden;
  position: relative;
  height: 797px; }

.home-plan-img {
  position: absolute;
  max-width: 100%;
  height: auto;
  right: 0;
  top: 0;
  /*.home-plan-img-2, .home-plan-img-4, .home-plan-img-5 {
	opacity: 0;
	transition: .2s;

	&.active {
		opacity: 1;
		transition: .7s;
	}
}

.home-plan-img-3 {
	transform: translateY(230px);
}*/ }

.home-plan-text {
  position: absolute;
  width: 415px;
  left: -20px;
  top: -20px;
  padding: 20px;
  text-align: left;
  background: rgba(255, 255, 255, .9); }

.home-menu {
  display: flex;
  justify-content: space-between;
  height: 560px; }
  .home-menu > div {
    flex-basis: calc(33% - 16px); }

.home-menu-btn {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  font-family: 'LeGrandQuartierHotel', Arial, sans-serif;
  font-size: 4rem;
  text-shadow: rgba(0, 0, 0, 0.8) 0 0 10px;
  line-height: 1em;
  background-size: cover;
  background-position: center;
  text-align: center; }
  .home-menu-btn:hover div, .home-menu-btn:focus div {
    opacity: 1;
    transition: opacity 0.2s; }
  .home-menu-btn div {
    opacity: 0;
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.75);
    transition: opacity 0.2s; }
  .home-menu-btn span {
    position: relative;
    color: #fff; }
  .home-menu-btn span:after {
    content: '+';
    display: block;
    text-align: center; }

.home-menu-btn-half {
  height: calc(50% - 16px); }
  .home-menu-btn-half:first-child {
    margin-bottom: 32px; }

.home-menu-btn-shop {
  font-family: 'LeGrandQuartierShop', Arial, sans-serif; }

.home-menu-btn-studio {
  font-family: 'LeGrandQuartierStudio', Arial, sans-serif; }

.home-menu-btn-cafe {
  font-family: 'LeGrandQuartierCafe', Arial, sans-serif; }

.home-offers {
  display: flex;
  justify-content: space-between; }

.home-offer {
  position: relative;
  overflow: hidden;
  flex-basis: calc(25% - 16px); }
  .home-offer span {
    position: absolute;
    display: flex;
    height: 100%;
    width: 100%;
    padding: 12px;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    line-height: 1.5;
    font-weight: 700;
    text-align: center;
    color: #fff;
    text-shadow: 2px 2px 3px #000;
    z-index: 2; }
  .home-offer img {
    display: block;
    width: 100%;
    height: auto;
    transition: transform 0.3s; }
  .home-offer:hover img, .home-offer:focus img {
    transform: scale(1.2);
    transition: transform 0.3s; }

.home-post {
  display: flex;
  justify-content: space-between; }
  .home-post h2 {
    margin: 0 0 0.2em;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 2.2rem;
    line-height: 1em; }
  .home-post h3 {
    margin: 0 0 1em;
    color: #808080;
    font-family: 'Roboto', Arial, sans-serif;
    font-size: 1.3rem;
    font-weight: 300;
    font-style: italic; }

.home-post-btns {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 2em 0 0; }

.home-post-1 {
  flex-direction: row-reverse;
  align-items: center; }
  .home-post-1 > div:first-child {
    flex-basis: calc(60% - 27px); }
  .home-post-1 > div:last-child {
    flex-basis: calc(40% - 27px);
    padding: 40px 0 40px 40px; }
  .home-post-1 > div img {
    display: block;
    width: 100%;
    height: auto; }
  .home-post-1 h3 {
    color: #f08372; }

.home-post-2 {
  margin-top: 3em; }
  .home-post-2 > div {
    flex-basis: calc(50% - 27px); }
  .home-post-2 > div:first-child img {
    display: block;
    width: 100%;
    height: auto; }
  .home-post-2 > div:last-child {
    padding: 40px; }
  .home-post-2 h3 {
    color: #f7ab59; }

.home-post-3 {
  flex-direction: row-reverse;
  margin-top: -190px; }
  .home-post-3 > div {
    flex-basis: calc(50% - 27px); }
  .home-post-3 > div:first-child img {
    display: block;
    width: 100%;
    height: auto; }
  .home-post-3 > div:last-child {
    align-self: flex-end;
    padding: 40px; }
  .home-post-3 h3 {
    color: #87cdc8; }

.home-post-date {
  position: absolute;
  right: -55px;
  top: 85px;
  padding: 15px 45px;
  color: #000;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-size: 1.4rem;
  text-align: center;
  background: #f7ab59; }
  .home-post-date strong {
    color: #fff;
    font-size: 4rem;
    line-height: 0.9em; }

.h1-hotel {
  margin-bottom: 0.8em;
  font-size: 4rem;
  font-family: 'LeGrandQuartierHotel', Arial, sans-serif;
  font-weight: normal;
  text-align: center; }

.hotel-intro {
  padding-top: 100px;
  padding-bottom: 100px; }
  .hotel-intro h2 {
    max-width: 235px;
    padding-left: 40px;
    margin-right: 120px;
    font-size: 3rem;
    line-height: 1.3em; }

.hotel-intro-steps {
  display: flex;
  margin-bottom: 3em; }

.room {
  display: flex;
  align-items: stretch;
  margin-bottom: 40px; }
  .room h2 em {
    color: #87cdc8; }
  .room:nth-child(even) {
    flex-direction: row-reverse; }
  .room:nth-child(even) .room-services {
    justify-content: flex-start; }
  .room:nth-child(2n) h2 em {
    color: #f7ab59; }
  .room:nth-child(2n) .slideshow-prev svg, .room:nth-child(2n) .slideshow-next svg {
    fill: #f7ab59; }
  .room:nth-child(3n) h2 em {
    color: #468bce; }
  .room:nth-child(3n) .slideshow-prev svg, .room:nth-child(3n) .slideshow-next svg {
    fill: #468bce; }
  .room:nth-child(4n) h2 em {
    color: #f08372; }
  .room:nth-child(4n) .slideshow-prev svg, .room:nth-child(4n) .slideshow-next svg {
    fill: #f08372; }

.room-gallery {
  flex-basis: 66.6%; }

.room-text {
  flex-basis: 33.3%;
  padding: 60px 60px 0; }

.room-services {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-end;
  margin: 2em 0 0;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-size: 0.85rem;
  text-align: center; }

.room-services-item {
  flex-basis: 90px;
  margin-bottom: 1.5em; }
  .room-services-item div {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 70px; }
  .room-services-item img {
    display: block;
    width: 46px;
    height: auto;
    margin: 0 auto 1em; }

.room-gallery .cycle-slideshow {
  height: 100%; }

div.last-room-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 40px; }
  div.last-room-top > div {
    flex-basis: calc(33.3% - 30px); }
  div.last-room-top img {
    display: block;
    width: 100%;
    height: auto; }
  div.last-room-top h2 em {
    color: #87cdc8; }

.last-room-bottom {
  display: flex;
  justify-content: space-between;
  align-items: stretch; }
  .last-room-bottom > div:first-child {
    flex-basis: 33.33%;
    padding: 60px; }
  .last-room-bottom > div:last-child {
    flex-basis: 66.66%; }
  .last-room-bottom h2 em {
    color: #87cdc8; }

.h1-cafe {
  margin-bottom: 0.8em;
  font-size: 4rem;
  font-family: 'LeGrandQuartierCafe', Arial, sans-serif;
  font-weight: normal;
  text-align: center; }

.cafe-chill {
  position: relative;
  height: 695px; }
  .cafe-chill img {
    position: absolute; }
  .cafe-chill img:nth-child(1) {
    left: 0;
    top: 165px; }
  .cafe-chill img:nth-child(2) {
    left: 440px;
    top: 0; }
  .cafe-chill img:nth-child(3) {
    left: 665px;
    top: 50px; }
  .cafe-chill img:nth-child(4) {
    left: 90px;
    top: 455px; }
  .cafe-chill img:nth-child(5) {
    left: 312px;
    top: 455px; }
  .cafe-chill img:nth-child(6) {
    left: 588px;
    top: 455px; }
  .cafe-chill img:nth-child(7) {
    left: 810px;
    top: 341px; }

.cafe-chill-text1 {
  position: absolute;
  width: 415px;
  left: 0;
  top: 0;
  font-size: 0.95rem;
  line-height: 1.4em; }

.cafe-chill-text2 {
  position: absolute;
  width: 345px;
  left: 440px;
  top: 350px; }

.cafe-chill-text3 {
  position: absolute;
  width: 535px;
  left: 600px;
  top: 635px;
  font-size: 0.95rem;
  line-height: 1.4em; }

.btn-file {
  margin: 5px 5px; }

.fake-anchor {
  position: absolute;
  top: 0;
  left: 0; }

body._cafe #section3 img {
  margin: 0 0 0 auto; }

.h1-studio {
  margin-bottom: 0.8em;
  font-size: 4rem;
  font-family: 'LeGrandQuartierStudio', Arial, sans-serif;
  font-weight: normal;
  text-align: center; }

.studios-steps {
  padding-top: 40px;
  padding-bottom: 40px; }

.studio {
  position: relative;
  height: 320px;
  margin-bottom: 25px;
  background-position: center;
  background-size: cover; }
  .studio:hover .studio-title, .studio:focus .studio-title, .studio.active .studio-title {
    opacity: 0;
    transition: opacity 0.3s; }
  .studio:hover .studio-content, .studio:focus .studio-content, .studio.active .studio-content {
    opacity: 1;
    transition: opacity 0.3s; }

.studio-big {
  height: 405px; }
  .studio-big .studio-details, .studio-big .studio-btns {
    margin-top: 2em; }

.studio-title {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  transition: opacity 0.3s; }
  .studio-title > div {
    display: flex;
    padding: 0.5em 1em;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 1.3rem;
    background: #fff; }
  .studio-title p {
    margin-bottom: 0; }
  .studio-title span {
    color: #f7ab59;
    font-family: 'Roboto', Arial, sans-serif;
    font-weight: bold;
    margin-left: 5px; }

.studio-content {
  opacity: 0;
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  left: 35px;
  right: 35px;
  top: 20px;
  bottom: 20px;
  padding: 35px;
  background: #fff;
  transition: opacity 0.3s; }
  .studio-content h2 {
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 1.2rem;
    text-align: center; }
  .studio-content h2 strong {
    color: #f7ab59; }

.studio-details {
  display: flex;
  justify-content: space-between;
  margin-top: 0.5em; }

.studio-detail {
  margin: 0 20px;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  text-align: center; }
  .studio-detail strong {
    color: #f7ab59;
    font-size: 2rem; }

.studio-btns {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 0.5em; }
  .studio-btns a {
    margin: 0 10px; }

.offer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 90px; }
  .offer:nth-child(even) {
    flex-direction: row-reverse; }
  .offer:nth-child(even) .offer-logo {
    left: -160px;
    right: auto; }
  .offer:nth-child(even) .offer-text {
    justify-content: flex-start; }
  .offer .btn span {
    display: block;
    transition: transform 0.2s; }
  .offer .btn:hover span, .offer .btn:focus span {
    transform: scale(1.15);
    transition: transform 0.2s; }
  .offer:nth-child(4n - 3) .btn {
    background: #87cdc8; }
  .offer:nth-child(4n - 2) .btn {
    background: #f7ab59; }
  .offer:nth-child(4n - 1) .btn {
    background: #468bce; }
  .offer:nth-child(4n) .btn {
    background: #f08372; }

.offer-img {
  position: relative;
  flex-basis: calc(60% - 15px); }

.offer-logo {
  position: absolute;
  width: 294px;
  height: 294px;
  right: -160px;
  top: 160px; }

.offer-text {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-basis: calc(40% - 15px); }
  .offer-text .text {
    width: 290px; }

.ariane {
  font-size: 0.9rem; }
  .ariane ul {
    display: flex;
    justify-content: center; }
  .ariane li:not(:last-child):after {
    content: '›';
    display: inline-block;
    margin: 0 0.3em 0 0; }
  .ariane a {
    color: #000; }
  .ariane a:hover, .ariane a:focus {
    color: #f08372;
    text-decoration: underline; }

.menu-categories {
  margin: 2em 0;
  font-family: 'PoliceStudioVedette', Arial, sans-serif; }
  .menu-categories ul {
    display: flex;
    justify-content: center; }
  .menu-categories li {
    margin: 0 15px; }
  .menu-categories a, .menu-categories button {
    display: block;
    padding: 0.5em 1em;
    color: #000;
    transition: color 0.2s, background 0.2s; }
  .menu-categories a:hover, .menu-categories button:hover, .menu-categories a:focus, .menu-categories button:focus, .menu-categories a.active, .menu-categories button.active {
    color: #fff;
    background: #f7ab59;
    transition: color 0.2s, background 0.2s; }

.post {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 55px; }

.post-event {
  flex-direction: row-reverse; }
  .post-event .post-content-text {
    padding-right: 85px; }
  .post-event:last-child .post-rate {
    color: #87cdc8; }
  .post-event:last-child .btn-calendar svg {
    fill: #87cdc8; }
  .post-event:last-child .post-event-date {
    background: #87cdc8; }
  .post-event:last-child .btn {
    background: #87cdc8; }

.post-img {
  position: relative;
  flex-basis: calc(50% - 8px); }

.post-content {
  flex-basis: calc(50% - 8px); }
  .post-content h2 {
    margin: 0;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 1.8rem; }
  .post-content h2 a {
    color: inherit; }

.post-rate {
  margin-bottom: 2em;
  color: #f7ab59;
  font-size: 1.4rem;
  font-weight: 300;
  font-style: italic; }

.post-date {
  margin: 2em 0;
  color: #808080;
  font-weight: 300;
  font-style: italic; }
  .post-date a {
    color: inherit;
    text-decoration: underline; }
  .post-date a:hover, .post-date a:focus {
    color: #000;
    text-decoration: none; }

.post-event-btns {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 2em 0; }

.btn-calendar {
  color: #000;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-size: 1.2rem; }
  .btn-calendar svg {
    width: 19px;
    height: 19px;
    margin: 0 0 0 5px;
    fill: #f7ab59;
    transition: transform 0.2s; }
  .btn-calendar:hover svg, .btn-calendar:focus svg {
    transform: scale(1.2);
    transition: transform 0.2s; }

.btn-calendar-proto {
  display: none; }

.add-to-calendar a {
  display: block;
  margin: 3px 0;
  color: #000;
  font-family: 'Roboto', Arial, sans-serif;
  font-size: 1rem; }

.add-to-calendar-checkbox {
  cursor: pointer; }

.add-to-calendar-checkbox ~ a::before {
  vertical-align: middle; }

.post-event-date {
  position: absolute;
  width: 155px;
  left: -77px;
  top: 190px;
  padding: 15px 45px;
  color: #000;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-size: 1.1rem;
  text-align: center;
  background: #f7ab59; }
  .post-event-date strong {
    color: #fff;
    font-size: 4rem;
    line-height: 0.9em; }

.blog-paginator {
  margin-top: 2em; }
  .blog-paginator ul {
    display: flex;
    justify-content: center; }
  .blog-paginator li {
    margin: 0 2px; }
  .blog-paginator a {
    display: block;
    padding: 0.3em 0.7em 0.2em;
    color: #000;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    border: transparent solid 3px;
    transition: border 0.2s; }
  .blog-paginator a:hover, .blog-paginator a:focus, .blog-paginator a.active {
    border: #87cdc8 solid 3px;
    transition: border 0.2s; }

.single-post {
  max-width: 800px;
  margin: 2em auto; }

.single-post-h1 {
  margin: 0 0 0.3em; }

.single-post-date {
  margin: 0 0 1.5em; }

.single-post-img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 0 auto 2em; }

.gallery-video {
  width: 100%; }

.grid-sizer {
  width: calc(33% - 5px); }

.gallery-item {
  position: relative;
  width: calc(33% - 5px);
  height: 270px;
  margin-bottom: 10px;
  background-position: center;
  background-size: cover; }
  .gallery-item div {
    opacity: 0;
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background: rgba(255, 255, 255, 0.8);
    transition: opacity 0.2s; }
  .gallery-item svg {
    width: 64px;
    height: 64px;
    fill: #f7ab59; }
  .gallery-item:hover div, .gallery-item:focus div {
    opacity: 1;
    transition: opacity 0.2s; }
  .gallery-item:nth-child(8n - 5) {
    height: 550px; }
  .gallery-item:nth-child(8n - 2) {
    width: 66%;
    height: 550px; }

.press {
  display: flex;
  flex-flow: row wrap;
  justify-content: center; }

.press-item {
  position: relative;
  margin-bottom: 28px; }
  .press-item:hover .press-item-overlay, .press-item:focus .press-item-overlay {
    opacity: 1;
    transition: opacity 0.2s; }

.press-item-overlay {
  opacity: 0;
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  text-align: center;
  background: rgba(255, 255, 255, 0.85);
  transition: opacity 0.2s; }
  .press-item-overlay strong {
    display: block;
    margin: 0 0 0.5em;
    color: #87cdc8;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 1.5rem; }
  .press-item-overlay span {
    display: block;
    margin: 0 0 2em;
    color: #000;
    font-size: 1.1rem; }
  .press-item-overlay svg {
    width: 40px;
    height: 40px;
    fill: #87cdc8; }

.community {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  margin-top: 3em; }

.community-item {
  margin: 0 50px 3em;
  text-align: center; }
  .community-item img {
    display: block;
    margin: 0 auto 1em; }
  .community-item strong {
    display: block;
    margin-bottom: 0.4em;
    color: #87cdc8;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 1.4rem; }
  .community-item:nth-child(2n) strong {
    color: #f7ab59; }
  .community-item:nth-child(3n) strong {
    color: #468bce; }
  .community-item:nth-child(4n) strong {
    color: #f08372; }

.intro-jobs h2 {
  color: #f7ab59;
  font-weight: 300; }

.jobs {
  display: flex;
  margin-top: 3em; }

.jobs-content {
  flex-basis: 75%; }

.jobs-sizer {
  width: calc(33% - 10px); }

.job-item {
  position: relative;
  width: calc(33% - 10px);
  margin-bottom: 10px;
  background-position: center;
  background-size: cover; }
  .job-item:nth-child(2) {
    width: calc(66% - 10px);
    height: 405px; }
  .job-item:nth-child(3) {
    height: 285px; }
  .job-item:nth-child(4) {
    height: 205px; }
  .job-item:nth-child(5) {
    height: 525px; }
  .job-item:nth-child(6) {
    height: 285px; }
  .job-item:nth-child(7) {
    height: 190px; }
  .job-item:nth-child(8) {
    width: calc(66% - 10px);
    height: 335px; }
  .job-item:nth-child(9) {
    height: 370px; }
  .job-item:nth-child(10), .job-item:nth-child(11) {
    height: 265px; }

.job-text-white {
  display: flex;
  align-items: flex-end;
  padding: 15px;
  color: #fff;
  font-size: 1.3rem; }
  .job-text-white button {
    color: #fff;
    text-align: left;
    text-shadow: rgba(0, 0, 0, .4) 1px 1px 2px;
    transition: transform 0.2s; }

.job-text-black {
  display: flex;
  align-items: flex-end;
  padding: 15px;
  color: #000;
  font-size: 1.3rem; }
  .job-text-black span {
    text-transform: uppercase;
    transition: transform 0.2s; }
  .job-text-black:hover span, .job-text-black:focus span {
    transform: scale(1.2);
    transition: transform 0.2s; }

.job-job, .job-subjob {
  display: flex;
  align-items: flex-end;
  padding: 15px;
  color: #fff;
  font-size: 1.2rem; }
  .job-job .f, .job-subjob .f {
    width: 100%;
    align-items: center;
    color: #fff;
    text-align: left;
    text-shadow: rgba(0, 0, 0, .4) 1px 1px 2px; }
  .job-job .f div:first-child, .job-subjob .f div:first-child {
    flex-basis: 45px; }
  .job-job .f div:last-child, .job-subjob .f div:last-child {
    flex-basis: calc(100% - 45px); }
  .job-job .f:hover .icon-job-more, .job-subjob .f:hover .icon-job-more, .job-job .f:focus .icon-job-more, .job-subjob .f:focus .icon-job-more {
    transform: scale(1.2);
    transition: transform 0.2s; }

.icon-job-more {
  display: inline-block;
  width: 26px;
  height: 26px;
  margin: 0 5px 0 0;
  color: #f7ab59;
  font-size: 22px;
  font-weight: bold;
  text-align: center;
  background: #fff;
  border-radius: 50%;
  text-shadow: none;
  transition: transform 0.2s; }

.job-latest {
  padding: 25px 20px;
  box-shadow: rgba(0, 0, 0, .2) 1px 1px 5px; }
  .job-latest h3 {
    margin: 0 0 1em;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 1.7rem; }

.job-text-green, .job-text-red {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 15px;
  color: #fff;
  font-family: 'LeGrandQuartierHotel', Arial, sans-serif;
  text-align: center;
  background: #87cdc8; }

.job-text-green {
  font-size: 1.5rem; }

.job-text-red {
  font-size: 2rem;
  background: #f08372; }

.subjob {
  display: block;
  padding-bottom: 0.5em;
  color: #87cdc8;
  line-height: 1.7em;
  text-decoration: none;
  border-bottom: #808080 solid 1px; }
  .subjob strong {
    color: #000;
    font-weight: normal; }

.jobs-about {
  flex-basis: 25%;
  padding-left: 40px; }

.job-content {
  z-index: 200;
  display: none;
  position: absolute;
  right: 0;
  top: 0;
  width: 600px; }
  .job-content img {
    display: block;
    width: 100%;
    height: auto;
    margin: 0 0 5px; }
  .job-content .text {
    padding: 25px 40px;
    color: #000;
    background: rgba(255, 255, 255, 0.95); }
  .job-content h2, .job-content h3 {
    margin: 0 0 1em;
    color: #f08372;
    font-weight: 300; }

.job-content-img {
  position: relative; }

.job-bottom .job-content {
  top: auto;
  bottom: 0; }

.job-content-close {
  position: absolute;
  display: flex;
  width: 100%;
  align-items: center;
  left: 30px;
  right: 30px;
  bottom: 30px;
  color: #fff;
  font-size: 1.3rem;
  text-align: center; }
  .job-content-close div:first-child {
    flex-basis: 30px; }
  .job-content-close div:last-child {
    flex-basis: calc(100% - 30px); }
  .job-content-close:hover .icon-job-more, .job-content-close:focus .icon-job-more {
    transform: scale(1.2);
    transition: transform 0.2s; }

.job-open:hover .icon-job-more, .job-open:focus .icon-job-more {
  transform: scale(1.2);
  transition: transform 0.2s; }

#map {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background: #e5e3df; }

.map-overlay {
  position: absolute;
  width: 375px;
  padding: 20px;
  right: 80px;
  bottom: 100px;
  background: #fff; }
  .map-overlay strong {
    display: block;
    margin: 0 0 2em;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 1.3rem;
    text-align: center; }

.map-item {
  display: flex;
  margin: 0 0 2em; }
  .map-item > div:first-child {
    flex-basis: 45px; }
  .map-item > div:last-child {
    flex-basis: calc(100% - 45px); }
  .map-item svg {
    width: 20px;
    height: 20px;
    fill: #87cdc8; }

.map-btns {
  display: flex;
  justify-content: space-between; }
  .map-btns .btn {
    max-width: 150px;
    text-align: center; }

div.location-text h2 em {
  color: #f7ab59; }

.come {
  display: flex;
  justify-content: space-between; }

.come-left, .come-right {
  flex-basis: calc(50% - 10px); }

.come-item {
  position: relative;
  height: 320px;
  margin-bottom: 20px;
  background-position: center;
  background-size: cover; }
  .come-item h3 {
    margin-bottom: 0.5em; }
  .come-item:hover .come-item-content, .come-item:focus .come-item-content, .come-item.active .come-item-content {
    opacity: 1;
    transition: opacity 0.3s; }

.come-item-high {
  height: 660px; }

.come-item-overlay {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0; }
  .come-item-overlay h3 {
    padding: 0.5em 1em;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 1.3rem;
    background: #fff; }
  .come-item-overlay strong {
    color: #f7ab59; }

.come-item-content {
  opacity: 0;
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px;
  left: 25px;
  right: 25px;
  top: 30px;
  bottom: 30px;
  text-align: center;
  background: #fff;
  transition: opacity 0.3s;
  /* contact */ }
  .come-item-content h3 {
    color: #f7ab59; }

::-webkit-input-placeholder {
  font-style: italic; }

::-moz-placeholder {
  font-style: italic; }

:-ms-input-placeholder {
  font-style: italic; }

.contact-form {
  max-width: 600px;
  margin: 0 auto; }
  .contact-form label {
    display: block;
    margin: 0 0 1.5em; }
  .contact-form input, .contact-form textarea {
    display: block;
    width: 100%;
    padding: 0.3em 0.5em;
    font-size: 1rem;
    font-family: inherit;
    border: #b3b3b3 solid 2px;
    transition: border-color 0.2s; }
  .contact-form input:focus, .contact-form textarea:focus {
    border-color: #333;
    transition: border-color 0.2s; }
  .contact-form textarea {
    min-height: 145px; }
  .contact-form .ajax-form-error {
    border-color: #f08372;
    transition: border-color 0.2s; }

.rgpd-msg {
  font-size: 0.8rem;
  font-style: italic; }

.form-error {
  display: none;
  margin: 5px 0 0;
  color: #f08372;
  font-size: 0.85rem; }

.ajax-form-error + .form-error {
  display: block; }

.recaptcha-wrap {
  text-align: center; }

#recaptcha-1 {
  margin-bottom: 1.5em; }

#recaptcha-1 > div {
  margin: 0 auto; }

.ajax-form-mail-sent {
  display: none;
  padding: 1em;
  margin: 1.5em 0 0;
  color: #fff;
  background: #87cdc8; }
  .ajax-form-mail-sent p:last-child {
    margin-bottom: 0; }

.svg-loader {
  width: 30px;
  height: 30px;
  fill: #f7ab59; }

.shop-date {
  position: absolute;
  left: calc(50% - 120px);
  bottom: -60px;
  width: 240px;
  padding: 15px;
  color: #000;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-size: 1.3rem;
  text-align: center;
  background: #87cdc8; }
  .shop-date span {
    display: block; }
  .shop-date strong {
    display: block;
    color: #fff;
    font-size: 3rem; }

.slideshow-shop-container {
  position: relative;
  padding: 0 60px; }

.slideshow-shop {
  margin: 3em 0 0; }
  .slideshow-shop div {
    padding: 0 20px; }
  .slideshow-shop img {
    display: block;
    width: 100%;
    height: auto; }

.shop-slideshow-prev, .shop-slideshow-next {
  position: absolute;
  top: 45%; }
  .shop-slideshow-prev svg, .shop-slideshow-next svg {
    width: 33px;
    height: 13px;
    fill: #87cdc8;
    transition: transform 0.3s; }

.shop-slideshow-prev {
  left: 0; }
  .shop-slideshow-prev:hover svg, .shop-slideshow-prev:focus svg {
    transform: translateX(-5px);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); }

.shop-slideshow-next {
  right: 0; }
  .shop-slideshow-next:hover svg, .shop-slideshow-next:focus svg {
    transform: translateX(5px);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); }

.journal {
  max-width: 980px;
  margin: 0 auto; }

.journal-item {
  display: flex;
  justify-content: space-between;
  align-items: center; }
  .journal-item:nth-child(even) {
    flex-direction: row-reverse; }
  .journal-item h2 {
    font-size: 1.6rem; }

.journal-img {
  flex-basis: calc(50% - 40px); }

.journal-text {
  flex-basis: calc(50% - 40px); }

.journal-date {
  margin: 2em 0 1.5em;
  color: #808080;
  font-weight: 300;
  font-style: italic; }

.page-text {
  max-width: 800px;
  margin: 0 auto; }

.menu-sitemap {
  text-align: center; }
  .menu-sitemap li {
    margin-bottom: 0.5em; }
  .menu-sitemap a {
    display: inline-block;
    color: #000;
    border-bottom: transparent solid 1px;
    transition: color 0.2s, border 0.2s; }
  .menu-sitemap a:hover, .menu-sitemap a:focus {
    color: #f7ab59;
    border-bottom: #f7ab59 solid 1px;
    transition: color 0.2s, border 0.2s; }

._city-guide, .city-guide-section {
  height: 100%; }

#cg {
  overflow: hidden;
  position: relative;
  height: 100%;
  background: #e5e3df; }

.city-guide-container {
  height: 100%; }

#cg-map {
  position: absolute;
  width: -webkit-calc(50% + 25px);
  width: calc(50% + 25px);
  height: 100%;
  left: -webkit-calc(50% - 25px);
  left: calc(50% - 25px);
  top: 0;
  transition: left 0.5s, width 0.5s; }
  #cg-map.is-fullscreen {
    width: 100%;
    left: 0;
    transition: left 0.5s, width 0.5s; }
  #cg-map.is-directions {
    width: -webkit-calc(60% - 325px);
    width: calc(60% - 325px);
    left: -webkit-calc(40% - 25px);
    left: calc(40% - 25px); }
  #cg-map.is-fullscreen.is-directions {
    width: -webkit-calc(100% - 350px);
    width: calc(100% - 350px);
    left: 0; }

#cg-sidebar {
  position: absolute;
  width: 50%;
  height: 100%;
  left: 0;
  top: 0;
  transition: width 0.5s; }
  #cg-sidebar.is-directions {
    width: 40%;
    transition: width 0.5s; }

#cg-sidebar-header {
  padding: 1.5em 1em 0.7em;
  background-color: #393939;
  text-transform: uppercase;
  position: relative; }
  #cg-sidebar-header h1 {
    margin-bottom: 0;
    color: #fff;
    font-size: 1.5em; }
  #cg-sidebar-header .cg-icon-navigation {
    display: inline-block;
    vertical-align: middle;
    margin-right: 5px; }
  #cg-sidebar-header .cg-icon-navigation * {
    fill: #fff; }
  #cg-sidebar-header img {
    position: absolute;
    top: 0;
    right: 0;
    height: 100%;
    opacity: 0.1; }

.cg-logo {
  width: 160px;
  height: 48px; }

#cg-sidebar-container {
  overflow: hidden;
  position: relative;
  width: -webkit-calc(100% - 25px);
  width: calc(100% - 25px);
  height: 100%;
  background: #f6f6f6;
  -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, .3);
  box-shadow: 0 0 10px rgba(0, 0, 0, .3); }

#cg-sidebar-content, #cg-sidebar-content-single {
  position: absolute;
  width: 100%;
  /*	h2 {
		padding: 0;
		margin: 0 0 1em;
		color: $color;
		font-size: 1.5em;
		font-weight: bold;
		text-align: center;
		text-transform: uppercase;
	}*/
  height: 100%;
  /*#cg-sidebar-content-single h2 {
	padding: 0 43px 0 0;
	margin-top: .5em;
}*/ }

#cg-button-toggle {
  cursor: pointer;
  position: absolute;
  width: 25px;
  height: 50px;
  padding: 0;
  right: 0;
  top: 70px;
  background: #fff;
  background: rgba(255, 255, 255, .9);
  border: none;
  -webkit-box-shadow: 0 0 7px rgba(0, 0, 0, .3);
  box-shadow: 0 0 7px rgba(0, 0, 0, .3); }
  #cg-button-toggle:after {
    content: '';
    position: absolute;
    width: 0;
    height: 0;
    left: -3px;
    top: 15px;
    border-style: solid;
    border-width: 10px;
    border-color: transparent #717374 transparent transparent; }
  #cg-button-toggle.is-closed:after {
    left: 7px;
    -webkit-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    -o-transform: rotate(180deg);
    transform: rotate(180deg); }

#cg-sidebar-filters {
  position: relative;
  overflow: visible;
  z-index: 1;
  background-color: #fff; }

#cg-filter-btns {
  padding: 20px;
  position: relative; }

#cg-filter-btns, #cg-categories {
  -webkit-box-shadow: 0px 6px 5px 0px rgba(0, 0, 0, 0.2);
  -moz-box-shadow: 0px 6px 5px 0px rgba(0, 0, 0, 0.2);
  box-shadow: 0px 6px 5px 0px rgba(0, 0, 0, 0.2); }

.cg-btn {
  padding: 5px 10px;
  display: inline-block;
  margin-right: 10px;
  border: 1px solid ;
  transition: color 0.2s, background-color 0.2s, fill 0.2s; }
  .cg-btn:hover {
    transition: color 0.2s, background-color 0.2s, fill 0.2s; }

#cg-toggle-filter, #cg-toggle-map {
  color: ;
  background-color: #fff; }
  #cg-toggle-filter svg *, #cg-toggle-map svg * {
    fill: ; }
  #cg-toggle-filter .cg-icon-close, #cg-toggle-map .cg-icon-close {
    display: none; }
  #cg-toggle-filter:hover, #cg-toggle-map:hover, #cg-toggle-filter.active, #cg-toggle-map.active {
    color: #fff;
    background-color: ; }
  #cg-toggle-filter:hover svg *, #cg-toggle-map:hover svg *, #cg-toggle-filter.active svg *, #cg-toggle-map.active svg * {
    fill: #fff; }
  #cg-toggle-filter.active .cg-icon-down, #cg-toggle-map.active .cg-icon-down {
    display: none; }
  #cg-toggle-filter.active .cg-icon-close, #cg-toggle-map.active .cg-icon-close {
    display: inline; }

#cg-toggle-map {
  display: none; }

#cg-toggle-favorites {
  color: #fff;
  background-color: ; }
  #cg-toggle-favorites svg * {
    fill: #fff; }
  #cg-toggle-favorites .cg-icon-close {
    display: none; }
  #cg-toggle-favorites:hover, #cg-toggle-favorites.active {
    color: ;
    background-color: #fff; }
  #cg-toggle-favorites:hover svg *, #cg-toggle-favorites.active svg * {
    fill: ; }
  #cg-toggle-favorites.active .cg-icon-favorites {
    display: none; }
  #cg-toggle-favorites.active .cg-icon-close {
    display: inline; }

#cg-categories {
  position: absolute;
  display: none;
  top: 100%;
  width: 100%;
  background-color: #fff;
  text-align: left; }

#cg-categories-close {
  display: none;
  position: absolute;
  right: 10px;
  top: 10px;
  cursor: pointer; }
  #cg-categories-close svg * {
    fill: #333; }

#cg-btn-categories {
  cursor: pointer;
  display: inline-block;
  vertical-align: top;
  padding: 0.4em 0.8em;
  color: #fff;
  font-size: 0.9em;
  font-family: inherit;
  text-transform: uppercase;
  background: ;
  border: none; }

.cg-lazy {
  background-image: none !important; }
  .cg-lazy * {
    background-image: none !important; }

.cg-cat-menu-icon {
  display: inline-block;
  vertical-align: middle;
  margin-bottom: 5px; }

.cg-cat-prototype {
  display: none; }

.cg-categories-separator {
  border-bottom: 1px solid ; }

.cg-cat-all {
  padding: 7px 3%;
  display: inline-block; }

.cg-cat-all span:after {
  content: '';
  border: 1px solid #0d4c51;
  border-radius: 2px;
  width: 13px;
  display: inline-block;
  height: 15px;
  vertical-align: middle;
  padding: 0 0 0 2px;
  line-height: 15px;
  margin-left: 5px; }

.cg-cat-all input:checked + span:after {
  content: '✔'; }

.cg-cat input, .cg-cat-all input {
  position: absolute;
  opacity: 0; }

#cg-categories-content {
  text-align: center;
  padding: 0 1% 2%; }

.cg-cat {
  cursor: pointer;
  display: block;
  padding: 5px;
  color: #333;
  font-size: 0.85em;
  font-weight: bold;
  display: inline-block;
  vertical-align: top;
  width: 20%;
  height: 100px;
  padding: 2%;
  min-width: 90px;
  border-radius: 5px;
  transition: border-color 0.2s;
  text-align: center;
  /*#cg-categories-content label{

	&:nth-of-type(1) > div{
		background-image:url('/res/img/city-guide/monuments-musees.jpg');
	}
	&:nth-of-type(2) > div{
		background-image:url('/res/img/city-guide/shopping.jpg');
	}
	&:nth-of-type(3) > div{
		background-image:url('/res/img/city-guide/restaurants-bars.jpg');
	}
	&:nth-of-type(4) > div{
		background-image:url('/res/img/city-guide/paris-by-night.jpg');
	}
	&:nth-of-type(5) > div{
		background-image:url('/res/img/city-guide/spectacles-loisirs.jpg');
	}
	&:nth-of-type(6) > div{
		background-image:url('/res/img/city-guide/spa-beaute.jpg');
	}
	&:nth-of-type(7) > div{
		background-image:url('/res/img/city-guide/parcs-jardins.jpg');
	}
	&:nth-of-type(8) > div{
		background-image:url('/res/img/city-guide/excursions-insolite.jpg');
	}
	&:nth-of-type(9) > div{
		background-image:url('/res/img/city-guide/vegetarien-vegan.jpg');
	}
}*/ }
  .cg-cat > div {
    padding: 10px;
    height: 73px;
    position: relative;
    background-repeat: no-repeat;
    background-position: center center;
    /*-webkit-box-shadow: inset 0px 0px 46px 0px rgba(140,140,140,1);
		-moz-box-shadow: inset 0px 0px 46px 0px rgba(140,140,140,1);
		box-shadow: inset 0px 0px 46px 0px rgba(140,140,140,1);*/
    background-size: cover;
    border-radius: 6%;
    overflow: hidden;
    /*input:not(:checked) + div:before {
		background-color: #efefef;
	}*/ }
  .cg-cat > div > div, .cg-cat > div:after {
    display: inline-block;
    vertical-align: middle; }
  .cg-cat > div > div {
    width: 100%;
    position: relative; }
  .cg-cat > div:after {
    content: '';
    height: 100%; }
  .cg-cat > div:before {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0.7; }
  .cg-cat input:checked + div {
    color: #fff; }
  .cg-cat input:checked + div svg * {
    fill: #fff; }

#cg-btn-favorites-container {
  margin: 0 0 2em;
  text-align: right; }

#cg-btn-see-favorites {
  cursor: pointer;
  color: #777;
  font-size: 0.9em;
  font-weight: bold;
  transition: color 0.2s; }
  #cg-btn-see-favorites svg {
    display: inline-block;
    vertical-align: -3px; }
  #cg-btn-see-favorites svg * {
    fill: #777;
    transition: fill 0.2s; }
  #cg-btn-see-favorites span:last-child {
    display: none; }
  #cg-btn-see-favorites:hover, #cg-btn-see-favorites:focus {
    color: #000;
    transition: color 0.2s; }
  #cg-btn-see-favorites:hover svg *, #cg-btn-see-favorites:focus svg * {
    fill: #000;
    transition: fill 0.2s; }
  #cg-btn-see-favorites.active {
    color: #000;
    transition: color 0.2s; }
  #cg-btn-see-favorites.active svg * {
    fill: #000;
    transition: fill 0.2s; }
  #cg-btn-see-favorites.active span:first-of-type {
    display: none; }
  #cg-btn-see-favorites.active span:last-child {
    display: inline-block; }

.cg-poi-prototype {
  display: none !important; }

#cg-pois-scroll {
  overflow-y: auto;
  height: 100%;
  height: calc(100% - 138px); }

#cg-pois-container {
  position: relative;
  padding: 0 10px;
  margin-top: 30px; }

.cg-poi {
  position: relative;
  display: inline-block;
  vertical-align: top;
  width: 50%;
  height: 240px;
  padding: 0 2% 4% 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  /* &:nth-child(even) {
		margin-left: 2%;
		margin-right: 0;
	} */
  transition: transform 0.2s; }
  .cg-poi > div {
    width: 100%;
    height: 100%;
    position: relative;
    box-shadow: 0 0 4px rgba(0, 0, 0, .3);
    transition: box-shadow 0.2s; }
  .cg-poi:hover, .cg-poi:focus, .cg-poi.active {
    transform: scale(1.05);
    transition: transform 0.2s; }
  .cg-poi:hover > div, .cg-poi:focus > div, .cg-poi.active > div {
    box-shadow: 0 0 9px rgba(0, 0, 0, .7);
    transition: box-shadow 0.2s; }

.cg-poi-bg {
  height: 160px;
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  background-size: cover; }

.cg-poi-favorite {
  position: absolute; }

.cg-poi-favorite-off {
  top: 15px;
  right: 15px; }
  .cg-poi-favorite-off * {
    fill: #000; }

.cg-poi-favorite-on {
  top: 16px;
  right: 16px; }
  .cg-poi-favorite-on * {
    fill: rgba(255, 255, 255, .8); }
  .cg-poi-favorite-on.active * {
    fill: #000; }

.cg-poi-content {
  position: absolute;
  width: 100%;
  height: calc(100% - 160px);
  padding: 7px 25px 7px 60px;
  box-sizing: border-box;
  left: 0;
  bottom: 0;
  color: #7e7e7e;
  background: #fff;
  background: rgba(255, 255, 255, .75); }
  .cg-poi-content .cg-icon-open {
    position: absolute;
    top: 16px;
    right: 3px; }
  .cg-poi-content .cg-icon-open * {
    fill: #7e7e7e; }

.cg-poi-category {
  position: absolute;
  width: 40px;
  height: 40px;
  left: 10px;
  top: 7px;
  text-align: center; }

.cg-icon {
  display: inline-block;
  margin: 6px 0 0; }
  .cg-icon * {
    fill: #fff; }

.cg-icon-open {
  transform: rotate(180deg);
  transform-origin: center center; }

.cg-icon-down {
  transform: rotate(-90deg);
  transform-origin: center center; }

.cg-poi-title {
  overflow: hidden;
  display: block;
  max-width: -webkit-calc(100% - 25px);
  max-width: calc(100% - 25px);
  margin: 0 0 0.2em;
  font-size: 0.95em;
  text-transform: uppercase;
  -ms-text-overflow: ellipsis;
  text-overflow: ellipsis;
  white-space: nowrap; }

.cg-poi-distance {
  display: block;
  font-size: 0.8em;
  font-style: italic; }

.cg-poi-cta {
  position: absolute;
  right: 10px;
  bottom: 5px;
  color: #fff;
  font-size: 30px;
  font-weight: bold; }

#cg-marker-content {
  display: table; }
  #cg-marker-content p {
    line-height: 1.1rem; }

#cg-marker-content > div, #cg-marker-content svg {
  display: table-cell;
  vertical-align: middle; }

#cg-marker-content svg {
  margin-right: 10px; }

#cg-marker-content-title {
  padding: 0;
  margin: 0;
  font-size: 0.9rem;
  font-weight: bold;
  text-transform: uppercase; }

#cg-marker-content-distance {
  padding: 0;
  margin: 0;
  color: #888;
  font-size: 0.8rem; }

#cg-svg-sprite {
  display: none; }

#cg-poi-single-header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1;
  background-color: rgba(255, 255, 255, .7);
  padding: 15px 3%; }

#cg-poi-single-content {
  position: relative;
  overflow-y: auto;
  height: 100%; }

#cg-btn-back {
  cursor: pointer;
  display: inline-block;
  font-family: inherit;
  font-size: 0.9rem;
  color: #333; }
  #cg-btn-back .cg-icon {
    margin: 0 2px 0 0; }
  #cg-btn-back .cg-icon, #cg-btn-back span {
    display: inline-block;
    vertical-align: middle; }
  #cg-btn-back svg {
    -webkit-transition: -webkit-transform 0.2s;
    transition: transform 0.2s; }
  #cg-btn-back svg * {
    fill: #333; }
  #cg-btn-back:hover svg, #cg-btn-back:focus svg {
    -webkit-transform: translateX(-2px);
    transform: translateX(-2px);
    -webkit-transition: -webkit-transform 0.2s;
    transition: transform 0.2s; }

#cg-poi-img {
  position: relative;
  height: 350px;
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  background-size: cover;
  /*#cg-poi-info {
	display: table;
	width: 100%;
	margin: 1em 0;
}

#cg-poi-info-left, #cg-poi-info-right {
	display: table-cell;
	vertical-align: middle;
	width: 50%;
}*/
  /*#cg-poi-info-right {
	text-align: right;
}*/ }

#cg-poi-info, #cg-poi-descriptions {
  padding-left: 50px;
  padding-right: 20px; }

#cg-poi-info {
  padding-top: 20px;
  padding-bottom: 20px;
  background-color: rgba(240, 240, 240, .7);
  overflow-y: auto;
  margin-bottom: 20px;
  color: #7e7e7e; }
  #cg-poi-info svg * {
    fill: #7e7e7e; }
  #cg-poi-info svg, #cg-poi-info p {
    display: inline-block;
    vertical-align: middle; }
  #cg-poi-info p {
    margin: 0 0 0 9px; }

.cg-poi-info-left {
  float: left;
  font-size: 0.9em; }

.cg-poi-info-right {
  float: right; }

#cg-sidebar-content-single {
  top: 0;
  left: 100%;
  background-color: #fff; }

#cg-sidebar-title-container {
  position: relative;
  color: #7e7e7e;
  overflow-y: auto;
  padding: 10px 20px 10px 50px; }
  #cg-sidebar-title-container h2, #cg-sidebar-title-container .cg-contact, #cg-sidebar-title-container svg {
    display: inline-block;
    vertical-align: middle; }
  #cg-sidebar-title-container a {
    color: #7e7e7e; }

#cg-poi-contact svg * {
  fill: #7e7e7e; }

.cg-contact span {
  margin: 0 20px 0 3px;
  /* #cg-poi-single-title-right{
	float: right;
} */ }

#cg-poi-single-title {
  padding: 10px 15px;
  transform: translateX(-50px); }

#cg-poi-single-title h2 {
  margin: 0;
  text-transform: uppercase; }

#cg-poi-single-title p {
  margin: 3px 35px 7px; }

#cg-poi-single-title svg {
  margin-right: 6px; }

#cg-poi-single-contact svg * {
  fill: #7e7e7e; }

#cg-poi-descriptions {
  clear: both;
  padding-bottom: 20px; }

#cg-poi-desc {
  border-top: 1px solid;
  border-bottom: 1px solid;
  padding: 10px 0; }

.cg-poi-text {
  font-size: 0.9em;
  line-height: 1.4em; }
  .cg-poi-text p {
    padding: 0;
    margin: 0 0 1em;
    text-align: justify; }
  .cg-poi-text p:last-child {
    margin-bottom: 0; }
  .cg-poi-text ul {
    list-style-position: inside; }

.cg-poi-text-2 {
  display: none;
  padding-left: 20px;
  /*.cg-accordion {
	margin: 1em 0;
}

.cg-accordion-btn {
	cursor: pointer;
	position: relative;
	display: block;
	width: 100%;
	padding: .4em .8em;
	color: #fff;
	font-family: inherit;
	font-size: .9em;
	text-align: left;
	text-transform: uppercase;
	background: $color;
	border-radius: 5px;

	svg {
		position: absolute;
		right: .6em;
		top: .6em;
		transition: transform .2s;
	}

	&.active {
		svg {
			-webkit-transform-origin: 50% 50%;
			-moz-transform-origin: 50% 50%;
			-ms-transform-origin: 50% 50%;
			-o-transform-origin: 50% 50%;
			transform-origin: 50% 50%;
			-webkit-transform: rotate(45deg);
			-ms-transform: rotate(45deg);
			-o-transform: rotate(45deg);
			transform: rotate(45deg);
			transition: transform .2s;
		}
	}
}

.cg-accordion-content {
	display: none;
	width: 96%;
	padding: 1em;
	margin: 0 auto;
	background: #fff;
	border-radius: 0 0 10px 10px;
}*/ }

#cg-btn-add-favorite {
  cursor: pointer;
  float: right; }
  #cg-btn-add-favorite svg * {
    fill: #333; }

#cg-directions-panel {
  overflow-y: auto;
  position: absolute;
  width: 350px;
  height: 100%;
  padding: 70px 1em 2em;
  right: -360px;
  top: 0;
  font-size: 0.9em;
  background: #fff;
  transition: right 0.5s; }
  #cg-directions-panel.active {
    right: 0;
    transition: right 0.5s; }

#cg-directions-panel-close, #cg-directions-panel-toggle-info {
  cursor: pointer; }

#cg-directions-panel-toggle-info {
  display: none; }

#cg-directions-btns {
  margin: 0.5em 0 0; }

.cg-btn-directions {
  cursor: pointer;
  display: inline-block;
  width: 30px;
  height: 30px;
  line-height: 33px;
  padding: 0;
  margin: 0 0 0 4px;
  text-align: center; }
  .cg-btn-directions svg * {
    transition: fill 0.2s;
    fill: #7e7e7e; }
  .cg-btn-directions.active svg *, .cg-btn-directions:hover svg *, .cg-btn-directions:focus svg * {
    transition: fill 0.2s; }

@media screen and (min-width: 768px) and (max-width: 1023px) {
  .cg-poi {
    width: 100%;
    padding: 0 0 4% 0;
    /* #cg-sidebar-content-single {
		padding-top: 30px;
	} */ }
    .cg-poi:nth-child(even) {
      margin-left: 0;
      margin-right: 0; }

  #cg-poi-info {
    display: block;
    text-align: center; }

  .cg-poi-info-left, .cg-poi-info-right {
    display: block;
    width: 100%;
    text-align: center; }

  #cg-poi-info-left {
    padding-bottom: 1em; } }

@media screen and (max-width: 767px) {
  #cg-sidebar-header {
    padding-left: 60px;
    padding-top: 1px;
    padding-bottom: 1px; }

  #cg-button-toggle {
    display: none; }

  #cg-toggle-map {
    display: inline-block; }

  .city-guide-container {
    height: auto;
    position: relative; }

  #cg, #cg-sidebar, #cg-sidebar-container, #cg-sidebar-content {
    height: auto; }

  #cg-map {
    height: calc(100vh - 190px);
    display: none; }
    #cg-map, #cg-map.is-directions {
      position: fixed;
      width: 100%;
      left: 0;
      top: 0; }
    #cg-map.is-directions {
      height: calc(100vh - 30px);
      z-index: 2; }
    #cg-map.active, #cg-map.is-directions {
      display: block; }

  #cg-sidebar {
    position: relative;
    width: 100%;
    left: auto;
    top: auto; }

  #cg-sidebar-content {
    position: relative; }

  #cg-sidebar-container {
    width: 100%; }

  #cg-sidebar-filters {
    text-align: center;
    width: 100%;
    position: fixed;
    left: 0;
    bottom: 0;
    background: none; }

  #cg-pois-scroll {
    height: auto; }

  #cg-sidebar-content {
    padding: 0 15px; }

  #cg-pois-container {
    margin-top: 0;
    padding-bottom: 50px; }

  #cg-filter-btns {
    display: inline-block;
    padding: 5px 0;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none; }

  #cg-categories, #cg-sidebar-content-single, .cg-map-open .city-guide-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh; }

  #cg-categories {
    padding: 20px 0; }

  #cg-sidebar-content-single {
    display: none;
    z-index: 1; }

  .cg-categories-separator {
    display: none; }

  #cg-categories-close {
    display: block; }

  .cg-poi {
    display: block;
    width: 100%; }

  #cg-poi-info {
    display: block;
    text-align: center; }

  .cg-poi-info-left, .cg-poi-info-right {
    display: block;
    width: 100%;
    text-align: center; }

  #cg-poi-info-left {
    padding-bottom: 1em; }

  .cg-btn {
    margin-right: 3px; }

  #cg-directions-panel {
    overflow-y: auto;
    position: fixed;
    width: 100%;
    height: auto;
    right: auto;
    left: 0;
    top: auto;
    bottom: 0;
    z-index: 3;
    display: none;
    padding: 10px;
    max-height: calc(100% - 30px); }
    #cg-directions-panel > div {
      display: none; }
    #cg-directions-panel.active {
      display: block;
      right: auto; }

  #cg-directions-panel-toggle-info {
    display: block;
    text-transform: uppercase;
    width: 100%; }
    #cg-directions-panel-toggle-info svg {
      margin-left: 5px; }
    #cg-directions-panel-toggle-info svg * {
      fill: #000;
      /* &.active svg{
			transform: rotate(-135deg);
			transform-origin: center center;
		} */ }

  #cg-directions-panel-close {
    position: fixed;
    top: 10px;
    left: 10px; }

  .cg-cat-open, .cg-content-single-open, .cg-map-open {
    overflow: hidden; }
    .cg-cat-open .city-guide-container, .cg-content-single-open .city-guide-container, .cg-map-open .city-guide-container {
      z-index: 1000000; }

  .cg-map-open #cg-pois-scroll {
    height: auto;
    white-space: nowrap;
    padding: 10px 0; }
    .cg-map-open #cg-sidebar-header {
      display: none; }
    .cg-map-open .cg-poi {
      display: inline-block;
      padding: 0 4%;
      white-space: normal;
      height: 120px;
      width: 150px; }
    .cg-map-open .cg-poi-bg {
      height: 100px; }
    .cg-map-open .cg-poi-content {
      padding: 5px;
      min-height: auto; }
    .cg-map-open .cg-poi-category {
      display: none; }
    .cg-map-open .cg-poi-title {
      font-size: 0.75em; }
    .cg-map-open #cg-sidebar-filters {
      position: fixed;
      top: 0;
      right: 0;
      width: calc(100% - 50px);
      left: auto;
      bottom: auto;
      text-align: right; }
    .cg-map-open #cg-pois-container {
      padding-bottom: 0; }
    .cg-map-open .city-guide-container {
      background-color: #fff; }
    .cg-map-open .cg-poi.active, .cg-map-open .cg-poi:hover, .cg-map-open .cg-poi:focus {
      transform: scale(1); }
      .cg-map-open .cg-poi.active > div, .cg-map-open .cg-poi:hover > div, .cg-map-open .cg-poi:focus > div {
        box-shadow: 0 0 4px rgba(0, 0, 0, .3);
        border-bottom: 5px solid #000; } }

.big-slideshow {
  position: relative;
  height: 600px; }
  .big-slideshow .cycle-carousel-wrap {
    height: 100%;
    margin-left: 135px !important; }

.big-slideshow-item {
  position: relative;
  width: 935px;
  height: 100%;
  margin: 0 20px; }

.big-slideshow-current {
  z-index: 10;
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 140px;
  height: 50px;
  left: calc(50% - 70px);
  top: calc(50% - 25px);
  padding: 0.7em;
  color: #f7ab59;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-size: 1.1rem;
  text-transform: uppercase;
  background: #fff; }
  .big-slideshow-current span {
    color: #000; }

.big-slideshow-prev, .big-slideshow-next {
  z-index: 200;
  position: absolute;
  height: 50px;
  top: calc(50% - 25px);
  padding: 0.7em;
  color: #000;
  font-family: 'PoliceStudioVedette', Arial, sans-serif;
  font-size: 1.1rem;
  text-transform: uppercase;
  background: #fff; }
  .big-slideshow-prev svg, .big-slideshow-next svg {
    width: 33px;
    height: 10px;
    fill: #f7ab59;
    transition: transform 0.3s; }

.big-slideshow-prev {
  left: 0; }
  .big-slideshow-prev svg {
    margin-right: 5px; }
  .big-slideshow-prev:hover svg, .big-slideshow-prev:focus svg {
    transform: translateX(-5px);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); }

.big-slideshow-next {
  right: 0; }
  .big-slideshow-next svg {
    margin-left: 5px; }
  .big-slideshow-next:hover svg, .big-slideshow-next:focus svg {
    transform: translateX(5px);
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); }

.big-slideshow-room-info {
  z-index: 10;
  position: absolute;
  display: flex;
  justify-content: space-between;
  align-items: center;
  min-width: 430px;
  left: calc(50% - 215px);
  bottom: 30px;
  padding: 5px 10px;
  background: #fff; }

.big-slideshow-room-info-proto {
  display: none; }

.big-slideshow-room-info-name {
  color: #468bce;
  font-style: italic;
  text-align: center; }
  .big-slideshow-room-info-name strong {
    color: #000;
    font-size: 1.15rem;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-style: normal; }

.insta-feed-container {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between; }

.insta-feed-container-small {
  margin-top: 2em; }
  .insta-feed-container-small .social-item {
    flex-basis: calc(20% - 10px);
    height: 235px; }
  .insta-feed-container-small .social-item-content {
    display: none; }

.social-item {
  position: relative;
  flex-basis: calc(25% - 15px);
  height: 295px;
  margin-bottom: 20px;
  background-size: cover;
  background-position: center; }
  .social-item:hover .social-item-content, .social-item:focus .social-item-content {
    opacity: 1;
    transition: opacity 0.3s; }

.social-item-content {
  opacity: 0;
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  padding: 20px;
  color: #000;
  font-size: 0.8rem;
  line-height: 1.5em;
  text-align: center;
  background: rgba(255, 255, 255, 0.9);
  transition: opacity 0.3s; }

.social-item-first {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center; }
  .social-item-first a {
    color: #808080;
    font-size: 1.2rem;
    font-style: italic; }
  .social-item-first svg {
    display: block;
    width: 36px;
    height: 36px;
    margin: 0 auto 2em;
    fill: #f7ab59; }

.social-wall-loader {
  display: inline-block;
  width: 60px;
  height: 60px;
  margin: 50px auto 20px;
  position: relative; }
  .social-wall-loader:before {
    content: "Loading...";
    position: absolute;
    top: 39px;
    left: 21px;
    font-size: 10px;
    font-weight: 700;
    display: block; }

html[lang="fr"] .social-wall-loader:before {
  content: "Chargement...";
  left: 13px; }

.social-wall-loader:after {
  content: "";
  display: block;
  width: 64px;
  height: 64px;
  margin: 8px;
  border-radius: 50%;
  border: 4px solid #000;
  border-color: #000 transparent #000 transparent;
  animation: lds-dual-ring 1.2s linear infinite; }

@keyframes lds-dual-ring {
  0% {
    transform: rotate(0deg); }

  100% {
    transform: rotate(360deg); } }

.faq-subtitle {
  color: #000001; }

.faq-qrs-container {
  margin-top: 40px; }

.faq-qr {
  border-bottom: 1px solid #000; }
  .faq-qr:first-child {
    border-top: 1px solid #000; }

.faq-question {
  font-weight: bold;
  cursor: pointer;
  display: table; }

.faq-question-col {
  display: table-cell;
  vertical-align: middle;
  color: #000001;
  padding: 1em; }
  .faq-question-col p {
    margin-bottom: 0; }

.faq-question-col-1 {
  width: 100%; }

.faq-question-col-2 {
  padding-right: 20px; }

.faq-toggle-icon {
  display: inline-block;
  font-size: 20px; }

.faq-response {
  display: none;
  padding-left: 20px; }

.faq-qr.active .faq-toggle-icon {
  transform: rotate(90deg); }

.selectize-control.plugin-drag_drop.multi > .selectize-input > div.ui-sortable-placeholder {
  visibility: visible !important;
  background: #f2f2f2 !important;
  background: rgba(0, 0, 0, 0.06) !important;
  border: 0 none !important;
  -webkit-box-shadow: inset 0 0 12px 4px white;
  box-shadow: inset 0 0 12px 4px white; }
  .selectize-control.plugin-drag_drop .ui-sortable-placeholder::after {
    content: '!';
    visibility: hidden; }
  .selectize-control.plugin-drag_drop .ui-sortable-helper {
    -webkit-box-shadow: 0 2px 5px rgba(0, 0, 0, .2);
    box-shadow: 0 2px 5px rgba(0, 0, 0, .2); }

.selectize-dropdown-header {
  position: relative;
  padding: 5px 8px;
  border-bottom: 1px solid #d0d0d0;
  background: #f8f8f8;
  -webkit-border-radius: 3px 3px 0 0;
  -moz-border-radius: 3px 3px 0 0;
  border-radius: 3px 3px 0 0; }

.selectize-dropdown-header-close {
  position: absolute;
  right: 8px;
  top: 50%;
  color: #303030;
  opacity: 0.4;
  margin-top: -12px;
  line-height: 20px;
  font-size: 20px !important; }

.selectize-dropdown-header-close:hover {
  color: #000; }

.selectize-dropdown.plugin-optgroup_columns .optgroup {
  border-right: 1px solid #f2f2f2;
  border-top: 0 none;
  float: left;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }
  .selectize-dropdown.plugin-optgroup_columns .optgroup:last-child {
    border-right: 0 none; }
  .selectize-dropdown.plugin-optgroup_columns .optgroup:before {
    display: none; }
  .selectize-dropdown.plugin-optgroup_columns .optgroup-header {
    border-top: 0 none; }

.selectize-control.plugin-remove_button [data-value] {
  position: relative;
  padding-right: 24px !important; }
  .selectize-control.plugin-remove_button [data-value] .remove {
    /* fixes ie bug (see #392) */
    z-index: 1;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 17px;
    text-align: center;
    font-weight: bold;
    font-size: 12px;
    color: inherit;
    text-decoration: none;
    vertical-align: middle;
    display: inline-block;
    padding: 2px 0 0 0;
    border-left: 1px solid #333;
    -webkit-border-radius: 0 2px 2px 0;
    -moz-border-radius: 0 2px 2px 0;
    border-radius: 0 2px 2px 0;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box; }
  .selectize-control.plugin-remove_button [data-value] .remove:hover {
    background: rgba(0, 0, 0, 0.05); }
  .selectize-control.plugin-remove_button [data-value].active .remove {
    border-left-color: #000; }
  .selectize-control.plugin-remove_button .disabled [data-value] .remove:hover {
    background: none; }
  .selectize-control.plugin-remove_button .disabled [data-value] .remove {
    border-left-color: #808080; }
  .selectize-control.plugin-remove_button .remove-single {
    position: absolute;
    right: 28px;
    top: 6px;
    font-size: 23px; }

.selectize-control {
  position: relative; }

.selectize-dropdown, .selectize-input, .selectize-input input {
  color: #303030;
  font-family: inherit;
  font-size: 13px;
  line-height: 18px;
  -webkit-font-smoothing: inherit; }

.selectize-input, .selectize-control.single .selectize-input.input-active {
  background: white;
  cursor: text;
  display: inline-block; }

.selectize-input {
  border: 1px solid #d0d0d0;
  padding: 8px 8px;
  display: inline-block;
  width: 100%;
  overflow: hidden;
  position: relative;
  z-index: 1;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.1);
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.1);
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  border-radius: 3px; }
  .selectize-control.multi .selectize-input.has-items {
    padding: 5px 8px 2px; }
  .selectize-input.full {
    background-color: white; }
  .selectize-input.disabled, .selectize-input.disabled * {
    cursor: default !important; }
  .selectize-input.focus {
    -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.15);
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.15); }
  .selectize-input.dropdown-active {
    -webkit-border-radius: 3px 3px 0 0;
    -moz-border-radius: 3px 3px 0 0;
    border-radius: 3px 3px 0 0; }
  .selectize-input > * {
    vertical-align: baseline;
    display: -moz-inline-stack;
    display: inline-block;
    zoom: 1;
    *display: inline; }
  .selectize-control.multi .selectize-input > div {
    cursor: pointer;
    margin: 0 3px 3px 0;
    padding: 2px 6px;
    background: #666;
    color: white;
    border: 1px solid #333; }
  .selectize-control.multi .selectize-input > div.active {
    background: #333;
    color: white;
    border: 1px solid #000; }
  .selectize-control.multi .selectize-input.disabled > div, .selectize-control.multi .selectize-input.disabled > div.active {
    color: #fff;
    background: #b3b3b3;
    border: 1px solid #808080; }
  .selectize-input > input {
    display: inline-block !important;
    padding: 0 !important;
    min-height: 0 !important;
    max-height: none !important;
    max-width: 100% !important;
    margin: 0 1px !important;
    text-indent: 0 !important;
    border: 0 none !important;
    background: none !important;
    line-height: inherit !important;
    -webkit-user-select: auto !important;
    -webkit-box-shadow: none !important;
    box-shadow: none !important; }
  .selectize-input > input::-ms-clear {
    display: none; }
  .selectize-input > input:focus {
    outline: none !important; }

.selectize-input::after {
  content: ' ';
  display: block;
  clear: left; }

.selectize-input.dropdown-active::before {
  content: ' ';
  display: block;
  position: absolute;
  background: #f0f0f0;
  height: 1px;
  bottom: 0;
  left: 0;
  right: 0; }

.selectize-dropdown {
  position: absolute;
  z-index: 10;
  border: 1px solid #d0d0d0;
  background: white;
  margin: -1px 0 0 0;
  border-top: 0 none;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  -webkit-border-radius: 0 0 3px 3px;
  -moz-border-radius: 0 0 3px 3px;
  border-radius: 0 0 3px 3px; }
  .selectize-dropdown [data-selectable] {
    cursor: pointer;
    overflow: hidden; }
  .selectize-dropdown [data-selectable] .highlight {
    background: rgba(125, 168, 208, 0.2);
    -webkit-border-radius: 1px;
    -moz-border-radius: 1px;
    border-radius: 1px; }
  .selectize-dropdown [data-selectable], .selectize-dropdown .optgroup-header {
    padding: 5px 8px; }
  .selectize-dropdown .optgroup:first-child .optgroup-header {
    border-top: 0 none; }
  .selectize-dropdown .optgroup-header {
    color: #303030;
    background: white;
    cursor: default; }
  .selectize-dropdown .active {
    background-color: #f5fafd;
    color: #495c68; }
  .selectize-dropdown .active.create {
    color: #495c68; }
  .selectize-dropdown .create {
    color: rgba(48, 48, 48, 0.5); }

.selectize-dropdown-content {
  overflow-y: auto;
  overflow-x: hidden;
  max-height: 200px; }

.selectize-control.single .selectize-input, .selectize-control.single .selectize-input input {
  cursor: pointer; }
  .selectize-control.single .selectize-input.input-active, .selectize-control.single .selectize-input.input-active input {
    cursor: text; }
  .selectize-control.single .selectize-input:after {
    content: ' ';
    display: block;
    position: absolute;
    top: 50%;
    right: 15px;
    margin-top: -3px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 5px 5px 0 5px;
    border-color: #808080 transparent transparent transparent; }
  .selectize-control.single .selectize-input.dropdown-active:after {
    margin-top: -4px;
    border-width: 0 5px 5px 5px;
    border-color: transparent transparent #808080 transparent; }

.selectize-control.rtl.single .selectize-input:after {
  left: 15px;
  right: auto; }
  .selectize-control.rtl .selectize-input > input {
    margin: 0 4px 0 -2px !important; }

.selectize-control .selectize-input.disabled {
  opacity: 0.5;
  background-color: #fafafa; }

.selectize-control.multi .selectize-input.has-items {
  padding-left: 5px;
  padding-right: 5px; }
  .selectize-control.multi .selectize-input.disabled [data-value] {
    color: #999;
    text-shadow: none;
    background: none;
    -webkit-box-shadow: none;
    box-shadow: none; }
    .selectize-control.multi .selectize-input.disabled [data-value], .selectize-control.multi .selectize-input.disabled [data-value] .remove {
      border-color: #e6e6e6; }
    .selectize-control.multi .selectize-input.disabled [data-value] .remove {
      background: none; }
  .selectize-control.multi .selectize-input [data-value] {
    text-shadow: 0 1px 0 rgba(0, 51, 83, 0.3);
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
    background-color: #525252;
    background-image: -moz-linear-gradient(top, #666, #333);
    background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#666), to(#333));
    background-image: -webkit-linear-gradient(top, #666, #333);
    background-image: -o-linear-gradient(top, #666, #333);
    background-image: linear-gradient(to bottom, #666, #333);
    background-repeat: repeat-x;
    filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr='argb(#666)', endColorstr='argb(#333)', GradientType=0)";
    -webkit-box-shadow: "0 1px 0 rgba(black, 0.2), inset 0 1px rgba(white, 0.03)";
    box-shadow: "0 1px 0 rgba(black, 0.2), inset 0 1px rgba(white, 0.03)"; }
    .selectize-control.multi .selectize-input [data-value].active {
      background-color: #1f1f1f;
      background-image: -moz-linear-gradient(top, #333, #000);
      background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#333), to(#000));
      background-image: -webkit-linear-gradient(top, #333, #000);
      background-image: -o-linear-gradient(top, #333, #000);
      background-image: linear-gradient(to bottom, #333, #000);
      background-repeat: repeat-x;
      filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr='argb(#333)', endColorstr='argb(#000)', GradientType=0)"; }
  .selectize-control.single .selectize-input {
    -webkit-box-shadow: "0 1px 0 rgba(black, 0.05), inset 0 1px 0 rgba(white, 0.8)";
    box-shadow: "0 1px 0 rgba(black, 0.05), inset 0 1px 0 rgba(white, 0.8)";
    background-color: #f9f9f9;
    background-image: -moz-linear-gradient(top, #fefefe, #f2f2f2);
    background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#fefefe), to(#f2f2f2));
    background-image: -webkit-linear-gradient(top, #fefefe, #f2f2f2);
    background-image: -o-linear-gradient(top, #fefefe, #f2f2f2);
    background-image: linear-gradient(to bottom, #fefefe, #f2f2f2);
    background-repeat: repeat-x;
    filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr='argb(#fefefe)', endColorstr='argb(#f2f2f2)', GradientType=0)"; }

.selectize-control.single .selectize-input, .selectize-dropdown.single {
  border-color: #b8b8b8; }

.selectize-dropdown .optgroup-header {
  padding-top: 7px;
  font-weight: bold;
  font-size: 0.85em; }
  .selectize-dropdown .optgroup {
    border-top: 1px solid #f0f0f0; }
  .selectize-dropdown .optgroup:first-child {
    border-top: 0 none; }

.selectize-input, .selectize-control.multi .selectize-input.has-items {
  border: 1px solid #000;
  padding: 15px 10px; }

._calendar {
  padding-top: 60px; }
  ._calendar .fbw-calendar--title h1[data-v-692ea5a4] {
    font-family: 'PoliceStudioVedette', Arial, sans-serif; }

.modal {
  z-index: 999;
  opacity: 0;
  overflow-y: auto;
  pointer-events: none;
  position: fixed;
  inset: 0;
  padding: 40px 20px;
  transition: opacity 0.5s; }
  .modal.active {
    opacity: 1;
    pointer-events: auto; }

.modal-bg {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, .7); }

.modal-content {
  position: relative;
  width: 1150px;
  max-width: 100%;
  margin: 0 auto;
  background: #fff;
  box-shadow: rgba(0, 0, 0, .3) 4px 4px 10px; }
  .modal-content iframe {
    display: block;
    width: 100%;
    height: 800px;
    border: none; }

.modal-close {
  position: absolute;
  display: grid;
  place-content: center;
  width: 36px;
  height: 36px;
  right: -18px;
  top: -18px;
  color: #fff;
  font-size: 2rem;
  background: #87cdc8;
  border-radius: 5px;
  transition: transform 0.3s; }
  .modal-close:hover, .modal-close:focus {
    transform: scale(1.1) rotate(10deg); }

html.swipebox-html.swipebox-touch {
  overflow: hidden !important; }

#swipebox-overlay img {
  border: none !important; }

#swipebox-overlay {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99999 !important;
  overflow: hidden;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none; }

#swipebox-container {
  position: relative;
  width: 100%;
  height: 100%; }

#swipebox-slider {
  -webkit-transition: -webkit-transform 0.4s ease;
  transition: transform 0.4s ease;
  height: 100%;
  left: 0;
  top: 0;
  width: 100%;
  white-space: nowrap;
  position: absolute;
  display: none;
  cursor: pointer; }

#swipebox-slider .slide {
  height: 100%;
  width: 100%;
  line-height: 1px;
  text-align: center;
  display: inline-block; }

#swipebox-slider .slide:before {
  content: "";
  display: inline-block;
  height: 50%;
  width: 1px;
  margin-right: -1px; }

#swipebox-slider .slide img, #swipebox-slider .slide .swipebox-video-container, #swipebox-slider .slide .swipebox-inline-container {
  display: inline-block;
  max-height: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
  width: auto;
  height: auto;
  vertical-align: middle; }

#swipebox-slider .slide .swipebox-video-container {
  background: none;
  max-width: 1140px;
  max-height: 100%;
  width: 100%;
  padding: 5%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

#swipebox-slider .slide .swipebox-video-container .swipebox-video {
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden;
  position: relative; }

#swipebox-slider .slide .swipebox-video-container .swipebox-video iframe {
  width: 100% !important;
  height: 100% !important;
  position: absolute;
  top: 0;
  left: 0; }

#swipebox-slider .slide-loading {
  background: url(/res/vendor/swipebox/loader.gif) no-repeat center center; }

#swipebox-bottom-bar, #swipebox-top-bar {
  -webkit-transition: 0.5s;
  transition: 0.5s;
  position: absolute;
  left: 0;
  z-index: 999;
  height: 50px;
  width: 100%; }

#swipebox-bottom-bar {
  bottom: -50px; }

#swipebox-bottom-bar.visible-bars {
  -webkit-transform: translate3d(0, -50px, 0);
  transform: translate3d(0, -50px, 0); }

#swipebox-top-bar {
  top: -50px; }

#swipebox-top-bar.visible-bars {
  -webkit-transform: translate3d(0, 50px, 0);
  transform: translate3d(0, 50px, 0); }

#swipebox-title {
  display: block;
  width: 100%;
  text-align: center; }

#swipebox-prev, #swipebox-next, #swipebox-close {
  background-image: url(/res/vendor/swipebox/icons.png);
  background-repeat: no-repeat;
  border: none !important;
  text-decoration: none !important;
  cursor: pointer;
  width: 50px;
  height: 50px;
  top: 0; }

#swipebox-arrows {
  display: block;
  margin: 0 auto;
  width: 100%;
  height: 50px; }

#swipebox-prev {
  background-position: -32px 13px;
  float: left; }

#swipebox-next {
  background-position: -78px 13px;
  float: right; }

#swipebox-close {
  top: 0;
  right: 0;
  position: absolute;
  z-index: 9999;
  background-position: 15px 12px; }

.swipebox-no-close-button #swipebox-close {
  display: none; }

#swipebox-prev.disabled, #swipebox-next.disabled {
  opacity: 0.3; }

.swipebox-no-touch #swipebox-overlay.rightSpring #swipebox-slider {
  -webkit-animation: rightSpring 0.3s;
  animation: rightSpring 0.3s; }

.swipebox-no-touch #swipebox-overlay.leftSpring #swipebox-slider {
  -webkit-animation: leftSpring 0.3s;
  animation: leftSpring 0.3s; }

.swipebox-touch #swipebox-container:before, .swipebox-touch #swipebox-container:after {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  content: ' ';
  position: absolute;
  z-index: 999;
  top: 0;
  height: 100%;
  width: 20px;
  opacity: 0; }

.swipebox-touch #swipebox-container:before {
  left: 0;
  -webkit-box-shadow: inset 10px 0px 10px -8px #656565;
  box-shadow: inset 10px 0px 10px -8px #656565; }

.swipebox-touch #swipebox-container:after {
  right: 0;
  -webkit-box-shadow: inset -10px 0px 10px -8px #656565;
  box-shadow: inset -10px 0px 10px -8px #656565; }

.swipebox-touch #swipebox-overlay.leftSpringTouch #swipebox-container:before {
  opacity: 1; }

.swipebox-touch #swipebox-overlay.rightSpringTouch #swipebox-container:after {
  opacity: 1; }

@-webkit-keyframes rightSpring {
  0% {
    left: 0; }

  50% {
    left: -30px; }

  100% {
    left: 0; } }

@keyframes rightSpring {
  0% {
    left: 0; }

  50% {
    left: -30px; }

  100% {
    left: 0; } }

@-webkit-keyframes leftSpring {
  0% {
    left: 0; }

  50% {
    left: 30px; }

  100% {
    left: 0; } }

@keyframes leftSpring {
  0% {
    left: 0; }

  50% {
    left: 30px; }

  100% {
    left: 0; } }

@media screen and (min-width: 800px) {
  /* Skin
--------------------------*/
    #swipebox-close {
      right: 10px; }
    #swipebox-arrows {
      width: 92%;
      max-width: 800px; } }

#swipebox-overlay {
  background: #0d0d0d; }

#swipebox-bottom-bar, #swipebox-top-bar {
  text-shadow: 1px 1px 1px black;
  background: #000;
  opacity: 0.95; }

#swipebox-top-bar {
  color: white !important;
  font-size: 15px;
  line-height: 43px;
  font-family: Helvetica, Arial, sans-serif; }

.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both; }

.animated.infinite {
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite; }

@-webkit-keyframes bounce {
  from, 20%, 53%, 80%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  40%, 43% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    -webkit-transform: translate3d(0, -30px, 0);
    transform: translate3d(0, -30px, 0); }

  70% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    -webkit-transform: translate3d(0, -15px, 0);
    transform: translate3d(0, -15px, 0); }

  90% {
    -webkit-transform: translate3d(0, -4px, 0);
    transform: translate3d(0, -4px, 0); } }

@keyframes bounce {
  from, 20%, 53%, 80%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  40%, 43% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    -webkit-transform: translate3d(0, -30px, 0);
    transform: translate3d(0, -30px, 0); }

  70% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    -webkit-transform: translate3d(0, -15px, 0);
    transform: translate3d(0, -15px, 0); }

  90% {
    -webkit-transform: translate3d(0, -4px, 0);
    transform: translate3d(0, -4px, 0); } }

.bounce {
  -webkit-animation-name: bounce;
  animation-name: bounce;
  -webkit-transform-origin: center bottom;
  transform-origin: center bottom; }

@-webkit-keyframes flash {
  from, 50%, to {
    opacity: 1; }

  25%, 75% {
    opacity: 0; } }

@keyframes flash {
  from, 50%, to {
    opacity: 1; }

  25%, 75% {
    opacity: 0; } }

.flash {
  -webkit-animation-name: flash;
  animation-name: flash;
  /* originally authored by Nick Pettit - https://github.com/nickpettit/glide */ }

@-webkit-keyframes pulse {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }

  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05); }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }

@keyframes pulse {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }

  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05); }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }

.pulse {
  -webkit-animation-name: pulse;
  animation-name: pulse; }

@-webkit-keyframes rubberBand {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }

  30% {
    -webkit-transform: scale3d(1.25, 0.75, 1);
    transform: scale3d(1.25, 0.75, 1); }

  40% {
    -webkit-transform: scale3d(0.75, 1.25, 1);
    transform: scale3d(0.75, 1.25, 1); }

  50% {
    -webkit-transform: scale3d(1.15, 0.85, 1);
    transform: scale3d(1.15, 0.85, 1); }

  65% {
    -webkit-transform: scale3d(0.95, 1.05, 1);
    transform: scale3d(0.95, 1.05, 1); }

  75% {
    -webkit-transform: scale3d(1.05, 0.95, 1);
    transform: scale3d(1.05, 0.95, 1); }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }

@keyframes rubberBand {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }

  30% {
    -webkit-transform: scale3d(1.25, 0.75, 1);
    transform: scale3d(1.25, 0.75, 1); }

  40% {
    -webkit-transform: scale3d(0.75, 1.25, 1);
    transform: scale3d(0.75, 1.25, 1); }

  50% {
    -webkit-transform: scale3d(1.15, 0.85, 1);
    transform: scale3d(1.15, 0.85, 1); }

  65% {
    -webkit-transform: scale3d(0.95, 1.05, 1);
    transform: scale3d(0.95, 1.05, 1); }

  75% {
    -webkit-transform: scale3d(1.05, 0.95, 1);
    transform: scale3d(1.05, 0.95, 1); }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }

.rubberBand {
  -webkit-animation-name: rubberBand;
  animation-name: rubberBand; }

@-webkit-keyframes shake {
  from, to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  10%, 30%, 50%, 70%, 90% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0); }

  20%, 40%, 60%, 80% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0); } }

@keyframes shake {
  from, to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  10%, 30%, 50%, 70%, 90% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0); }

  20%, 40%, 60%, 80% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0); } }

.shake {
  -webkit-animation-name: shake;
  animation-name: shake; }

@-webkit-keyframes headShake {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0); }

  6.5% {
    -webkit-transform: translateX(-6px) rotateY(-9deg);
    transform: translateX(-6px) rotateY(-9deg); }

  18.5% {
    -webkit-transform: translateX(5px) rotateY(7deg);
    transform: translateX(5px) rotateY(7deg); }

  31.5% {
    -webkit-transform: translateX(-3px) rotateY(-5deg);
    transform: translateX(-3px) rotateY(-5deg); }

  43.5% {
    -webkit-transform: translateX(2px) rotateY(3deg);
    transform: translateX(2px) rotateY(3deg); }

  50% {
    -webkit-transform: translateX(0);
    transform: translateX(0); } }

@keyframes headShake {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0); }

  6.5% {
    -webkit-transform: translateX(-6px) rotateY(-9deg);
    transform: translateX(-6px) rotateY(-9deg); }

  18.5% {
    -webkit-transform: translateX(5px) rotateY(7deg);
    transform: translateX(5px) rotateY(7deg); }

  31.5% {
    -webkit-transform: translateX(-3px) rotateY(-5deg);
    transform: translateX(-3px) rotateY(-5deg); }

  43.5% {
    -webkit-transform: translateX(2px) rotateY(3deg);
    transform: translateX(2px) rotateY(3deg); }

  50% {
    -webkit-transform: translateX(0);
    transform: translateX(0); } }

.headShake {
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-name: headShake;
  animation-name: headShake; }

@-webkit-keyframes swing {
  20% {
    -webkit-transform: rotate3d(0, 0, 1, 15deg);
    transform: rotate3d(0, 0, 1, 15deg); }

  40% {
    -webkit-transform: rotate3d(0, 0, 1, -10deg);
    transform: rotate3d(0, 0, 1, -10deg); }

  60% {
    -webkit-transform: rotate3d(0, 0, 1, 5deg);
    transform: rotate3d(0, 0, 1, 5deg); }

  80% {
    -webkit-transform: rotate3d(0, 0, 1, -5deg);
    transform: rotate3d(0, 0, 1, -5deg); }

  to {
    -webkit-transform: rotate3d(0, 0, 1, 0deg);
    transform: rotate3d(0, 0, 1, 0deg); } }

@keyframes swing {
  20% {
    -webkit-transform: rotate3d(0, 0, 1, 15deg);
    transform: rotate3d(0, 0, 1, 15deg); }

  40% {
    -webkit-transform: rotate3d(0, 0, 1, -10deg);
    transform: rotate3d(0, 0, 1, -10deg); }

  60% {
    -webkit-transform: rotate3d(0, 0, 1, 5deg);
    transform: rotate3d(0, 0, 1, 5deg); }

  80% {
    -webkit-transform: rotate3d(0, 0, 1, -5deg);
    transform: rotate3d(0, 0, 1, -5deg); }

  to {
    -webkit-transform: rotate3d(0, 0, 1, 0deg);
    transform: rotate3d(0, 0, 1, 0deg); } }

.swing {
  -webkit-transform-origin: top center;
  transform-origin: top center;
  -webkit-animation-name: swing;
  animation-name: swing; }

@-webkit-keyframes tada {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }

  10%, 20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg); }

  30%, 50%, 70%, 90% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg); }

  40%, 60%, 80% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg); }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }

@keyframes tada {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }

  10%, 20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg); }

  30%, 50%, 70%, 90% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg); }

  40%, 60%, 80% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg); }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }

.tada {
  -webkit-animation-name: tada;
  animation-name: tada;
  /* originally authored by Nick Pettit - https://github.com/nickpettit/glide */ }

@-webkit-keyframes wobble {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  15% {
    -webkit-transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
    transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg); }

  30% {
    -webkit-transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
    transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg); }

  45% {
    -webkit-transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
    transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg); }

  60% {
    -webkit-transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
    transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg); }

  75% {
    -webkit-transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
    transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg); }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes wobble {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  15% {
    -webkit-transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
    transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg); }

  30% {
    -webkit-transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
    transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg); }

  45% {
    -webkit-transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
    transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg); }

  60% {
    -webkit-transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
    transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg); }

  75% {
    -webkit-transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
    transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg); }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.wobble {
  -webkit-animation-name: wobble;
  animation-name: wobble; }

@-webkit-keyframes jello {
  from, 11.1%, to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  22.2% {
    -webkit-transform: skewX(-12.5deg) skewY(-12.5deg);
    transform: skewX(-12.5deg) skewY(-12.5deg); }

  33.3% {
    -webkit-transform: skewX(6.25deg) skewY(6.25deg);
    transform: skewX(6.25deg) skewY(6.25deg); }

  44.4% {
    -webkit-transform: skewX(-3.125deg) skewY(-3.125deg);
    transform: skewX(-3.125deg) skewY(-3.125deg); }

  55.5% {
    -webkit-transform: skewX(1.5625deg) skewY(1.5625deg);
    transform: skewX(1.5625deg) skewY(1.5625deg); }

  66.6% {
    -webkit-transform: skewX(-0.78125deg) skewY(-0.78125deg);
    transform: skewX(-0.78125deg) skewY(-0.78125deg); }

  77.7% {
    -webkit-transform: skewX(0.39063deg) skewY(0.39063deg);
    transform: skewX(0.39063deg) skewY(0.39063deg); }

  88.8% {
    -webkit-transform: skewX(-0.19531deg) skewY(-0.19531deg);
    transform: skewX(-0.19531deg) skewY(-0.19531deg); } }

@keyframes jello {
  from, 11.1%, to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  22.2% {
    -webkit-transform: skewX(-12.5deg) skewY(-12.5deg);
    transform: skewX(-12.5deg) skewY(-12.5deg); }

  33.3% {
    -webkit-transform: skewX(6.25deg) skewY(6.25deg);
    transform: skewX(6.25deg) skewY(6.25deg); }

  44.4% {
    -webkit-transform: skewX(-3.125deg) skewY(-3.125deg);
    transform: skewX(-3.125deg) skewY(-3.125deg); }

  55.5% {
    -webkit-transform: skewX(1.5625deg) skewY(1.5625deg);
    transform: skewX(1.5625deg) skewY(1.5625deg); }

  66.6% {
    -webkit-transform: skewX(-0.78125deg) skewY(-0.78125deg);
    transform: skewX(-0.78125deg) skewY(-0.78125deg); }

  77.7% {
    -webkit-transform: skewX(0.39063deg) skewY(0.39063deg);
    transform: skewX(0.39063deg) skewY(0.39063deg); }

  88.8% {
    -webkit-transform: skewX(-0.19531deg) skewY(-0.19531deg);
    transform: skewX(-0.19531deg) skewY(-0.19531deg); } }

.jello {
  -webkit-animation-name: jello;
  animation-name: jello;
  -webkit-transform-origin: center;
  transform-origin: center; }

@-webkit-keyframes bounceIn {
  from, 20%, 40%, 60%, 80%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

  0% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); }

  20% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1); }

  40% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9); }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(1.03, 1.03, 1.03);
    transform: scale3d(1.03, 1.03, 1.03); }

  80% {
    -webkit-transform: scale3d(0.97, 0.97, 0.97);
    transform: scale3d(0.97, 0.97, 0.97); }

  to {
    opacity: 1;
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }

@keyframes bounceIn {
  from, 20%, 40%, 60%, 80%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

  0% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); }

  20% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1); }

  40% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9); }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(1.03, 1.03, 1.03);
    transform: scale3d(1.03, 1.03, 1.03); }

  80% {
    -webkit-transform: scale3d(0.97, 0.97, 0.97);
    transform: scale3d(0.97, 0.97, 0.97); }

  to {
    opacity: 1;
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }

.bounceIn {
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-animation-name: bounceIn;
  animation-name: bounceIn; }

@-webkit-keyframes bounceInDown {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -3000px, 0);
    transform: translate3d(0, -3000px, 0); }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, 25px, 0);
    transform: translate3d(0, 25px, 0); }

  75% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0); }

  90% {
    -webkit-transform: translate3d(0, 5px, 0);
    transform: translate3d(0, 5px, 0); }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes bounceInDown {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -3000px, 0);
    transform: translate3d(0, -3000px, 0); }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, 25px, 0);
    transform: translate3d(0, 25px, 0); }

  75% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0); }

  90% {
    -webkit-transform: translate3d(0, 5px, 0);
    transform: translate3d(0, 5px, 0); }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.bounceInDown {
  -webkit-animation-name: bounceInDown;
  animation-name: bounceInDown; }

@-webkit-keyframes bounceInLeft {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

  0% {
    opacity: 0;
    -webkit-transform: translate3d(-3000px, 0, 0);
    transform: translate3d(-3000px, 0, 0); }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(25px, 0, 0);
    transform: translate3d(25px, 0, 0); }

  75% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0); }

  90% {
    -webkit-transform: translate3d(5px, 0, 0);
    transform: translate3d(5px, 0, 0); }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes bounceInLeft {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

  0% {
    opacity: 0;
    -webkit-transform: translate3d(-3000px, 0, 0);
    transform: translate3d(-3000px, 0, 0); }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(25px, 0, 0);
    transform: translate3d(25px, 0, 0); }

  75% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0); }

  90% {
    -webkit-transform: translate3d(5px, 0, 0);
    transform: translate3d(5px, 0, 0); }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.bounceInLeft {
  -webkit-animation-name: bounceInLeft;
  animation-name: bounceInLeft; }

@-webkit-keyframes bounceInRight {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

  from {
    opacity: 0;
    -webkit-transform: translate3d(3000px, 0, 0);
    transform: translate3d(3000px, 0, 0); }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(-25px, 0, 0);
    transform: translate3d(-25px, 0, 0); }

  75% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0); }

  90% {
    -webkit-transform: translate3d(-5px, 0, 0);
    transform: translate3d(-5px, 0, 0); }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes bounceInRight {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

  from {
    opacity: 0;
    -webkit-transform: translate3d(3000px, 0, 0);
    transform: translate3d(3000px, 0, 0); }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(-25px, 0, 0);
    transform: translate3d(-25px, 0, 0); }

  75% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0); }

  90% {
    -webkit-transform: translate3d(-5px, 0, 0);
    transform: translate3d(-5px, 0, 0); }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.bounceInRight {
  -webkit-animation-name: bounceInRight;
  animation-name: bounceInRight; }

@-webkit-keyframes bounceInUp {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 3000px, 0);
    transform: translate3d(0, 3000px, 0); }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0); }

  75% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0); }

  90% {
    -webkit-transform: translate3d(0, -5px, 0);
    transform: translate3d(0, -5px, 0); }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes bounceInUp {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 3000px, 0);
    transform: translate3d(0, 3000px, 0); }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0); }

  75% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0); }

  90% {
    -webkit-transform: translate3d(0, -5px, 0);
    transform: translate3d(0, -5px, 0); }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.bounceInUp {
  -webkit-animation-name: bounceInUp;
  animation-name: bounceInUp; }

@-webkit-keyframes bounceOut {
  20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9); }

  50%, 55% {
    opacity: 1;
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1); }

  to {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); } }

@keyframes bounceOut {
  20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9); }

  50%, 55% {
    opacity: 1;
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1); }

  to {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); } }

.bounceOut {
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-animation-name: bounceOut;
  animation-name: bounceOut; }

@-webkit-keyframes bounceOutDown {
  20% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0); }

  40%, 45% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0); }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0); } }

@keyframes bounceOutDown {
  20% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0); }

  40%, 45% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0); }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0); } }

.bounceOutDown {
  -webkit-animation-name: bounceOutDown;
  animation-name: bounceOutDown; }

@-webkit-keyframes bounceOutLeft {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(20px, 0, 0);
    transform: translate3d(20px, 0, 0); }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0); } }

@keyframes bounceOutLeft {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(20px, 0, 0);
    transform: translate3d(20px, 0, 0); }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0); } }

.bounceOutLeft {
  -webkit-animation-name: bounceOutLeft;
  animation-name: bounceOutLeft; }

@-webkit-keyframes bounceOutRight {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(-20px, 0, 0);
    transform: translate3d(-20px, 0, 0); }

  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0); } }

@keyframes bounceOutRight {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(-20px, 0, 0);
    transform: translate3d(-20px, 0, 0); }

  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0); } }

.bounceOutRight {
  -webkit-animation-name: bounceOutRight;
  animation-name: bounceOutRight; }

@-webkit-keyframes bounceOutUp {
  20% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0); }

  40%, 45% {
    opacity: 1;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0); }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0); } }

@keyframes bounceOutUp {
  20% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0); }

  40%, 45% {
    opacity: 1;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0); }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0); } }

.bounceOutUp {
  -webkit-animation-name: bounceOutUp;
  animation-name: bounceOutUp; }

@-webkit-keyframes fadeIn {
  from {
    opacity: 0; }

  to {
    opacity: 1; } }

@keyframes fadeIn {
  from {
    opacity: 0; }

  to {
    opacity: 1; } }

.fadeIn {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn; }

@-webkit-keyframes fadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes fadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.fadeInDown {
  -webkit-animation-name: fadeInDown;
  animation-name: fadeInDown; }

@-webkit-keyframes fadeInDownBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes fadeInDownBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.fadeInDownBig {
  -webkit-animation-name: fadeInDownBig;
  animation-name: fadeInDownBig; }

@-webkit-keyframes fadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes fadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.fadeInLeft {
  -webkit-animation-name: fadeInLeft;
  animation-name: fadeInLeft; }

@-webkit-keyframes fadeInLeftBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes fadeInLeftBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.fadeInLeftBig {
  -webkit-animation-name: fadeInLeftBig;
  animation-name: fadeInLeftBig; }

@-webkit-keyframes fadeInRight {
  from {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes fadeInRight {
  from {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.fadeInRight {
  -webkit-animation-name: fadeInRight;
  animation-name: fadeInRight; }

@-webkit-keyframes fadeInRightBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes fadeInRightBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.fadeInRightBig {
  -webkit-animation-name: fadeInRightBig;
  animation-name: fadeInRightBig; }

@-webkit-keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.fadeInUp {
  -webkit-animation-name: fadeInUp;
  animation-name: fadeInUp; }

@-webkit-keyframes fadeInUpBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes fadeInUpBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.fadeInUpBig {
  -webkit-animation-name: fadeInUpBig;
  animation-name: fadeInUpBig; }

@-webkit-keyframes fadeOut {
  from {
    opacity: 1; }

  to {
    opacity: 0; } }

@keyframes fadeOut {
  from {
    opacity: 1; }

  to {
    opacity: 0; } }

.fadeOut {
  -webkit-animation-name: fadeOut;
  animation-name: fadeOut; }

@-webkit-keyframes fadeOutDown {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); } }

@keyframes fadeOutDown {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); } }

.fadeOutDown {
  -webkit-animation-name: fadeOutDown;
  animation-name: fadeOutDown; }

@-webkit-keyframes fadeOutDownBig {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0); } }

@keyframes fadeOutDownBig {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0); } }

.fadeOutDownBig {
  -webkit-animation-name: fadeOutDownBig;
  animation-name: fadeOutDownBig; }

@-webkit-keyframes fadeOutLeft {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); } }

@keyframes fadeOutLeft {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); } }

.fadeOutLeft {
  -webkit-animation-name: fadeOutLeft;
  animation-name: fadeOutLeft; }

@-webkit-keyframes fadeOutLeftBig {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0); } }

@keyframes fadeOutLeftBig {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0); } }

.fadeOutLeftBig {
  -webkit-animation-name: fadeOutLeftBig;
  animation-name: fadeOutLeftBig; }

@-webkit-keyframes fadeOutRight {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0); } }

@keyframes fadeOutRight {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0); } }

.fadeOutRight {
  -webkit-animation-name: fadeOutRight;
  animation-name: fadeOutRight; }

@-webkit-keyframes fadeOutRightBig {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0); } }

@keyframes fadeOutRightBig {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0); } }

.fadeOutRightBig {
  -webkit-animation-name: fadeOutRightBig;
  animation-name: fadeOutRightBig; }

@-webkit-keyframes fadeOutUp {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); } }

@keyframes fadeOutUp {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); } }

.fadeOutUp {
  -webkit-animation-name: fadeOutUp;
  animation-name: fadeOutUp; }

@-webkit-keyframes fadeOutUpBig {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0); } }

@keyframes fadeOutUpBig {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0); } }

.fadeOutUpBig {
  -webkit-animation-name: fadeOutUpBig;
  animation-name: fadeOutUpBig; }

@-webkit-keyframes flip {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }

  40% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }

  50% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }

  80% {
    -webkit-transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; } }

@keyframes flip {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }

  40% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }

  50% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }

  80% {
    -webkit-transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; } }

.animated.flip {
  -webkit-backface-visibility: visible;
  backface-visibility: visible;
  -webkit-animation-name: flip;
  animation-name: flip; }

@-webkit-keyframes flipInX {
  from {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0; }

  40% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }

  60% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    opacity: 1; }

  80% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -5deg); }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); } }

@keyframes flipInX {
  from {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0; }

  40% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }

  60% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    opacity: 1; }

  80% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -5deg); }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); } }

.flipInX {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipInX;
  animation-name: flipInX; }

@-webkit-keyframes flipInY {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0; }

  40% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }

  60% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    opacity: 1; }

  80% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -5deg); }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); } }

@keyframes flipInY {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0; }

  40% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }

  60% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    opacity: 1; }

  80% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -5deg); }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); } }

.flipInY {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipInY;
  animation-name: flipInY; }

@-webkit-keyframes flipOutX {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); }

  30% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    opacity: 1; }

  to {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    opacity: 0; } }

@keyframes flipOutX {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); }

  30% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    opacity: 1; }

  to {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    opacity: 0; } }

.flipOutX {
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-animation-name: flipOutX;
  animation-name: flipOutX;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important; }

@-webkit-keyframes flipOutY {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); }

  30% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    opacity: 1; }

  to {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    opacity: 0; } }

@keyframes flipOutY {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); }

  30% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    opacity: 1; }

  to {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    opacity: 0; } }

.flipOutY {
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipOutY;
  animation-name: flipOutY; }

@-webkit-keyframes lightSpeedIn {
  from {
    -webkit-transform: translate3d(100%, 0, 0) skewX(-30deg);
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0; }

  60% {
    -webkit-transform: skewX(20deg);
    transform: skewX(20deg);
    opacity: 1; }

  80% {
    -webkit-transform: skewX(-5deg);
    transform: skewX(-5deg);
    opacity: 1; }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1; } }

@keyframes lightSpeedIn {
  from {
    -webkit-transform: translate3d(100%, 0, 0) skewX(-30deg);
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0; }

  60% {
    -webkit-transform: skewX(20deg);
    transform: skewX(20deg);
    opacity: 1; }

  80% {
    -webkit-transform: skewX(-5deg);
    transform: skewX(-5deg);
    opacity: 1; }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1; } }

.lightSpeedIn {
  -webkit-animation-name: lightSpeedIn;
  animation-name: lightSpeedIn;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out; }

@-webkit-keyframes lightSpeedOut {
  from {
    opacity: 1; }

  to {
    -webkit-transform: translate3d(100%, 0, 0) skewX(30deg);
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0; } }

@keyframes lightSpeedOut {
  from {
    opacity: 1; }

  to {
    -webkit-transform: translate3d(100%, 0, 0) skewX(30deg);
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0; } }

.lightSpeedOut {
  -webkit-animation-name: lightSpeedOut;
  animation-name: lightSpeedOut;
  -webkit-animation-timing-function: ease-in;
  animation-timing-function: ease-in; }

@-webkit-keyframes rotateIn {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, -200deg);
    transform: rotate3d(0, 0, 1, -200deg);
    opacity: 0; }

  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1; } }

@keyframes rotateIn {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, -200deg);
    transform: rotate3d(0, 0, 1, -200deg);
    opacity: 0; }

  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1; } }

.rotateIn {
  -webkit-animation-name: rotateIn;
  animation-name: rotateIn; }

@-webkit-keyframes rotateInDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1; } }

@keyframes rotateInDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1; } }

.rotateInDownLeft {
  -webkit-animation-name: rotateInDownLeft;
  animation-name: rotateInDownLeft; }

@-webkit-keyframes rotateInDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1; } }

@keyframes rotateInDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1; } }

.rotateInDownRight {
  -webkit-animation-name: rotateInDownRight;
  animation-name: rotateInDownRight; }

@-webkit-keyframes rotateInUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1; } }

@keyframes rotateInUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1; } }

.rotateInUpLeft {
  -webkit-animation-name: rotateInUpLeft;
  animation-name: rotateInUpLeft; }

@-webkit-keyframes rotateInUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -90deg);
    transform: rotate3d(0, 0, 1, -90deg);
    opacity: 0; }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1; } }

@keyframes rotateInUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -90deg);
    transform: rotate3d(0, 0, 1, -90deg);
    opacity: 0; }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1; } }

.rotateInUpRight {
  -webkit-animation-name: rotateInUpRight;
  animation-name: rotateInUpRight; }

@-webkit-keyframes rotateOut {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    opacity: 1; }

  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, 200deg);
    transform: rotate3d(0, 0, 1, 200deg);
    opacity: 0; } }

@keyframes rotateOut {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    opacity: 1; }

  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, 200deg);
    transform: rotate3d(0, 0, 1, 200deg);
    opacity: 0; } }

.rotateOut {
  -webkit-animation-name: rotateOut;
  animation-name: rotateOut; }

@-webkit-keyframes rotateOutDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1; }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; } }

@keyframes rotateOutDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1; }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; } }

.rotateOutDownLeft {
  -webkit-animation-name: rotateOutDownLeft;
  animation-name: rotateOutDownLeft; }

@-webkit-keyframes rotateOutDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1; }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; } }

@keyframes rotateOutDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1; }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; } }

.rotateOutDownRight {
  -webkit-animation-name: rotateOutDownRight;
  animation-name: rotateOutDownRight; }

@-webkit-keyframes rotateOutUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1; }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; } }

@keyframes rotateOutUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1; }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; } }

.rotateOutUpLeft {
  -webkit-animation-name: rotateOutUpLeft;
  animation-name: rotateOutUpLeft; }

@-webkit-keyframes rotateOutUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1; }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 90deg);
    transform: rotate3d(0, 0, 1, 90deg);
    opacity: 0; } }

@keyframes rotateOutUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1; }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 90deg);
    transform: rotate3d(0, 0, 1, 90deg);
    opacity: 0; } }

.rotateOutUpRight {
  -webkit-animation-name: rotateOutUpRight;
  animation-name: rotateOutUpRight; }

@-webkit-keyframes hinge {
  0% {
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out; }

  20%, 60% {
    -webkit-transform: rotate3d(0, 0, 1, 80deg);
    transform: rotate3d(0, 0, 1, 80deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out; }

  40%, 80% {
    -webkit-transform: rotate3d(0, 0, 1, 60deg);
    transform: rotate3d(0, 0, 1, 60deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
    opacity: 1; }

  to {
    -webkit-transform: translate3d(0, 700px, 0);
    transform: translate3d(0, 700px, 0);
    opacity: 0; } }

@keyframes hinge {
  0% {
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out; }

  20%, 60% {
    -webkit-transform: rotate3d(0, 0, 1, 80deg);
    transform: rotate3d(0, 0, 1, 80deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out; }

  40%, 80% {
    -webkit-transform: rotate3d(0, 0, 1, 60deg);
    transform: rotate3d(0, 0, 1, 60deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
    opacity: 1; }

  to {
    -webkit-transform: translate3d(0, 700px, 0);
    transform: translate3d(0, 700px, 0);
    opacity: 0; } }

.hinge {
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
  -webkit-animation-name: hinge;
  animation-name: hinge; }

@-webkit-keyframes jackInTheBox {
  from {
    opacity: 0;
    -webkit-transform: scale(0.1) rotate(30deg);
    transform: scale(0.1) rotate(30deg);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom; }

  50% {
    -webkit-transform: rotate(-10deg);
    transform: rotate(-10deg); }

  70% {
    -webkit-transform: rotate(3deg);
    transform: rotate(3deg); }

  to {
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1); } }

@keyframes jackInTheBox {
  from {
    opacity: 0;
    -webkit-transform: scale(0.1) rotate(30deg);
    transform: scale(0.1) rotate(30deg);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom; }

  50% {
    -webkit-transform: rotate(-10deg);
    transform: rotate(-10deg); }

  70% {
    -webkit-transform: rotate(3deg);
    transform: rotate(3deg); }

  to {
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1); } }

.jackInTheBox {
  -webkit-animation-name: jackInTheBox;
  animation-name: jackInTheBox;
  /* originally authored by Nick Pettit - https://github.com/nickpettit/glide */ }

@-webkit-keyframes rollIn {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
    transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes rollIn {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
    transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg); }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.rollIn {
  -webkit-animation-name: rollIn;
  animation-name: rollIn;
  /* originally authored by Nick Pettit - https://github.com/nickpettit/glide */ }

@-webkit-keyframes rollOut {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
    transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg); } }

@keyframes rollOut {
  from {
    opacity: 1; }

  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
    transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg); } }

.rollOut {
  -webkit-animation-name: rollOut;
  animation-name: rollOut; }

@-webkit-keyframes zoomIn {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); }

  50% {
    opacity: 1; } }

@keyframes zoomIn {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); }

  50% {
    opacity: 1; } }

.zoomIn {
  -webkit-animation-name: zoomIn;
  animation-name: zoomIn; }

@-webkit-keyframes zoomInDown {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

@keyframes zoomInDown {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

.zoomInDown {
  -webkit-animation-name: zoomInDown;
  animation-name: zoomInDown; }

@-webkit-keyframes zoomInLeft {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

@keyframes zoomInLeft {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

.zoomInLeft {
  -webkit-animation-name: zoomInLeft;
  animation-name: zoomInLeft; }

@-webkit-keyframes zoomInRight {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

@keyframes zoomInRight {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

.zoomInRight {
  -webkit-animation-name: zoomInRight;
  animation-name: zoomInRight; }

@-webkit-keyframes zoomInUp {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

@keyframes zoomInUp {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

.zoomInUp {
  -webkit-animation-name: zoomInUp;
  animation-name: zoomInUp; }

@-webkit-keyframes zoomOut {
  from {
    opacity: 1; }

  50% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); }

  to {
    opacity: 0; } }

@keyframes zoomOut {
  from {
    opacity: 1; }

  50% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); }

  to {
    opacity: 0; } }

.zoomOut {
  -webkit-animation-name: zoomOut;
  animation-name: zoomOut; }

@-webkit-keyframes zoomOutDown {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

  to {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

@keyframes zoomOutDown {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

  to {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

.zoomOutDown {
  -webkit-animation-name: zoomOutDown;
  animation-name: zoomOutDown; }

@-webkit-keyframes zoomOutLeft {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0); }

  to {
    opacity: 0;
    -webkit-transform: scale(0.1) translate3d(-2000px, 0, 0);
    transform: scale(0.1) translate3d(-2000px, 0, 0);
    -webkit-transform-origin: left center;
    transform-origin: left center; } }

@keyframes zoomOutLeft {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0); }

  to {
    opacity: 0;
    -webkit-transform: scale(0.1) translate3d(-2000px, 0, 0);
    transform: scale(0.1) translate3d(-2000px, 0, 0);
    -webkit-transform-origin: left center;
    transform-origin: left center; } }

.zoomOutLeft {
  -webkit-animation-name: zoomOutLeft;
  animation-name: zoomOutLeft; }

@-webkit-keyframes zoomOutRight {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0); }

  to {
    opacity: 0;
    -webkit-transform: scale(0.1) translate3d(2000px, 0, 0);
    transform: scale(0.1) translate3d(2000px, 0, 0);
    -webkit-transform-origin: right center;
    transform-origin: right center; } }

@keyframes zoomOutRight {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0); }

  to {
    opacity: 0;
    -webkit-transform: scale(0.1) translate3d(2000px, 0, 0);
    transform: scale(0.1) translate3d(2000px, 0, 0);
    -webkit-transform-origin: right center;
    transform-origin: right center; } }

.zoomOutRight {
  -webkit-animation-name: zoomOutRight;
  animation-name: zoomOutRight; }

@-webkit-keyframes zoomOutUp {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

  to {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

@keyframes zoomOutUp {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

  to {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

.zoomOutUp {
  -webkit-animation-name: zoomOutUp;
  animation-name: zoomOutUp; }

@-webkit-keyframes slideInDown {
  from {
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
    visibility: visible; }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes slideInDown {
  from {
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
    visibility: visible; }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.slideInDown {
  -webkit-animation-name: slideInDown;
  animation-name: slideInDown; }

@-webkit-keyframes slideInLeft {
  from {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible; }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes slideInLeft {
  from {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible; }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.slideInLeft {
  -webkit-animation-name: slideInLeft;
  animation-name: slideInLeft; }

@-webkit-keyframes slideInRight {
  from {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible; }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes slideInRight {
  from {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible; }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.slideInRight {
  -webkit-animation-name: slideInRight;
  animation-name: slideInRight; }

@-webkit-keyframes slideInUp {
  from {
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: visible; }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes slideInUp {
  from {
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: visible; }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.slideInUp {
  -webkit-animation-name: slideInUp;
  animation-name: slideInUp; }

@-webkit-keyframes slideOutDown {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); } }

@keyframes slideOutDown {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); } }

.slideOutDown {
  -webkit-animation-name: slideOutDown;
  animation-name: slideOutDown; }

@-webkit-keyframes slideOutLeft {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); } }

@keyframes slideOutLeft {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); } }

.slideOutLeft {
  -webkit-animation-name: slideOutLeft;
  animation-name: slideOutLeft; }

@-webkit-keyframes slideOutRight {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0); } }

@keyframes slideOutRight {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0); } }

.slideOutRight {
  -webkit-animation-name: slideOutRight;
  animation-name: slideOutRight; }

@-webkit-keyframes slideOutUp {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); } }

@keyframes slideOutUp {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); } }

.slideOutUp {
  -webkit-animation-name: slideOutUp;
  animation-name: slideOutUp; }

.pup-layout {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999; }

.pup-image {
  display: none; }

.close-pup-btn {
  background: rgba(135, 205, 200, .4);
  border-radius: 50%;
  display: block;
  margin: 0;
  padding: 0;
  position: absolute;
  top: 10px;
  right: 15px;
  width: 25px;
  height: 25px;
  transition: background 0.2s;
  padding-bottom: 2px; }
  .close-pup-btn:hover {
    background: rgba(135, 205, 200, .8);
    transition: background 0.2s; }
  .close-pup-btn:hover svg path {
    fill: #fff; }
  .close-pup-btn svg {
    width: 12px;
    height: 12px;
    vertical-align: middle; }
  .close-pup-btn svg path {
    fill: #000; }

.pup-flex {
  display: flex;
  align-items: center;
  height: 100%;
  justify-content: center; }

.pup-encart {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  background: #fff;
  max-width: 830px;
  width: 100%;
  margin: auto;
  box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.3); }

.pup-bg {
  min-height: 480px;
  height: 100%;
  display: block; }

.pup-content {
  height: 100%;
  padding: 30px;
  display: grid;
  grid-template-rows: 1fr min-content;
  gap: 24px;
  justify-content: space-between; }

.pup-title {
  font-size: 23px;
  font-family: 'PoliceStudioVedette', Arial, sans-serif; }

.pup-link-description {
  margin-top: 16px;
  font-size: 12px; }

@media all and (min-width: 768px) {
  .pup-layout {
    background: rgba(0, 0, 0, .75); }

  .pup-image {
    display: block; }

  .pup-encart {
    border-radius: 5px;
    overflow: hidden;
    grid-template-columns: 1fr 1fr; } }

@media all and (max-width: 767px) {
  .pup-not-mobile {
    display: none; }

  .pup-encart {
    position: absolute;
    bottom: 0; }

  .pup-link a {
    display: block;
    text-align: center; } }

@media screen and (max-width: 1350px) {
  .stupid-overlaping-block-less-stupid {
    margin-top: 0; } }

@media screen and (max-width: 1250px) {
  .block-content {
    padding-left: 30px;
    padding-right: 30px; }

  .big-slideshow .cycle-carousel-wrap {
    margin-left: 90px !important; }

  .steps-item {
    width: 150px;
    font-size: 0.8rem; }

  .stupid-overlaping-block {
    margin-top: -300px; } }

@media screen and (max-width: 1150px) {
  .opening {
    top: -35px; }

  .trip-certificat {
    top: -35px; }

  .logo img {
    width: 400px;
    height: 35px; }

  .home-post-3 {
    margin-top: -100px; }

  .social-item {
    height: 225px; }

  .insta-feed-container-small .social-item {
    height: 175px; }

  .social-item-content {
    display: none; }

  .steps-item {
    width: 130px; }
    .steps-item img {
      max-width: 60px;
      max-height: 60px; }

  .stupid-overlaping-block {
    margin-top: -200px; }

  .menu-hotel a {
    height: 310px; }

  .room-text {
    padding: 30px 0 30px 30px; }

  .room:nth-child(even) .room-text {
    padding: 30px 30px 30px 0; }

  .last-room-bottom > div:first-child {
    padding: 30px 30px 30px 0; }

  .footer-top > div {
    padding-left: 30px;
    padding-right: 30px; } }

@media screen and (max-width: 1024px) {
  .big-slideshow .cycle-carousel-wrap {
    margin-left: 0 !important; }

  .opening {
    top: 95px; }

  .trip-certificat {
    top: 95px; } }

@media screen and (min-width: 768px) and (max-width: 1023px) {
  .menu-container {
    padding-left: 16px;
    padding-right: 16px;
    text-align: center; }

  .menu li {
    padding: 0 15px; }

  .home-menu-btn {
    font-size: 3rem; }

  .menu-page {
    width: 255px;
    padding: 30px 16px 16px; }
    .menu-page ul {
      font-size: 1.3rem; }

  .hotel-intro h2 {
    padding-left: 0;
    margin-right: 0; }

  .hotel-intro-steps {
    display: block; }

  .steps-item {
    width: 90px; }

  .menu-hotel ul {
    font-size: 2.5rem; }

  .stupid-overlaping-block {
    margin-top: 0; }

  .cafe-chill {
    height: auto; }
    .cafe-chill img {
      position: static;
      display: block;
      margin: 0 auto 1em;
      left: auto;
      top: auto; }

  .cafe-chill-text1, .cafe-chill-text2, .cafe-chill-text3 {
    position: static;
    width: 100%;
    left: auto;
    top: auto; }

  .offer-logo {
    width: 164px;
    height: 164px;
    right: 110px;
    top: 150px; }

  .offer:nth-child(even) .offer-logo {
    left: 120px; }

  .map-overlay {
    right: 30px;
    bottom: 80px; }

  .come {
    flex-flow: row wrap; }

  .come-left, .come-right {
    flex-basis: 100%; }

  .come-item, .come-item-high {
    height: 400px; }

  .come-item-content {
    left: 10px;
    right: 10px;
    top: 10px;
    bottom: 10px; }

  .social-item {
    height: 165px; }

  .footer {
    padding-bottom: 80px; }

  .footer-content {
    padding-left: 16px;
    padding-right: 16px; }

  .footer-logo img {
    width: 210px;
    height: 155px; } }

@media screen and (max-width: 767px) {
  .min-340 img, .min-605 img {
    height: 320px;
    object-fit: cover; }

  .btn-gift {
    display: none; }

  body {
    padding-top: 50px; }

  .m-mb {
    margin-bottom: 1em; }

  .header {
    min-height: 0;
    padding: 14px 0 14px 5px; }

  .header-content {
    padding: 0; }
    .header-content > div:first-child {
      flex-basis: initial;
      padding-left: 5px; }

  .logo img {
    width: 240px;
    height: 23px;
    object-fit: contain; }

  .btn-menu-mobile {
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 41px;
    height: 51px;
    right: 0;
    top: 0;
    background: #87cdc8; }
    .btn-menu-mobile.active .btn-menu-icon:before {
      top: 50%;
      transform: rotate(-45deg);
      transition: all 0.3s; }
      .btn-menu-mobile.active .btn-menu-icon span {
        opacity: 0;
        transition: all 0.3s; }
      .btn-menu-mobile.active .btn-menu-icon:after {
        width: 100%;
        top: 50%;
        transform: rotate(45deg);
        transition: all 0.3s; }

  .btn-menu-icon {
    position: relative;
    width: 17px;
    height: 10px;
    background: #87cdc8; }
    .btn-menu-icon:before {
      content: '';
      position: absolute;
      width: 100%;
      height: 2px;
      left: 0;
      top: 0;
      background: #fff;
      transition: all 0.3s; }
    .btn-menu-icon span {
      position: absolute;
      width: 100%;
      height: 2px;
      left: 0;
      top: 4px;
      background: #fff;
      transition: all 0.3s; }
    .btn-menu-icon:after {
      content: '';
      position: absolute;
      width: 80%;
      height: 2px;
      left: 0;
      top: 8px;
      background: #fff;
      transition: all 0.3s; }

  .menu-container {
    display: none;
    padding: 1.5em 0; }

  .menu {
    flex-flow: row wrap;
    font-size: 1.3rem; }
    .menu li {
      width: 100%;
      padding: 0 0 0 10px; }
    .menu a:after {
      width: 100%; }

  .btn-gift {
    position: fixed;
    justify-content: center;
    width: 102px;
    height: 102px;
    right: 5px;
    bottom: 290px;
    border-radius: 50%; }

  .btn-book {
    position: fixed;
    justify-content: center;
    width: 100%;
    height: 40px;
    right: 0;
    bottom: 0; }
    .btn-book svg {
      display: none; }
    .btn-book span {
      flex-basis: initial; }

  .btn-book-meeting {
    z-index: 202;
    position: fixed;
    align-items: center;
    justify-content: center;
    width: 102px;
    height: 102px;
    right: 5px;
    bottom: 60px;
    border-radius: 50%; }
    .btn-book-meeting svg {
      display: none; }
    .btn-book-meeting span {
      flex-basis: initial; }

  .opening {
    z-index: 200;
    left: auto;
    right: 5px;
    top: 58px; }

  .trip-certificat {
    z-index: 200;
    left: auto;
    right: 5px;
    top: 58px; }

  .menu-contact {
    display: none; }

  h1, h2.h1 {
    font-size: 1.8rem; }
    h1 em, h2.h1 em {
      font-size: 1.2rem; }

  .m-padded {
    padding-left: 16px;
    padding-right: 16px; }

  .block-content {
    padding-left: 0;
    padding-right: 0; }

  .text {
    padding-left: 16px;
    padding-right: 16px; }

  .home-menu {
    height: auto; }
    .home-menu > div {
      flex-basis: 100%;
      margin: 0 0 1em; }

  .home-menu-btn {
    height: 200px; }

  .big-slideshow {
    height: 300px; }
    .big-slideshow .cycle-carousel-wrap {
      width: 100%; }

  .big-slideshow-room-info {
    z-index: 200;
    width: 100%;
    min-width: 0;
    left: 0;
    bottom: 0; }
    .big-slideshow-room-info .btn {
      padding-left: 0.8em;
      padding-right: 0.8em; }

  .big-slideshow-item {
    width: 100%;
    margin: 0; }

  .big-slideshow-room-info-name strong {
    font-size: 0.9rem; }

  .big-slideshow-prev, .big-slideshow-next {
    padding: 0.4em;
    font-size: 0.9rem; }

  .home-offers {
    flex-flow: row wrap; }

  .home-offer {
    flex-basis: calc(50% - 4px);
    margin-bottom: 8px; }

  .home-post {
    flex-flow: row wrap;
    margin: 0 0 1.5em; }
    .home-post h2, .home-post h3 {
      padding-left: 16px;
      padding-right: 16px; }
    .home-post .btn {
      padding-left: 1em;
      padding-right: 1em; }

  .home-post-1 > div:first-child, .home-post-2 > div:first-child, .home-post-3 > div:first-child, .home-post-1 > div:last-child, .home-post-2 > div:last-child, .home-post-3 > div:last-child {
    flex-basis: 100%; }
    .home-post-1 > div:last-child, .home-post-2 > div:last-child, .home-post-3 > div:last-child {
      padding: 16px 0; }

  .home-post-3 {
    margin-top: 0; }

  .home-post-date {
    right: 5px;
    top: 5px; }

  .btn-img {
    height: 200px; }

  .home-post-btns {
    padding-left: 16px;
    padding-right: 16px; }

  .social-item {
    flex-basis: calc(50% - 8px);
    height: 135px; }
    .social-item:nth-child(n + 6) {
      display: none; }

  .social-item-first {
    flex-basis: 100%;
    margin-bottom: 2em; }
    .social-item-first svg {
      margin-bottom: 1em; }

  .menu-page-mosa-container {
    display: none; }

  .room {
    flex-flow: row wrap; }
    .room:nth-child(even) .room-services {
      justify-content: center; }

  .room-gallery {
    flex-basis: 100%;
    height: 320px; }

  .room-text {
    flex-basis: 100%;
    padding: 16px 0; }

  .room-services {
    justify-content: center; }

  div.last-room-top {
    flex-flow: row wrap; }
    div.last-room-top > div {
      flex-basis: 100%; }
    div.last-room-top img {
      display: block;
      width: 100%;
      height: auto;
      margin-bottom: 1em; }

  .last-room-bottom {
    flex-flow: row-reverse wrap; }
    .last-room-bottom > div:first-child {
      flex-basis: 100%;
      padding: 16px 0; }
      .last-room-bottom > div:last-child {
        flex-basis: 100%; }

  .h1-hotel, .h1-cafe, .h1-studio {
    padding: 0 16px;
    font-size: 2.2rem;
    text-align: left; }

  .menu-page-mobile {
    overflow-x: auto;
    margin: 0 0 1.5em;
    color: #fff;
    font-family: 'PoliceStudioVedette', Arial, sans-serif;
    font-size: 1.1rem;
    text-align: center;
    background: #dadada;
    white-space: nowrap; }
    .menu-page-mobile ul {
      display: flex;
      align-items: center; }
    .menu-page-mobile a, .menu-page-mobile button {
      display: block;
      padding: 0.5em 1.5em;
      color: #fff; }

  .hotel-intro {
    padding: 32px 0; }
    .hotel-intro h2 {
      max-width: none;
      padding: 0;
      margin-right: 0;
      text-align: center; }

  .hotel-intro-steps {
    display: block; }

  .steps-line {
    display: block;
    text-align: center; }
    .steps-line:before {
      display: none; }

  .steps-line-title {
    width: 130px;
    min-height: 50px;
    margin: 0 auto; }

  .steps-item {
    display: inline-block;
    margin-left: 16px;
    margin-right: 16px; }

  .steps-line-spaced .steps-item {
    margin-left: 16px;
    margin-right: 16px; }

  .block-text-img, .m-cols {
    margin-bottom: 16px; }
    .block-text-img .f3, .m-cols .f3, .block-text-img .f4, .m-cols .f4, .block-text-img .f5, .m-cols .f5, .block-text-img .f6, .m-cols .f6, .block-text-img .f7, .m-cols .f7 {
      flex-basis: 100%; }
    .block-text-img > div:first-child, .m-cols > div:first-child {
      margin-bottom: 1em; }
    .block-text-img .text, .m-cols .text {
      padding-top: 0; }

  .stupid-overlaping-block {
    margin-top: 0; }

  .menu-hotel div {
    background: none; }
    .menu-hotel ul {
      flex-flow: row wrap; }
    .menu-hotel li {
      flex-basis: 100%;
      margin-bottom: 16px; }
    .menu-hotel a {
      height: 240px; }
      .menu-hotel a:hover div, .menu-hotel a:focus div {
        background: none; }

  .menu-page-detail {
    padding-left: 16px;
    padding-right: 16px; }

  .cafe-chill-text1, .cafe-chill-text2, .cafe-chill-text3 {
    position: static;
    width: 100%;
    left: auto;
    top: auto;
    padding-left: 16px;
    padding-right: 16px; }

  .cafe-chill {
    height: auto; }
    .cafe-chill img {
      position: static;
      width: 100%;
      height: auto;
      left: auto;
      right: auto;
      top: auto;
      bottom: auto; }

  .studio, .studio-big {
    height: 420px; }

  .studio-content {
    display: block;
    padding: 16px;
    left: 16px;
    right: 16px;
    top: 16px;
    bottom: 16px; }

  .studio-details {
    flex-flow: row wrap;
    justify-content: center; }

  .shop-splash {
    height: 80%; }

  .slideshow-shop-container {
    display: none; }

  .offer {
    flex-flow: row wrap; }

  .offer-img {
    flex-basis: 100%;
    margin-bottom: 1em; }

  .offer-text {
    flex-basis: 100%; }
    .offer-text .text {
      width: 100%; }

  .offer-logo {
    width: 150px;
    height: 150px;
    right: 5px;
    top: 5px; }

  .post {
    flex-flow: row wrap; }

  .post-img {
    flex-basis: 100%;
    margin-bottom: 1em; }

  .post-content {
    flex-basis: 100%; }
    .post-content h2 {
      padding-left: 16px;
      padding-right: 16px; }
    .post-content .btn-with-arrow {
      margin-right: 16px; }

  .post-event .post-content-text {
    padding: 0 16px; }

  .post-date {
    padding: 0 16px;
    margin: 0 0 1em; }

  .post-event-date {
    left: 5px;
    top: 5px; }

  .menu-page {
    display: none; }

  .location-splash {
    height: auto; }

  #map {
    position: static;
    height: 320px;
    margin-bottom: 1em; }

  .map-overlay {
    position: static;
    width: 100%;
    padding: 16px;
    right: auto;
    bottom: auto; }

  .come {
    flex-flow: row wrap; }

  .come-left, .come-right {
    flex-basis: 100%; }

  .come-item, .come-item-high {
    height: 400px; }

  .menu-gallery {
    display: none; }

  .grid-sizer, .gallery-item {
    flex-basis: calc(50% - 5px);
    width: calc(50% - 5px);
    height: 200px; }

  .gallery-item:nth-child(8n - 5) {
    height: 200px; }
    .gallery-item:nth-child(8n - 2) {
      width: calc(50% - 5px);
      flex-basis: calc(50% - 5px);
      height: 200px; }

  .press-item {
    width: calc(50% - 5px);
    height: 200px;
    margin: 0 0 10px; }
    .press-item img {
      width: 100%;
      height: 100%;
      object-fit: cover; }

  .journal-item {
    flex-flow: row wrap;
    margin-bottom: 1em; }
    .journal-item h2 {
      padding-left: 16px;
      padding-right: 16px; }
    .journal-item .btn-with-arrow {
      margin-left: 16px; }

  .journal-img {
    flex-basis: 100%; }
    .journal-img img {
      display: block;
      width: 100%;
      height: auto; }

  .journal-text {
    flex-basis: 100%; }

  .journal-date {
    padding-left: 16px;
    padding-right: 16px; }

  .jobs {
    flex-flow: row wrap; }

  .jobs-content {
    flex-basis: 100%; }

  .job-content {
    width: 100%; }

  .job-content-close {
    text-align: left; }

  .jobs-about {
    flex-basis: 100%; }

  .jobs-sizer {
    width: 100%; }

  .job-item {
    width: 100%; }
    .job-item:nth-child(2) {
      width: 100%; }
    .job-item:nth-child(8) {
      width: 100%; }

  .quote {
    font-size: 1.2rem;
    line-height: 1.4em; }

  .footer {
    padding: 16px 0 126px; }

  .footer-content {
    padding-left: 16px;
    padding-right: 16px; }

  .footer-top {
    flex-flow: row wrap;
    text-align: center; }
    .footer-top > div {
      flex-basis: 100%;
      padding: 0;
      margin: 0 0 1em;
      border-right: none; }

  .footer-logo img {
    width: 200px;
    height: 148px; } }

.newsletter {
  position: relative;
  padding: 0 30px 50px; }
  .newsletter h2 {
    margin-bottom: 2em;
    text-transform: uppercase; }
  .newsletter .ns-icon {
    position: absolute;
    right: 100px; }
  .newsletter .ns-icon svg {
    fill: rgba(0, 0, 0, .3);
    width: 320px;
    height: 320px; }

.newsletter-form {
  max-width: 640px;
  width: 100%;
  margin: auto; }
  .newsletter-form .icon {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 25px; }
  .newsletter-form .icon svg {
    width: 25px;
    height: 25px; }
  .newsletter-form label {
    display: block;
    position: relative;
    width: 80%;
    margin: 0 auto 10px; }
  .newsletter-form input[type="email"] {
    background: none;
    border: none;
    padding: 10px 5px 10px 35px;
    border-bottom: 1px solid;
    bottom: 25%;
    width: 100%;
    font-size: 15px;
    letter-spacing: 2px; }
  .newsletter-form input[type="email"]:hover {
    background: rgba(0, 0, 0, 0.1); }
  .newsletter-form input[type="email"].ajax-form-error + .form-error {
    display: block; }
  .newsletter-form input[type="checkbox"] {
    appearance: checkbox;
    width: 15px;
    height: 14px;
    vertical-align: bottom; }
  .newsletter-form button {
    border: none;
    cursor: pointer;
    margin-top: 2em;
    padding: 13px 28px;
    background: #87cdc8; }
  .newsletter-form button:after, .newsletter-form button:before {
    background: #000; }

.ajax-form-in-error.form-error {
  display: block; }

.newsletter-recaptcha.ajax-form-error + .form-error {
  display: block;
  text-align: center; }
  .newsletter-recaptcha > div {
    margin: 20px auto 0; }

@media all and (max-width: 767px) {
  .newsletter .ns-icon {
    left: 0; }
    .newsletter .ns-icon svg {
      fill: rgba(0, 0, 0, .1); } }

:root {
  --header-height: 100px;
  --header-dark: #212121; }

.btn-book-container {
  position: relative; }
  .btn-book-container:hover .book-menu, .btn-book-container.active .book-menu {
    pointer-events: auto; }
  .btn-book-container:hover .book-menu li a, .btn-book-container.active .book-menu li a, .btn-book-container:hover .book-menu li button, .btn-book-container.active .book-menu li button {
    animation: showUp 0.3s cubic-bezier(0.25, 0.25, 0.22, 1.285) forwards; }
  .btn-book-container:hover .book-menu li:nth-child(2) a, .btn-book-container.active .book-menu li:nth-child(2) a, .btn-book-container:hover .book-menu li:nth-child(2) button, .btn-book-container.active .book-menu li:nth-child(2) button {
    animation-delay: 0.1s; }
  .btn-book-container:hover .book-menu li:nth-child(3) a, .btn-book-container.active .book-menu li:nth-child(3) a, .btn-book-container:hover .book-menu li:nth-child(3) button, .btn-book-container.active .book-menu li:nth-child(3) button {
    animation-delay: 0.2s; }
  .btn-book-container:hover .book-menu li:nth-child(4) a, .btn-book-container.active .book-menu li:nth-child(4) a, .btn-book-container:hover .book-menu li:nth-child(4) button, .btn-book-container.active .book-menu li:nth-child(4) button {
    animation-delay: 0.3s; }
  .btn-book-container:hover .book-menu li:nth-child(5) a, .btn-book-container.active .book-menu li:nth-child(5) a, .btn-book-container:hover .book-menu li:nth-child(5) button, .btn-book-container.active .book-menu li:nth-child(5) button {
    animation-delay: 0.4s; }
  .btn-book-container:hover .book-menu li:nth-child(6) a, .btn-book-container.active .book-menu li:nth-child(6) a, .btn-book-container:hover .book-menu li:nth-child(6) button, .btn-book-container.active .book-menu li:nth-child(6) button {
    animation-delay: 0.5s; }

.book-menu {
  pointer-events: none;
  position: absolute;
  right: 0;
  width: 100%;
  min-width: 160px;
  display: flex;
  flex-direction: column;
  padding: 0;
  margin: 0;
  list-style: none;
  z-index: 9; }
  .book-menu li:last-child a {
    border-bottom: none; }
  .book-menu a, .book-menu button {
    display: flex;
    justify-content: center;
    width: 100%;
    padding: 0.75em 0.75em;
    color: var(--header-dark);
    font: inherit;
    text-align: left;
    text-transform: uppercase;
    background: #fff;
    border-bottom: var(--header-dark) solid 1px;
    transform: translateX(100%);
    transition: color 0.3s, background 0.3s; }
  .book-menu a > div, .book-menu button > div {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 140px; }
  .book-menu a:hover, .book-menu button:hover, .book-menu a:focus, .book-menu button:focus {
    color: #fff;
    background: var(--header-dark); }
  .book-menu a:hover img, .book-menu button:hover img, .book-menu a:focus img, .book-menu button:focus img {
    filter: invert(1); }
  .book-menu img {
    width: 20px;
    height: auto;
    transition: all 0.3s; }
  .book-menu button span:last-of-type {
    display: none; }
  .book-menu button:hover span:first-of-type, .book-menu button:focus span:first-of-type {
    display: none; }
  .book-menu button:hover span:last-of-type, .book-menu button:focus span:last-of-type {
    display: block; }

@keyframes showUp {
  0% {
    transform: translateX(100%); }

  100% {
    transform: translateX(0); } }

@media screen and (max-width: 767px) {
  .book-menu {
    position: fixed;
    bottom: 40px; } }
