@charset "UTF-8";
/* Welcome to Compass.
 * In this file you should write your main styles. (or centralize your imports)
 * Import this file using the following HTML or equivalent:
 * <link href="/stylesheets/screen.css" media="screen, projection" rel="stylesheet" type="text/css" /> */
/**
 * CONTENTS
 *
 * SETTINGS
 *
 *
 * GENERIC
 *
 * BASE

 *
 * OBJECTS

 *
 * COMPONENTS

 *
 * TRUMPS

 */
/**
 * #SETTINGS
 */
/*!
 * inuitcss, by @csswizardry
 *
 * github.com/inuitcss | inuitcss.com
 */
@font-face {
  font-family: "Atlas Grotesk";
  src: url(0e029fb20d4fc487d9781842b58f9259.woff2) format("woff2"), url(7b1da535b002a437a71171cbabc05813.woff) format("woff");
  font-weight: 200;
  font-style: normal;
}
@font-face {
  font-family: "Atlas Grotesk";
  src: url(225f1f77bcda7505223a3b3cfb2b5bb3.woff2) format("woff2"), url(1f9b4d0e6b0f7213a5d5fbc2c160dc8f.woff) format("woff");
  font-weight: 300;
  font-style: normal;
}
@font-face {
  font-family: "Atlas Grotesk";
  src: url(744e0aaa36cc723a8a11a2982a5dde36.woff2) format("woff2"), url(557c8556b59fcbdb20a039347e3b5d57.woff) format("woff");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "Atlas Grotesk";
  src: url(6987032be3c20d4451f972b9e191ddfc.woff2) format("woff2"), url(ce2abb497a01c9a1978d55f1bc157c34.woff) format("woff");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "Atlas Grotesk";
  src: url(a358809eb9de9485f2c61972bbae360c.woff2) format("woff2"), url(cebfd57fe2d365ea4544bd7d08e157da.woff) format("woff");
  font-weight: 600;
  font-style: normal;
}
@font-face {
  font-family: "Ivy Mode";
  src: url(29cf5fe9134a6d281bde39de1f108b42.eot);
  src: local("Ivy Mode Regular"), local("IvyMode-Regular"), url(29cf5fe9134a6d281bde39de1f108b42.eot?#iefix) format("embedded-opentype"), url(fde4ae547ba2c1ce909290631191427a.woff2) format("woff2"), url(69c62c620a8cf46ba1be61cc27ab492f.woff) format("woff"), url(bd7ba1ec86f59a011535a677f6e76494.ttf) format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Ivy Mode";
  src: url(b7c886a4ab669e1df0682005b3f1efa7.eot);
  src: local("Ivy Mode Light Italic"), local("IvyMode-LightItalic"), url(b7c886a4ab669e1df0682005b3f1efa7.eot?#iefix) format("embedded-opentype"), url(d9c229b851e6b478bc2bc848ce8c7632.woff2) format("woff2"), url(b6d694fc05392ed11d4e4f50f98b96b6.woff) format("woff"), url(c5170f68e2f5d188dffb9c1ad8c48f06.ttf) format("truetype");
  font-weight: 300;
  font-style: italic;
}
@font-face {
  font-family: "Ivy Mode";
  src: url(fbb9485562c4d71126fcf8563fc489e4.eot);
  src: local("Ivy Mode SemiBold Italic"), local("IvyMode-SemiBoldItalic"), url(fbb9485562c4d71126fcf8563fc489e4.eot?#iefix) format("embedded-opentype"), url(1e6fe14542b9dc28d85f67ae49163f0a.woff2) format("woff2"), url(e92212c83afe2bd3873ec1aa9a9deea8.woff) format("woff"), url(eda26408c7e94f810f554243a7d9c371.ttf) format("truetype");
  font-weight: 600;
  font-style: italic;
}
@font-face {
  font-family: "Ivy Mode";
  src: url(e2172359a57e59c298cc3fb2bfc8bf42.eot);
  src: local("Ivy Mode Thin Italic"), local("IvyMode-ThinItalic"), url(e2172359a57e59c298cc3fb2bfc8bf42.eot?#iefix) format("embedded-opentype"), url(8e59f111e853f3cdf14eac52fbde69d2.woff2) format("woff2"), url(7788e243fee72027c42afd40204d8980.woff) format("woff"), url(e4a34693446378e9077503f47ad84d5a.ttf) format("truetype");
  font-weight: 100;
  font-style: italic;
}
@font-face {
  font-family: "Ivy Mode";
  src: url(8d2c48b9a376b21ad684622c198858ee.eot);
  src: local("Ivy Mode Italic"), local("IvyMode-Italic"), url(8d2c48b9a376b21ad684622c198858ee.eot?#iefix) format("embedded-opentype"), url(b40094b74b4a3a540d560d67b7140b48.woff2) format("woff2"), url(9e936eb2d71c2e838024859cbcf6d7dd.woff) format("woff"), url(ec2fd5390dd3e4d558987133574cf7c0.ttf) format("truetype");
  font-weight: normal;
  font-style: italic;
}
@font-face {
  font-family: "Ivy Mode";
  src: url(11dc76e07e23bc76b29d569be4c2ea60.eot);
  src: local("Ivy Mode Bold Italic"), local("IvyMode-BoldItalic"), url(11dc76e07e23bc76b29d569be4c2ea60.eot?#iefix) format("embedded-opentype"), url(6b2931b6b48766c81e800cffed3d0afa.woff2) format("woff2"), url(8e5f03e5e3e0ef830b1099b77d350a7f.woff) format("woff"), url(a6cf38a17dcf1581618f9f0156f7ae1e.ttf) format("truetype");
  font-weight: bold;
  font-style: italic;
}
@font-face {
  font-family: "Ivy Mode";
  src: url(d0776a4a681da1d681be7e5f25325ea2.eot);
  src: local("Ivy Mode Bold"), local("IvyMode-Bold"), url(d0776a4a681da1d681be7e5f25325ea2.eot?#iefix) format("embedded-opentype"), url(04e3d9cc1bcb55e95099e46a53d50b21.woff2) format("woff2"), url(d79837e958af40a3af374472191f63a5.woff) format("woff"), url(7677b5ea0f228c2026ca725665ac6932.ttf) format("truetype");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: "Ivy Mode";
  src: url(5f07e4b15e48c2c6c5e40f860df7f7ac.eot);
  src: local("Ivy Mode Light"), local("IvyMode-Light"), url(5f07e4b15e48c2c6c5e40f860df7f7ac.eot?#iefix) format("embedded-opentype"), url(c94b3141ab1841f2e33f8677610d2345.woff2) format("woff2"), url(bf4d1baa0292eab717489a6c55a41491.woff) format("woff"), url(ed01910a905210d07db6e46d0b69033f.ttf) format("truetype");
  font-weight: 300;
  font-style: normal;
}
@font-face {
  font-family: "Ivy Mode";
  src: url(1250ed510851c2ad6ed4270b9accd201.eot);
  src: local("Ivy Mode Thin"), local("IvyMode-Thin"), url(1250ed510851c2ad6ed4270b9accd201.eot?#iefix) format("embedded-opentype"), url(41fe49fd57b264fde1f6e60dec88f4cf.woff2) format("woff2"), url(d4067273282ec1dfd9f9bff7302da0b0.woff) format("woff"), url(e4250f166b2258c670dd8c536e465fb1.ttf) format("truetype");
  font-weight: 100;
  font-style: normal;
}
@font-face {
  font-family: "Ivy Mode";
  src: url(747d5091b89995a9537b198aefe616ad.eot);
  src: local("Ivy Mode SemiBold"), local("IvyMode-SemiBold"), url(747d5091b89995a9537b198aefe616ad.eot?#iefix) format("embedded-opentype"), url(df0c6a3b36540e573cff0d0b995fd647.woff2) format("woff2"), url(ca87996a0c37de46f88073b1ccd24757.woff) format("woff"), url(005beb6a3eb3614e5b7d9c7ea8548a02.ttf) format("truetype");
  font-weight: 600;
  font-style: normal;
}
/**
 * #TOOLS
 */
input, textarea, form {
  color: #6F6F6F;
  font-family: inherit;
  font-family: inherit;
  font-size: inherit;
  outline: none;
  border: transparent;
  background: none;
}

textarea {
  resize: vertical;
}

button:focus {
  outline: none;
}

::-moz-placeholder { /* Mozilla Firefox 19+ */
  color: rgba(111, 111, 111, 0.8);
  opacity: 1;
}

::placeholder { /* Most modern browsers support this now. */
  color: rgba(111, 111, 111, 0.8);
}

input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 30px white inset;
}

/*Change text in autofill textbox*/
input:-webkit-autofill {
  -webkit-text-fill-color: rgb(47.25, 47.25, 47.25) !important;
}

.input--white:-webkit-autofill,
.input--white:-webkit-autofill:hover,
.input--white:-webkit-autofill:focus,
.input--white:-webkit-autofill:active {
  -webkit-transition-delay: 99999s;
}

select, button, form fieldset {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0px;
  background: none;
}

/**
 * #GENERIC
 */
/*! normalize.css v3.0.1 | MIT License | git.io/normalize */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */
html {
  font-family: sans-serif; /* 1 */
  -ms-text-size-adjust: 100%; /* 2 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/**
 * Remove default margin.
 */
body {
  margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11 and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none;
}

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background: transparent;
}

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
a:active,
a:hover {
  outline: 0;
}

/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic;
}

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: 1em 40px;
}

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  box-sizing: content-box;
  height: 0;
}

/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button,
input,
optgroup,
select,
textarea {
  color: inherit; /* 1 */
  font: inherit; /* 2 */
  margin: 0; /* 3 */
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
  text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type=button],
input[type=reset],
input[type=submit] {
  -webkit-appearance: button; /* 2 */
  cursor: pointer; /* 3 */
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal;
}

/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
input[type=checkbox],
input[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome
 *    (include `-moz` to future-proof).
 */
input[type=search] {
  -webkit-appearance: textfield; /* 1 */ /* 2 */
  box-sizing: content-box;
}

/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold;
}

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
}

/*------------------------------------*\
    #RESET
\*------------------------------------*/
/**
 * As well as using normalize.css, it is often advantageous to remove all
 * margins from certain elements.
 */
body,
h1, h2, h3, h4, h5, h6,
p, blockquote, pre,
dl, dd, ol, ul,
form, fieldset, legend,
figure,
table, th, td, caption,
hr {
  margin: 0;
  padding: 0;
}

/**
 * Give a help cursor to elements that give extra info on `:hover`.
 */
abbr[title],
dfn[title] {
  cursor: help;
}

/**
 * Remove underlines from potentially troublesome elements.
 */
u,
ins {
  text-decoration: none;
}

/**
 * Apply faux underlines to inserted text via `border-bottom`.
 */
ins {
  border-bottom: 1px solid;
}

/*------------------------------------*\
    #BOX-SIZING
\*------------------------------------*/
/**
 * Set the global `box-sizing` state to `border-box`.
 *
 * css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice
 * paulirish.com/2012/box-sizing-border-box-ftw
 */
html {
  box-sizing: border-box;
}

*, *:before, *:after {
  box-sizing: inherit;
}

/**
 * #BASE
 */
html figure {
  margin-bottom: 0px;
}

html {
  font-family: "Atlas Grotesk", "Avenir", "Helvetica", "Source Sans Pro", sans-serif;
  line-height: 1.6;
  font-size: 15px;
  font-weight: 200;
  color: #6F6F6F;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  max-width: 1900px;
  margin: 0px auto;
  overflow-x: hidden;
  scroll-behavior: smooth;
}

body {
  width: 100%;
  scroll-behavior: smooth;
}

.site__content {
  transition: all 0.55s ease 0s;
}

.site__content--locked {
  filter: blur(8px) grayscale(0);
  width: 100vw;
  height: 100vh;
  overflow: hidden;
}

.container--img {
  position: relative;
}
.container--img:after {
  display: block;
  content: "";
  width: 100%;
}
.container--img > img, .container--img > video {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0px;
  top: 0px;
  -o-object-fit: cover;
     object-fit: cover;
}

.item--wrap {
  position: relative;
}
.item--wrap > a {
  text-indent: -999999px;
  position: absolute;
  z-index: 10;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
}

.item--enlarge:before {
  position: absolute;
  bottom: 20px;
  right: 20px;
  width: 35px;
  height: 35px;
  content: "";
  z-index: 4;
  background: url(3f39dac09ea69c04b619e4c6c1db235a.svg) no-repeat center center;
  background-size: contain;
  -webkit-background-size: contain;
}

.fr-window canvas {
  display: none !important;
}

@media (max-width: 900px) {
  .page__content, footer {
    width: 100dvw;
    overflow: hidden;
  }
}
h1, h2, h3, h4, h5 {
  position: relative;
  font-family: "Ivy Mode";
  font-weight: 300;
  line-height: 1.25;
  color: black;
}

.title--header {
  font-size: 4.3333333333em;
  color: white;
  text-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
}

.title--footer {
  font-size: 1.1333333333em;
  font-weight: 400;
  margin-bottom: 0.5882352941em;
}

.title--section {
  font-size: 2.6666666667em;
}

.title--reservation, .title--place, .title--choice {
  color: #B18D4C;
  font-size: 1.6666666667em;
}

.title--place, .title--modal {
  font-size: 1.8666666667em;
}

.title--choice {
  font-size: 1.5333333333em;
}

@media (max-width: 1150px) {
  .title--section {
    font-size: 2.3333333333em;
  }
  .title--header {
    font-size: 3.6666666667em;
  }
}
@media (max-width: 1100px) {
  .title--place {
    font-size: 1.6em;
  }
  .title--reservation {
    font-size: 1.4em;
  }
}
@media (max-width: 900px) {
  .title--header {
    font-size: 3.1333333333em;
  }
}
@media (max-width: 800px) {
  .title--section {
    font-size: 2em;
  }
}
@media (max-width: 720px) {
  .title--reservation {
    font-size: 1.3333333333em;
  }
}
@media (max-width: 700px) {
  .title--header {
    font-size: 2.8em;
  }
}
@media (max-width: 550px) {
  .title--header {
    font-size: 2.6em;
  }
  .title--section {
    font-size: 1.8666666667em;
  }
}
@media (max-width: 500px) {
  .title--modal {
    font-size: 1.6em;
  }
  .title--choice {
    font-size: 1.2666666667em;
  }
}
@media (max-width: 460px) {
  .title--reservation {
    font-size: 1.2666666667em;
  }
  .title--place {
    font-size: 1.4666666667em;
  }
}
@media (max-width: 420px) {
  .title--section {
    font-size: 1.6666666667em;
  }
}
@media (max-width: 370px) {
  .title--header {
    font-size: 2.3333333333em;
  }
  .title--modal {
    font-size: 1.4666666667em;
  }
  .title--choice {
    font-size: 1.2em;
  }
}
@media (max-width: 340px) {
  .title--reservation {
    font-size: 1.2em;
  }
}
@media (max-width: 315px) {
  .title--header {
    font-size: 2.1333333333em;
  }
}
a {
  text-decoration: none;
  color: #B18D4C;
  transition: all 0.25s ease 0s;
}
a:hover {
  color: rgb(159.1600790514, 126.7885375494, 68.3399209486);
  border-color: rgb(159.1600790514, 126.7885375494, 68.3399209486);
}

svg path, svg g, svg circle {
  transition: all 0.2s ease-in-out 0s;
}

/**
 * #OBJECTS
 */
/*------------------------------------*\
    #LIST-INLINE
\*------------------------------------*/
/**
 * The list-inline object simply displays a list of items in one line.
 */
.list-inline {
  margin: 0;
  padding: 0;
  list-style: none;
}
.list-inline > li {
  display: inline-block;
}

.column--free {
  display: flex;
}

.column {
  display: flex;
  flex-wrap: wrap;
}

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

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

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

.column--spaced {
  justify-content: space-between;
}

.column--reversed {
  flex-direction: row-reverse;
}

.column--column-reversed {
  flex-direction: column-reverse;
}

.column--centered {
  align-items: center;
}

.column--equal {
  align-items: stretch;
}

.column--centered-w {
  justify-content: center;
}

.wrapper--centered {
  margin-left: auto;
  margin-right: auto;
}

.wrapper--main {
  width: 88.4393063584%;
}

@media (max-width: 1000px) {
  .wrapper--main {
    width: 90%;
  }
}
.section {
  position: relative;
}

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

.section--bottom + footer {
  margin-top: 0px;
}

.section--ending {
  margin-top: 6em;
}

.section--small {
  margin-top: 3.3333333333em;
}

.section--middle {
  margin-top: 6.936416185%;
}

.section--big {
  margin-top: 8.0924855491%;
}

.section--intro:before {
  background-color: #F3F1EF;
  display: block;
  width: 100%;
  height: 260px;
  content: "";
}

.section--bg {
  background-color: #F9F9F9;
}

.section--story {
  padding-top: 5.7803468208%;
  padding-bottom: 4.6242774566%;
}

@media (max-width: 1150px) {
  .section--intro:before {
    height: 170px;
  }
}
@media (max-width: 1000px) {
  .section--intro {
    text-align: center;
    flex-direction: column-reverse;
  }
  .section--intro:before {
    height: 120px;
    order: 3;
  }
  .section--story {
    padding-top: 5.3333333333em;
    padding-bottom: 4em;
  }
}
@media (max-width: 720px) {
  .section--intro:before {
    height: 100px;
  }
}
@media (max-width: 700px) {
  .section--ending {
    margin-top: 3.3333333333em;
  }
}
@media (max-width: 650px) {
  .section--story {
    padding-top: 4em;
    padding-bottom: 2em;
  }
}
@media (max-width: 570px) {
  .section--small {
    margin-top: 2em;
  }
}
@media (max-width: 550px) {
  .section--story {
    padding-top: 3.3333333333em;
    padding-bottom: 1.3333333333em;
  }
}
@media (max-width: 460px) {
  .section--story {
    margin-top: 3.3333333333em;
  }
}
@media (max-width: 390px) {
  .section--small {
    margin-top: 1em;
  }
}
@media (max-width: 330px) {
  .section--story {
    padding-bottom: 0.3333333333em;
  }
}
em {
  font-style: normal;
}

.text__break {
  display: block;
}

footer {
  margin-top: 7.5144508671%;
  margin-bottom: 1.3333333333em;
}

.footer__upper {
  border-top: 1px solid #F3F3F3;
  border-bottom: 1px solid #F3F3F3;
  padding-top: 3.3333333333em;
  padding-bottom: 3.3333333333em;
}

.footer__bottom {
  margin-top: 1.3333333333em;
}

.footer__part + .footer__part {
  margin-left: 9.8039215686%;
}

.footer__part--company {
  margin-right: 16.339869281%;
}
.footer__part--company + .footer__part {
  margin-left: 0px;
}

.company__logo {
  width: 60px;
  display: table;
  margin-bottom: 2em;
}
.company__logo img {
  display: block;
  width: 100%;
  height: auto;
}

.contacts__list {
  margin-top: 1.6666666667em;
}

.contact__item {
  display: block;
}
.contact__item a {
  text-decoration: underline;
}
.contact__item + .contact__item {
  margin-top: 0.6666666667em;
}

.footer__socials {
  margin-top: 1.3333333333em;
}
.footer__socials li {
  display: block;
}
.footer__socials img {
  height: 17px;
}
.footer__socials li + li {
  margin-left: 1em;
}
.footer__socials a {
  display: block;
}
.footer__socials a:hover {
  transform: scale(1.2);
}

.company__place {
  margin-top: 0.6666666667em;
}

.copy__logo {
  transition: all 0.25s ease 0s;
}
.copy__logo:hover {
  transform: scale(1.1) rotate(-2deg);
}

.cardi__logo {
  height: 13px;
  display: inline-block;
}

.daaboo__logo {
  height: 16px;
  display: inline-block;
  margin-right: 2px;
}

.place--block span {
  display: block;
}

@media (max-width: 1170px) {
  .footer__part--company {
    margin-right: 9.8039215686%;
  }
}
@media (max-width: 970px) {
  .footer__upper {
    padding-top: 2em;
    padding-bottom: 2em;
  }
  .footer__part {
    order: 0;
    width: 25%;
  }
  .footer__part--company {
    margin-top: 2em;
    order: 3;
    margin-right: 0px;
    width: 100%;
  }
  footer {
    margin-top: 7.3333333333em;
  }
  .footer__upper {
    padding-top: 0px;
  }
  .footer__part {
    width: 50%;
  }
  .footer__part + .footer__part {
    margin-left: 0px;
    margin-top: 2em;
  }
  .footer__part--company {
    width: 100%;
    text-align: center;
    padding-top: 3.3333333333em;
    border-top: 1px solid #F3F3F3;
    margin-top: 2em;
  }
  .company__logo {
    margin-left: auto;
    margin-right: auto;
  }
}
@media (max-width: 650px) {
  footer {
    margin-top: 5.3333333333em;
  }
}
@media (max-width: 550px) {
  .company__place, .company__vat {
    font-size: 0.9333333333em;
  }
}
@media (max-width: 470px) {
  footer {
    margin-top: 4.6666666667em;
  }
}
@media (max-width: 440px) {
  .footer__part--company {
    padding-top: 2.6666666667em;
  }
  .footer__part {
    width: 100%;
  }
  .footer__part + .footer__part {
    margin-left: 0px;
  }
}
@media (max-width: 370px) {
  .footer__bottom {
    flex-direction: column;
    align-items: center;
  }
  .footer__cardi {
    margin-top: 0.3333333333em;
  }
}
.header--home {
  height: 88dvh;
  background-color: black;
  color: white;
  text-align: center;
  padding-top: 2.6666666667em;
  position: relative;
}
.header--home .header__content {
  margin-top: 15.6069364162%;
  position: relative;
  z-index: 3;
}
.header--home:after, .header--home:before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0px;
  left: 0px;
  pointer-events: none;
  background-image: radial-gradient(circle at 50% 50%, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.85) 50%);
  z-index: 1;
}
.header--home:before {
  z-index: 2;
  background: rgba(0, 0, 0, 0.5);
}

.header__bg {
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  left: 0px;
  top: 0px;
}

.header__subtitle {
  font-size: 1.8666666667em;
  font-weight: 200;
  margin-top: 0.2142857143em;
  text-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
}

.logos__list, .header__logos {
  width: 100%;
}

.header__logos {
  position: relative;
  z-index: 3;
}

.logo__item {
  display: block;
}
.logo__item + .logo__item {
  margin-left: 8.6705202312%;
}
.logo__item img {
  display: block;
  height: 55px;
  width: auto;
}
.logo__item.logo__item--big img {
  height: 100px;
}

.header__reservation {
  background-color: white;
  position: absolute;
  bottom: 0px;
  z-index: 4;
  left: 5.7803468208%;
  box-shadow: 0px 0px 40px 0px rgba(0, 0, 0, 0.09);
  border-radius: 50px;
  flex-wrap: nowrap;
  text-align: left;
  transform: translateY(50%);
}

.reservations__list {
  width: 100%;
}

.reservation__item {
  width: 50%;
  color: #6F6F6F;
  display: block;
  padding: 1.1333333333em 1.3333333333em 1.2666666667em 6em;
  position: relative;
}
.reservation__item article {
  transition: all 0.2s ease-in-out;
}
.reservation__item + .reservation__item {
  border-left: 1px solid #F3F3F3;
}
.reservation__item:hover article {
  transform: translateY(-4px);
  color: #B18D4C;
}
.reservation__item:before {
  background: url(d07e65486d63a270feac75396092a9c8.svg) no-repeat center center;
  background-size: contain;
  -webkit-background-size: contain;
  content: "";
  width: 25px;
  height: 25px;
  display: block;
  position: absolute;
  left: 2.3333333333em;
  top: 50%;
  transform: translateY(-50%);
}

.reservation__place {
  font-size: 1.1333333333em;
  margin-top: 0.1764705882em;
  transition: all 0.2s ease-in-out;
}

.btn--reservation {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

@media (max-width: 1300px) {
  .reservation__item {
    padding: 1.1333333333em 1.3333333333em 1.2666666667em 4.6666666667em;
  }
  .reservation__item:before {
    left: 1.6666666667em;
  }
}
@media (max-width: 1150px) {
  .header__subtitle {
    font-size: 1.6em;
  }
  .header--home {
    height: 85dvh;
  }
  .logo__item + .logo__item {
    margin-left: 5.7803468208%;
  }
  .logo__item img {
    height: 45px;
  }
  .logo__item.logo__item--big img {
    height: 80px;
  }
}
@media (max-width: 1100px) {
  .reservation__place {
    font-size: 1.0666666667em;
  }
}
@media (max-width: 1000px) {
  .reservation__item {
    padding: 1.1333333333em 1.3333333333em 1.2666666667em 2.3333333333em;
  }
  .reservation__item:before {
    display: none;
  }
}
@media (max-width: 900px) {
  .header__subtitle {
    font-size: 1.4em;
  }
}
@media (max-width: 840px) {
  .header--home {
    height: auto;
    padding-bottom: 20em;
    padding-top: 1.3333333333em;
  }
  .header--home .header__content {
    margin-top: 11.3333333333em;
  }
  .logos__list {
    transform: translateY(75px);
  }
}
@media (max-width: 720px) {
  .reservation__place {
    font-size: 1em;
  }
  .header__reservation {
    flex-direction: column;
    border-radius: 30px;
  }
  .header__subtitle {
    margin-top: 0.7894736842em;
  }
}
@media (max-width: 700px) {
  .header--home {
    padding-bottom: 13.3333333333em;
  }
  .header--home .header__content {
    max-width: 70%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 10em;
  }
  .header__subtitle {
    font-size: 1.3333333333em;
  }
  .logos__list {
    transform: translateY(85px);
  }
}
@media (max-width: 550px) {
  .logo__item img {
    height: 40px;
  }
  .logo__item.logo__item--big img {
    height: 70px;
  }
  .header__subtitle {
    font-size: 1.2666666667em;
  }
  .reservation__item {
    padding: 1em 1.3333333333em;
  }
  .reservation__place {
    font-size: 0.9333333333em;
  }
}
@media (max-width: 450px) {
  .reservations__list {
    flex-direction: column;
  }
  .reservation__item {
    width: 100%;
    padding: 0.8em 1.3333333333em 0.5333333333em;
  }
  .reservation__item + .reservation__item {
    padding: 0.5333333333em 1.3333333333em 0.8em;
    border-left: inherit;
  }
  .header--home {
    padding-bottom: 13.3333333333em;
  }
  .header--home .header__content {
    max-width: 80%;
  }
}
@media (max-width: 390px) {
  .logo__item img {
    height: 30px;
  }
  .logo__item.logo__item--big img {
    height: 60px;
  }
}
@media (max-width: 370px) {
  .header--home {
    padding-bottom: 14.6666666667em;
  }
  .header--home .header__content {
    margin-top: 9.3333333333em;
  }
  .header__subtitle {
    font-size: 1.2em;
    margin-top: 0.2777777778em;
  }
}
@media (max-width: 315px) {
  .header__subtitle {
    font-size: 1.1333333333em;
    margin-top: 0.5555555556em;
  }
}
.lang-dropdown {
  display: inline-block;
  z-index: 30;
  position: absolute;
  left: 5.7803468208%;
  width: 80px;
  display: none;
}

/* Menu caché par défaut */
.lang-dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;
  display: none;
  margin: 0;
  padding: 0;
  list-style: none;
  background: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 15px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
  z-index: 9999;
  transform: translateY(1px);
}

.lang-dropdown:hover .lang-dropdown-menu {
  display: block;
}

.lang-dropdown-menu a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0.3333333333em 0.9333333333em 0.4666666667em;
  text-decoration: none;
  color: white;
}

.lang-dropdown-menu a:hover {
  color: #B18D4C;
}

.lang-dropdown-toggle {
  background: rgba(255, 255, 255, 0.15);
  border-radius: 50px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 0.3333333333em 0.9333333333em 0.4666666667em;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
}

.lang-flag {
  width: 20px;
  height: auto;
}

.lang-code {
  font-weight: 400;
}

@media (max-width: 1000px) {
  .lang-dropdown {
    right: 5%;
  }
}
ul.slick-dots {
  bottom: 20px;
}

ul.slick-dots li {
  background: white;
  border-radius: 100%;
  width: 12px;
  height: 12px;
}
ul.slick-dots li.slick-active {
  background: #B18D4C;
}
ul.slick-dots li button {
  opacity: 0;
}

.slick-slider .slick-arrow {
  background: blue;
  position: absolute;
  right: 0px;
  bottom: -30px;
  z-index: 40;
  top: inherit;
  left: inherit;
  background: white;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.slick-slider .slick-arrow:focus {
  background: white;
}
.slick-slider .slick-arrow:hover {
  background: #B18D4C;
}
.slick-slider .slick-arrow:before {
  color: black;
  width: 6px;
  height: 11px;
  display: block;
}
.slick-slider .slick-prev {
  right: 60px;
  border-right: 1px solid #6F6F6F;
}
.slick-slider .slick-next:before {
  content: "";
  background: url(98de41c48072d5c3665d553ef441f045.svg) no-repeat center center;
  background-size: contain;
  -webkit-background-size: contain;
}
.slick-slider .slick-prev:before {
  content: "";
  background: url(98de41c48072d5c3665d553ef441f045.svg) no-repeat center center;
  background-size: contain;
  -webkit-background-size: contain;
}

.btn {
  display: inline-block;
  text-align: center;
  border-radius: 50px;
  font-size: 1.2em;
  padding: 0.6666666667em 1.3888888889em 0.7777777778em;
  font-weight: 400;
  transition: all 0.2s ease-in-out;
  line-height: 1.2;
}

.btn--primary {
  color: white;
  background-color: #B18D4C;
  box-shadow: 0px 0px 40px 0px rgba(177, 141, 76, 0.4);
}
.btn--primary:hover {
  background-color: rgb(152.0241106719, 121.1039525692, 65.2758893281);
  color: white;
}

.btn--full {
  display: block;
  width: 100%;
}

.btn--reservation {
  font-size: 1.2666666667em;
  display: flex;
  align-items: center;
  padding-left: 2.6315789474em;
  padding-right: 1.8421052632em;
}
.btn--reservation.btn--arrow:after {
  width: 31px;
  height: 31px;
  margin-left: 1.3157894737em;
}
.btn--reservation .text--responsive {
  display: none;
}

.btn--arrow, .intro__menu, .btn--food {
  display: inline-flex;
  align-items: center;
}
.btn--arrow:after, .intro__menu:after, .btn--food:after {
  transition: all 0.2s ease-in-out;
  position: relative;
  top: 2px;
  margin-left: 0.9444444444em;
  width: 23px;
  height: 23px;
  display: inline-block;
  content: "";
  background: url(172a5c9608af43c4aeef666797497fdc.svg) no-repeat center center;
  background-size: contain;
  -webkit-background-size: contain;
}
.btn--arrow:hover:after, .intro__menu:hover:after, .btn--food:hover:after {
  transform: translateX(3px) scale(1.03);
}

.intro__menu:after {
  margin-left: 0.8333333333em;
  background: url(d07e65486d63a270feac75396092a9c8.svg) no-repeat center center;
  background-size: contain;
  -webkit-background-size: contain;
}
.intro__menu:hover:after {
  transform: translateX(3px) scale(1.03);
}

.btn--food {
  z-index: 5;
  position: absolute;
  right: 5.7803468208%;
}
.btn--food:after {
  top: 2px;
  margin-left: 0.9444444444em;
  width: 16px;
  height: 23px;
  background: url(0ad7b7b897603a534fc85cb997015418.svg) no-repeat center center;
  background-size: contain;
  -webkit-background-size: contain;
}

@media (max-width: 1450px) {
  .btn--reservation {
    font-size: 1.2em;
    padding-left: 1.6666666667em;
    padding-right: 1.1111111111em;
  }
  .btn--reservation.btn--arrow:after {
    margin-left: 0.7894736842em;
  }
}
@media (max-width: 1000px) {
  .btn--food {
    right: 5%;
  }
}
@media (max-width: 900px) {
  .btn {
    font-size: 1.1333333333em;
  }
}
@media (max-width: 870px) {
  .btn--reservation span {
    display: none;
  }
  .btn--reservation .text--responsive {
    display: block;
  }
}
@media (max-width: 840px) {
  .btn--food {
    font-size: 1em;
  }
  .btn--food:after {
    margin-left: 0.7222222222em;
    width: 14px;
    height: 20px;
  }
}
@media (max-width: 720px) {
  .btn--reservation {
    width: 100%;
    justify-content: center;
    border-top-left-radius: 0px;
    border-top-right-radius: 0px;
    border-bottom-left-radius: 30px;
    border-bottom-right-radius: 30px;
  }
}
@media (max-width: 450px) {
  .btn--reservation.btn--arrow:after {
    width: 25px;
    height: 25px;
  }
}
span.select2-container--default .select2-selection--single {
  border: 1px solid rgb(230.25, 230.25, 230.25) !important;
  border-radius: 0px !important;
}

textarea {
  min-height: 100px;
}

.woocommerce form .form-row label, .woocommerce-page form .form-row label {
  font-size: 0.9333333333em;
  color: rgb(85.5, 85.5, 85.5);
  margin-bottom: 5px;
  display: block;
}

.woocommerce-variation-add-to-cart {
  margin-top: 1.3333333333em;
}

.form__part input, .form__part textarea {
  width: 100%;
}

.form__part--half {
  width: 47.5%;
}

.form__part--full {
  width: 100%;
}

.form__lign + .form__lign {
  margin-top: 1em;
}

.form__submit {
  margin-top: 2em;
}

.form__error {
  border: 1px solid red;
  color: red;
  background: rgba(255, 0, 0, 0.2);
}

.form__success {
  border: 1px solid green;
  color: green;
  background: rgba(0, 128, 0, 0.2);
}

select {
  position: relative;
  background: url(98de41c48072d5c3665d553ef441f045.svg) no-repeat 97.5% center rgba(255, 255, 255, 0.1);
}

@media (max-width: 450px) {
  .form__part--half {
    width: 100%;
  }
  .form__part--half + .form__part--half {
    margin-top: 1em;
  }
}
.intro__text {
  font-size: 1.2em;
  margin-top: 1.1111111111em;
  line-height: 2.2;
}
.intro__text p + p {
  margin-top: 1.4em;
}
.intro__text.intro__text--sans {
  margin-top: 0.2777777778em;
}

.intro__left {
  width: 42.1965317919%;
  margin-left: 10.9826589595%;
  position: relative;
  top: -6em;
}

.intro__picture {
  margin-bottom: 1.6666666667em;
}
.intro__picture:after {
  padding-bottom: 68.4931506849%;
}

.intro__menu {
  font-size: 1.6666666667em;
  margin-left: 1.2em;
  font-family: "Ivy Mode";
  font-weight: 300;
}

.intro__right {
  margin-top: 4em;
  margin-left: 5.7803468208%;
  width: 34.6820809249%;
}

@media (max-width: 1150px) {
  .intro__left {
    margin-left: 5.7803468208%;
    top: -3.3333333333em;
  }
  .intro__text {
    font-size: 1.1333333333em;
  }
  .intro__menu {
    font-size: 1.5333333333em;
    margin-left: 0.8695652174em;
  }
}
@media (max-width: 1000px) {
  .intro__left {
    width: 70%;
    margin-left: 15%;
    order: 1;
    top: 0px;
    display: flex;
    flex-direction: column-reverse;
  }
  .intro__picture {
    margin-top: 3.6666666667em;
  }
  .intro__menu {
    margin: 0px auto;
  }
  .intro__right {
    order: 2;
    width: 60%;
    margin-left: 20%;
    margin-right: 20%;
    margin-bottom: 1.6666666667em;
  }
}
@media (max-width: 720px) {
  .intro__right {
    margin-top: 3.3333333333em;
    width: 80%;
    margin-left: 10%;
    margin-right: 10%;
    margin-bottom: 2em;
  }
}
@media (max-width: 650px) {
  .intro__left {
    width: 90%;
    margin-left: 5%;
    margin-right: 5%;
  }
}
@media (max-width: 600px) {
  .intro__text {
    font-size: 1.0666666667em;
  }
}
@media (max-width: 550px) {
  .intro__text {
    margin-top: 0.625em;
  }
}
@media (max-width: 420px) {
  .intro__text {
    font-size: 1em;
  }
}
@media (max-width: 390px) {
  .intro__right {
    margin-bottom: 1.6666666667em;
  }
  .intro__picture {
    margin-top: 2.6666666667em;
  }
  .intro__menu {
    font-size: 1.4em;
  }
}
button.remodal-close {
  left: inherit;
  right: 10px;
  z-index: 10;
  top: 10px;
}
button.remodal-close:hover {
  color: #B18D4C;
}

.remodal {
  border-radius: 30px;
  max-height: 92.5dvh;
  top: 2.5dvh;
  overflow: scroll;
  padding: 0px !important;
  max-width: 600px !important;
  scrollbar-width: none;
}
.remodal::-webkit-scrollbar {
  display: none;
}
.remodal iframe {
  scrollbar-width: none;
}
.remodal iframe::-webkit-scrollbar {
  display: none;
}

.reservation__start {
  padding: 3.3333333333em 2.6666666667em 0px 2.6666666667em;
  transition: all 0.45s ease 0s;
}
.reservation__start.reservation__start--hide {
  display: none;
}

.start__choice {
  margin-top: 3.3333333333em;
}

.choice__item {
  display: block;
  text-align: left;
  padding-bottom: 1.3333333333em;
}
.choice__item + .choice__item {
  border-top: 1px solid #F3F3F3;
  padding-top: 1.3333333333em;
}
.choice__item:after {
  transition: all 0.25s ease 0s;
  background: url(d07e65486d63a270feac75396092a9c8.svg) no-repeat center center;
  background-size: contain;
  -webkit-background-size: contain;
  content: "";
  width: 30px;
  height: 30px;
  display: block;
  position: absolute;
  right: 0px;
  top: 50%;
  transform: translateY(-50%);
}
.choice__item:hover {
  color: #B18D4C;
  cursor: pointer;
}
.choice__item:hover:after {
  transform: translateY(-50%) translateX(3px);
}

.modal__close {
  margin-top: 2.6666666667em;
  margin-bottom: 1.3333333333em;
}
.modal__close a {
  font-size: 1.0666666667em;
}

.reservation__solo {
  text-align: left;
  display: none;
}

.reservation__solo--current {
  display: block;
}

.solo__header {
  position: relative;
}

.modal__back {
  position: absolute;
  top: 20px;
  left: 20px;
  z-index: 3;
  width: 40px;
  height: 40px;
  border-radius: 50%;
}
.modal__back img {
  display: block;
  width: 100%;
  height: 100%;
}
.modal__back:hover {
  transform: scale(1.08);
  box-shadow: 0px 0px 40px 0px rgba(177, 141, 76, 0.25);
}

.solo__img:after {
  padding-bottom: 45.7142857143%;
}

.solo__infos {
  text-align: center;
  padding: 1.6666666667em 1.3333333333em;
}

.second-step-container iframe, .second-step-container > div {
  border-radius: 0px !important;
  width: 100% !important;
}

.widget__container {
  display: none;
}
.widget__container .second-step-container > div, .widget__container .second-step-container > iframe {
  display: none !important;
}
.widget__container .second-step-container > div.widget--show, .widget__container .second-step-container > iframe.widget--show {
  display: flex !important;
}

.widget__container--show {
  display: block;
}
.widget__container--show + .modal__close {
  margin-top: 0px;
}

.container--voucher iframe:first-child {
  height: 1370px !important;
}
.container--voucher iframe {
  height: 1800px !important;
}

@media (max-width: 650px) {
  .remodal {
    max-width: 90% !important;
  }
  .container--voucher iframe:first-child {
    height: 2850px !important;
  }
  .container--voucher iframe {
    max-width: 400px;
    height: 3300px !important;
  }
}
@media (max-width: 500px) {
  .modal__inner {
    display: flex;
    flex-direction: column;
    min-height: 50dvh;
  }
  .remodal {
    max-width: 100% !important;
    max-height: 95dvh !important;
    min-height: 50dvh !important;
    top: inherit !important;
    bottom: 0px !important;
    vertical-align: bottom !important;
    border-bottom-left-radius: 0px;
    border-bottom-right-radius: 0px;
    margin-bottom: 0px !important;
  }
  .remodal-wrapper {
    padding: 0px !important;
  }
  .start__choice {
    margin-top: 2.3333333333em;
  }
  .modal__close {
    margin-top: auto;
  }
  .widget__container--show {
    display: block;
  }
  .widget__container--show + .modal__close {
    margin-top: auto;
  }
  .reservation__start {
    padding-left: 2em;
    padding-right: 2em;
    padding-top: 2.6666666667em;
  }
  .choice__item {
    padding-bottom: 1em;
    padding-right: 2em;
  }
  .choice__item + .choice__item {
    padding-top: 1em;
  }
  .choice__item:after {
    width: 23px;
    height: 23px;
  }
}
@media (max-width: 400px) {
  .container--voucher iframe:first-child {
    height: 2500px !important;
  }
  .container--voucher iframe {
    max-width: 300px;
    height: 2900px !important;
  }
}
.cookie__banner {
  width: 550px;
  background-color: white;
  box-shadow: 0px 0px 30px 30px rgba(1, 1, 1, 0.06);
  position: fixed;
  left: 20px;
  bottom: 20px;
  border-radius: 17px;
  z-index: 15;
  transform: translateX(-200%);
  animation-name: cookiebox;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  animation-delay: 0.5s;
  padding: 2em 2.6666666667em;
}

.cookie__upper {
  margin-bottom: 2.6666666667em;
}
.cookie__upper ul {
  margin: 0.6666666667em 0px;
}
.cookie__upper li {
  display: block;
  padding-left: 0.6666666667em;
}
.cookie__upper li:before {
  content: "- ";
}
.cookie__upper li + li {
  margin-top: 0.3333333333em;
}
.cookie__upper a {
  text-decoration: underline;
}
.cookie__upper p + p {
  margin-top: 1.3333333333em;
}

.cookie__texts {
  margin-top: 0.6666666667em;
}

.cookie__banner--hidden {
  animation-name: cookiebox-reverse;
  animation-delay: 0s;
}

@keyframes cookiebox {
  from {
    transform: translateX(-200%);
  }
  to {
    transform: translateX(0%);
  }
}
@keyframes cookiebox-reverse {
  from {
    transform: translateX(0%);
  }
  to {
    transform: translateX(-200%);
  }
}
@media (max-width: 700px) {
  .cookie__banner {
    width: 95%;
    left: 2.5%;
  }
}
@media (max-width: 450px) {
  .cookie__banner {
    font-size: 14px;
  }
}
.bottom__call {
  max-width: 750px;
}
.bottom__call .title--call {
  max-width: 600px;
}

.call--centered {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}
.call--centered .title--section, .call--centered .call__text {
  margin-left: auto;
  margin-right: auto;
}

.call__text {
  font-size: 1.2em;
  margin-top: 1.1111111111em;
  max-width: 530px;
  line-height: 2.2;
}

.call__btn {
  margin-top: 3.3333333333em;
}

@media (max-width: 1050px) {
  .call__text {
    font-size: 1.1333333333em;
    margin-top: 1.1764705882em;
  }
  .call__btn {
    margin-top: 2.6666666667em;
  }
}
@media (max-width: 900px) {
  .bottom__call {
    max-width: 80%;
  }
}
@media (max-width: 600px) {
  .call__text {
    font-size: 1.0666666667em;
    margin-top: 1.25em;
  }
  .call__btn {
    margin-top: 2em;
  }
}
@media (max-width: 450px) {
  .call__text {
    margin-top: 0.6666666667em;
    font-size: 1em;
  }
}
.pictures__list {
  margin-top: 1.3333333333em;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}

.picture__item {
  cursor: pointer;
}
.picture__item figure {
  transition: all 0.25s ease 0s;
}
.picture__item:hover figure {
  transform: translateY(-5px);
  box-shadow: 0px 0px 10px 0px rgba(1, 1, 1, 0.1);
}

.picture__picture {
  background-color: #F9F9F9;
}
.picture__picture:after {
  padding-bottom: 145.2054794521%;
}

@media (max-width: 750px) {
  .pictures__list {
    margin-top: 1.3333333333em;
  }
}
@media (max-width: 510px) {
  .pictures__list {
    margin-top: 1em;
  }
}
.places__container {
  margin-top: 3em;
  position: relative;
}
.places__container .swiper__arrows {
  position: absolute;
  top: 0px;
  right: 23.4682080925%;
  display: flex;
  transform: translateY(-100%);
  padding-bottom: 3.3333333333em;
}
.places__container .swiper__arrows div {
  position: static;
  margin-top: 0px;
  width: 30px;
  height: 30px;
  background: url(d07e65486d63a270feac75396092a9c8.svg) no-repeat center center;
  background-size: contain;
  -webkit-background-size: contain;
}
.places__container .swiper__arrows .swiper-button-prev {
  transform: rotate(180deg);
}
.places__container .swiper__arrows div + div {
  margin-left: 0.5333333333em;
}
.places__container .swiper__arrows svg {
  display: none;
}

.place__item {
  overflow: hidden;
}
.place__item:hover {
  cursor: grab;
}
.place__item:nth-child(1).swiper-slide-active .place__datas {
  padding-left: 7.4074074074%;
}
.place__item:nth-child(2).swiper-slide-active .place__datas {
  padding-right: 7.4074074074%;
}

.gallery__picture:after {
  padding-bottom: 55.5555555556%;
}

.place__datas {
  margin-top: 1.6666666667em;
}

.place__location {
  font-size: 1.1333333333em;
  margin-top: 0.4705882353em;
}

.contacts__list.contacts__list--place {
  margin-top: 1.3333333333em;
}
.contacts__list.contacts__list--place li {
  font-size: 1.0666666667em;
}
.contacts__list.contacts__list--place li + li {
  margin-top: 0px;
  margin-left: 1.25em;
}
.contacts__list.contacts__list--place a {
  text-decoration: none;
}

.place__btns {
  margin-top: 3.3333333333em;
  padding-bottom: 2.6666666667em;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.3333333333em;
}
.place__btns li {
  display: block;
}
.place__btns li:last-child {
  grid-column: 1/-1;
}
.place__btns li:last-child a {
  display: flex;
}
.place__btns a {
  box-shadow: inherit;
  min-width: 140px;
  justify-content: space-between;
}
.place__btns a span {
  font-size: 0.95em;
}
.place__btns a .responsive {
  display: none;
}

.place__right {
  margin-left: 13.8728323699%;
}

.subtitle--place {
  font-size: 1.4666666667em;
}

.place__info {
  margin-top: 0.3333333333em;
}

.place__opening {
  table-layout: fixed;
  margin-top: 1.6666666667em;
}

.opening__item + .opening__item .opening__day, .opening__item + .opening__item .opening__time {
  padding-top: 0.6875em;
}

.opening__day {
  font-family: "Ivy Mode";
  font-weight: 300;
  color: black;
  font-size: 1.0666666667em;
}

.opening__time {
  padding-left: 1.6666666667em;
}

.swiper--gallery {
  position: relative;
}
.swiper--gallery .swiper-pagination-gallery {
  background-color: rgba(0, 0, 0, 0.7);
  border-radius: 20px;
  padding: 0.6666666667em 1.1333333333em;
  display: inline-flex;
  position: absolute;
  bottom: 20px !important;
  left: 0px;
  z-index: 100;
  width: auto !important;
  transform: translateX(-50%) !important;
  left: 50% !important;
  backdrop-filter: blur(3px);
  border: 1px solid rgba(180, 165, 131, 0.2) !important;
}
.swiper--gallery .swiper-pagination-gallery span {
  width: 11px;
  height: 11px;
  border: 1px solid #B4A583 !important;
  background-color: transparent !important;
  transition: all 0.25s ease 0s;
  opacity: 1 !important;
}
.swiper--gallery .swiper-pagination-gallery span:hover {
  background-color: #B4A583 !important;
}
.swiper--gallery .swiper-pagination-gallery .swiper-pagination-bullet-active {
  background-color: #B4A583 !important;
}

@media (max-width: 1450px) {
  .place__info {
    max-width: 350px;
  }
}
@media (max-width: 1200px) {
  .places__container .swiper__arrows {
    right: 13.3333333333%;
  }
}
@media (max-width: 1100px) {
  .subtitle--place {
    font-size: 1.2666666667em;
  }
  .place__location {
    font-size: 1em;
  }
  .contacts__list.contacts__list--place li {
    font-size: 1em;
  }
  .contacts__list.contacts__list--place li + li {
    margin-left: 0.6666666667em;
  }
  .place__btns {
    display: flex;
    flex-direction: column;
    margin-top: 2.3333333333em;
    gap: inherit;
  }
  .place__btns li + li {
    margin-left: 0px;
    margin-top: 0.6666666667em;
  }
  .place__btns a {
    font-size: 1.0666666667em;
    display: flex;
    justify-content: space-between;
    padding: 0.5333333333em 1.3333333333em 0.6666666667em;
  }
  .place__btns a span {
    font-size: 1em;
  }
}
@media (max-width: 1000px) {
  .place__item:nth-child(1).swiper-slide-active .place__datas {
    padding-left: 5%;
  }
}
@media (max-width: 800px) {
  .contacts__list.contacts__list--place {
    flex-direction: column;
  }
  .contacts__list.contacts__list--place li + li {
    margin-left: 0px;
    margin-top: 0.6666666667em;
  }
  .places__list {
    flex-direction: column;
  }
  .places__list .place__datas {
    padding-left: 5%;
    padding-right: 5%;
  }
  .place__item + .place__item {
    margin-top: 1.3333333333em;
  }
  .place__item:hover {
    cursor: inherit;
  }
  .places__container {
    margin-top: 2em;
  }
}
@media (max-width: 600px) {
  .place__btns li:last-child a span {
    display: none;
  }
  .place__btns li:last-child a .responsive {
    display: inline-block;
  }
}
@media (max-width: 460px) {
  .place__datas {
    flex-direction: column;
  }
  .place__right {
    margin-left: 0px;
  }
  .places__container {
    margin-top: 1.3333333333em;
  }
  .place__btns {
    padding-bottom: 2em;
  }
  .place__item + .place__item {
    margin-top: 2.6666666667em;
  }
}
.story__left {
  width: 39.8692810458%;
  margin-right: 5.8823529412%;
}
.story__left .story__picture {
  margin-top: 6em;
  margin-left: auto;
  width: 79.5081967213%;
}
.story__left .story__picture:after {
  padding-bottom: 131.9587628866%;
}
.story__left .section__intro {
  max-width: 540px;
}

.story__right {
  width: 53.5947712418%;
}
.story__right .story__picture {
  margin-bottom: 6em;
  width: 93.9024390244%;
  margin-left: auto;
}
.story__right .story__picture:after {
  padding-bottom: 62.987012987%;
}
.story__right .section__intro {
  max-width: 600px;
}

@media (max-width: 1000px) {
  .story__left .story__picture {
    margin-top: 3.3333333333em;
  }
  .story__right .story__picture {
    margin-bottom: 2.6666666667em;
  }
  .story__right .section__intro {
    width: 93.9024390244%;
    margin-left: auto;
  }
}
@media (max-width: 650px) {
  .story__container {
    flex-direction: column;
    text-align: center;
  }
  .story__left, .story__right {
    width: 100%;
  }
  .story__left .story__picture, .story__left .section__intro, .story__right .story__picture, .story__right .section__intro {
    margin-left: 0px;
    margin-right: 0px;
    width: 100%;
  }
  .story__left .section__intro, .story__right .section__intro {
    max-width: inherit;
  }
  .story__left .story__picture {
    max-width: 450px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 2.6666666667em;
  }
  .story__right {
    display: flex;
    flex-direction: column-reverse;
  }
  .story__right .section__intro .intro__text {
    margin-top: 2.6666666667em;
    margin-bottom: 2.6666666667em;
  }
}
@media (max-width: 550px) {
  .story__right .section__intro .intro__text {
    margin-top: 1.6666666667em;
    margin-bottom: 2.6666666667em;
  }
}
@media (max-width: 390px) {
  .story__left .story__picture {
    margin-top: 2em;
  }
}
.vp--parent .vp--item {
  transition: all 0.6s ease 0s;
  opacity: 0;
  transform: translate3d(0px, 50px, 0px);
}
.vp--parent .vp--item-left {
  transition: all 0.6s ease 0s;
  opacity: 0;
  transform: translate3d(-50px, 0px, 0px);
}
.vp--parent .vp--item-right {
  transition: all 0.6s ease 0s;
  opacity: 0;
  transform: translate3d(50px, 0px, 0px);
}
.vp--parent .vp--img {
  transition: all 0.8s ease 0s;
  opacity: 0;
  transition-delay: 0.3s;
  transform: scale(0.98);
}
.vp--parent .vp--delay1 {
  transition-delay: 0s;
}
.vp--parent .vp--delay2 {
  transition-delay: 0.25s;
}
.vp--parent .vp--delay3 {
  transition-delay: 0.5s;
}
.vp--parent .vp--delay4 {
  transition-delay: 0.75s;
}
.vp--parent .vp--delay5 {
  transition-delay: 1s;
}
.vp--parent .header__reservation {
  transform: translate3d(0px, 100px, 0px);
}
.vp--parent[data-in-viewport=true] .vp--item, .vp--parent[data-in-viewport=true] .vp--item-left, .vp--parent[data-in-viewport=true] .vp--item-right, .vp--parent[data-in-viewport=true] .vp--img {
  opacity: 1;
  transform: translate3d(0px, 0px, 0px);
}
.vp--parent[data-in-viewport=true] .header__reservation {
  transform: translate3d(0px, 50px, 0px);
}
.vp--parent[data-in-viewport=true] .btn--food, .vp--parent[data-in-viewport=true] .lang__container {
  transform: translate3d(0px, -10px, 0px);
}
.vp--parent[data-in-viewport=true] .vp--img {
  transform: scale(1);
}
@media (max-width: 450px) {
  .vp--parent[data-in-viewport=true] .header__reservation {
    transform: translate3d(0px, 70px, 0px);
  }
}

/**
 * #COMPONENTS
 */
/**
 * #TRUMPS
 */
/*------------------------------------*\
    #CLEARFIX
\*------------------------------------*/
/**
 * Micro clearfix, as per: css-101.org/articles/clearfix/latest-new-clearfix-so-far.php
 * Extend the clearfix class with Sass to avoid the `.clearfix` class appearing
 * over and over in your markup.
 */
.clearfix:after {
  content: "";
  display: table;
  clear: both;
}

/*------------------------------------*\
    #WIDTHS
\*------------------------------------*/
/**
 * A series of width helper classes that you can use to size things like grid
 * systems. Classes can take a fraction-like format (e.g. `.2/3`) or a spoken-
 * word format (e.g. `two-thirds`). Toggle formats by overriding the
 * `$inuit-use-fractions` variable defined below.
 */
/**
 * Whole.
 */
.one-whole {
  width: 100% !important;
}

/**
 * Halves.
 */
.one-half,
.two-quarters,
.three-sixths,
.four-eighths,
.five-tenths,
.six-twelfths {
  width: 50% !important;
}

/**
 * Thirds.
 */
.one-third,
.two-sixths,
.three-ninths,
.four-twelfths {
  width: 33.3333333% !important;
}

.two-thirds,
.four-sixths,
.six-ninths,
.eight-twelfths {
  width: 66.6666666% !important;
}

/**
 * Quarters.
 */
.one-quarter,
.two-eighths,
.three-twelfths {
  width: 25% !important;
}

.three-quarters,
.six-eighths,
.nine-twelfths {
  width: 75% !important;
}

/**
 * Fifths.
 */
.one-fifth,
.two-tenths {
  width: 20% !important;
}

.two-fifths,
.four-tenths {
  width: 40% !important;
}

.three-fifths,
.six-tenths {
  width: 60% !important;
}

.four-fifths,
.eight-tenths {
  width: 80% !important;
}

/**
 * Sixths.
 */
.one-sixth,
.two-twelfths {
  width: 16.6666666% !important;
}

.five-sixths,
.ten-twelfths {
  width: 83.3333333% !important;
}

/**
 * Eighths.
 */
.one-eighth {
  width: 12.5% !important;
}

.three-eighths {
  width: 37.5% !important;
}

.five-eighths {
  width: 62.5% !important;
}

.seven-eighths {
  width: 87.5% !important;
}

/**
 * Ninths.
 */
.one-ninth {
  width: 11.1111111% !important;
}

.two-ninths {
  width: 22.2222222% !important;
}

.four-ninths {
  width: 44.4444444% !important;
}

.five-ninths {
  width: 55.5555555% !important;
}

.seven-ninths {
  width: 77.7777777% !important;
}

.eight-ninths {
  width: 88.8888888% !important;
}

/**
 * Tenths.
 */
.one-tenth {
  width: 10% !important;
}

.three-tenths {
  width: 30% !important;
}

.seven-tenths {
  width: 70% !important;
}

.nine-tenths {
  width: 90% !important;
}

/**
 * Twelfths.
 */
.one-twelfth {
  width: 8.3333333% !important;
}

.five-twelfths {
  width: 41.6666666% !important;
}

.seven-twelfths {
  width: 58.3333333% !important;
}

.eleven-twelfths {
  width: 91.6666666% !important;
}

/*------------------------------------*\
    #SPACING
\*------------------------------------*/
/**
 * Margin and padding helper classes. Use these to tweak layout on a micro
 * level.
 *
 * `.(m|p)(t|r|b|l|h|v)(-|+|0) {}` = margin/padding top/right/bottom/left/horizontal/vertical less/more/none
 */
/**
 * Margin helper classes.
 *
 * Add margins.
 */
.m {
  margin: 24px !important;
}

.mt {
  margin-top: 24px !important;
}

.mr {
  margin-right: 24px !important;
}

.mb {
  margin-bottom: 24px !important;
}

.ml {
  margin-left: 24px !important;
}

.mh {
  margin-right: 24px !important;
  margin-left: 24px !important;
}

.mv {
  margin-top: 24px !important;
  margin-bottom: 24px !important;
}

/**
 * Add huge margins.
 */
.m\+\+ {
  margin: 96px !important;
}

.mt\+\+ {
  margin-top: 96px !important;
}

.mr\+\+ {
  margin-right: 96px !important;
}

.mb\+\+ {
  margin-bottom: 96px !important;
}

.ml\+\+ {
  margin-left: 96px !important;
}

.mh\+\+ {
  margin-right: 96px !important;
  margin-left: 96px !important;
}

.mv\+\+ {
  margin-top: 96px !important;
  margin-bottom: 96px !important;
}

/**
 * Remove margins.
 */
.m0 {
  margin: 0 !important;
}

.mt0 {
  margin-top: 0 !important;
}

.mr0 {
  margin-right: 0 !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.ml0 {
  margin-left: 0 !important;
}

.mh0 {
  margin-right: 0 !important;
  margin-left: 0 !important;
}

.mv0 {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.hide {
  position: absolute;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  clip: rect(1px 1px 1px 1px);
  width: 1px;
  height: 1px;
}

.text-cut {
  white-space: nowrap;
  overflow: hidden; /* pour Opera 9 */
  text-overflow: ellipsis; /* pour le reste du monde */
}
