a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
s,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
li,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strike,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
tt,
u,
ul,
var,
video {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: top;
  text-decoration: none;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}
.inline-block,
ul.hack-inline > li {
  display: inline-block;
}
ol,
ul {
  list-style: none;
}
blockquote,
q {
  quotes: none;
}
blockquote:after,
blockquote:before,
q:after,
q:before {
  content: '';
  content: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 400;
}
body * {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
}
.relative {
  position: relative;
}
.absolute {
  position: absolute;
}
.fixed {
  position: fixed;
}
.hack-inline {
  letter-spacing: -0.5em !important;
}
.hack-inline > * {
  letter-spacing: normal;
  display: inline-block;
}
.block {
  display: block;
}
.none {
  display: none;
}
.flex {
  display: flex;
  -webkit-display: -webkit-flex;
}
.flex > * {
  flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
}
.float-left {
  float: left;
}
.float-right {
  float: right;
}
.center {
  text-align: center;
}
.left {
  text-align: left;
}
.right {
  text-align: right;
}
.clear {
  clear: both;
}
.padding_top_0 {
  padding-top: 0 !important;
}
.padding_bottom_0 {
  padding-bottom: 0 !important;
}
.margin_top_0 {
  margin-top: 0 !important;
}
.margin_0_auto {
  margin: 0 auto;
}
.centerblock {
  margin: 0 auto;
  display: block;
}
.uppercase {
  text-transform: uppercase;
}
.justify {
  text-align: justify;
}
.photo {
  overflow: hidden;
  justify-content: center;
  object-position: 50% 50%;
}
.photo img {
  flex: 1;
  object-fit: cover;
}
.photo img.contain {
  object-fit: contain;
}
.centerX,
.centerXY,
.centerY {
  position: absolute;
}
.centerXY {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
}
.centerX {
  left: 50%;
  transform: translate(-50%, 0);
  -webkit-transform: translate(-50%, 0);
}
.centerY,
.trigger:after {
  transform: translate(0, -50%);
}
.centerY {
  top: 50%;
  -webkit-transform: translate(0, -50%);
}
.grid_2 > .element {
  width: 50%;
}
.grid_3 > .element {
  width: 33.3%;
}
.grid_4 > .element {
  width: 25%;
}
.grid_5 > .element {
  width: 20%;
}
.flex_wrap {
  flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
}
.align_content_center {
  align-content: center;
  -webkit-align-content: center;
  -ms-align-content: center;
}
.justify_center {
  justify-content: center;
  -webkit-justify-content: center;
  -ms-justify-content: center;
}
.flex_0 {
  flex: 0;
  -webkit-flex: 0;
  -ms-flex: 0;
}
.flex_column {
  flex-direction: column;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
}
.element {
  position: relative;
}
.mailto {
  cursor: pointer;
}
.container,
.small_container,
.big_container {
  width: 100%;
  display: block;
  margin: 0 auto;
}
.container {
  max-width: 100rem;
}
.big_container {
  max-width: 160rem;
}
.small_container {
  max-width: 80rem;
}
.opa0 {
  opacity: 0;
}
.opa1 {
  opacity: 1;
}
.apparition {
  transition: all 1000ms;
}
.apparition.hide {
  opacity: 0;
}
.apparition_right.hide {
  transform: translate(15rem);
  -webkit-transform: translate(15rem);
}
.apparition_left.hide {
  transform: translate(-15rem);
  -webkit-transform: translate(-15rem);
}
.apparition_top.hide {
  transform: translate(0, -15rem);
  -webkit-transform: translate(0, -15rem);
}
.apparition_bottom.hide {
  transform: translate(0, 15rem);
  -webkit-transform: translate(0, 15rem);
}
.apparition_bottom {
  transform: translate(0);
  -webkit-transform: translate(0);
}
.apparition_top {
  transform: translate(0);
  -webkit-transform: translate(0);
}
.apparition_left {
  transform: translate(0);
  -webkit-transform: translate(0);
}
.apparition_right {
  transform: translate(0);
  -webkit-transform: translate(0);
}
.apparition_bottom_absolute {
  margin-top: 5rem;
}
.apparition_bottom_absolute.show {
  margin-top: 0;
}
.apparition_top_absolute {
  margin-bottom: 5rem;
}
.apparition_top_absolute.show {
  margin-bottom: 0;
}
.apparition_left_absolute {
  margin-right: 5rem;
}
.apparition_left_absolute.show {
  margin-right: 0;
}
.apparition_right_absolute {
  margin-left: 5rem;
}
.apparition_right_absolute.show {
  margin-left: 0;
}
.main.no_diapo {
  margin-top: 15rem;
}
.delay_0 {
  transition-delay: 0s !important;
  -webkit-transition-delay: 0s !important;
  transition: all 0s !important;
  -webkit-transition: all 0s !important;
}
.overflow {
  overflow: hidden;
}
.popup {
  width: 800px;
}
.popup.document {
  height: 90vh;
}
.popup.document > iframe {
  height: 100%;
}
.popup iframe {
  width: 100%;
}
.mw1000 {
  max-width: 100rem;
}
.mw1200 {
  max-width: 120rem;
}
.mw1600 {
  max-width: 160rem;
}
.mw800 {
  max-width: 80rem;
}
.mw900 {
  max-width: 90rem;
}
.w1 {
  width: 1%;
}
.h1 {
  height: 1%;
}
.mw1 {
  max-width: 1%;
}
.w2 {
  width: 2%;
}
.h2 {
  height: 2%;
}
.mw2 {
  max-width: 2%;
}
.w3 {
  width: 3%;
}
.h3 {
  height: 3%;
}
.mw3 {
  max-width: 3%;
}
.w4 {
  width: 4%;
}
.h4 {
  height: 4%;
}
.mw4 {
  max-width: 4%;
}
.w5 {
  width: 5%;
}
.h5 {
  height: 5%;
}
.mw5 {
  max-width: 5%;
}
.w6 {
  width: 6%;
}
.h6 {
  height: 6%;
}
.mw6 {
  max-width: 6%;
}
.w7 {
  width: 7%;
}
.h7 {
  height: 7%;
}
.mw7 {
  max-width: 7%;
}
.w8 {
  width: 8%;
}
.h8 {
  height: 8%;
}
.mw8 {
  max-width: 8%;
}
.w9 {
  width: 9%;
}
.h9 {
  height: 9%;
}
.mw9 {
  max-width: 9%;
}
.w10 {
  width: 10%;
}
.h10 {
  height: 10%;
}
.mw10 {
  max-width: 10%;
}
.w11 {
  width: 11%;
}
.h11 {
  height: 11%;
}
.mw11 {
  max-width: 11%;
}
.w12 {
  width: 12%;
}
.h12 {
  height: 12%;
}
.mw12 {
  max-width: 12%;
}
.w13 {
  width: 13%;
}
.h13 {
  height: 13%;
}
.mw13 {
  max-width: 13%;
}
.w14 {
  width: 14%;
}
.h14 {
  height: 14%;
}
.mw14 {
  max-width: 14%;
}
.w15 {
  width: 15%;
}
.h15 {
  height: 15%;
}
.mw15 {
  max-width: 15%;
}
.w16 {
  width: 16%;
}
.h16 {
  height: 16%;
}
.mw16 {
  max-width: 16%;
}
.w17 {
  width: 17%;
}
.h17 {
  height: 17%;
}
.mw17 {
  max-width: 17%;
}
.w18 {
  width: 18%;
}
.h18 {
  height: 18%;
}
.mw18 {
  max-width: 18%;
}
.w19 {
  width: 19%;
}
.h19 {
  height: 19%;
}
.mw19 {
  max-width: 19%;
}
.w20 {
  width: 20%;
}
.h20 {
  height: 20%;
}
.mw20 {
  max-width: 20%;
}
.w21 {
  width: 21%;
}
.h21 {
  height: 21%;
}
.mw21 {
  max-width: 21%;
}
.w22 {
  width: 22%;
}
.h22 {
  height: 22%;
}
.mw22 {
  max-width: 22%;
}
.w23 {
  width: 23%;
}
.h23 {
  height: 23%;
}
.mw23 {
  max-width: 23%;
}
.w24 {
  width: 24%;
}
.h24 {
  height: 24%;
}
.mw24 {
  max-width: 24%;
}
.w25 {
  width: 25%;
}
.h25 {
  height: 25%;
}
.mw25 {
  max-width: 25%;
}
.w26 {
  width: 26%;
}
.h26 {
  height: 26%;
}
.mw26 {
  max-width: 26%;
}
.w27 {
  width: 27%;
}
.h27 {
  height: 27%;
}
.mw27 {
  max-width: 27%;
}
.w28 {
  width: 28%;
}
.h28 {
  height: 28%;
}
.mw28 {
  max-width: 28%;
}
.w29 {
  width: 29%;
}
.h29 {
  height: 29%;
}
.mw29 {
  max-width: 29%;
}
.w30 {
  width: 30%;
}
.h30 {
  height: 30%;
}
.mw30 {
  max-width: 30%;
}
.w31 {
  width: 31%;
}
.h31 {
  height: 31%;
}
.mw31 {
  max-width: 31%;
}
.w32 {
  width: 32%;
}
.h32 {
  height: 32%;
}
.mw32 {
  max-width: 32%;
}
.w33 {
  width: 33%;
}
.h33 {
  height: 33%;
}
.mw33 {
  max-width: 33%;
}
.w34 {
  width: 34%;
}
.h34 {
  height: 34%;
}
.mw34 {
  max-width: 34%;
}
.w35 {
  width: 35%;
}
.h35 {
  height: 35%;
}
.mw35 {
  max-width: 35%;
}
.w36 {
  width: 36%;
}
.h36 {
  height: 36%;
}
.mw36 {
  max-width: 36%;
}
.w37 {
  width: 37%;
}
.h37 {
  height: 37%;
}
.mw37 {
  max-width: 37%;
}
.w38 {
  width: 38%;
}
.h38 {
  height: 38%;
}
.mw38 {
  max-width: 38%;
}
.w39 {
  width: 39%;
}
.h39 {
  height: 39%;
}
.mw39 {
  max-width: 39%;
}
.w40 {
  width: 40%;
}
.h40 {
  height: 40%;
}
.mw40 {
  max-width: 40%;
}
.w41 {
  width: 41%;
}
.h41 {
  height: 41%;
}
.mw41 {
  max-width: 41%;
}
.w42 {
  width: 42%;
}
.h42 {
  height: 42%;
}
.mw42 {
  max-width: 42%;
}
.w43 {
  width: 43%;
}
.h43 {
  height: 43%;
}
.mw43 {
  max-width: 43%;
}
.w44 {
  width: 44%;
}
.h44 {
  height: 44%;
}
.mw44 {
  max-width: 44%;
}
.w45 {
  width: 45%;
}
.h45 {
  height: 45%;
}
.mw45 {
  max-width: 45%;
}
.w46 {
  width: 46%;
}
.h46 {
  height: 46%;
}
.mw46 {
  max-width: 46%;
}
.w47 {
  width: 47%;
}
.h47 {
  height: 47%;
}
.mw47 {
  max-width: 47%;
}
.w48 {
  width: 48%;
}
.h48 {
  height: 48%;
}
.mw48 {
  max-width: 48%;
}
.w49 {
  width: 49%;
}
.h49 {
  height: 49%;
}
.mw49 {
  max-width: 49%;
}
.w50 {
  width: 50%;
}
.h50 {
  height: 50%;
}
.mw50 {
  max-width: 50%;
}
.w51 {
  width: 51%;
}
.h51 {
  height: 51%;
}
.mw51 {
  max-width: 51%;
}
.w52 {
  width: 52%;
}
.h52 {
  height: 52%;
}
.mw52 {
  max-width: 52%;
}
.w53 {
  width: 53%;
}
.h53 {
  height: 53%;
}
.mw53 {
  max-width: 53%;
}
.w54 {
  width: 54%;
}
.h54 {
  height: 54%;
}
.mw54 {
  max-width: 54%;
}
.w55 {
  width: 55%;
}
.h55 {
  height: 55%;
}
.mw55 {
  max-width: 55%;
}
.w56 {
  width: 56%;
}
.h56 {
  height: 56%;
}
.mw56 {
  max-width: 56%;
}
.w57 {
  width: 57%;
}
.h57 {
  height: 57%;
}
.mw57 {
  max-width: 57%;
}
.w58 {
  width: 58%;
}
.h58 {
  height: 58%;
}
.mw58 {
  max-width: 58%;
}
.w59 {
  width: 59%;
}
.h59 {
  height: 59%;
}
.mw59 {
  max-width: 59%;
}
.w60 {
  width: 60%;
}
.h60 {
  height: 60%;
}
.mw60 {
  max-width: 60%;
}
.w61 {
  width: 61%;
}
.h61 {
  height: 61%;
}
.mw61 {
  max-width: 61%;
}
.w62 {
  width: 62%;
}
.h62 {
  height: 62%;
}
.mw62 {
  max-width: 62%;
}
.w63 {
  width: 63%;
}
.h63 {
  height: 63%;
}
.mw63 {
  max-width: 63%;
}
.w64 {
  width: 64%;
}
.h64 {
  height: 64%;
}
.mw64 {
  max-width: 64%;
}
.w65 {
  width: 65%;
}
.h65 {
  height: 65%;
}
.mw65 {
  max-width: 65%;
}
.w66 {
  width: 66%;
}
.h66 {
  height: 66%;
}
.mw66 {
  max-width: 66%;
}
.w67 {
  width: 67%;
}
.h67 {
  height: 67%;
}
.mw67 {
  max-width: 67%;
}
.w68 {
  width: 68%;
}
.h68 {
  height: 68%;
}
.mw68 {
  max-width: 68%;
}
.w69 {
  width: 69%;
}
.h69 {
  height: 69%;
}
.mw69 {
  max-width: 69%;
}
.w70 {
  width: 70%;
}
.h70 {
  height: 70%;
}
.mw70 {
  max-width: 70%;
}
.w71 {
  width: 71%;
}
.h71 {
  height: 71%;
}
.mw71 {
  max-width: 71%;
}
.w72 {
  width: 72%;
}
.h72 {
  height: 72%;
}
.mw72 {
  max-width: 72%;
}
.w73 {
  width: 73%;
}
.h73 {
  height: 73%;
}
.mw73 {
  max-width: 73%;
}
.w74 {
  width: 74%;
}
.h74 {
  height: 74%;
}
.mw74 {
  max-width: 74%;
}
.w75 {
  width: 75%;
}
.h75 {
  height: 75%;
}
.mw75 {
  max-width: 75%;
}
.w76 {
  width: 76%;
}
.h76 {
  height: 76%;
}
.mw76 {
  max-width: 76%;
}
.w77 {
  width: 77%;
}
.h77 {
  height: 77%;
}
.mw77 {
  max-width: 77%;
}
.w78 {
  width: 78%;
}
.h78 {
  height: 78%;
}
.mw78 {
  max-width: 78%;
}
.w79 {
  width: 79%;
}
.h79 {
  height: 79%;
}
.mw79 {
  max-width: 79%;
}
.w80 {
  width: 80%;
}
.h80 {
  height: 80%;
}
.mw80 {
  max-width: 80%;
}
.w81 {
  width: 81%;
}
.h81 {
  height: 81%;
}
.mw81 {
  max-width: 81%;
}
.w82 {
  width: 82%;
}
.h82 {
  height: 82%;
}
.mw82 {
  max-width: 82%;
}
.w83 {
  width: 83%;
}
.h83 {
  height: 83%;
}
.mw83 {
  max-width: 83%;
}
.w84 {
  width: 84%;
}
.h84 {
  height: 84%;
}
.mw84 {
  max-width: 84%;
}
.w85 {
  width: 85%;
}
.h85 {
  height: 85%;
}
.mw85 {
  max-width: 85%;
}
.w86 {
  width: 86%;
}
.h86 {
  height: 86%;
}
.mw86 {
  max-width: 86%;
}
.w87 {
  width: 87%;
}
.h87 {
  height: 87%;
}
.mw87 {
  max-width: 87%;
}
.w88 {
  width: 88%;
}
.h88 {
  height: 88%;
}
.mw88 {
  max-width: 88%;
}
.w89 {
  width: 89%;
}
.h89 {
  height: 89%;
}
.mw89 {
  max-width: 89%;
}
.w90 {
  width: 90%;
}
.h90 {
  height: 90%;
}
.mw90 {
  max-width: 90%;
}
.w91 {
  width: 91%;
}
.h91 {
  height: 91%;
}
.mw91 {
  max-width: 91%;
}
.w92 {
  width: 92%;
}
.h92 {
  height: 92%;
}
.mw92 {
  max-width: 92%;
}
.w93 {
  width: 93%;
}
.h93 {
  height: 93%;
}
.mw93 {
  max-width: 93%;
}
.w94 {
  width: 94%;
}
.h94 {
  height: 94%;
}
.mw94 {
  max-width: 94%;
}
.w95 {
  width: 95%;
}
.h95 {
  height: 95%;
}
.mw95 {
  max-width: 95%;
}
.w96 {
  width: 96%;
}
.h96 {
  height: 96%;
}
.mw96 {
  max-width: 96%;
}
.w97 {
  width: 97%;
}
.h97 {
  height: 97%;
}
.mw97 {
  max-width: 97%;
}
.w98 {
  width: 98%;
}
.h98 {
  height: 98%;
}
.mw98 {
  max-width: 98%;
}
.w99 {
  width: 99%;
}
.h99 {
  height: 99%;
}
.mw99 {
  max-width: 99%;
}
.w100 {
  width: 100%;
}
.h100 {
  height: 100%;
}
.mw100 {
  max-width: 100%;
}
.object-fit {
  object-fit: cover;
  object-position: 50% 50%;
}
.opa0 {
  opacity: 0;
}
.bginv {
  transform: translateY(-50%) rotateX(180deg);
  filter: brightness(0) invert(1);
}
[data-aos='blur'] {
  filter: blur(5px);
  opacity: 0;
  transition-property: filter, opacity;
}
[data-aos='blur'].aos-animate {
  filter: blur(0px);
  opacity: 1;
}
[data-aos='name'] {
  transform: translateY(20px);
  opacity: 0 !important;
  transition-property: transform, opacity;
}
[data-aos='name'].aos-animate {
  transform: translateY(0);
  opacity: 1 !important;
  transition: all 1s ease;
}
[data-aos='rub'] {
  transform: translate(-50%, -30%) !important;
  opacity: 0 !important;
  transition-property: transform, opacity;
}
[data-aos='rub'].aos-animate {
  transform: translate(-50%, -50%) !important;
  opacity: 1 !important;
  transition: all 1s ease;
}
[data-aos='openslide'] {
  opacity: 1 !important;
  clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0% 100%);
}
[data-aos='openslide'].aos-animate {
  animation: inset 1.5s ease-out forwards;
}
@keyframes inset {
  0% {
    clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0% 100%);
  }
  100% {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
  }
}
.openslide {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 9;
  background: white;
  display: block;
  top: 0;
  left: 0;
  transform-origin: bottom left;
}
[data-aos='scaleX'] {
  transform: scaleX(0);
  transition-property: transform;
  transform-origin: left;
}
[data-aos='scaleX'].aos-animate {
  transform: scaleX(1);
}
@keyframes expand {
  0% {
    letter-spacing: -0.5em;
    opacity: 0;
  }
  40% {
    opacity: 0.6;
  }
  100% {
    opacity: 1;
  }
}
[data-aos='expand'].aos-animate {
  animation: expand 1s cubic-bezier(0.215, 0.61, 0.355, 1) forwards;
}
.zones {
  overflow-x: hidden;
}
.zones .zone {
  padding-top: 100px;
  position: relative;
  overflow: hidden;
}
.zones .zone:last-of-type {
  margin-bottom: 100px;
}
.zones.stickyHeader {
  margin-top: 0;
}
.photo img {
  transition: all 0.3s ease;
}
.photo:hover img {
  transition: all 2s ease-out;
}
[data-aos] {
  opacity: 0;
}
.aos-animate {
  opacity: 1;
}
p {
  line-height: 1.5;
}
.cfluid {
  width: 80%;
  margin: 0 auto;
  position: relative;
}
.swiper-container {
  cursor: grab;
}
.swiper-container:focus {
  cursor: grabbing;
}
.swiper-button-next,
.swiper-button-prev {
  background-image: none !important;
  font-size: 1.8rem;
  outline: none;
  overflow: hidden;
  width: auto !important;
}
.swiper-button-next img,
.swiper-button-prev img {
  width: 100%;
}
.swiper-button-prev:hover img {
  animation: roll 1s ease-in-out infinite both reverse;
}
.swiper-button-next:hover img {
  animation: roll 1s ease-in-out both infinite;
}
@keyframes roll {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(100%);
  }
}
.fond {
  opacity: 0.5 !important;
  z-index: -1;
}
.zone:not(.diapotop) .rub .titre {
  text-transform: uppercase;
}
.rub {
  margin-bottom: 25px;
}
.rub .titre {
  font-size: 3.5rem;
  letter-spacing: 2px;
  font-weight: 400;
  line-height: 1;
  font-family: 'Butler';
  text-align: center;
}
.rub .titre.price {
  color: #456b60;
  text-align: start;
}
.rub .titre.light {
  font-size: 2.5rem;
  letter-spacing: 1px;
}
.rub.titre-container {
  display: flex;
  flex-direction: column;
}
.rub.titre-container .separator {
  display: flex;
  width: 100%;
  align-items: center;
  margin-top: 12px;
}
.rub.titre-container .separator::before,
.rub.titre-container .separator::after {
  content: '';
  width: 100%;
  display: block;
  height: 1px;
  background: black;
}
.rub.titre-container .separator img {
  object-fit: contain;
  width: 47px;
  margin: 0 8px;
}
.sstitre {
  font-size: 1.5rem;
  font-weight: 400;
  font-family: unset;
  margin-bottom: 25px;
  font-style: italic;
}
.plus:not(.action) {
  height: 28px;
  width: 28px;
  font-size: 2.8rem;
  font-weight: 100;
  border: 1px solid;
  border-radius: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  color: white;
  position: absolute;
  bottom: 15px;
  right: 15px;
}
.button {
  border: 0;
  display: inline-block;
  margin-top: 4rem;
  font-weight: 500;
  transition: all 0.3s ease;
  position: relative;
  z-index: 0;
  letter-spacing: 1px;
  font-style: italic;
  border: 1px solid #456b60;
  background: #456b60;
  color: white;
  padding: 15px 30px;
  max-width: max-content;
  transition: 250ms color ease-out, 250ms background ease-out, 300ms box-shadow 150ms ease-out;
}
.button i {
  margin-right: 10px;
  font-size: 2rem;
}
.button:hover {
  background-color: white;
  color: #456b60 !important;
  box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.125);
}
.links-container {
  margin-top: 4rem;
}
.links-container .button {
  margin-top: 0;
}
.frame {
  border-left: 1px solid;
}
.frame:before {
  position: absolute;
  content: '';
  top: 0;
  right: 0;
  height: 100%;
  width: 15%;
  border: 1px solid;
  border-left: 0;
}
.links-container {
  display: flex;
  align-items: center;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 20px;
}
.buttonPhone {
  position: relative;
  font-size: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  height: max-content;
}
.buttonPhone:hover i {
  animation: shake 2s;
}
.buttonPhone > i {
  color: #456b60;
  font-size: 28px;
  transform: scaleX(-1) rotate(-10deg);
}
.buttonPhone .text-phone {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 5px;
  line-height: 20px;
  color: #456b60;
}
.buttonPhone .text-phone > span {
  text-transform: uppercase;
  transition: all 500ms;
}
.buttonPhone .text-phone > a {
  display: flex;
  flex-direction: row;
  gap: 10px;
}
@keyframes shake {
  from {
    transform: rotate(0deg) scaleX(-1);
  }
  10% {
    transform: rotate(10deg) scaleX(-1);
  }
  20% {
    transform: rotate(-10deg) scaleX(-1);
  }
  30% {
    transform: rotate(10deg) scaleX(-1);
  }
  40% {
    transform: rotate(-10deg) scaleX(-1);
  }
  50% {
    transform: rotate(10deg) scaleX(-1);
  }
  60% {
    transform: rotate(-10deg) scaleX(-1);
  }
  70% {
    transform: rotate(10deg) scaleX(-1);
  }
  80% {
    transform: rotate(-10deg) scaleX(-1);
  }
  90% {
    transform: rotate(10deg) scaleX(-1);
  }
  to {
    transform: rotate(0deg) scaleX(-1);
  }
}
.redirect-shipping,
.addcart {
  background: #456b60;
  color: white;
  display: flex;
  padding: 15px 25px;
  align-items: center;
  width: fit-content;
  width: max-content;
  position: relative;
  transition: 500ms color ease-out 250ms, 500ms border ease-out;
  border: 1px solid transparent;
}
.redirect-shipping:hover,
.addcart:hover {
  color: #456b60;
  border: 1px solid #456b60;
}
.redirect-shipping:hover::before,
.addcart:hover::before {
  transform: none;
}
.redirect-shipping:hover svg path,
.addcart:hover svg path {
  fill: #456b60;
  transition: 500ms fill ease-out 250ms;
}
.redirect-shipping svg,
.addcart svg {
  position: relative;
  z-index: 2;
  width: 25px;
  height: 25px;
  margin-right: 12px;
}
.redirect-shipping svg path,
.addcart svg path {
  fill: white;
}
.redirect-shipping span,
.addcart span {
  z-index: 2;
  font-style: italic;
  font-size: 110%;
  position: relative;
}
@media all and (min-width: 1000px) {
  .hasOverflow {
    overflow: auto;
    padding-right: 25px;
    margin-right: -25px;
    scrollbar-width: thin;
  }
  .hasOverflow::-webkit-scrollbar {
    width: 3px;
  }
  .hasOverflow::-webkit-scrollbar-thumb {
    background-clip: content-box;
    border-left: 3px solid #456b60;
  }
  .hasOverflow::-webkit-scrollbar-track {
    border-left: 3px solid rgba(0, 0, 0, 0.075);
  }
}
@media all and (max-width: 1600px) {
  .rub {
    margin-bottom: 3.5rem;
  }
}
@media all and (max-width: 1442px) {
  .links-container {
    margin-top: 3rem;
  }
  .button {
    padding: 8px 20px;
  }
  .buttonPhone {
    font-size: 14px;
  }
  .buttonPhone > i {
    font-size: 24px;
  }
  .rub {
    margin-bottom: 2rem;
  }
  .rub .titre {
    font-size: 2.5rem;
  }
  .rub .titre.light {
    font-size: 2rem;
  }
}
@media all and (max-width: 1280px) {
  .rub {
    margin-bottom: 1rem;
  }
  .rub .titre {
    font-size: 2.4rem;
  }
  .links-container {
    margin-top: 2rem;
  }
  .sstitre {
    margin-bottom: 15px;
  }
}
@media all and (max-width: 1000px) {
  .rub {
    margin-bottom: 1rem;
  }
  .sstitre {
    font-size: 1.5rem;
  }
}
@media all and (max-width: 800px) {
  .rub {
    margin-bottom: 3rem;
  }
  .rub .titre {
    font-size: 2.5rem;
  }
}
@media all and (max-width: 600px) {
  .zones .zone {
    padding-top: 50px;
  }
  .zones .zone:only-child,
  .zones .zone:last-of-type {
    margin-bottom: 50px;
  }
  .rub {
    margin-bottom: 3rem;
  }
  .rub .name {
    font-size: 5rem;
    letter-spacing: 5px;
  }
  .rub .titre {
    font-size: 3rem;
  }
  .sstitre {
    margin-top: -2rem;
  }
  .button {
    padding: 10px 20px;
    margin-top: 2rem;
    font-size: 1.4rem;
  }
  .links-container {
    margin-top: 2rem;
  }
  .links-container .button {
    margin-top: 0;
  }
  .zone:not(.diapo) .button {
    margin-left: auto;
    margin-right: auto;
    display: block;
  }
  .zone:not(.diapo) .links-container {
    margin-left: auto;
    margin-right: auto;
  }
  .zone:not(.diapo) .links-container .button {
    margin-left: 0;
    margin-right: 0;
  }
}
@media all and (max-width: 450px) {
  .button {
    display: block;
  }
  .fond {
    left: 0 !important;
  }
  .rub {
    margin-bottom: 3rem;
  }
  .rub .hr {
    margin-bottom: 3rem;
  }
  .rub .name {
    font-size: 2.5rem;
    letter-spacing: 4px;
  }
}
@font-face {
  font-family: 'Butler';
  font-style: normal;
  font-weight: normal;
  font-display: swap;
  src: url('../fonts/Butler.woff2') format('woff2'), url('../fonts/Butler.woff') format('woff');
}
@keyframes fade {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
html {
  font-size: 62.5%;
  color: #2b2b2b;
}
body {
  font: 1.55rem/1.42 'Montserrat', sans-serif;
  overflow-x: hidden;
  transition: all 150ms;
  -webkit-transition: all 150ms;
  font-weight: 400;
}
h1,
h2,
h3,
h4 {
  font-family: 'Butler';
  font-weight: 600;
}
.fancybox-container {
  z-index: 999999 !important;
}
iframe .guarantees {
  display: none !important;
}
.align_content_right {
  align-content: right;
}
.text_right {
  text-align: right;
}
.top0 {
  top: 0;
}
.left0 {
  left: 0;
}
.right0 {
  right: 0;
}
.photo {
  justify-content: center;
  height: 100%;
}
.photo > img {
  opacity: 0;
  object-fit: cover;
  object-position: 50% 50%;
  transition: all 500ms;
  width: 100%;
  height: 100%;
}
.photo.loaded > img {
  opacity: 1;
}
a {
  color: black;
  transition: color 500ms;
}
@keyframes loadend {
  0% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    transform: translateY(-100%);
  }
}
@keyframes danone {
  0% {
    opacity: 1;
  }
  100% {
    z-index: -1;
  }
}
@keyframes fadeIn {
  from {
    opacity: 0;
    filter: blur(15px);
  }
  to {
    opacity: 1;
    filter: blur(0);
  }
}
body.no-hover .zone.grillecards2 .grid .brick:hover .text {
  transform: translate(-50%, -50%);
  /* ou la valeur que vous utilisez normalement sans le hover */
  opacity: 1;
  /* ou la valeur que vous utilisez normalement sans le hover */
}
.swiper-pagination-bullet {
  width: 14px !important;
  height: 14px !important;
  background: transparent !important;
  border: 1px solid white !important;
  transition: 500ms background ease-out !important;
  opacity: 1 !important;
}
.swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: white !important;
}
.aside {
  position: fixed;
  z-index: 100;
  right: 0;
  top: 50%;
  display: flex;
  flex-direction: column;
}
.aside a {
  background: #456b60;
  color: white;
  display: flex;
  align-items: center;
  transform: translateX(calc(100% - 56px));
  transition: 500ms transform ease-out;
}
.aside a:hover {
  transform: none;
}
.aside a:hover .text span {
  transform: translate(0, 2px);
  opacity: 1;
}
.aside a i {
  padding: 16px;
  font-size: 24px;
  min-width: 62px;
}
.aside a .text {
  height: 56px;
  background: #e0d8ce;
  display: flex;
  align-items: center;
  padding: 16px;
  font-size: 115%;
}
.aside a .text span {
  display: block;
  font-family: 'Butler';
  letter-spacing: 1px;
  opacity: 0;
  transform: translate(50%, 2px);
  transition: 500ms transform ease-out 250ms, 750ms opacity ease-out 250ms;
}
.textphoto_boutique .desc ul {
  margin-top: 15px;
}
.textphoto_boutique .desc ul li {
  padding-left: 10px;
  position: relative;
}
.textphoto_boutique .desc ul li::before {
  content: '';
  display: block;
  min-width: 6px;
  width: 6px;
  min-height: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: #000;
  margin-right: 4px;
  position: absolute;
  left: 0;
  top: 9px;
}
header {
  display: flex;
  height: 150px;
  align-items: center;
  width: 100%;
  letter-spacing: 1px;
  z-index: 9999;
  justify-content: space-between;
  position: absolute;
  top: 20px;
  left: 0;
  color: white;
}
header .menu-mobile {
  display: none;
}
header .phone {
  white-space: nowrap;
  letter-spacing: -0.5px;
  color: white;
  font-weight: 500;
  font-style: italic;
}
header .phone:before {
  content: '';
  margin-right: 1rem;
  display: inline-block;
  vertical-align: middle;
  height: 1px;
  width: 60px;
  background: white;
}
header .resa {
  color: white;
  font-weight: 500;
  font-style: italic;
}
header .resa:after {
  content: '';
  margin-left: 1rem;
  display: inline-block;
  vertical-align: middle;
  height: 1px;
  width: 60px;
  background: white;
}
header .logo {
  display: block !important;
  transition: 0s ease;
  margin: 0 0rem;
  width: 150px;
  position: relative;
}
header .logo a {
  padding-bottom: 0 !important;
}
header .logo img {
  width: 100%;
  /*width  : 130px;
      height   : 145px;*/
}
header .menu {
  display: flex;
  font-weight: 400;
  margin: 0 auto;
  height: 100%;
  width: 70%;
}
header .menu nav {
  margin: 0;
  width: 100%;
}
header .menu nav ul {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
}
header .menu nav ul li {
  display: inline-block;
  margin-right: 6rem;
}
header .menu nav ul li:last-child {
  margin-right: 0;
}
header .menu nav ul li a {
  transition: all 0.3s ease;
  display: block;
  position: relative;
  padding: 0;
  padding-bottom: 7px;
  font-family: 'Butler';
  letter-spacing: 1px;
  color: white;
  font-size: 115%;
}
header .menu nav ul li a:after {
  width: 0%;
  height: 1px;
  display: block;
  content: '';
  position: absolute;
  bottom: 0px;
  left: 0;
  z-index: -1;
  transition: all 0.3s ease;
  background: white;
}
header .menu nav ul .withsub {
  position: relative;
}
header .menu nav ul .withsub .pluplus {
  vertical-align: -2px;
  margin-left: 3px;
  font-size: 95%;
}
header .menu nav ul .withsub .submenu {
  opacity: 0;
  display: none;
  position: absolute;
  top: 100%;
  padding: 10px 0;
  left: 0;
  height: auto;
  transition: all 0.3s ease-out;
  flex-direction: column;
  background: #456b60;
  border-radius: 0px;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
}
header .menu nav ul .withsub .submenu li {
  display: flex;
  align-items: center;
  min-width: 200px;
  text-align: center;
  padding: 0.25rem 20px;
  justify-content: center;
  height: auto;
  transition: all 0.3s ease;
  margin: 0;
}
header .menu nav ul .withsub .submenu li a {
  color: white;
  letter-spacing: 1px;
  font-size: 95%;
  font-weight: 400;
  padding: 0;
}
header .menu nav ul .withsub .submenu li a:after {
  width: 0;
  height: 1px;
  transition: all 0.3s ease;
}
header .menu nav ul .withsub .submenu li:hover {
  transition: all 0.3s ease;
}
header .menu nav ul .withsub .submenu li:hover a {
  letter-spacing: 2px;
  transition: all 0.3s ease;
}
header .menu nav ul .withsub .submenu li:hover a:after {
  width: 100% !important;
  height: 0;
  transition: all 0.3s ease;
}
header .menu nav ul .withsub .submenu:before {
  position: relative;
  width: 50%;
  height: 1px;
  background: white;
  margin: 0.5rem auto;
  display: block;
  content: '';
}
header .menu nav ul .withsub .submenu:after {
  position: relative;
  width: 50%;
  height: 1px;
  background: white;
  margin: 0.5rem auto;
  display: block;
  content: '';
}
header .menu nav ul .withsub:hover .submenu {
  display: flex;
  opacity: 1;
  transition: all 0.3s ease-out;
}
header .menu nav ul li:hover {
  border: 0;
}
header .menu nav ul li:hover a {
  transition: all 0.3s ease;
}
header .menu nav ul li:hover a:after {
  width: 100%;
  transition: all 0.3s ease;
}
header .menu nav ul .current a {
  transition: border 0.3s ease;
}
header .menu nav ul .current a:after {
  width: 20px;
  height: 1px;
}
header .lang {
  text-transform: uppercase;
  position: relative;
  cursor: pointer;
  color: #777;
  margin: 0 2rem;
  margin-right: 1rem;
}
header .lang .drop {
  display: block;
  min-width: 50px;
}
header .lang img {
  width: 25px;
  vertical-align: -4px;
}
header .lang .dropdown {
  position: absolute;
  opacity: 0;
  top: 0;
  left: -5px;
  padding-top: 3rem;
  z-index: 999999999;
  transition: opacity 0.3s ease;
  display: none;
}
header .lang .dropdown li {
  height: 40px;
  width: 40px;
  text-align: center;
  margin: 5px 0;
  display: flex;
  background: #016678;
  align-items: center;
  justify-content: center;
  transition: background 0.3s ease;
}
header .lang .dropdown li:hover {
  background: #456b60;
  transition: background 0.3s ease;
}
header .lang .dropdown li:hover a {
  color: white;
}
header .lang:hover .dropdown {
  display: block;
  opacity: 1;
  transition: opacity 0.3s ease;
}
header .cart {
  color: white;
  margin-left: 10px;
  margin-right: 10px;
  font-size: 26px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
header .cart svg {
  width: 30px;
  height: 30px;
  fill: white;
}
header .cart .badge {
  background: white;
  border: 1px solid #456b60;
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translate(25%, 50%);
  color: #456b60;
  opacity: 0;
  border-radius: 4px;
  transition: all 500ms;
  padding: 5px;
  font-size: 1.25rem;
  font-family: 'Montserrat';
  font-weight: bold;
  border-radius: 50%;
  width: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 20px;
}
header .cart .badge:not([data-cart='']) {
  opacity: 1;
}
header .cart .badge[data-cart]:after {
  content: attr(data-cart);
}
@keyframes sticky {
  0% {
    opacity: 1;
    transform: translateY(-10rem);
    transform-origin: top;
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    transform-origin: top;
  }
}
.sticky,
.all-sticky {
  position: fixed;
  top: 0;
  width: 100%;
  animation: sticky 0.5s forwards;
  z-index: 10001;
  border: none;
  height: 100px;
  background: white;
  color: black;
  box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.125);
}
.sticky .cart,
.all-sticky .cart {
  color: #456b60;
}
.sticky .cart .badge,
.all-sticky .cart .badge {
  background: #456b60;
  color: white;
}
.sticky .cart svg,
.all-sticky .cart svg {
  fill: #456b60;
}
.sticky a,
.all-sticky a {
  color: black;
}
.sticky .menu nav ul li a,
.all-sticky .menu nav ul li a {
  color: black;
}
.sticky .logo,
.all-sticky .logo {
  transition: 0.2s ease;
  width: 120px;
}
.sticky .logo img,
.all-sticky .logo img {
  filter: grayscale(1) brightness(0%);
  height: auto;
  width: 100%;
  padding: 5px;
}
.sticky .resa:after,
.all-sticky .resa:after,
.sticky .phone:before,
.all-sticky .phone:before {
  background: black;
}
.burglar {
  transform: scale(0.8);
  margin: 40px auto;
  position: relative;
  display: block;
  width: 64px;
  height: 64px;
  -webkit-touch-callout: none;
  user-select: none;
}
#bottom,
#top {
  position: absolute;
  display: block;
  height: 4px;
  width: 36px;
  border-radius: 2px;
  background: white;
}
#top {
  top: 19px;
  left: 14px;
}
#bottom {
  top: 41px;
  left: 14px;
}
line,
path {
  stroke: white;
  stroke-linecap: round;
}
#bottom,
#top {
  transform-origin: 34px 2px;
  transform: rotate(0deg);
  transition: all 500ms cubic-bezier(0.8, -1.1, 0.5, 1.9);
}
#circle {
  stroke-dasharray: 1 100 32 300;
  stroke-dashoffset: 101;
  transition: all 750ms ease;
}
.burglar.is-closed {
  border-radius: 32px;
}
.burglar.is-closed #circle {
  stroke-dasharray: 1 100 190 300;
  stroke-dashoffset: 1;
}
.burglar.is-closed #top {
  transform: translateX(-4.5px) rotate(-45deg);
}
.burglar.is-closed #bottom {
  transform: translateX(-4.5px) rotate(45deg);
}
.burger {
  position: fixed;
  top: 20px;
  right: 20px;
  background: rgba(25, 42, 49, 0.8);
  z-index: 99999999;
  width: 6rem;
  height: 6rem;
  display: inline-block;
  color: #fff;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  transition: background 0.3s ease;
  display: none;
}
.burger span {
  position: absolute;
  width: 50%;
  height: 2px;
  background: white;
  border-radius: 10px;
  transition: background 0.3s ease;
}
.burger span::before {
  content: '';
  position: absolute;
  transition: 0.3s all;
  width: 100%;
  height: 2px;
  background: white;
  border-radius: 10px;
  bottom: -1rem;
  transition: background 0.3s ease;
}
.burger span::after {
  content: '';
  position: absolute;
  transition: 0.3s all;
  width: 100%;
  height: 2px;
  background: white;
  border-radius: 10px;
  top: -1rem;
  transition: all 0.3s ease;
}
.burger.active {
  background: none;
}
.burger.active span {
  transform: rotate(45deg);
}
.burger.active span:after {
  transform: rotate(-90deg) translate(-30%);
}
.burger.active span:before {
  display: none;
}
.burger:hover {
  transition: all 0.3s ease;
}
.burger:hover ::after,
.burger:hover ::before,
.burger:hover span {
  background: white;
  transform: scale(0.9);
  transition: all 0.3s ease;
}
#fullpage_menu {
  position: fixed;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 100%;
  height: 100vh;
  min-height: 100vh;
  margin: 0;
  padding: 0;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background: #456b60;
  opacity: 0;
  z-index: 1000;
  display: flex;
  transform: scale(0);
  transform-origin: top right;
  transition: all 0.3s ease-in-out;
  overflow: auto;
}
#fullpage_menu.active {
  opacity: 1;
  transform: scale(1);
  transform-origin: top right;
  transition: transform opacity 0.3s ease-in-out;
}
#fullpage_menu.active .logo {
  filter: brightness(5);
}
#fullpage_menu.active nav {
  opacity: 1;
  transition: opacity 0.8s;
  transition-delay: 0.3s;
}
#fullpage_menu.active nav ul li {
  transform: translate3d(0, 0, 0);
  transition: transform 0.3s;
}
#fullpage_menu.active nav ul li:nth-child(1) {
  transition-delay: 0.3s;
}
#fullpage_menu.active nav ul li:nth-child(2) {
  transition-delay: 0.35s;
}
#fullpage_menu.active nav ul li:nth-child(3) {
  transition-delay: 0.4s;
}
#fullpage_menu.active nav ul li:nth-child(4) {
  transition-delay: 0.45s;
}
#fullpage_menu.active nav ul li:nth-child(5) {
  transition-delay: 0.5s;
}
#fullpage_menu.active nav ul li:nth-child(6) {
  transition-delay: 0.55s;
}
#fullpage_menu.active nav ul li:nth-child(7) {
  transition-delay: 0.6s;
}
#fullpage_menu.active nav ul li:nth-child(8) {
  transition-delay: 0.7s;
}
#fullpage_menu.active nav ul li:nth-child(9) {
  transition-delay: 0.8s;
}
#fullpage_menu nav {
  opacity: 0;
  transition: opacity 0.8s;
}
#fullpage_menu nav ul li {
  text-align: center;
  font-size: 2.5rem;
  margin: 15px 0;
  font-weight: 400;
  letter-spacing: 2px;
  transform: translate3d(0, 100%, 0);
  transition: transform 0.3s ease;
}
#fullpage_menu nav ul li a {
  transition: all 0.2s ease-in-out;
  padding: 0 15px;
  color: white;
}
#fullpage_menu nav ul li a:hover {
  transition: all 0.2s ease-in-out;
  letter-spacing: 5px;
}
#fullpage_menu nav ul li.withsub a {
  position: relative;
}
#fullpage_menu nav ul li.withsub a:after {
  content: '+';
  margin-left: 10px;
}
#fullpage_menu nav ul li.withsub.show .submenu {
  height: auto;
  opacity: 1;
  transition: all 0.3s ease;
  padding: 10px 0;
}
#fullpage_menu nav ul li .submenu {
  padding: 0;
  font-size: 85%;
  height: 0;
  opacity: 0;
  transition: all 0.3s ease;
}
#fullpage_menu nav ul li .submenu li {
  margin: 5px 0;
  font-size: 1.5rem;
}
#fullpage_menu nav ul li .submenu a {
  border: 0 !important;
}
#fullpage_menu nav ul li .submenu a:after {
  display: none;
}
#fullpage_menu nav .current a {
  border-bottom: 2px dashed;
  padding: 5px 0px;
}
#fullpage_menu nav .current a:hover {
  letter-spacing: 2px;
}
@media all and (max-width: 1750px) {
  header .menu nav ul li {
    margin-right: 6rem;
  }
  header .phone:before,
  header .resa:after {
    width: 50px;
  }
}
@media all and (max-width: 1599px) {
  header .menu nav ul li {
    margin-right: 6rem;
  }
  header .menu nav ul li {
    margin-right: 4rem;
  }
  header .phone,
  header .resa {
    font-size: 13px;
  }
  header .phone:before,
  header .resa:after {
    width: 40px;
  }
  header .menu nav ul li a {
    font-size: 108%;
  }
}
@media all and (max-width: 1442px) {
  header .logo {
    width: 120px;
  }
  header .phone:before {
    width: 20px;
  }
  header .resa span {
    font-size: 12px;
    letter-spacing: 0;
  }
  header .resa:after {
    width: 20px;
  }
  header .contattu {
    font-size: 1.3rem;
  }
  header .contattu a {
    height: 45px;
  }
  header .menu {
    width: 70%;
  }
  header .menu nav ul li {
    margin-right: 5rem;
  }
  header .menu nav ul li {
    margin-right: 4rem;
  }
  header .menu nav ul li a {
    font-size: 95%;
  }
}
@media all and (max-width: 1300px) {
  header .menu nav ul li {
    margin-right: 2.5rem;
  }
  header .resa:after {
    width: 25px;
  }
}
@media all and (max-width: 1200px) {
  header {
    justify-content: space-between;
  }
  header .phone-mobile + .burger-mobile {
    margin-left: 25px;
  }
  header .cart,
  header .phone {
    display: none;
  }
  header .lang {
    display: none;
  }
  header .menu {
    width: 100%;
  }
  header .resa {
    display: none;
  }
  header .logo {
    top: 0;
    left: 50%;
    position: absolute;
    width: auto;
    max-width: 90%;
    transform: translateX(-50%);
  }
  header .logo a {
    width: 80%;
  }
  header .contattu {
    display: none;
  }
  header .reserver {
    margin-right: 7rem;
  }
  header .social {
    display: none;
  }
  header .menu {
    display: none;
  }
  header .menu nav ul li {
    display: none;
  }
  header .vids {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 87px;
    right: 25px;
  }
  header .vids .videoframe {
    cursor: pointer;
    background: #016678;
    width: 6rem;
    height: 6rem;
    display: flex;
    align-items: center;
    border: 2px solid;
    margin-bottom: 2px;
    justify-content: center;
    color: white;
  }
  header .vids .videoframe:first-child {
    margin-left: auto;
  }
  .subheader {
    font-size: 1.8rem;
  }
  .burger {
    display: flex;
  }
  #fullpage_menu .lang {
    display: block;
  }
  header .menu-mobile {
    display: flex;
  }
}
@media all and (max-width: 1200px) {
  header {
    padding: 0 25px !important;
    position: fixed;
    top: 0;
    left: 0;
  }
  header.show .menu-mobile .logo-mobile {
    opacity: 0;
  }
  header.show .menu-mobile .burger-mobile .bars span:first-child {
    position: absolute;
    transform: rotate(45deg);
  }
  header.show .menu-mobile .burger-mobile .bars span:nth-child(2) {
    opacity: 0;
  }
  header.show .menu-mobile .burger-mobile .bars span:nth-child(3) {
    position: absolute;
    transform: rotate(-45deg);
  }
  header.all-sticky,
  header.sticky {
    height: 80px !important;
  }
  header.all-sticky .menu-mobile,
  header.sticky .menu-mobile {
    align-items: center;
  }
  header.all-sticky .menu-mobile .logo-mobile img:not(.sticky-logo),
  header.sticky .menu-mobile .logo-mobile img:not(.sticky-logo) {
    display: none;
  }
  header.all-sticky .menu-mobile .logo-mobile img.sticky-logo,
  header.sticky .menu-mobile .logo-mobile img.sticky-logo {
    display: flex;
  }
  header.all-sticky .menu-mobile .phone-mobile,
  header.sticky .menu-mobile .phone-mobile,
  header.all-sticky .menu-mobile .cart-mobile,
  header.sticky .menu-mobile .cart-mobile {
    color: #456b60;
  }
  header .menu-mobile {
    width: 100%;
    display: flex;
    align-items: flex-start;
  }
  header .menu-mobile .mobile-right-wrapper {
    display: flex;
    align-items: center;
  }
  header .menu-mobile .logo-mobile {
    display: flex;
    margin-right: auto;
  }
  header .menu-mobile .logo-mobile img {
    width: 161px;
    height: 110px;
  }
  header .menu-mobile .logo-mobile img.sticky-logo {
    width: 60px;
    height: 60px;
    filter: invert(1);
    display: none;
  }
  header .menu-mobile .phone-mobile {
    font-size: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    margin: 0;
  }
  header .menu-mobile .cart-mobile {
    width: 34px;
    height: 34px;
    margin: 0 25px;
    color: white;
  }
  header .menu-mobile .cart-mobile svg {
    width: 100%;
    height: 100%;
  }
  header .menu-mobile .cart-mobile svg path {
    fill: currentColor;
  }
  header .menu-mobile .burger-mobile {
    align-items: center;
    background: #456b60;
    cursor: pointer;
    display: flex;
    gap: 10px;
    height: 40px;
    justify-content: center;
    width: 40px;
    z-index: 9999;
  }
  header .menu-mobile .burger-mobile .bars {
    display: flex;
    flex-direction: column;
    gap: 7px;
  }
  header .menu-mobile .burger-mobile .bars span {
    background: white;
    height: 1px;
    transform-origin: center;
    transition: all 0.4s ease;
    width: 20px;
  }
}
@media all and (max-width: 800px) {
  header {
    padding: 0 15px !important;
  }
  .burger {
    top: 20px;
    right: 20px;
  }
  #fullpage_menu nav {
    margin-top: 25px;
    opacity: 0;
    transition: opacity 0.8s;
  }
  #fullpage_menu nav ul li {
    font-size: 2rem;
  }
}
@media all and (max-width: 450px) {
  .fancybox-container {
    z-index: 99999999 !important;
  }
  #startproject {
    padding: 2rem 2rem;
    width: 90%;
  }
  #startproject .formulaire form .form-group {
    width: 100% !important;
    margin-right: 0 !important;
  }
  .subheader {
    font-size: 1.7rem;
  }
  .burger {
    top: 10px;
    right: 10px;
    transform: scale(0.9);
  }
  #fullpage_menu nav {
    opacity: 0;
    transition: opacity 0.8s;
  }
  #fullpage_menu nav ul li {
    font-size: 1.8rem;
    margin: 12px 0;
  }
}
footer {
  padding: 50px;
  background: #456b60;
  overflow-y: visible;
  position: relative;
  color: white;
  font-size: 1.5rem;
  font-weight: 300;
}
footer #back2top {
  display: flex;
  justify-content: center;
  align-items: center;
  color: white;
  background-color: #456b60;
  width: 65px;
  height: 65px;
  text-align: center;
  border-radius: 0;
  position: absolute;
  top: -33px;
  right: 5rem;
  opacity: 1;
  visibility: visible;
  z-index: 9;
  border: 0;
  outline: none;
  font-size: 2rem;
  transition: all 0.3s ease-in-out;
  transform: translateY(0);
  margin: 0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
}
footer #back2top a {
  color: white;
}
footer #back2top i {
  margin: 0;
}
footer #back2top:after {
  display: none;
}
footer #back2top:hover {
  cursor: pointer;
  transform: translateY(-5px);
  transition: all 0.3s ease;
  background-color: #456b60;
  color: white;
}
footer #back2top:active {
  background-color: #555;
}
footer .rub {
  padding: 0;
  margin: 0;
  width: auto;
  text-align: left;
  font-family: 'Glacial';
  width: 100%;
}
footer .rub:before {
  display: none;
}
footer a {
  transition: 0.5s;
  color: white;
}
footer a:hover {
  color: #eaeceb;
}
footer .ul {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
footer .ul .col {
  width: 25%;
  padding: 0 5rem;
}
footer .ul .col:first-child {
  align-self: center;
}
footer .ul .col .logo {
  font-size: 4rem;
  letter-spacing: 3px;
  width: 100%;
  max-width: 220px;
  margin: 0 auto;
  filter: grayscale(1) brightness(5);
}
footer .ul .col .logo img {
  width: 100%;
}
footer .ul .col .sous {
  font-weight: 300;
  font-size: 1.6rem;
  text-transform: uppercase;
  margin-top: -6px;
}
footer .ul .col .rub {
  font-weight: 500;
  text-transform: uppercase;
  margin-bottom: 2rem;
  border-bottom: 1px solid #fff;
  padding-bottom: 2rem;
  font-size: 2rem;
}
footer .ul .col .cgv {
  text-transform: uppercase;
}
footer .ul .col .cgv:hover {
  text-decoration: underline;
  transition: all 0.3s ease;
  color: white;
}
footer .ul .col .loc {
  text-align: left;
  line-height: 25px;
}
footer .ul .col .coords li {
  margin-bottom: 5px;
}
footer .ul .col .coords li.withsub .submenu {
  display: none;
}
footer .ul .col .coords li.withsub a {
  position: relative;
  color: white;
}
footer .ul .col .coords li.withsub a:after {
  content: '+';
  position: absolute;
  right: -20px;
  top: 50%;
  transform: translateY(-50%);
}
footer .ul .col .coords li.withsub.show .submenu {
  display: block;
  height: auto;
  opacity: 1;
  transition: all 0.3s ease;
  padding: 10px 0;
}
footer .ul .col .coords li .submenu {
  padding: 0;
  font-size: 85%;
  height: 0;
  opacity: 0;
  transition: all 0.3s ease;
}
footer .ul .col .coords li .submenu li {
  margin-bottom: 5px;
}
footer .ul .col .coords li .submenu a:after {
  display: none;
}
footer .ul .col .coords li a {
  display: inline-block;
}
footer .ul .col .coords .copy {
  vertical-align: 0;
  margin-right: 5px;
}
footer .ul .log {
  border-top: 0;
  border-bottom: 0;
}
footer .suivre {
  font-weight: 600;
  text-transform: uppercase;
}
footer .social {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  position: relative;
  margin-top: 1rem;
}
footer .social li {
  padding: 0;
  z-index: 1;
  margin-right: 15px;
  margin-bottom: 0;
}
footer .social li:last-child {
  margin-right: 0;
}
footer .social li a {
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
  transition: color 0.3s ease;
}
footer .social li a:hover {
  transition: all 0.3s ease;
}
footer .social li a:hover i {
  margin: 0;
}
footer .social li .facebook:hover {
  color: #3b5998;
}
footer .social li .twitter:hover {
  color: #0bf;
}
footer .social li .insta:hover {
  color: #d6249f;
  color: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285aeb 90%);
}
footer .social li .tripadvisor:hover {
  color: #00af87;
}
footer .social li i {
  font-size: 2.8rem;
  padding: 0;
}
footer .social li:last-child {
  margin-right: 0;
}
footer .real {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  flex-direction: column;
}
footer .real i {
  vertical-align: 0;
  margin-right: 3px;
}
footer .real .rub {
  text-align: end;
  text-transform: uppercase;
}
footer .real .edc {
  display: block;
  margin-right: -10px;
}
footer .real .edc img {
  width: 180px;
  height: 51px;
  margin-bottom: 10px;
}
footer .real li {
  margin: 0;
  text-align: right;
}
footer .real li:first-child {
  margin-left: 0;
}
footer .real li:last-child {
  margin-right: 0;
}
footer .coords {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  /* Divisez en 2 colonnes égales */
  gap: 10px;
  /* Espacement entre les éléments */
}
footer .col.col-logo {
  width: auto;
}
@media screen and (max-width: 1770px) {
  footer .ul .col {
    padding: 0 3rem;
  }
}
@media screen and (max-width: 1600px) {
  footer .ul .col .logo {
    width: 100%;
    max-width: auto;
  }
}
@media all and (max-width: 1500px) {
  footer .ul .col {
    padding: 0 1rem;
    margin: 20px 0;
  }
  footer .ul .col .edc img {
    margin-right: 0;
  }
}
@media all and (max-width: 1200px) {
  footer .ul .col:first-child {
    margin-right: 0;
  }
}
@media screen and (max-width: 1150px) {
  footer {
    text-align: center;
  }
  footer .real {
    align-items: center;
  }
  footer .real li {
    text-align: center;
  }
  footer .social {
    justify-content: center;
  }
  footer .ul {
    flex-wrap: wrap;
    justify-content: center;
  }
  footer .ul .col {
    min-width: 50%;
    max-width: 50%;
  }
  footer .ul .col .logo {
    margin: 0 auto;
  }
  footer .ul .col .rub {
    text-align: center;
  }
  footer .ul .col:first-child {
    min-width: 100%;
    max-width: 100%;
  }
  footer .ul .col:first-child .loc {
    text-align: center;
  }
}
@media all and (max-width: 1000px) {
  .bandeau .cfluid {
    justify-content: space-between;
  }
  .bandeau .cfluid li {
    width: 18%;
    height: auto;
    margin: auto;
  }
  .bandeau .cfluid li img {
    width: 100%;
  }
}
@media all and (max-width: 800px) {
  footer {
    text-align: center;
  }
  footer .rub {
    text-align: center;
  }
  footer .ul .log {
    border: 0;
  }
  footer .ul .col {
    width: 100% !important;
    max-width: 100% !important;
  }
  footer .ul .col .edc {
    text-align: center;
  }
  footer .real {
    flex-wrap: wrap;
  }
  footer .real li:first-child {
    width: 100%;
    margin-bottom: 3rem;
  }
  footer .real li {
    margin-bottom: 1.5rem;
  }
  footer .coords {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    /* Divisez en 2 colonnes égales */
    gap: 10px;
    /* Espacement entre les éléments */
  }
}
@media all and (max-width: 600px) {
  .bandeau .cfluid {
    justify-content: center;
    flex-wrap: wrap;
  }
  .bandeau .cfluid li {
    width: 100%;
    height: 70px;
    margin: 0 auto;
    text-align: center;
    margin-bottom: 3rem;
  }
  .bandeau .cfluid li img {
    width: auto;
    filter: grayscale(0);
  }
  .bandeau .cfluid li:last-child {
    margin-bottom: 0;
  }
}
@media screen and (max-width: 600px) {
  footer .ul .col .logo {
    width: 90%;
  }
  footer #back2top {
    width: 60px;
    height: 60px;
    right: 20px;
  }
  footer .langues {
    display: block;
  }
  footer .langues .dropdown li {
    display: inline-block;
    font-weight: 600;
    text-transform: uppercase;
    margin: 0 0.5rem;
  }
  footer .langues .dropdown li a {
    color: #999;
    font-weight: 600 !important;
  }
  footer .langues .dropdown li a.active {
    color: black;
    text-decoration: underline;
  }
}
@media screen and (max-width: 390px) {
  footer .ul .col {
    min-width: 100%;
    max-width: 100%;
  }
}
.zone.diapotop {
  position: relative;
  top: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100vh;
  min-height: 400px;
  color: white;
  overflow: hidden;
  padding: 0;
  width: 100%;
  padding-top: 10rem;
}
.zone.diapotop .scrollto {
  cursor: pointer;
}
.zone.diapotop .sliderback .swiper-slide img {
  width: 100vw;
  height: 100vh;
  object-fit: cover;
  transform: scale(1.1);
  transition: transform 1000ms ease-out;
}
.zone.diapotop .sliderback .swiper-slide-active img {
  transform: none;
}
.zone.diapotop .background-image {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -2;
  filter: brightness(0.8);
}
.zone.diapotop .background-image:after {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.2);
  z-index: 0;
}
.zone.diapotop .text {
  width: auto;
  height: auto;
  z-index: 9;
  width: 100%;
}
.zone.diapotop .text .area {
  margin: 0 auto;
  margin-bottom: 5rem;
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
}
.zone.diapotop .text .area .rub {
  margin-bottom: 2.5rem;
}
.zone.diapotop .text .area .titre {
  font-size: 4.5rem;
  font-weight: 500;
  color: white;
  animation: fadee 1s forwards;
}
.zone.diapotop .text .area .desc {
  max-width: 500px;
  font-weight: bold;
  text-align-last: center;
  font-size: 16px;
}
.zone.diapotop .text .area .button {
  margin-top: 2rem;
  color: white;
}
.zone.diapotop .text .hr {
  background: white;
}
.zone.diapotop #resa {
  position: absolute;
  bottom: 4rem;
  height: 90px;
  display: flex;
  justify-content: flex-start;
  z-index: 9;
}
.zone.diapotop #resa .formulaire {
  display: flex;
  flex-direction: row;
  justify-content: center;
  transition: all 0.3s ease;
}
.zone.diapotop #resa .formulaire:hover {
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.3);
  transition: all 0.3s ease;
}
.zone.diapotop #resa .formulaire li {
  background: white;
  color: #456b60;
  padding: 0 2rem;
  min-width: 200px;
  border-right: 1px solid #eee;
  display: flex;
  align-items: center;
  cursor: pointer;
  position: relative;
  justify-content: center;
  flex-direction: column;
}
.zone.diapotop #resa .formulaire li i {
  margin-top: 3px;
  margin-right: 5px;
}
.zone.diapotop #resa .formulaire li:first-child {
  min-width: 220px;
}
.zone.diapotop #resa .formulaire li:last-child {
  background: #456b60;
  color: white;
  border: none;
  transition: background 0.3s ease;
  position: relative;
  z-index: 9;
  letter-spacing: 1px;
  transition: all 0.3s ease;
  min-width: 0;
  padding: 0 4rem;
}
.zone.diapotop #resa .formulaire li:last-child:after {
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: #e0d8ce;
  content: "";
  position: absolute;
  z-index: -1;
  transform: scaleY(0);
  transition: transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
  transform-origin: top left;
}
.zone.diapotop #resa .formulaire li:last-child:hover {
  transition: all 0.3s ease;
}
.zone.diapotop #resa .formulaire li:last-child:hover:after {
  transform: scaleX(1);
}
.zone.diapotop #resa .formulaire li .label,
.zone.diapotop #resa .formulaire li label {
  pointer-events: none;
  color: #444;
  left: unset !important;
  font-size: 1.7rem;
  white-space: nowrap;
}
.zone.diapotop #resa .formulaire li .label.active,
.zone.diapotop #resa .formulaire li label.active {
  transform: translateY(-10px) scale(0.8);
}
.zone.diapotop #resa .formulaire input {
  border: none;
  text-align: center;
  width: auto;
  font-size: 2rem;
  font-family: 'Butler';
  width: 150px;
  color: #456b60;
}
.zone.diapotop .slider {
  position: absolute;
  bottom: 2rem;
  right: 3rem;
  width: 300px;
  text-align: center;
}
.zone.diapotop .slider .photo {
  height: 250px;
  width: 100%;
  display: block;
  border-radius: 10px 0 0 0;
}
.zone.diapotop .slider .infos {
  text-align: right;
  padding: 10px 15px;
  display: inline-block;
  width: auto;
  float: right;
  background: white;
}
.zone.diapotop .slider .bloc {
  padding: 2rem;
  border-radius: 0 0 10px 10px;
  background: white;
  text-transform: uppercase;
  font-weight: 600;
}
.zone.diapotop .slider .bloc .button {
  margin-top: 2rem;
}
.zone.diapotop .slider .bloc .text {
  width: 100%;
  padding: 3rem 2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-transform: uppercase;
  font-weight: 600;
}
.zone.diapotop .slider .bloc .text .titre {
  font-weight: 600;
  font-size: 2rem;
  text-align: center;
}
.zone.diapotop .slider .bloc .text .desc li {
  margin: 5px 0;
}
.zone.diapotop .slider .bloc .text .desc li i {
  vertical-align: 0;
  margin-right: 8px;
}
.zone.diapotop .slider .swiper-button-next,
.zone.diapotop .slider .swiper-button-prev {
  color: white;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.7);
}
.zone.diapotop.subtype2 {
  height: 50vh;
  min-height: 300px;
  width: 100%;
  margin-left: 0;
}
.zone.diapotop.subtype2 .scrollto {
  display: none;
}
.zone.diapotop.subtype2:after {
  background: rgba(0, 0, 0, 0.3);
}
.zone.diapotop.subtype2 .text {
  margin: 0;
  padding: 0;
}
.zone.diapotop.subtype2 .text .area {
  text-align: center;
}
.zone.diapotop.subtype2 .text .area .titre {
  margin-bottom: 1rem;
}
.zone.diapotop.subtype2 .text i {
  font-size: 4rem;
  margin-bottom: 5rem;
}
.zone.diapotop.subtype2 .text .sstitre {
  color: white;
  text-transform: initial;
  margin-bottom: 2rem;
}
.zone.diapotop .mouse {
  border: 2px solid white;
  bottom: 5%;
  width: 42px;
  height: 68px;
  border-radius: 100px;
  position: absolute;
  z-index: 9;
  left: 50%;
  transform: translateX(-50%) scale(0.85);
  animation: mouse 0.8s forwards;
  animation-delay: 2.5s;
  opacity: 0;
}
.zone.diapotop .mouse:before {
  content: "";
  width: 8px;
  height: 8px;
  position: absolute;
  top: 10px;
  border: 2px solid white;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 50%;
  opacity: 1;
  animation: mouseafter 2s infinite;
}
@keyframes mouse {
  0% {
    opacity: 0;
    transform: translate(-50%, 100px) scale(0.85);
  }
  60% {
    transform: translate(-50%, -10px) scale(0.85);
  }
  100% {
    opacity: 1;
    transform: translate(-50%, 0) scale(0.85);
  }
}
@keyframes mouseafter {
  from {
    opacity: 1;
    top: 8px;
  }
  to {
    opacity: 0;
    top: 50px;
  }
}
@keyframes bounce {
  0%,
  100%,
  20%,
  50%,
  80% {
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
  40% {
    -moz-transform: translateY(-30px);
    -ms-transform: translateY(-30px);
    -webkit-transform: translateY(-30px);
    transform: translateY(-30px);
  }
  60% {
    -moz-transform: translateY(-15px);
    -ms-transform: translateY(-15px);
    -webkit-transform: translateY(-15px);
    transform: translateY(-15px);
  }
}
@media all and (max-width: 1400px) {
  .zone.diapotop .text .area {
    width: 100%;
  }
}
@media all and (max-width: 1200px) {
  .zone.diapotop {
    padding-top: 5rem;
  }
  .zone.diapotop #resa .formulaire li label {
    font-size: 1.6rem;
  }
  .zone.diapotop .logo {
    display: block;
    margin: 0 auto;
    margin-bottom: 1.5rem;
    position: absolute;
    left: 15px;
    z-index: 9;
    top: 15px;
  }
  .zone.diapotop .logo img {
    width: 100%;
  }
  .zone.diapotop .text .area .sstitre {
    font-size: 2.5rem;
  }
  .zone.diapotop .text .button {
    margin-top: 3rem;
  }
}
@media all and (max-width: 1000px) {
  .zone.diapotop {
    width: 100%;
    margin-left: 0;
    padding-left: 7%;
    padding-right: 5%;
    padding-top: 8rem;
  }
  .zone.diapotop #resa {
    left: 0%;
    justify-content: center;
    bottom: 0rem;
    height: auto;
  }
  .zone.diapotop #resa .formulaire li {
    height: 80px;
  }
  .zone.diapotop #resa .formulaire li label {
    font-size: 1.6rem;
  }
  .zone.diapotop .mouse {
    bottom: 20px;
  }
  .zone.diapotop .text {
    width: 50%;
  }
  .zone.diapotop .text .button {
    margin-top: 2rem;
    padding: 10px 25px;
  }
  .zone.diapotop .text .area {
    width: 100%;
  }
  .zone.diapotop .sliderback .swiper-slide img {
    height: 100%;
  }
}
@media all and (max-width: 800px) {
  .zone.diapotop {
    flex-direction: column;
    height: auto;
    padding-bottom: 0;
    min-height: 100vh;
  }
  .zone.diapotop #resa {
    left: 0%;
    justify-content: center;
    bottom: 0rem;
    height: auto;
    position: relative;
  }
  .zone.diapotop #resa .formulaire {
    width: 100%;
  }
  .zone.diapotop #resa .formulaire input {
    font-size: 2.5rem;
  }
  .zone.diapotop #resa .formulaire li {
    padding: 0 3rem;
    height: 80px;
    min-width: 0 !important;
  }
  .zone.diapotop #resa .formulaire li label {
    font-size: 1.5rem;
    left: 3rem;
  }
  .zone.diapotop .background-image {
    filter: brightness(0.6);
    height: auto;
    bottom: 0px;
  }
  .zone.diapotop .text {
    width: 100%;
    margin-bottom: 25px;
  }
  .zone.diapotop .text .button {
    margin-top: 2rem;
  }
  .zone.diapotop .text .area {
    width: 100%;
  }
  .zone.diapotop .text .area .rub {
    margin-bottom: 2rem;
  }
  .zone.diapotop .text .area .titre {
    font-size: 4.5rem;
  }
  .zone.diapotop .text .area .titre div {
    display: inline-block;
  }
  .zone.diapotop .text .area .titre div:first-child:not(:only-child) {
    margin-right: 10px;
  }
  .zone.diapotop .text .area .button {
    margin-top: 1rem;
  }
  .zone.diapotop .text .area .desc {
    max-width: none;
    margin: 12px 0;
    font-size: 14px;
  }
  .zone.diapotop .text .area .sstitre {
    font-size: 2rem;
  }
}
@media all and (max-width: 600px) {
  .zone.diapotop {
    flex-direction: column;
    padding-right: 0;
    padding-left: 0;
  }
  .zone.diapotop #resa {
    left: 0;
    bottom: 0;
    justify-content: center;
    height: auto;
  }
  .zone.diapotop #resa .formulaire {
    width: 100%;
    flex-wrap: wrap;
  }
  .zone.diapotop #resa .formulaire input {
    font-size: 2.25rem;
  }
  .zone.diapotop #resa .formulaire li {
    padding: 0 3rem;
    height: 60px;
    width: 50%;
    min-width: 0 !important;
  }
  .zone.diapotop #resa .formulaire li label {
    font-size: 1.5rem;
    left: 3rem;
  }
  .zone.diapotop .text {
    padding: 0 25px;
  }
  .zone.diapotop .text .area {
    width: 100%;
  }
  .zone.diapotop .text .area .titre {
    font-size: 2.5rem;
  }
  .zone.diapotop .text .area .sstitre {
    font-size: 2rem;
  }
}
@media all and (max-width: 450px) {
  .zone.diapotop {
    padding-top: 150px;
  }
  .zone.diapotop .text {
    width: 100%;
  }
  .zone.diapotop .text .area {
    width: 100%;
  }
  .zone.diapotop .text .area .rub {
    margin-bottom: 1rem;
  }
  .zone.diapotop .text .area .titre {
    font-size: 2.5rem;
  }
  .zone.diapotop #resa {
    left: 0%;
    justify-content: center;
    bottom: 0rem;
    height: auto;
  }
  .zone.diapotop #resa .formulaire {
    width: 100%;
    flex-wrap: wrap;
  }
  .zone.diapotop #resa .formulaire input {
    font-size: 2rem;
  }
  .zone.diapotop #resa .formulaire li {
    padding: 0;
    height: 60px;
    width: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .zone.diapotop #resa .formulaire li:first-child {
    border-right: 1px solid #456b60;
    border-bottom: 1px solid #456b60;
  }
  .zone.diapotop #resa .formulaire li label {
    font-size: 14px;
    left: unset;
  }
}
.zone.textphoto {
  display: flex;
  padding-bottom: 0;
  position: relative;
}
.zone.textphoto .back-button {
  top: 0;
  position: absolute;
  top: -15px;
  left: 25px;
  padding: 5px 15px;
  background: transparent;
  color: #456b60;
  /* border: none; */
}
.zone.textphoto.textphoto_boutique {
  margin-top: 50px;
}
.zone.textphoto.textphoto_boutique .wrap {
  justify-content: center;
}
.zone.textphoto.textphoto_boutique .wrap .images {
  max-width: 600px;
}
.zone.textphoto.textphoto_boutique .wrap .images .photo::after {
  display: block;
  content: '';
  padding-top: 125%;
}
.zone.textphoto.textphoto_boutique .wrap .images .photo::after img.round {
  height: 80% !important;
}
.zone.textphoto.textphoto_boutique .alert {
  width: 100%;
  margin-top: 12px;
}
.zone.textphoto.subtype1 .wrap {
  flex-direction: row-reverse;
  padding-left: 0;
  padding-right: 100px;
}
.zone.textphoto.subtype1 .wrap .images {
  margin-left: 0;
  margin-right: 100px;
}
.zone.textphoto .wrap {
  display: flex;
  padding-left: 100px;
  flex-direction: row;
  width: 100%;
}
.zone.textphoto .wrap .texte {
  width: 25%;
  display: flex;
  z-index: 1;
}
.zone.textphoto .wrap .texte .area {
  width: 100%;
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: center;
}
.zone.textphoto .wrap .texte .desc {
  text-align: justify;
  overflow: auto;
}
.zone.textphoto .wrap .images {
  flex: 2;
  height: 100%;
  z-index: 0;
  overflow: hidden;
  margin-left: 100px;
  max-height: calc(100vh - 200px);
}
.zone.textphoto .wrap .images .swiper-container {
  height: 100%;
}
.zone.textphoto .wrap .images .swiper-container .swiper-slide {
  clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
  opacity: 0;
  transition: 1500ms clip-path ease-out, 1250ms opacity ease-out;
}
.zone.textphoto .wrap .images .swiper-container .swiper-slide.swiper-slide-active {
  opacity: 1;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}
.zone.textphoto .wrap .images .photo {
  position: relative;
}
.zone.textphoto .wrap .images .photo img {
  position: absolute;
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.zone.textphoto .wrap .images .photo img.png {
  object-fit: contain;
}
.zone.textphoto .wrap .images .photo img.round {
  height: 80% !important;
}
@media screen and (min-width: 1301px) {
  .zone.textphoto {
    min-height: calc(100vh - 100px);
    max-height: calc(100vh - 200px);
  }
  .zone.textphoto.textphoto_boutique {
    max-height: unset !important;
    margin-top: 100px;
  }
  .zone.textphoto.subtype1 .swiper-pagination {
    top: 0;
    width: 32px;
    height: 100%;
    bottom: 0;
    left: unset;
    right: 16px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .zone.textphoto .swiper-pagination {
    top: 0;
    width: 32px;
    height: 100%;
    bottom: 0;
    left: 16px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .zone.textphoto .swiper-pagination .swiper-pagination-bullet:not(:last-child) {
    margin-bottom: 8px;
  }
}
@media all and (max-width: 1600px) {
  .zone.textphoto.subtype1 .wrap {
    padding-left: 0;
    padding-right: 75px;
  }
  .zone.textphoto.subtype1 .wrap .images {
    margin-left: 0;
    margin-right: 75px;
  }
  .zone.textphoto .wrap {
    padding-left: 75px;
  }
  .zone.textphoto .wrap .texte {
    width: 30%;
  }
  .zone.textphoto .wrap .images {
    margin-left: 75px;
  }
}
@media all and (max-width: 1400px) {
  .zone.textphoto.subtype1 .wrap {
    padding-left: 0;
    padding-right: 50px;
  }
  .zone.textphoto.subtype1 .wrap .images {
    margin-left: 0;
    margin-right: 50px;
  }
  .zone.textphoto .wrap {
    padding-left: 50px;
  }
  .zone.textphoto .wrap .texte {
    width: 35%;
  }
  .zone.textphoto .wrap .images {
    margin-left: 50px;
  }
}
@media all and (max-width: 1200px) {
  .zone.textphoto .wrap .texte {
    width: calc(50% - 100px);
  }
}
@media all and (max-width: 1300px) {
  .zone.textphoto.textphoto_boutique {
    display: flex;
    flex-direction: column;
  }
  .zone.textphoto .back-button {
    position: relative;
    top: unset;
    left: unset;
    margin: auto;
    margin-bottom: 25px;
  }
  .zone.textphoto.textphoto_boutique .wrap .images {
    height: unset;
  }
  .zone.textphoto.textphoto_boutique .wrap .images .photo {
    position: relative;
    height: auto;
  }
  .zone.textphoto.textphoto_boutique .wrap .images .photo:after {
    content: '';
    display: block;
    padding-top: 125%;
  }
  .zone.textphoto .wrap {
    margin-left: 0;
    flex-wrap: wrap;
    padding: 0 !important;
  }
  .zone.textphoto .wrap .fond {
    width: 70%;
    bottom: 50vh;
    height: 30px;
    top: auto;
  }
  .zone.textphoto .wrap .texte {
    width: 100%;
    margin: 0 auto;
    padding: 0 100px;
  }
  .zone.textphoto .wrap .texte .desc {
    width: 100%;
    max-height: initial;
  }
  .zone.textphoto .wrap .images {
    min-width: 100%;
    width: 100%;
    height: 50vh;
    margin-top: 50px;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .zone.textphoto .fond {
    display: none;
  }
  .zone.textphoto .wrap .images {
    height: auto;
  }
  .zone.textphoto .wrap .images .photo {
    position: relative;
    height: auto;
    max-height: 400px;
  }
  .zone.textphoto .wrap .images .photo:after {
    content: '';
    display: block;
    padding-top: 75%;
  }
  .zone.textphoto .wrap .images .photo > * {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
  }
  .zone.textphoto .wrap .images .photo img {
    transform: unset !important;
  }
  .zone.textphoto .wrap .images .photo img.round {
    height: 80% !important;
  }
}
@media all and (max-width: 800px) {
  .zone.textphoto .wrap {
    margin-left: 0;
    flex-wrap: wrap;
  }
  .zone.textphoto .wrap .texte {
    margin: 0 auto;
  }
  .zone.textphoto .wrap .texte .desc {
    width: 100%;
    max-height: initial;
    text-align: center;
  }
  .zone.textphoto .wrap .texte .desc ul {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .zone.textphoto .wrap .texte .desc ul li::before {
    top: 7px;
  }
}
@media all and (max-width: 600px) {
  .zone.textphoto .wrap .texte {
    width: 100%;
    padding: 0 25px;
  }
  .zone.textphoto .wrap .texte .rub.titre-container {
    margin-left: auto;
    margin-right: auto;
  }
  .zone.textphoto .wrap .texte .sstitre {
    text-align: center;
  }
}
@media all and (max-width: 450px) {
  .zone.textphoto .wrap .images .photo:after {
    padding-top: 125%;
  }
}
.zone.altern {
  padding-top: 5rem;
  min-height: 100vh;
}
.zone.altern .fond {
  position: absolute;
  top: 10rem;
  left: 10%;
  background-repeat: repeat;
  width: 100%;
  height: 100%;
}
.zone.altern.moveup {
  margin-top: -10rem;
}
.zone.altern .wrap {
  display: flex;
  width: 90%;
  margin: 0 auto;
  align-items: center;
  justify-content: space-between;
}
.zone.altern .wrap .images {
  height: 90vh;
  min-height: 400px;
  width: 50%;
  position: relative;
}
.zone.altern .wrap .images .photo a {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.zone.altern .wrap .images .swiper-container {
  height: 100%;
  width: 100%;
}
.zone.altern .wrap .images .swiper-container div {
  height: 100%;
}
.zone.altern .wrap .images .swiper-container .photo {
  height: 100%;
  position: relative;
}
.zone.altern .wrap .images .swiper-container .photo a {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.zone.altern .wrap .images .swiper-container .photo img {
  height: 100%;
}
.zone.altern .wrap .images .swiper-controls {
  position: absolute;
  width: 100px;
  right: -10px;
  bottom: -4rem;
}
.zone.altern .wrap .texte {
  width: 40%;
  padding: 0rem;
  display: flex;
  align-items: center;
  margin-top: 10rem;
  margin-right: 5rem;
}
.zone.altern .wrap .texte .sstitre {
  font-size: 2rem;
  font-weight: 500;
  margin-top: -2rem;
}
.zone.altern .wrap .texte .desc {
  text-align: justify;
}
.zone.altern .wrap .texte .swiper-controls {
  display: flex;
}
.zone.altern .wrap .texte .swiper-controls .swiper-button-next,
.zone.altern .wrap .texte .swiper-controls .swiper-button-prev {
  position: relative;
  margin: 0;
  font-size: 2.2rem;
}
.zone.altern .wrap .texte .swiper-controls .swiper-button-prev {
  margin-right: 4rem;
  left: 0;
}
.zone.altern .wrap .texte .btnresa {
  transition: all 0.3s ease;
  border: 1px solid;
  text-transform: uppercase;
  padding: 7px 30px;
}
.zone.altern .wrap .texte .btnresa:before {
  display: none;
}
.zone.altern .wrap .texte .btnresa:hover {
  background: #456b60;
  color: white;
  transition: all 0.3s ease;
  border-color: #456b60;
}
.zone.altern.subtype2 .rub {
  left: auto;
  right: 20%;
}
.zone.altern.subtype2 .wrap {
  position: relative;
}
.zone.altern.subtype2 .wrap .texte {
  order: 1;
}
.zone.altern.subtype2 .wrap .images {
  order: 2;
}
@media all and (max-width: 1400px) {
  .zone.altern {
    margin-top: -7rem;
  }
  .zone.altern .wrap .images {
    width: 45%;
  }
  .zone.altern.subtype2 .wrap .rub {
    left: 0;
    transform: none;
  }
}
@media all and (max-width: 1000px) {
  .zone.altern {
    margin-top: -5rem;
  }
  .zone.altern .wrap .images {
    height: auto;
  }
  .zone.altern .wrap .images .photo {
    position: relative;
    height: auto;
  }
  .zone.altern .wrap .images .photo .simpleParallax {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
  }
  .zone.altern .wrap .images .photo:after {
    content: "";
    padding-top: 100%;
    display: block;
  }
  .zone.altern .wrap .images .photo .lax {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    object-fit: cover;
    width: 100%;
  }
  .zone.altern.moveup {
    margin-top: 1rem;
  }
  .zone.altern .wrap .images {
    width: 50%;
  }
}
@media all and (max-width: 800px) {
  .zone.diapotop + div > .zone.altern:nth-of-type(1) {
    margin-top: 1rem;
  }
  .zone.altern {
    margin-top: -10%;
    min-height: 0;
  }
  .zone.altern .rub {
    position: relative;
    left: 45%;
    top: auto;
    left: auto;
    transform: none !important;
    order: 2;
  }
  .zone.altern .rub:before {
    display: none;
  }
  .zone.altern .wrap {
    flex-wrap: wrap !important;
    width: 90% !important;
  }
  .zone.altern .wrap .texte {
    padding: 0;
    order: 2 !important;
    width: 100% !important;
    min-height: auto;
    margin-top: 0;
  }
  .zone.altern .wrap .images {
    order: 1 !important;
    width: 100% !important;
    min-height: 200px;
    margin-bottom: 2rem;
  }
  .zone.altern .wrap .images .photo {
    max-height: 300px;
  }
  .zone.altern .wrap .images .photo:after {
    padding-top: 75%;
  }
}
@media all and (max-width: 600px) {
  .zone.altern .wrap {
    flex-wrap: wrap;
  }
  .zone.altern .wrap .texte {
    padding: 0;
    width: 100%;
    min-height: auto;
    margin-right: 0;
  }
  .zone.altern .wrap .images {
    width: 100%;
  }
  .zone.altern .wrap .images .photo {
    height: 100%;
  }
}
@media all and (max-width: 450px) {
  .zone.altern .wrap {
    flex-wrap: wrap;
  }
  .zone.altern .wrap .texte {
    padding: 0;
    width: 100%;
    min-height: auto;
  }
  .zone.altern .wrap .rub {
    margin-top: 0rem;
  }
  .zone.altern .wrap .images {
    width: 100%;
  }
  .zone.altern .wrap .images .photo img {
    width: 100%;
  }
}
.zone.doubleslider {
  position: relative;
  padding-top: 15rem;
}
.zone.doubleslider .rub {
  width: 50%;
  padding-left: 10%;
  margin-bottom: 0;
  margin-bottom: 10rem;
}
.zone.doubleslider .wrap {
  justify-content: space-between;
  width: 100%;
  padding-left: 10%;
  align-items: center;
}
.zone.doubleslider .wrap .text {
  width: 100%;
}
.zone.doubleslider .wrap .text .swipertop,
.zone.doubleslider .wrap .text .top {
  width: 100%;
}
.zone.doubleslider .wrap .text .swipertop .swiper-slide,
.zone.doubleslider .wrap .text .top .swiper-slide {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.zone.doubleslider .wrap .text .swipertop .swiper-slide .area,
.zone.doubleslider .wrap .text .top .swiper-slide .area {
  margin-right: -10rem;
  width: 30%;
}
.zone.doubleslider .wrap .text .swipertop .swiper-slide .photo,
.zone.doubleslider .wrap .text .top .swiper-slide .photo {
  width: calc(70% + 10rem);
  height: 400px;
  margin-left: -10rem;
  z-index: -1;
}
.zone.doubleslider .wrap .image {
  width: 100%;
  display: flex;
  justify-content: flex-end;
  position: relative;
  overflow: hidden;
  margin-top: -15rem;
}
.zone.doubleslider .wrap .image .scrollbar {
  margin-left: 24%;
  margin-top: 25rem;
  width: 30%;
  height: 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.zone.doubleslider .wrap .image .scrollbar .debut,
.zone.doubleslider .wrap .image .scrollbar .fin {
  font-family: 'Butler';
  font-size: 120%;
}
.zone.doubleslider .wrap .image .swiper-scrollbar {
  height: 2px;
  width: 85%;
  z-index: 9;
  cursor: grab;
}
.zone.doubleslider .wrap .image .swiper-scrollbar .swiper-scrollbar-drag {
  height: 130%;
  top: auto;
}
.zone.doubleslider .wrap .image .swiper-container {
  width: 30%;
  margin-right: 5%;
}
.zone.doubleslider .wrap .image .swiper-slide {
  height: 100%;
}
.zone.doubleslider .wrap .image .photo {
  z-index: 1;
  position: relative;
}
.zone.doubleslider .wrap .image .photo:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 120%;
}
.zone.doubleslider .wrap .image .photo img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.zone.doubleslider .wrap .image .swiper-slide {
  color: white;
  position: relative;
}
.zone.doubleslider .wrap .image .swiper-slide .back {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: -1;
}
.zone.doubleslider .wrap .image .swiper-slide .back:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 2;
  background: rgba(1, 0, 66, 0.4);
}
.zone.doubleslider .wrap .image .swiper-slide .titre {
  border-bottom: 1px solid;
  padding: 0rem 4rem;
  font-size: 3.5rem;
  font-weight: 600;
  text-align: center;
  width: 100%;
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.zone.doubleslider .wrap .image .swiper-slide .bigwrap {
  display: flex;
  justify-content: space-between;
}
.zone.doubleslider .wrap .image .swiper-slide .wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 33%;
  padding-left: 0;
}
.zone.doubleslider .wrap .image .swiper-slide .wrap .pantop,
.zone.doubleslider .wrap .image .swiper-slide .wrap .panbottom {
  height: 50%;
  border: 1px solid;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 3rem;
  border-left: 0;
  border-top: 0;
}
.zone.doubleslider .wrap .image .swiper-slide .wrap .pantop {
  font-weight: 600;
}
.zone.doubleslider .wrap .image .swiper-slide .wrap .panbottom {
  text-transform: uppercase;
  font-size: 1.8rem;
  flex-direction: column;
  align-items: flex-start;
  letter-spacing: 1px;
}
.zone.doubleslider .wrap .image .swiper-slide .wrap .panbottom .price {
  font-weight: 600;
  font-size: 3rem;
  display: block;
}
.zone.doubleslider .wrap .image .swiper-slide .map {
  position: relative;
  width: 67%;
  display: flex;
  align-items: center;
  height: 60vh;
  min-height: 500px;
}
.zone.doubleslider .wrap .image .swiper-slide .map img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.zone.doubleslider.subtype2 .wrap .image {
  margin-left: 20rem;
  width: 90%;
}
.zone.doubleslider.subtype2 .wrap .image .scrollbar {
  margin-top: 25rem;
  width: 33%;
}
.zone.doubleslider.subtype2 .wrap .image .swiper-container {
  margin-right: 5%;
}
@media all and (max-width: 1600px) {
  .zone.doubleslider .rub {
    width: 60%;
  }
}
@media all and (max-width: 1400px) {
  .zone.doubleslider .wrap .image .swiper-container {
    width: 40%;
  }
  .zone.doubleslider .wrap .image .scrollbar {
    margin-left: 20%;
  }
  .zone.doubleslider.subtype2 .wrap .image .scrollbar {
    margin-left: 5%;
  }
  .zone.doubleslider.subtype2 .wrap .image .swiper-container {
    margin-right: 15%;
  }
}
@media all and (max-width: 1000px) {
  .zone.doubleslider {
    padding-top: 8rem;
  }
  .zone.doubleslider .wrap {
    padding-left: 5%;
  }
  .zone.doubleslider .wrap .text .swipertop .swiper-slide .area {
    margin-right: 12rem;
  }
  .zone.doubleslider .wrap .image .scrollbar {
    margin-left: 0;
    width: 40%;
  }
  .zone.doubleslider.subtype2 .wrap .image {
    margin-left: 15rem;
  }
  .zone.doubleslider.subtype2 .wrap .text .top .swiper-slide .photo {
    width: 68%;
  }
}
@media all and (max-width: 800px) {
  .zone.doubleslider {
    padding-top: 6rem;
  }
  .zone.doubleslider .rub {
    margin-bottom: 5rem;
    padding-left: 5%;
  }
  .zone.doubleslider .wrap {
    padding-left: 5%;
  }
  .zone.doubleslider .wrap .text .swipertop .swiper-slide,
  .zone.doubleslider .wrap .text .top .swiper-slide {
    flex-direction: column;
  }
  .zone.doubleslider .wrap .text .swipertop .swiper-slide .area,
  .zone.doubleslider .wrap .text .top .swiper-slide .area {
    width: 100%;
    margin-right: 0rem;
    margin-bottom: 4rem;
  }
  .zone.doubleslider .wrap .text .swipertop .swiper-slide .photo,
  .zone.doubleslider .wrap .text .top .swiper-slide .photo {
    width: 100%;
  }
  .zone.doubleslider .wrap .image .scrollbar {
    margin-left: 0;
    width: 40%;
  }
  .zone.doubleslider .wrap .image .swiper-container {
    width: 50%;
  }
  .zone.doubleslider .wrap .image .swiper-scrollbar {
    width: 70%;
  }
  .zone.doubleslider.subtype2 {
    margin-bottom: 10%;
  }
  .zone.doubleslider.subtype2 .wrap .text .top .swiper-slide .photo {
    width: 100%;
    margin-left: -8rem;
  }
  .zone.doubleslider.subtype2 .wrap .image .scrollbar {
    margin-left: 0;
  }
  .zone.doubleslider.subtype2 .wrap .image .swiper-container {
    margin-right: 9%;
  }
}
@media all and (max-width: 600px) {
  .zone.doubleslider {
    padding-top: 5rem;
  }
  .zone.doubleslider .rub {
    margin-bottom: 2rem;
    width: 100%;
  }
  .zone.doubleslider .wrap {
    padding-left: 5%;
  }
  .zone.doubleslider .wrap .text .swipertop .swiper-slide {
    flex-direction: column;
  }
  .zone.doubleslider .wrap .text .swipertop .swiper-slide .area {
    width: 100%;
    margin-right: 0rem;
    margin-bottom: 4rem;
  }
  .zone.doubleslider .wrap .text .swipertop .swiper-slide .photo {
    width: 100%;
  }
  .zone.doubleslider .wrap .image .scrollbar {
    margin-left: 0;
    width: 40%;
  }
  .zone.doubleslider.subtype2 {
    margin-bottom: 10%;
  }
  .zone.doubleslider.subtype2 .rub {
    margin-bottom: 0rem;
    width: 100%;
  }
  .zone.doubleslider.subtype2 .wrap .text .top .swiper-slide .area {
    padding-right: 10px;
  }
  .zone.doubleslider.subtype2 .wrap .text .top .swiper-slide .photo {
    width: 95%;
    margin-left: -16%;
  }
  .zone.doubleslider.subtype2 .wrap .image {
    margin-left: 2rem;
  }
  .zone.doubleslider.subtype2 .wrap .image .scrollbar {
    margin-left: 0;
    display: none;
  }
  .zone.doubleslider.subtype2 .wrap .image .swiper-container {
    margin-right: 0%;
    width: 70%;
  }
}
@media all and (max-width: 450px) {
  .zone.doubleslider {
    padding-top: 5rem;
  }
  .zone.doubleslider .rub {
    margin-bottom: 2rem;
    width: 100%;
  }
  .zone.doubleslider .wrap {
    padding-left: 5%;
  }
  .zone.doubleslider .wrap .text .swipertop .swiper-slide {
    flex-direction: column;
  }
  .zone.doubleslider .wrap .text .swipertop .swiper-slide .area {
    width: 100%;
    margin-right: 0rem;
    margin-bottom: 4rem;
  }
  .zone.doubleslider .wrap .text .swipertop .swiper-slide .photo {
    width: 100%;
  }
  .zone.doubleslider .wrap .image .swiper-container {
    width: 60%;
  }
  .zone.doubleslider .wrap .image .scrollbar {
    margin-left: 0;
    width: 40%;
    display: none;
  }
}
.zone.quote {
  display: flex;
  min-height: 100vh;
  padding-bottom: 20rem;
  margin-top: 5rem;
  overflow: visible;
}
.zone.quote .fond {
  position: absolute;
  top: -5rem;
  left: 10%;
  background-repeat: repeat;
  width: 100%;
  height: 90%;
}
.zone.quote .wrap {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-left: 10%;
  width: 85%;
}
.zone.quote .wrap .texte {
  width: 60%;
  display: flex;
  z-index: 3;
  justify-content: center;
  flex-direction: column;
  margin-left: 4rem;
}
.zone.quote .wrap .texte .area {
  width: 100%;
}
.zone.quote .wrap .texte .rub {
  margin-bottom: 10rem;
}
.zone.quote .wrap .texte .desc {
  width: calc(80%);
  text-align: justify;
  font-family: 'Butler';
  font-size: 2.5rem;
  letter-spacing: 1px;
  line-height: 1.8;
  padding-left: 15rem;
  position: relative;
}
.zone.quote .wrap .texte .desc .guillemet {
  position: absolute;
  top: -7rem;
  left: 2rem;
  display: block;
  width: 180px;
}
.zone.quote .wrap .texte .desc .guillemet img {
  width: 180px;
  height: 180px;
  filter: invert(0.2);
}
.zone.quote .wrap .texte .button {
  padding-left: 12rem;
  margin-top: 5rem;
}
.zone.quote .wrap .texte .swiper-prog {
  margin-top: 10rem;
  top: 0;
  width: 50%;
  height: 2px;
  padding: 0 4rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.zone.quote .wrap .texte .swiper-prog .debut,
.zone.quote .wrap .texte .swiper-prog .fin {
  font-family: 'Butler';
  font-size: 120%;
}
.zone.quote .wrap .texte .swiper-prog .swiper-pagination-progressbar {
  width: 85%;
  height: 100%;
  position: relative;
  background: rgba(0, 0, 0, 0.3);
}
.zone.quote .wrap .texte .swiper-prog .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: #000;
  width: 100%;
}
.zone.quote .wrap .images {
  right: 15rem;
  width: 35%;
  height: 80vh;
  overflow: visible;
  position: absolute;
  top: 0rem;
}
.zone.quote .wrap .images .swiper-container,
.zone.quote .wrap .images .swiper-wrapper {
  height: 100%;
  width: 100%;
  z-index: 2;
}
.zone.quote .wrap .images .background {
  position: absolute;
  right: -5rem;
  top: 5rem;
  height: 100%;
  width: 100%;
  background: #456b60;
  z-index: 1;
  display: flex;
  justify-content: flex-start;
  align-items: flex-end;
}
.zone.quote .wrap .images .background .swiper-controls {
  position: relative;
  color: white;
  width: 70px;
  margin-bottom: 1.4rem;
  margin-left: 2rem;
}
.zone.quote .wrap .images .photo {
  width: 80%;
  position: relative;
  right: 0rem;
  width: 100%;
}
.zone.quote .wrap .images .photo img {
  position: absolute;
  height: 100%;
  width: 100%;
}
@media all and (max-width: 1600px) {
  .zone.quote .wrap .images {
    right: 10rem;
  }
  .zone.quote .wrap .texte .desc {
    font-size: 2.2rem;
  }
}
@media all and (max-width: 1400px) {
  .zone.quote .wrap .texte .swiper-prog {
    width: 70%;
  }
  .zone.quote .wrap .texte .swiper-prog .swiper-pagination-progressbar {
    width: 70%;
  }
  .zone.quote .wrap .texte .desc {
    font-size: 2rem;
    width: 75%;
    padding-left: 10rem;
  }
  .zone.quote .wrap .texte .desc .guillemet {
    width: 140px;
    top: -6rem;
  }
  .zone.quote .wrap .images {
    right: 10rem;
  }
  .zone.quote .wrap .images .background {
    right: -5rem;
  }
}
@media all and (max-width: 1200px) {
  .zone.quote .wrap .texte .desc {
    font-size: 2rem;
    padding-left: 9rem;
  }
  .zone.quote .wrap .texte .desc .guillemet {
    width: 120px;
    top: -5rem;
  }
  .zone.quote .wrap .images {
    right: 10rem;
  }
  .zone.quote .wrap .images .background {
    right: -5rem;
  }
}
@media all and (max-width: 1000px) {
  .zone.quote {
    padding-bottom: 120px;
  }
  .zone.quote .wrap {
    flex-wrap: wrap;
  }
  .zone.quote .wrap .texte {
    width: 100%;
  }
  .zone.quote .wrap .texte .swiper-prog {
    margin-top: 5rem;
    margin-bottom: 5rem;
    width: 100%;
  }
  .zone.quote .wrap .texte .desc {
    font-size: 2rem;
    padding-left: 10rem;
    width: 100%;
  }
  .zone.quote .wrap .texte .desc .guillemet {
    width: 120px;
    top: -5rem;
  }
  .zone.quote .wrap .images {
    right: 5%;
    width: 100%;
    position: relative;
    height: 65vh;
  }
  .zone.quote .wrap .images .background {
    right: -5rem;
    top: 7rem;
  }
  .zone.quote .wrap .images .background .swiper-controls {
    margin-bottom: 3rem;
  }
  .zone.quote {
    min-height: unset;
    margin-top: 0;
  }
  .zone.quote .fond {
    display: none;
  }
  .zone.quote .wrap .images {
    height: auto;
  }
  .zone.quote .wrap .images .swiper-slide {
    max-height: 400px;
  }
  .zone.quote .wrap .images .swiper-slide:after {
    content: "";
    display: block;
    padding-top: 75%;
  }
  .zone.quote .wrap .images .swiper-slide img {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
  }
}
@media all and (max-width: 800px) {
  .zone.quote .wrap {
    flex-wrap: wrap;
  }
  .zone.quote .wrap .texte {
    width: 100%;
  }
  .zone.quote .wrap .texte .swiper-prog {
    margin-top: 5rem;
    margin-bottom: 5rem;
    width: 100%;
  }
  .zone.quote .wrap .texte .desc {
    font-size: 2rem;
    padding-left: 2rem;
    width: 90%;
  }
  .zone.quote .wrap .texte .desc .guillemet {
    width: 120px;
    top: -5rem;
    left: -8rem;
  }
  .zone.quote .wrap .texte .button {
    padding-left: 2rem;
  }
  .zone.quote .wrap .images {
    right: 5%;
    width: 100%;
    position: relative;
  }
  .zone.quote .wrap .images .background {
    right: -5rem;
    top: 7rem;
  }
  .zone.quote .wrap .images .background .swiper-controls {
    margin-bottom: 3rem;
  }
}
@media all and (max-width: 450px) {
  .zone.quote .wrap {
    flex-wrap: wrap;
  }
  .zone.quote .wrap .texte {
    width: 100%;
  }
  .zone.quote .wrap .texte .rub {
    margin-bottom: 8rem;
  }
  .zone.quote .wrap .texte .swiper-prog {
    margin-top: 5rem;
    margin-bottom: 5rem;
    width: 100%;
    display: none;
  }
  .zone.quote .wrap .texte .desc {
    font-size: 1.7rem;
    padding-left: 0rem;
  }
  .zone.quote .wrap .texte .desc .guillemet {
    width: 120px;
    top: -5rem;
  }
  .zone.quote .wrap .texte .button {
    padding-left: 0;
    margin-bottom: 5rem;
  }
  .zone.quote .wrap .images {
    right: 5%;
    width: 100%;
    position: relative;
  }
  .zone.quote .wrap .images .background {
    right: -5rem;
  }
}
.zone.phototext {
  display: flex;
  align-items: center;
  min-height: 110vh;
  padding-bottom: 0;
}
.zone.phototext .wrap {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  width: 90%;
  margin: 0 auto;
  position: relative;
  margin-top: -40rem;
}
.zone.phototext .wrap .images {
  width: 35%;
  position: relative;
  height: 100%;
  left: 0;
  z-index: 0;
}
.zone.phototext .wrap .images .photo {
  position: relative;
}
.zone.phototext .wrap .images .photo:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 140%;
}
.zone.phototext .wrap .images .photo img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.zone.phototext .wrap .texte {
  width: 65%;
  display: flex;
  align-items: center;
  z-index: 1;
}
.zone.phototext .wrap .texte .rub {
  margin-left: -10rem;
}
.zone.phototext .wrap .texte .rub .titre {
  white-space: nowrap;
}
.zone.phototext .wrap .texte .area {
  width: 100%;
}
.zone.phototext .wrap .texte .desc {
  width: 50%;
  text-align: justify;
}
@media all and (max-width: 1600px) {
  .zone.phototext .wrap .texte .desc {
    margin-left: 12rem;
    width: calc(100% - 12rem);
  }
}
@media all and (max-width: 1400px) {
  .zone.phototext .wrap .texte {
    padding: 8rem;
  }
  .zone.phototext .wrap .texte .desc {
    margin-left: 10rem;
    width: calc(100% - 10rem);
  }
}
@media all and (max-width: 1200px) {
  .zone.phototext .wrap .texte {
    padding: 6rem;
  }
  .zone.phototext .wrap .texte .desc {
    margin-left: 4rem;
    width: calc(100% - 4rem);
  }
  .zone.phototext.prio .wrap {
    padding-top: 5rem;
  }
}
@media all and (max-width: 1000px) {
  .zone.phototext .wrap {
    flex-wrap: wrap;
  }
  .zone.phototext .wrap .texte {
    padding: 6rem;
    width: 100%;
    min-height: auto;
  }
  .zone.phototext .wrap .texte .desc {
    margin-left: 4rem;
    width: calc(100% - 4rem);
  }
  .zone.phototext .wrap .images {
    width: 100%;
    height: 50vh;
    min-height: 400px;
  }
  .zone.phototext .wrap .images .photo img {
    height: 50vh;
    min-height: 400px;
    width: 100%;
  }
}
@media all and (max-width: 600px) {
  .zone.phototext .wrap {
    flex-wrap: wrap;
  }
  .zone.phototext .wrap .texte {
    padding: 4rem;
    width: 100%;
    min-height: auto;
  }
  .zone.phototext .wrap .texte .desc {
    margin-left: 4rem;
    width: calc(100% - 4rem);
  }
  .zone.phototext .wrap .images {
    width: 100%;
    height: 50vh;
    min-height: 400px;
  }
}
@media all and (max-width: 450px) {
  .zone.phototext .wrap {
    flex-wrap: wrap;
  }
  .zone.phototext .wrap .texte {
    padding: 4rem 2.5rem;
    width: 100%;
    min-height: auto;
  }
  .zone.phototext .wrap .texte .desc {
    margin-left: 0rem;
    width: calc(100% - 0rem);
  }
  .zone.phototext .wrap .images {
    width: 100%;
    height: 45vh;
    min-height: 300px;
  }
  .zone.phototext .wrap .images .photo img {
    width: 100%;
  }
}
.zone.horislider {
  padding: 5rem 0;
  padding-left: 10%;
}
.zone.horislider .swiper-pagination-progressbar {
  width: 100%;
  height: 1px;
  position: absolute;
  top: 10rem;
  left: 0;
  position: relative;
  background: rgba(0, 0, 0, 0.3);
  animation: scaleX 2s ease forwards;
}
@keyframes scaleX {
  from {
    transform: scaleX(0);
    transform-origin: right;
  }
  to {
    transform: scaleX(1);
  }
}
.zone.horislider .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: #000;
  width: 100%;
  height: 1px;
  margin-top: -1px;
  animation: opa 0.8s ease forwards;
  animation-delay: 1.75s;
  opacity: 0;
}
@keyframes opa {
  to {
    opacity: 1;
  }
}
.zone.horislider .swiper-container {
  width: 175%;
  overflow: visible;
  margin: 0;
}
.zone.horislider .swiper-container .swiper-wrapper {
  width: 100%;
  overflow: visible;
  margin-left: -55vw;
}
.zone.horislider .swiper-container .swiper-wrapper .swiper-slide {
  position: relative;
  text-align: left;
  width: 100%;
  overflow: visible;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  padding-top: 14rem;
  height: 75vh;
}
.zone.horislider .swiper-container .swiper-wrapper .swiper-slide:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 130%;
}
.zone.horislider .swiper-container .swiper-wrapper .swiper-slide .title {
  font-size: 4.5rem;
  font-family: 'Butler';
  width: 100%;
  white-space: nowrap;
  text-align: left;
  margin-left: -5rem;
}
.zone.horislider .swiper-container .swiper-wrapper .swiper-slide .photo {
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 50%;
  bottom: 0;
  left: 0%;
  transition: all 0.5s ease;
  z-index: -1;
  transform: scale(1.25);
}
.zone.horislider .swiper-container .swiper-wrapper .swiper-slide .photo img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.zone.horislider .swiper-container .swiper-wrapper .swiper-slide .text {
  transition: all 0.5s ease;
  opacity: 0;
  text-align: left;
  position: absolute;
  left: 55%;
  bottom: 0;
  width: 50vw;
  line-height: 1.7;
  letter-spacing: 1px;
  transform: translate(-100px, 0px);
}
.zone.horislider .swiper-container .swiper-wrapper .swiper-slide .text .ss {
  display: block;
  font-weight: 500;
  font-style: italic;
  font-size: 120%;
  margin-bottom: 2rem;
}
.zone.horislider .swiper-container .swiper-wrapper .swiper-slide-active .photo,
.zone.horislider .swiper-container .swiper-wrapper .swiper-slide-active .text {
  transform: scale(1) translate(0, 0);
  opacity: 1;
  pointer-events: all;
  transition: all 0.5s ease;
}
@media all and (max-width: 1600px) {
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide {
    padding-top: 12rem;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide .title {
    font-size: 4rem;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide .text {
    width: 60vw;
  }
}
@media all and (max-width: 1400px) {
  .zone.horislider .swiper-pagination-progressbar {
    top: 7rem;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide {
    padding-top: 10rem;
    height: 70vh;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide .title {
    font-size: 3.5rem;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide .text {
    width: 60vw;
  }
}
@media all and (max-width: 1200px) {
  .zone.horislider .swiper-pagination-progressbar {
    top: 2rem;
  }
  .zone.horislider .swiper-container .swiper-wrapper {
    margin-left: -60vw;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide {
    padding-top: 3rem;
    height: 70vh;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide .title {
    font-size: 3rem;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide .text {
    width: 67vw;
  }
}
@media all and (max-width: 1000px) {
  .zone.horislider {
    padding-left: 7.5%;
  }
  .zone.horislider .swiper-pagination-progressbar {
    top: 2rem;
  }
  .zone.horislider .swiper-container {
    width: 100%;
  }
  .zone.horislider .swiper-container .swiper-wrapper {
    margin-left: 0vw;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide {
    padding-top: 3rem;
    height: auto;
    display: flex;
    flex-wrap: wrap;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide:before {
    display: none;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide .title {
    font-size: 3rem;
    margin-left: 0;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide .photo {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    height: 30vh;
  }
  .zone.horislider .swiper-container .swiper-wrapper .swiper-slide .text {
    position: relative;
    left: auto;
    width: 90%;
  }
}
.zone.cardslider {
  position: relative;
  text-align: center;
}
.zone.cardslider .swiper-container {
  width: 90%;
  position: relative;
  height: 100%;
  margin-left: 10%;
  padding-bottom: 10rem;
}
.zone.cardslider .swiper-container .swiper-wrapper {
  height: 100%;
  text-align: center;
}
.zone.cardslider .swiper-container .swiper-wrapper .photo {
  display: block;
}
.zone.cardslider .swiper-container .swiper-wrapper .title {
  margin-top: 3rem;
  text-align: center;
  font-weight: 500;
  font-style: italic;
}
.zone.cardslider .swiper-container .swiper-wrapper img {
  height: 120px;
  width: auto;
}
.zone.cardslider .swiper-pagination-progressbar {
  width: 100%;
  height: 1px;
  position: absolute;
  top: 25rem;
  left: 0;
  background: rgba(0, 0, 0, 0.3);
}
.zone.cardslider .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: #000;
  width: 100%;
  height: 2px;
  margin-top: -1px;
}
.zone.verticalslider {
  position: relative;
  text-align: center;
  height: calc(100vh - 100px);
  padding-top: 7.5rem;
}
.zone.verticalslider .fond {
  position: absolute;
  top: -5rem;
  left: 5%;
  background-repeat: repeat;
  width: 100%;
  height: 90%;
}
.zone.verticalslider .cfluid {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 90%;
}
.zone.verticalslider .text {
  width: 40%;
  text-align: left;
}
.zone.verticalslider .text .titre {
  font-family: sans-serif;
  font-size: initial;
  font-weight: 500;
  margin-bottom: 2rem;
}
.zone.verticalslider .swiper-controls {
  opacity: 0;
}
.zone.verticalslider .sliders {
  width: 55%;
  position: relative;
  height: 72.5vh;
  padding-left: 10rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.zone.verticalslider .sliders .swiper-container {
  height: 100%;
  width: 48%;
}
.zone.verticalslider .sliders .swiper-container .swiper-wrapper {
  height: 100%;
  text-align: center;
}
.zone.verticalslider .sliders .swiper-container .swiper-wrapper .photo {
  display: block;
  width: auto;
}
.zone.verticalslider .sliders .swiper-container .swiper-wrapper .swiper-slide {
  transition: all 0.5s ease;
}
.zone.verticalslider .sliders .swiper-container .swiper-wrapper .swiper-slide img {
  transform: scale(1.35);
  transition: all 0.5s ease;
}
.zone.verticalslider .sliders .swiper-container .swiper-wrapper .swiper-slide-active {
  transition: all 0.5s ease;
}
.zone.verticalslider .sliders .swiper-container .swiper-wrapper .swiper-slide-active img {
  transform: scale(1);
  transition: all 0.5s ease;
}
.zone.verticalslider .swiper-pagination-progressbar {
  width: 1px;
  height: 70%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  background: rgba(0, 0, 0, 0.3);
}
.zone.verticalslider .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: #000;
  width: 3px;
  height: 100%;
}
@media all and (max-width: 1000px) {
  .zone.verticalslider {
    min-height: auto;
    height: auto;
  }
  .zone.verticalslider .cfluid {
    flex-wrap: wrap;
  }
  .zone.verticalslider .cfluid .text {
    width: 100%;
    margin-bottom: 5rem;
    overflow: visible;
  }
  .zone.verticalslider .cfluid .text .swiper-button-prev {
    left: -33px;
  }
  .zone.verticalslider .cfluid .text .swiper-button-next {
    right: -33px;
  }
  .zone.verticalslider .cfluid .sliders {
    width: 100%;
    padding-left: 0;
  }
  .zone.verticalslider .cfluid .swiper-controls {
    display: block;
    opacity: 1;
  }
  .zone.verticalslider .cfluid .swiper-pagination {
    display: none;
  }
}
@media all and (max-width: 600px) {
  .zone.verticalslider {
    min-height: auto;
    height: auto;
  }
  .zone.verticalslider .cfluid {
    flex-wrap: wrap;
  }
  .zone.verticalslider .cfluid .text {
    width: 100%;
    margin-bottom: 5rem;
    overflow: visible;
  }
  .zone.verticalslider .cfluid .text .swiper-controls {
    position: relative;
    width: 100px;
    margin-top: 4rem;
  }
  .zone.verticalslider .cfluid .text .swiper-button-prev {
    left: 0px;
    font-size: 2.5rem;
  }
  .zone.verticalslider .cfluid .text .swiper-button-next {
    right: 0px;
    font-size: 2.5rem;
  }
  .zone.verticalslider .cfluid .sliders {
    width: 100%;
    padding-left: 0;
  }
  .zone.verticalslider .cfluid .swiper-pagination {
    display: none;
  }
}
.zone.contact_form {
  min-height: 100vh;
  padding-top: 200px;
}
.zone.contact_form .fond {
  position: absolute;
  top: 0rem;
  left: 0;
  background-repeat: repeat;
  width: 40%;
  height: 100%;
}
.zone.contact_form.subtype2 .fond {
  display: none;
}
.zone.contact_form .wrap {
  justify-content: space-between;
  margin: 0 auto;
  display: flex;
  width: 80%;
}
.zone.contact_form.subtype2 .text .formulaire form .form-group.mail {
  width: 100%;
  margin-right: 0;
}
.zone.contact_form .text {
  width: 45%;
  text-align: justify;
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: black;
}
.zone.contact_form .text .undertitre {
  letter-spacing: 2px;
  margin-top: 5px;
  font-weight: 500;
}
.zone.contact_form .text .tite {
  font-weight: 600;
  letter-spacing: 1px;
  margin-bottom: 1rem;
}
.zone.contact_form .text .coords {
  margin: 0 0 2rem 0;
  font-weight: 300;
}
.zone.contact_form .text .button {
  margin-left: 140px;
}
.zone.contact_form .text .formulaire {
  width: 100%;
  text-align: center;
  margin: 0 auto;
}
.zone.contact_form .text .formulaire form {
  z-index: 99;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  width: 100%;
}
.zone.contact_form .text .formulaire form .form-group {
  margin-bottom: 12px;
  width: 48%;
  text-align: left;
  margin-right: 4%;
  position: relative;
}
.zone.contact_form .text .formulaire form .form-group label {
  display: none;
}
.zone.contact_form .text .formulaire form .form-group input {
  border: none;
  background: #456b60;
  height: 35px;
  text-align: left;
  width: 100%;
  display: inline-block;
  font-size: 15px;
  transition: all 0.3s ease;
  color: white;
  padding-left: 20px;
  font-family: 'Montserrat';
}
.zone.contact_form .text .formulaire form .form-group input:focus,
.zone.contact_form .text .formulaire form .form-group textarea:focus {
  outline: none;
}
.zone.contact_form .text .formulaire form .form-group textarea {
  border: none;
  background: #456b60;
  height: 150px;
  color: white;
  width: 100%;
  font-size: 15px;
  padding: 20px;
  width: calc(100%);
  font-family: 'Montserrat';
}
.zone.contact_form .text .formulaire form .form-group ::-webkit-input-placeholder {
  color: white;
  font-size: 15px;
}
.zone.contact_form .text .formulaire form .form-group :-moz-placeholder {
  color: white;
  font-size: 15px;
}
.zone.contact_form .text .formulaire form .form-group ::-moz-placeholder {
  color: white;
  font-size: 15px;
}
.zone.contact_form .text .formulaire form .form-group :-ms-input-placeholder {
  color: white;
  font-size: 15px;
}
.zone.contact_form .text .formulaire form .form-group ::-ms-input-placeholder {
  color: white;
  font-size: 15px;
}
.zone.contact_form .text .formulaire form .form-group ::placeholder {
  color: white;
  font-size: 15px;
}
.zone.contact_form .text .formulaire form .g-recaptcha {
  display: inline-block;
}
.zone.contact_form .text .formulaire form .form-group:nth-child(2),
.zone.contact_form .text .formulaire form .form-group:nth-child(4),
.zone.contact_form .text .formulaire form .form-group:nth-child(5) {
  margin-right: 0;
}
.zone.contact_form .text .formulaire form .form-group:nth-child(10),
.zone.contact_form .text .formulaire form .form-group:nth-child(5),
.zone.contact_form .text .formulaire form .form-group:nth-child(7),
.zone.contact_form .text .formulaire form .form-group:nth-child(8) {
  width: 100%;
}
.zone.contact_form .text .formulaire form .form-group:nth-child(10),
.zone.contact_form .text .formulaire form .form-group:nth-child(9) {
  width: 100%;
  text-align: center;
}
.zone.contact_form .text .formulaire form .form-group.message {
  width: 100%;
}
.zone.contact_form .text .formulaire form .form-group.rgpd {
  width: 100%;
}
.zone.contact_form .text .formulaire form .form-group.rgpd label {
  display: inline-block;
  position: relative;
  top: -4px;
}
.zone.contact_form .text .formulaire form .form-group.rgpd input {
  border: unset;
  height: unset;
  width: unset;
  opacity: 1;
  pointer-events: all;
  position: relative;
  width: 20px;
  height: 20px;
  margin-left: 15px;
  margin-top: -2px;
}
.zone.contact_form .text .global_error,
.zone.contact_form .text .success {
  text-align: center;
  width: 100%;
  font-size: 1.8rem;
}
.zone.contact_form .carte {
  position: relative;
  width: 45%;
  min-height: 90vh;
}
.zone.contact_form .carte .simpleParallax {
  height: 100%;
}
.zone.contact_form .carte .photo,
.zone.contact_form .carte iframe {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.zone.contact_form button {
  margin-top: 0;
  letter-spacing: 1px;
  border: 0;
  font-weight: 500;
  text-transform: uppercase;
  cursor: pointer;
  background: #456b60;
  color: white;
  padding: 15px 30px;
  font-family: 'Montserrat';
}
.zone.contact_form button::after {
  background: #016678;
}
@media all and (max-width: 1600px) {
  .zone.contact_form .text {
    padding: 4rem 5rem;
  }
}
@media all and (max-width: 1400px) {
  .zone.contact_form .text {
    padding: 0;
  }
}
@media all and (max-width: 1200px) {
  .zone.contact_form .wrap {
    flex-wrap: wrap;
  }
  .zone.contact_form .titre-container {
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .zone.contact_form .coords {
    text-align: center;
  }
  .zone.contact_form .text {
    order: 1;
    padding: 0rem;
    width: 100%;
    padding-bottom: 0;
    position: relative;
  }
  .zone.contact_form .text .rub {
    top: -5rem;
    margin-left: 0;
    margin-bottom: 0;
  }
  .zone.contact_form .carte {
    order: 2;
    width: 100%;
    height: 400px;
    margin-top: 4rem;
  }
}
@media all and (max-width: 800px) {
  .zone.contact_form .wrap {
    flex-wrap: wrap;
  }
  .zone.contact_form .text {
    padding: 0;
    width: 100%;
    padding-bottom: 0;
  }
  .zone.contact_form .text .formulaire form .form-group {
    width: 100% !important;
    margin-right: 0 !important;
  }
  .zone.contact_form .carte {
    width: 100%;
    height: auto;
    min-height: unset;
  }
  .zone.contact_form .carte .photo {
    max-height: 400px;
  }
  .zone.contact_form .carte .photo img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
  }
  .zone.contact_form .carte .photo:after {
    content: '';
    display: block;
    padding-top: 75%;
  }
}
@media all and (max-width: 600px) {
  .zone.contact_form {
    padding-top: 150px;
  }
  .zone.contact_form .wrap {
    flex-wrap: wrap;
    width: calc(100% - 50px);
  }
  .zone.contact_form .text {
    padding: 0;
    width: 100%;
    padding-bottom: 0;
  }
  .zone.contact_form .text .formulaire form .form-group {
    width: 100% !important;
    margin-right: 0 !important;
  }
  .zone.contact_form .carte .photo:after {
    padding-top: 125%;
  }
}
@media all and (max-width: 450px) {
  .zone.contact_form .wrap {
    flex-wrap: wrap;
  }
  .zone.contact_form .text {
    width: 100%;
    padding-bottom: 0;
  }
  .zone.contact_form .text .coords {
    font-size: 1.5rem;
  }
  .zone.contact_form .text .formulaire form .form-group {
    width: 100% !important;
    margin-right: 0 !important;
  }
}
.zone.slider {
  text-align: center;
}
.zone.slider .fond {
  position: absolute;
  top: 0rem;
  left: 10%;
  background-repeat: repeat;
  width: 100%;
  height: 100%;
}
.zone.slider .swiper-controls {
  position: relative;
  width: 70px;
  margin-top: -20px;
  display: inline-block;
}
.zone.slider .text {
  width: 50%;
  margin: 0 auto;
  margin-top: 25px;
  text-align: center !important;
}
.zone.slider .text .desc {
  text-align: justify;
  text-align-last: center;
}
.zone.slider .text .links-container {
  justify-content: center;
}
.zone.slider .text .swiper-text .swiper-slide {
  transform: scale(0.5);
  transition: 750ms opacity ease-out 0ms, 750ms transform ease-out 0ms;
  opacity: 0;
}
.zone.slider .text .swiper-text .swiper-slide.swiper-slide-active {
  transform: none;
  opacity: 1;
}
.zone.slider > .titre-container {
  width: 50%;
}
.zone.slider .rub {
  margin-left: auto;
  margin-right: auto;
}
.zone.slider .slider {
  margin-top: 50px;
}
.zone.slider .slider .swiper-container {
  width: 100%;
}
.zone.slider .slider .swiper-container .swiper-slide {
  position: relative;
  display: flex;
  flex-direction: column;
}
.zone.slider .slider .swiper-container .swiper-slide .photo {
  position: relative;
  width: 100%;
  height: 700px;
}
.zone.slider .slider .swiper-container .swiper-slide .photo img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.1);
  transition: transform 1000ms ease-out;
}
.zone.slider .slider .swiper-container .swiper-slide.swiper-slide-active .photo img {
  transform: none;
}
.zone.slider .photos-container {
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 50px;
  margin-top: 50px;
  margin-bottom: 25px;
}
.zone.slider .photos-container .photo {
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  position: relative;
}
.zone.slider .photos-container .photo::after {
  content: '';
  display: block;
  padding-top: 100%;
}
.zone.slider .photos-container .photo > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 500ms filter ease-out, 750ms transform ease-out;
}
.zone.slider .photos-container .photo .titre-container {
  position: absolute;
  opacity: 0;
  transform: scale(1.1);
  transition: 500ms opacity ease-out, 750ms transform ease-out;
  filter: invert(1);
  margin-bottom: 0 !important;
}
.zone.slider .photos-container .photo .titre-container .titre {
  color: black;
}
.zone.slider .photos-container .photo:hover > img {
  filter: brightness(0.8);
  transform: scale(1.1);
}
.zone.slider .photos-container .photo:hover .titre-container {
  transform: none;
  opacity: 1;
}
.zone.slider .element {
  display: flex;
  flex-direction: column;
}
.zone.slider .element .sstitre {
  margin-bottom: 0;
}
.zone.slider .element .background {
  width: 100%;
  height: 700px;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  background-attachment: fixed;
  margin-bottom: 25px;
}
.zone.slider .element:not(:last-of-type) {
  margin-bottom: 100px;
}
.zone.slider .element .desc {
  text-align: justify;
  text-align-last: center;
}
@media all and (max-width: 1600px) {
  .zone.slider .slider .swiper-container .swiper-slide .wrap .text {
    padding: 4rem;
  }
  .zone.slider .slider .swiper-container .swiper-slide .wrap .photo:before {
    padding-top: 75%;
  }
}
@media all and (max-width: 1400px) {
  .zone.slider .slider .swiper-container .swiper-slide .wrap .text {
    padding: 3rem;
  }
  .zone.slider .slider .swiper-container .swiper-slide .wrap .photo:before {
    padding-top: 80%;
  }
  .zone.slider {
    padding-left: 0%;
  }
}
@media all and (max-width: 1200px) {
  .zone.slider .swiper-slide-active .name {
    font-size: 3rem;
  }
  .zone.slider {
    padding-left: 5%;
    padding-right: 5%;
  }
  .zone.slider .slider .swiper-container .swiper-slide {
    height: 65vh;
  }
  .zone.slider .slider .swiper-container .swiper-slide .fotoback {
    top: 50%;
    left: 5rem;
    transform: translateY(-50%);
    height: 80%;
  }
}
@media all and (max-width: 1000px) {
  .zone.slider {
    padding-left: 0;
    padding-right: 0;
  }
  .zone.slider .text {
    width: 75%;
  }
  .zone.slider.subtype2 .slider .swiper-container .swiper-slide .fotoback {
    left: 0;
  }
  .zone.slider.subtype2 .slider .swiper-container .swiper-slide .wrap .photo {
    width: 70%;
    right: 0rem;
  }
  .zone.slider.subtype2 .slider .swiper-container .swiper-slide .wrap .photo::before {
    padding-top: 70%;
  }
  .zone.slider.subtype2 .slider .swiper-container .swiper-slide .wrap .text {
    width: 60%;
    margin-left: 0;
  }
  .zone.slider .slider {
    margin-top: 50px;
  }
  .zone.slider .slider .swiper-container .swiper-slide {
    height: auto !important;
  }
  .zone.slider .slider .swiper-container .swiper-slide .photo {
    height: auto !important;
    position: relative;
    max-height: 400px;
  }
  .zone.slider .slider .swiper-container .swiper-slide .photo img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
  }
  .zone.slider .slider .swiper-container .swiper-slide .photo:after {
    content: '';
    display: block;
    padding-top: 75%;
  }
}
@media all and (max-width: 800px) {
  .zone.slider {
    padding-left: 5%;
    padding-right: 5%;
    text-align: center;
  }
  .zone.slider .slider {
    width: 100%;
    margin-right: 0;
  }
}
@media all and (max-width: 600px) {
  .zone.slider {
    padding-left: 0%;
    padding-right: 0%;
  }
  .zone.slider.presentation .rub.titre-container {
    width: calc(100% - 50px);
    margin-bottom: 25px;
  }
  .zone.slider.presentation .rub.titre-container .sstitre {
    width: 100%;
  }
  .zone.slider .element .background {
    background-attachment: unset;
    margin-bottom: unset;
  }
  .zone.slider .element:not(:last-of-type) {
    margin-bottom: 50px;
  }
  .zone.slider .sstitre {
    margin-top: 0;
    text-align: left;
    width: calc(100% - 50px);
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }
  .zone.slider .text {
    width: calc(100% - 50px);
    margin-left: auto;
    margin-right: auto;
    text-align: justify !important;
  }
  .zone.slider .rub.titre-container {
    margin: 0 auto;
    width: calc(100% - 50px);
  }
  .zone.slider .slider {
    margin-top: 25px;
  }
  .zone.slider .slider .swiper-container .swiper-slide .wrap {
    flex-wrap: wrap;
    align-items: flex-start;
    height: auto !important;
  }
  .zone.slider .slider .swiper-container .swiper-slide .wrap .photo {
    width: 100% !important;
    position: relative;
    left: 0;
  }
  .zone.slider .slider .swiper-container .swiper-slide .wrap .text {
    width: 100% !important;
  }
  .zone.slider .photos-container {
    margin-top: 25px;
    width: calc(100% - 50px);
    margin-left: auto;
    margin-right: auto;
    grid-template-columns: repeat(1, 1fr);
    gap: 25px;
  }
  .zone.slider .photos-container .photo .titre-container .titre {
    font-size: 24px;
    letter-spacing: 0px;
  }
  .zone.slider .slider .swiper-container .swiper-slide .photo:after {
    padding-top: 125%;
  }
}
.zone.textslider {
  padding-left: 100px;
  padding-right: 100px;
}
.zone.textslider.subtype2 .wrap .images {
  margin-right: 0;
  margin-left: 100px;
}
.zone.textslider .wrap {
  display: flex;
  width: 100%;
}
.zone.textslider .wrap .images {
  min-height: 400px;
  flex: 2;
  position: relative;
  overflow: hidden;
  margin-right: 100px;
}
.zone.textslider .wrap .images .slider {
  height: 100%;
  width: 100%;
}
.zone.textslider .wrap .images .slider .swiper-slide .simpleParallax {
  transform: scale(1.1);
  transition: transform 1000ms ease-out;
}
.zone.textslider .wrap .images .slider .swiper-slide.swiper-slide-active .simpleParallax {
  transform: none;
}
.zone.textslider .wrap .images .slider .photo {
  height: 75vh;
}
.zone.textslider .wrap .images .slider .photo img {
  height: 100%;
}
.zone.textslider .wrap .texte {
  width: 400px;
  max-width: 50%;
  padding: 0rem;
  display: flex;
}
.zone.textslider .wrap .texte .area {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.zone.textslider .wrap .texte .desc {
  overflow: auto;
  text-align: justify;
}
.zone.textslider .wrap .texte .swiper-controls {
  display: flex;
}
.zone.textslider .wrap .texte .swiper-controls .swiper-button-next,
.zone.textslider .wrap .texte .swiper-controls .swiper-button-prev {
  position: relative;
  margin: 0;
  font-size: 2.2rem;
}
.zone.textslider .wrap .texte .swiper-controls .swiper-button-prev {
  margin-right: 4rem;
  left: 0;
}
.zone.textslider .wrap .texte .btnresa {
  transition: all 0.3s ease;
  border: 1px solid;
  text-transform: uppercase;
  padding: 7px 30px;
}
.zone.textslider .wrap .texte .btnresa:before {
  display: none;
}
.zone.textslider .wrap .texte .btnresa:hover {
  background: #456b60;
  color: white;
  transition: all 0.3s ease;
  border-color: #456b60;
}
.zone.textslider.subtype2 .rub {
  left: auto;
  right: 20%;
}
.zone.textslider.subtype2 .wrap {
  position: relative;
}
.zone.textslider.subtype2 .wrap .texte {
  order: 1;
}
.zone.textslider.subtype2 .wrap .images {
  order: 2;
}
@media screen and (min-width: 1000px) {
  .zone.textslider {
    min-height: calc(100vh - 100px);
    max-height: calc(100vh - 200px);
    display: flex;
  }
  .zone.textslider.subtype1 .swiper-pagination {
    top: 0;
    width: 32px;
    height: 100%;
    bottom: 0;
    left: unset;
    right: 16px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .zone.textslider .swiper-pagination {
    top: 0;
    width: 32px;
    height: 100%;
    bottom: 0;
    left: 16px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .zone.textslider .swiper-pagination .swiper-pagination-bullet:not(:last-child) {
    margin-bottom: 8px;
  }
}
@media screen and (min-width: 1000px) and (max-width: 1280px) {
  .zone.textslider {
    min-height: calc(100vh - 50px);
    max-height: calc(100vh - 100px);
  }
}
@media all and (max-width: 1600px) {
  .zone.textslider {
    padding-left: 75px;
    padding-right: 75px;
  }
  .zone.textslider .wrap .images {
    margin-right: 75px;
  }
  .zone.textslider.subtype2 .wrap .images {
    margin-right: 0;
    margin-left: 75px;
  }
}
@media all and (max-width: 1400px) {
  .zone.textslider {
    padding-left: 50px;
    padding-right: 50px;
  }
  .zone.textslider .wrap .images {
    margin-right: 50px;
  }
  .zone.textslider.subtype2 .wrap .images {
    margin-right: 0;
    margin-left: 50px;
  }
}
@media all and (max-width: 1200px) {
  .zone.textslider .wrap .texte {
    width: calc(50% - 100px);
  }
}
@media all and (max-width: 1000px) {
  .zone.textslider {
    padding-left: 0;
    padding-right: 0;
  }
  .zone.textslider .wrap {
    flex-direction: column-reverse;
    width: 100% !important;
  }
  .zone.textslider .wrap .texte {
    padding: 0;
    max-width: unset;
    width: calc(100% - 200px) !important;
    margin-left: auto;
    margin-right: auto;
  }
  .zone.textslider .wrap .images {
    width: 100% !important;
    margin-top: 50px;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .zone.textslider.subtype2 .wrap .images {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .zone.textslider .wrap .images .slider .photo {
    height: auto;
    max-height: 400px;
  }
  .zone.textslider .wrap .images .slider .photo:after {
    content: '';
    display: block;
    padding-top: 75%;
  }
  .zone.textslider .wrap .images .slider .photo img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
  }
}
@media all and (max-width: 600px) {
  .zone.textslider .wrap .texte {
    width: calc(100% - 50px) !important;
  }
  .zone.textslider .wrap .texte .rub.titre-container {
    margin-left: auto;
    margin-right: auto;
  }
  .zone.textslider .wrap .texte .sstitre {
    text-align: center;
  }
  .zone.textslider .wrap .texte .desc {
    text-align-last: center;
  }
  .zone.textslider .wrap .images {
    width: 100%;
    margin-bottom: 0;
    margin-top: 25px;
  }
  .zone.textslider .wrap .images .slider .photo {
    height: unset;
    max-height: unset;
  }
  .zone.textslider .wrap .images .slider .photo img {
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
  }
  .zone.textslider .wrap .images .slider .photo::after {
    padding-top: 125%;
  }
}
@media all and (max-width: 450px) {
  .zone.textslider.subtype2 .wrap {
    flex-direction: column;
  }
  .zone.textslider.subtype2 .wrap .texte {
    order: 1;
  }
  .zone.textslider.subtype2 .wrap .images {
    order: 2;
  }
  .zone.textslider .wrap .rub {
    margin-top: 0rem;
  }
  .zone.textslider .wrap .images {
    width: 100%;
  }
  .zone.textslider .wrap .images .photo img {
    width: 100%;
  }
}
.zone.grillecards {
  background: white;
  color: #456b60;
  margin-bottom: 0;
}
.zone.grillecards .filters {
  text-transform: uppercase;
  overflow: hidden;
  margin: 0 auto;
  margin-bottom: 8rem;
  color: white;
  width: 75%;
}
.zone.grillecards .filters .cfluid {
  height: 100%;
}
.zone.grillecards .filters ul {
  height: 100%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.zone.grillecards .filters ul li {
  width: 23%;
  margin-bottom: 1.5rem;
}
.zone.grillecards .filters ul li i {
  vertical-align: 0;
  margin-left: 5px;
}
.zone.grillecards .filters ul li a,
.zone.grillecards .filters ul li button {
  height: 60px;
  color: #456b60;
  outline: none;
  background: none;
  border: none;
  font-size: 1.9rem;
  letter-spacing: 1px;
  cursor: pointer;
  padding: 0 1rem;
  width: 100%;
  border: 1px solid rgba(216, 193, 153, 0.5);
  font-family: 'Butler';
}
.zone.grillecards .filters ul li a.active,
.zone.grillecards .filters ul li button.active,
.zone.grillecards .filters ul li a.is-checked,
.zone.grillecards .filters ul li button.is-checked {
  background: #456b60;
  color: white;
  transition: all 0.3s ease;
  border-color: #456b60;
}
.zone.grillecards .filters ul li a:hover,
.zone.grillecards .filters ul li button:hover {
  background: #456b60;
  color: white;
  transition: all 0.3s ease;
  border-color: #456b60;
}
.zone.grillecards .cfluid {
  width: 88%;
  text-align: center;
}
.zone.grillecards .cfluid .desc {
  color: black;
  margin-top: 25px;
  font-size: 16px;
}
.zone.grillecards .grid {
  overflow-y: hidden;
  margin-top: 8rem;
  width: 100%;
  position: relative;
  height: auto;
  overflow: hidden;
  overflow: visible;
}
.zone.grillecards .grid .gutter {
  width: 2%;
}
.zone.grillecards .grid .brick {
  width: 32%;
  margin-bottom: 8rem;
  color: #000000;
  position: relative;
  padding: 15rem 5rem;
  height: 60vh;
  min-height: 350px;
  max-height: 800px;
  text-align: center;
}
.zone.grillecards .grid .brick:before {
  content: '';
  position: absolute;
  top: 5rem;
  left: 9rem;
  border: 1px solid #456b60;
  background: none;
  z-index: -1;
  width: calc(100% - 20rem);
  height: calc(100% - 15rem);
}
.zone.grillecards .grid .brick .photo {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 100%;
  height: 100%;
  transform: translateX(-50%);
  transition: all 0.3s ease-out;
}
.zone.grillecards .grid .brick .photo img {
  width: 100%;
  height: 100%;
}
.zone.grillecards .grid .brick .text {
  opacity: 0;
  transition: all 0.3s ease-out;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  transform: translate(-52%, -50%);
  text-align: center;
}
.zone.grillecards .grid .brick .text .name {
  font-size: 2rem;
  color: #456b60;
  font-style: italic;
}
.zone.grillecards .grid .brick .text .titre {
  font-size: 2rem;
}
.zone.grillecards .grid .brick .text .hr {
  display: inline-block;
  width: 80px;
  margin: 2.5rem auto;
  height: 1px;
  background: #456b60;
}
.zone.grillecards .grid .brick .text .more:not(.addcart) {
  text-decoration: underline;
  display: flex;
  align-items: center;
  justify-content: center;
}
.zone.grillecards .grid .brick .text .more:not(.addcart) span {
  padding-left: 4px;
}
.zone.grillecards .grid .brick:hover .photo {
  opacity: 0.05;
  transform: translateX(-52%);
  transition: all 0.3s ease-out;
}
.zone.grillecards .grid .brick:hover .text {
  opacity: 1;
  transform: translate(-50%, -50%);
  transition: all 0.3s ease-out;
}
.zone.grillecards .pager {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 200px;
  margin: 0 auto;
}
.zone.grillecards .pager .forme {
  transform: scaleY(1);
  top: -19px;
}
.zone.grillecards .pager .forme path {
  fill: #eaeceb;
}
.zone.grillecards .pager li {
  margin: 0 5px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.zone.grillecards .pager li a {
  color: white;
  font-size: 18px;
  transition: all 500ms;
  padding: 0 5px;
}
.zone.grillecards .pager li a:hover,
.zone.grillecards .pager li a.active {
  color: white;
  font-weight: 600;
}
.zone.grillecards .pager li a:hover:after,
.zone.grillecards .pager li a.active:after {
  transform: scaleX(1);
}
.zone.grillecards.subtype2 .filters {
  display: none;
}
.zone.grillecards.subtype2 .grid {
  overflow: visible;
}
.zone.grillecards.subtype2 .grid .gutter {
  width: 8%;
}
.zone.grillecards.subtype2 .grid .brick {
  padding: 0;
  max-height: none;
  min-height: auto;
  height: auto;
  width: 28%;
}
.zone.grillecards.subtype2 .grid .brick:before {
  display: none;
}
.zone.grillecards.subtype2 .grid .brick .photo {
  position: relative;
  margin-bottom: 3rem;
  left: auto;
  top: auto;
  bottom: auto;
  transform: none;
  opacity: 1 !important;
}
.zone.grillecards.subtype2 .grid .brick .photo:before {
  display: block;
  content: '';
  width: 100%;
  padding-top: 130%;
}
.zone.grillecards.subtype2 .grid .brick .photo a.document-link,
.zone.grillecards.subtype2 .grid .brick .photo img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.zone.grillecards.subtype2 .grid .brick .text {
  position: relative;
  text-align: left;
  opacity: 1;
  left: auto;
  top: auto;
  bottom: auto;
  transform: none;
}
.zone.grillecards.subtype2 .grid .brick .text em {
  color: #456b60;
  font-size: 1.8rem;
  letter-spacing: 2px;
}
.zone.grillecards.subtype2 .grid .brick .text .titre {
  margin: 2rem 0;
  font-size: 3rem;
}
.zone.grillecards.subtype3 .filters {
  display: none;
}
.zone.grillecards.subtype3 .grid {
  overflow: visible;
}
.zone.grillecards.subtype3 .grid .gutter {
  width: 8%;
}
.zone.grillecards.subtype3 .grid .brick {
  padding: 0;
  max-height: none;
  min-height: auto;
  height: auto;
  width: 28%;
}
.zone.grillecards.subtype3 .grid .brick:before {
  display: none;
}
.zone.grillecards.subtype3 .grid .brick .photo {
  position: relative;
  left: auto;
  top: auto;
  bottom: auto;
  transform: none;
  opacity: 1 !important;
}
.zone.grillecards.subtype3 .grid .brick .photo:before {
  display: block;
  content: '';
  width: 100%;
  padding-top: 130%;
}
.zone.grillecards.subtype3 .grid .brick .photo img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.zone.grillecards.subtype3 .grid .brick .text {
  position: relative;
  text-align: left;
  opacity: 1;
  left: auto;
  top: auto;
  bottom: auto;
  transform: none;
  display: none;
}
.zone.grillecards.subtype3 .grid .brick .text em {
  color: #456b60;
  font-size: 1.8rem;
  letter-spacing: 2px;
}
.zone.grillecards.subtype3 .grid .brick .text .titre {
  margin: 2rem 0;
  font-size: 3rem;
}
.zone.grillecards.subtype1 .grid .brick .text {
  top: 46%;
}
.zone.grillecards.subtype1 .price {
  font-size: 26px;
  font-family: 'Butler';
  margin-top: 16px;
  color: #456b60;
}
.zone.grillecards.subtype1 .button.more {
  display: block;
  margin: 2.5rem auto 0 auto;
  color: black;
}
.zone.grillecards.subtype1 .addcart {
  margin: 2.5rem auto 0 auto;
}
@media all and (max-width: 1400px) {
  .zone.grillecards .grid .brick .image_zone .img:hover .hover .desc {
    font-size: 1.4rem;
  }
  .zone.grillecards .grid .brick .image_zone .img:hover .hover .desc p {
    line-height: 1.2;
  }
  .zone.grillecards .grid .brick .titre {
    font-size: 2.5rem;
  }
  .zone.grillecards .grid .brick .map {
    right: 0;
  }
  .zone.grillecards .filters ul li a,
  .zone.grillecards .filters ul li button {
    font-size: 1.5rem;
  }
}
@media all and (max-width: 1200px) {
  .zone.grillecards .grid .brick {
    width: 48%;
  }
  .zone.grillecards .filters {
    width: 90%;
  }
  .zone.grillecards .button {
    color: #000000;
  }
  .zone.grillecards .filters ul li a,
  .zone.grillecards .filters ul li button {
    font-size: 1.5rem;
    padding: 0 1rem;
    min-width: 200px;
  }
}
@media all and (max-width: 1000px) {
  .zone.grillecards .cfluid {
    width: 90%;
  }
  .zone.grillecards .grid .brick {
    width: 48%;
  }
  .zone.grillecards .grid .brick .map {
    height: calc(80% - 70px);
  }
  .zone.grillecards .grid .brick .wrap .panbottom {
    font-size: 1.6rem;
  }
  .zone.grillecards .grid .brick .wrap .panbottom .price {
    font-size: 2rem;
  }
  .zone.grillecards .grid .gutter {
    width: 4%;
  }
  .zone.grillecards.subtype2 .grid .gutter,
  .zone.grillecards.subtype3 .grid .gutter {
    width: 4%;
  }
  .zone.grillecards.subtype2 .grid .brick,
  .zone.grillecards.subtype3 .grid .brick {
    width: 48%;
  }
  .zone.grillecards .filters ul li a,
  .zone.grillecards .filters ul li button {
    font-size: 1.5rem;
    padding: 0 0.5rem;
  }
  .zone.grillecards .filters ul {
    height: auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .zone.grillecards .filters ul li {
    width: auto;
    margin: 0 1rem;
    margin-bottom: 1.5rem;
  }
  .zone.grillecards .filters .cfluid {
    width: 100%;
  }
}
@media all and (max-width: 800px) {
  .zone.grillecards .grid .brick {
    width: 100%;
  }
  .zone.grillecards .grid .brick .map {
    height: calc(90% - 70px);
  }
  .zone.grillecards .grid .gutter {
    width: 0%;
  }
  .zone.grillecards .filters ul li a,
  .zone.grillecards .filters ul li button {
    font-size: 1.5rem;
    padding: 0 2.5rem;
    height: 45px;
    min-width: 0;
  }
  .zone.grillecards .filters {
    margin-bottom: 3rem;
  }
  .zone.grillecards .filters ul {
    margin: 1rem 0;
    height: auto;
    flex-wrap: wrap;
  }
  .zone.grillecards .filters .cfluid {
    width: 100%;
  }
  .zone.grillecards.subtype1 .grid .brick {
    height: auto;
    max-height: unset;
    display: flex;
    text-align: center;
    flex-direction: column;
    align-items: center;
    padding: 0rem;
    padding-bottom: 40px;
  }
  .zone.grillecards.subtype1 .grid .brick:before {
    top: 15rem;
    left: 0rem;
    right: 0rem;
    width: unset;
  }
  .zone.grillecards.subtype1 .grid .brick .photo {
    position: relative;
    left: auto;
    transform: none;
    margin-bottom: 0rem;
    height: 350px;
    bottom: auto;
  }
  .zone.grillecards.subtype1 .grid .brick .text {
    position: relative;
    opacity: 1;
    left: auto;
    top: auto;
    transform: none;
  }
  .zone.grillecards.subtype1 .grid .brick .text .desc {
    padding: 0 25px;
  }
  .zone.grillecards.subtype2 .grid .gutter,
  .zone.grillecards.subtype3 .grid .gutter {
    width: 0%;
  }
  .zone.grillecards.subtype2 .grid .brick,
  .zone.grillecards.subtype3 .grid .brick {
    width: 100%;
    margin-bottom: 4rem;
  }
  .zone.grillecards.subtype2 .grid .brick .photo:before,
  .zone.grillecards.subtype3 .grid .brick .photo:before {
    padding-top: 70%;
  }
  .zone.grillecards.subtype2 .grid .brick .images .text,
  .zone.grillecards.subtype3 .grid .brick .images .text {
    position: relative;
    width: 100%;
    left: auto;
    top: auto;
    transform: none;
  }
  .zone.grillecards.subtype2 .grid .brick .images .text .title,
  .zone.grillecards.subtype3 .grid .brick .images .text .title {
    margin-top: 1rem;
  }
  .zone.grillecards.subtype2 .grid .brick,
  .zone.grillecards.subtype3 .grid .brick {
    margin-bottom: 4rem;
  }
  .pagetype_blog .zone.grillecards .grid .brick .wrap {
    width: 100%;
    height: auto;
    min-height: 0px;
  }
  .pagetype_blog .zone.grillecards .grid .brick .wrap .pantop {
    height: 100%;
    padding: 2rem 2rem;
    min-height: 200px;
  }
  .pagetype_blog .zone.grillecards .grid .brick .wrap .panbottom {
    height: auto;
    padding: 2rem;
  }
}
@media all and (max-width: 768px) {
  .zone.grillecards2 .grid .brick .swiper-container {
    left: auto;
    height: auto;
    transform: none;
  }
}
@media all and (max-width: 600px) {
  .zone.grillecards .filters ul li a,
  .zone.grillecards .filters ul li button {
    padding: 0rem 1.5rem;
    font-size: 1.25rem;
    margin: 0rem;
    border: 1px solid !important;
  }
  .zone.grillecards .filters {
    width: 100%;
  }
  .zone.grillecards .filters ul li {
    width: auto;
    margin: 0 0.5rem;
    margin-bottom: 1rem;
  }
  .zone.grillecards .grid .brick .map {
    height: calc(75% - 70px);
  }
  .zone.grillecards .grid .brick .titre {
    font-size: 2rem;
  }
  .zone.grillecards .grid .brick .wrap .panbottom,
  .zone.grillecards .grid .brick .wrap .pantop {
    padding: 1rem 2rem;
  }
  .zone.grillecards.subtype2 .grid .brick .images,
  .zone.grillecards.subtype3 .grid .brick .images {
    padding: 0;
  }
  .zone.grillecards.subtype2 .grid .brick .images .text,
  .zone.grillecards.subtype3 .grid .brick .images .text {
    position: relative;
    width: 100%;
    left: auto;
    top: auto;
    transform: none;
  }
  .zone.grillecards.subtype2 .grid .brick .images .text .title,
  .zone.grillecards.subtype3 .grid .brick .images .text .title {
    font-size: 2.8rem;
    margin-top: 1rem;
  }
}
@media all and (max-width: 450px) {
  .zone.grillecards .grid .brick .bigwrap {
    flex-wrap: wrap;
  }
  .zone.grillecards .grid .brick .bigwrap .wrap {
    width: 100%;
    order: 2;
  }
  .zone.grillecards .grid .brick .bigwrap .wrap .pantop {
    border-top: 1px solid rgba(255, 255, 255, 0.5);
    height: 75px;
  }
  .zone.grillecards .grid .brick .bigwrap .wrap .panbottom {
    align-items: center;
    height: 75px;
  }
  .zone.grillecards .grid .brick .bigwrap .map {
    width: 100%;
    height: 50vh;
    min-height: 400px;
  }
  .zone.grillecards .grid .brick .bigwrap .map img {
    height: 100%;
    object-fit: contain;
  }
  .pagetype_blog .zone.grillecards .grid .brick .bigwrap {
    flex-wrap: wrap;
  }
  .pagetype_blog .zone.grillecards .grid .brick .bigwrap .wrap {
    width: 100%;
    order: 2;
  }
  .pagetype_blog .zone.grillecards .grid .brick .bigwrap .wrap .pantop,
  .pagetype_blog .zone.grillecards .grid .brick .bigwrap .wrap .panbottom {
    height: 50%;
  }
}
.zone.detail {
  padding: 50px 0 0;
}
.zone.detail .btnresa {
  transition: all 0.3s ease;
  border: 1px solid;
  text-transform: uppercase;
  padding: 7px 30px;
}
.zone.detail .btnresa:hover {
  background: ;
  color: white;
  border-color: #b6c3cc;
}
.zone.detail .btnresa::before {
  display: none;
}
.zone.detail .slider {
  height: 400px;
}
.zone.detail .slider .swiper-slide .media {
  position: relative;
  height: 100%;
  overflow: hidden;
}
.zone.detail .slider .swiper-slide .media video,
.zone.detail .slider .swiper-slide .media img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: 1500ms transform ease-out;
  transform: scale(1.1);
}
.zone.detail .slider .swiper-slide.swiper-slide-active .media video,
.zone.detail .slider .swiper-slide.swiper-slide-active .media img {
  transform: none;
}
.zone.detail .content {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.zone.detail .content .text {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0 25px 0 25px;
  padding: 25px 12px;
  z-index: 2;
  position: relative;
}
.zone.detail .content .text .titre-container {
  width: 100%;
}
.zone.detail .content .text .title,
.zone.detail .content .text .description,
.zone.detail .content .text .subtitle {
  text-align: center;
}
.zone.detail .content .text .description {
  margin-bottom: 25px;
  text-align: justify;
  text-align-last: center;
}
.zone.detail .content > .description {
  width: calc(100% - 50px);
  margin: 25px auto 0;
}
.zone.detail .content .description ul {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 16px;
}
.zone.detail .content .description ul li {
  border-bottom: 1px solid black;
  font-family: 'Butler';
  padding: 8px;
  letter-spacing: 1px;
  text-align: center;
}
.zone.detail .content .illustrations {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 15px;
}
.zone.detail .content .illustrations .illustration-item {
  display: flex;
  align-items: center;
  margin-bottom: 4px;
  width: 100%;
  padding: 4px;
  border-bottom: 1px solid black;
}
.zone.detail .content .illustrations .illustration-item .illu {
  position: relative;
  width: 50px;
  height: 50px;
}
.zone.detail .content .illustrations .illustration-item .illu img {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.zone.detail .content .illustrations .illustration-item .legend {
  font-family: 'Butler';
  padding: 8px 8px 0;
  letter-spacing: 1px;
  text-align: center;
}
@media only screen and (min-width: 600px) {
  .zone.detail .content {
    max-width: 1600px;
    margin: 0 auto;
  }
  .zone.detail .content .text {
    max-width: 85%;
    margin: 0 25px 0 25px;
  }
}
@media only screen and (min-width: 768px) {
  .zone.detail {
    padding: 100px 0 0;
  }
  .zone.detail .content .description ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
  .zone.detail .content .illustrations .illustration-item {
    width: calc(50% - 25px);
  }
  .zone.detail .content > .description {
    width: calc(100%);
  }
}
@media only screen and (min-width: 992px) {
  .zone.detail .slider {
    height: 70vh;
  }
  .zone.detail .content .text {
    margin: 0 25px 0 25px;
    padding: 50px 100px;
  }
  .zone.detail .content .text .subtitle {
    max-width: 400px;
  }
}
@media only screen and (min-width: 1200px) {
  .zone.detail .content .description ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
  }
  .zone.detail .content .illustrations {
    justify-content: space-evenly;
    max-width: 85%;
  }
  .zone.detail .content .illustrations .illustration-item {
    width: calc(calc(100% / 3) - 25px);
  }
}
.zone.press {
  padding: 80px 40px !important;
  width: 100%;
  max-width: 1600px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
}
.zone.press .list-container {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 80px;
}
.zone.press .list-item {
  display: flex;
  flex-direction: column;
  position: relative;
}
.zone.press .list-item:hover .media img {
  transform: scale(1.25);
}
.zone.press .list-item:hover .media .title {
  transition: 250ms transform ease-out 250ms;
  transform: none;
}
.zone.press .list-item .button-holder {
  margin-top: auto;
}
.zone.press .list-item .absolute-link {
  z-index: 1000;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.zone.press .list-item .media {
  width: 100%;
  display: flex;
  position: relative;
  height: unset;
}
.zone.press .list-item .media::after {
  width: 100%;
  content: '';
  display: block;
  padding-top: 100%;
}
.zone.press .list-item .media a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.zone.press .list-item .media img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: 250ms filter ease-out, 500ms transform ease-out;
}
.zone.press .list-item .media img.media-origin {
  top: 25px;
  right: 25px;
  width: 85px;
  object-fit: contain;
  left: unset;
  height: auto;
  max-height: 60px;
}
.zone.press .list-item .media .title {
  position: absolute;
  color: #f3f1ed;
  transform: scale(0);
  transition: 250ms transform ease-out;
  display: flex;
  align-items: center;
  justify-content: center;
}
.zone.press .list-item .content {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.zone.press .list-item .content .title-wrapper {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
}
.zone.press .list-item .content .title-wrapper .date {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #456b60;
  color: white;
  padding: 8px;
  font-family: 'Butler';
  width: 100px;
  height: 100px;
  min-width: 100px;
}
.zone.press .list-item .content .title-wrapper .date .day {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.zone.press .list-item .content .title-wrapper .date .day .nb {
  font-size: 20px;
  line-height: 0;
}
.zone.press .list-item .content .title-wrapper .date .day .month {
  font-size: 16px;
  line-height: 0;
  margin: 24px 0;
}
.zone.press .list-item .content .title-wrapper .date .day .year {
  font-size: 20px;
  line-height: 0;
}
.zone.press .list-item .content .title-wrapper .title {
  text-transform: none;
  text-align: left;
  flex: 1;
  padding: 8px;
  color: #456b60;
  font-size: 2rem;
  letter-spacing: 1px;
}
.zone.press .list-item .content .text {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.zone.press .list-item .content .text .description {
  margin-bottom: 12px;
  flex: 1;
}
@media screen and (min-width: 600px) {
  .zone.press {
    padding: 80px 60px !important;
  }
  .zone.press .list-item .content .title-wrapper {
    margin-bottom: 25px;
  }
}
@media screen and (min-width: 768px) {
  .zone.press .list-item .content .title-wrapper .title {
    padding: 12px;
  }
  .zone.press .list-container {
    grid-template-columns: repeat(2, 1fr);
  }
  .zone.press .pagination {
    margin-top: 50px;
  }
  .zone.press .pagination .pagination-item {
    padding: 12px;
  }
}
@media screen and (min-width: 1024px) {
  .zone.press {
    padding: 50px !important;
  }
}
@media screen and (min-width: 1200px) {
  .zone.press {
    padding: 100px !important;
  }
  .zone.press .list-item .content .title-wrapper .date {
    margin-top: -25px;
    z-index: 2;
  }
}
@media screen and (min-width: 1400px) {
  .zone.press {
    padding: 50px !important;
  }
  .zone.press .list-container {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (min-width: 1600px) {
  .zone.press {
    padding: 100px !important;
  }
  .zone.press .list-container {
    gap: 100px;
  }
  .zone.press .list-item .content .title-wrapper .date .day .nb {
    font-size: 24px;
    line-height: 0;
  }
  .zone.press .list-item .content .title-wrapper .date .day .month {
    font-size: 18px;
    line-height: 0;
  }
  .zone.press .list-item .content .title-wrapper .date .day .year {
    font-size: 24px;
    line-height: 0;
  }
}
.zone.slide_grille {
  text-align: center;
  position: relative;
}
.zone.slide_grille .desc {
  width: 50%;
  margin: 0 auto;
  margin-top: 25px;
  text-align: center !important;
}
.zone.slide_grille .swiper-container {
  width: 100%;
  overflow: hidden;
}
.zone.slide_grille .swiper-wrapper {
  display: flex;
  transition: all 0.3s ease;
}
.zone.slide_grille .swiper-slide {
  flex: 0 0 auto;
  width: 33.33%;
}
.zone.slide_grille .photo {
  width: 100%;
  height: auto;
  position: relative;
}
.zone.slide_grille .photo img {
  width: 100%;
  height: auto;
  display: block;
}
@media (max-width: 767px) {
  .zone.slide_grille .swiper-slide {
    width: 100%;
  }
  .zone.slide_grille .desc {
    width: 100%;
  }
}
.zone.slider_produits {
  background: white;
  color: #456b60;
  margin-bottom: 0;
}
.zone.slider_produits .swiper-container {
  width: 100%;
  height: auto;
  overflow: hidden;
  position: relative;
}
.zone.slider_produits .swiper-container .swiper-wrapper {
  display: flex;
  transition: all 0.3s ease-out;
}
.zone.slider_produits .swiper-container .swiper-slide {
  width: 32%;
  margin-right: 2%;
  position: relative;
}
.zone.slider_produits .swiper-container .swiper-slide .product-card {
  background: #456b60;
  border: 1px solid rgba(216, 193, 153, 0.5);
  padding: 2rem;
  transition: all 0.3s ease-out;
}
.zone.slider_produits .swiper-container .swiper-slide .product-card:hover {
  background: #314c44;
}
.zone.slider_produits .swiper-container .swiper-slide .product-card .product-photos {
  position: relative;
  width: 100%;
  height: auto;
}
.zone.slider_produits .swiper-container .swiper-slide .product-card .product-photos .fancy.photo {
  display: block;
  width: 100%;
  height: auto;
  position: relative;
  overflow: hidden;
}
.zone.slider_produits .swiper-container .swiper-slide .product-card .product-photos .fancy.photo img {
  width: 100%;
  height: auto;
  transition: all 0.3s ease-out;
}
.zone.slider_produits .swiper-container .swiper-slide .product-card .product-info {
  padding: 1rem 0;
  text-align: center;
}
.zone.slider_produits .swiper-container .swiper-slide .product-card .product-info .product-name {
  font-size: 2rem;
  color: #456b60;
  margin-bottom: 1rem;
}
.zone.slider_produits .swiper-container .swiper-slide .product-card .product-info .product-description {
  font-size: 1.6rem;
  color: #1d2d28;
  margin-bottom: 1rem;
}
.zone.slider_produits .swiper-container .swiper-slide .product-card .product-info .product-price {
  font-size: 1.8rem;
  color: #090e0d;
  font-weight: bold;
}
.zone.slider_produits .swiper-container .swiper-pagination {
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.zone.slider_produits .swiper-container .swiper-pagination .swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  background: #456b60;
  opacity: 0.5;
  transition: all 0.3s ease-out;
}
.zone.slider_produits .swiper-container .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
  opacity: 1;
}
.zone.grillecards2 {
  background: white;
  color: #456b60;
  margin-bottom: 0;
}
.zone.grillecards2 .filters {
  text-transform: uppercase;
  overflow: hidden;
  margin: 0 auto;
  margin-bottom: 8rem;
  color: white;
  width: 75%;
}
.zone.grillecards2 .filters .cfluid {
  height: 100%;
}
.zone.grillecards2 .filters ul {
  height: 100%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.zone.grillecards2 .filters ul li {
  width: 23%;
  margin-bottom: 1.5rem;
}
.zone.grillecards2 .filters ul li i {
  vertical-align: 0;
  margin-left: 5px;
}
.zone.grillecards2 .filters ul li a,
.zone.grillecards2 .filters ul li button {
  height: 60px;
  color: #456b60;
  outline: none;
  background: none;
  border: none;
  font-size: 1.9rem;
  letter-spacing: 1px;
  cursor: pointer;
  padding: 0 1rem;
  width: 100%;
  border: 1px solid rgba(216, 193, 153, 0.5);
  font-family: "Butler";
}
.zone.grillecards2 .filters ul li a.active,
.zone.grillecards2 .filters ul li button.active,
.zone.grillecards2 .filters ul li a.is-checked,
.zone.grillecards2 .filters ul li button.is-checked {
  background: #456b60;
  color: white;
  transition: all 0.3s ease;
  border-color: #456b60;
}
.zone.grillecards2 .filters ul li a:hover,
.zone.grillecards2 .filters ul li button:hover {
  background: #456b60;
  color: white;
  transition: all 0.3s ease;
  border-color: #456b60;
}
.zone.grillecards2 .cfluid {
  width: 88%;
  text-align: center;
}
.zone.grillecards2 .cfluid .desc {
  color: black;
  margin-top: 25px;
  font-size: 16px;
}
.zone.grillecards2 .grid {
  overflow-y: hidden;
  margin-top: 8rem;
  width: 100%;
  position: relative;
  height: auto;
  overflow: hidden;
  overflow: visible;
}
.zone.grillecards2 .grid .gutter {
  width: 2%;
}
.zone.grillecards2 .grid .brick {
  width: 32%;
  margin-bottom: 8rem;
  color: #000000;
  position: relative;
  padding: 15rem 5rem;
  height: 60vh;
  min-height: 350px;
  max-height: 800px;
  text-align: center;
}
.zone.grillecards2 .grid .brick:before {
  content: "";
  position: absolute;
  top: 5rem;
  left: 9rem;
  border: 1px solid #456b60;
  background: none;
  z-index: -1;
  width: calc(100% - 20rem);
  height: calc(100% - 15rem);
}
.zone.grillecards2 .grid .brick .swiper-container {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 100%;
  height: 100%;
  transform: translateX(-50%);
  transition: all 0.3s ease-out;
}
.zone.grillecards2 .grid .brick .swiper-container img {
  width: 100%;
  height: 100%;
}
.zone.grillecards2 .grid .brick .text {
  opacity: 0;
  transition: all 0.3s ease-out;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  transform: translate(-52%, -50%);
  text-align: center;
}
.zone.grillecards2 .grid .brick .text .name {
  font-size: 2rem;
  color: #456b60;
  font-style: italic;
}
.zone.grillecards2 .grid .brick .text .titre {
  font-size: 2rem;
}
.zone.grillecards2 .grid .brick .text .hr {
  display: inline-block;
  width: 80px;
  margin: 2.5rem auto;
  height: 1px;
  background: #456b60;
}
.zone.grillecards2 .grid .brick .text .more:not(.addcart) {
  text-decoration: underline;
  display: flex;
  align-items: center;
  justify-content: center;
}
.zone.grillecards2 .grid .brick .text .more:not(.addcart) span {
  padding-left: 4px;
}
.zone.grillecards2 .pager {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 200px;
  margin: 0 auto;
}
.zone.grillecards2 .pager .forme {
  transform: scaleY(1);
  top: -19px;
}
.zone.grillecards2 .pager .forme path {
  fill: #eaeceb;
}
.zone.grillecards2 .pager li {
  margin: 0 5px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.zone.grillecards2 .pager li a {
  color: white;
  font-size: 18px;
  transition: all 500ms;
  padding: 0 5px;
}
.zone.grillecards2 .pager li a:hover,
.zone.grillecards2 .pager li a.active {
  color: white;
  font-weight: 600;
}
.zone.grillecards2 .pager li a:hover:after,
.zone.grillecards2 .pager li a.active:after {
  transform: scaleX(1);
}
.zone.grillecards2.subtype2 .filters {
  display: none;
}
.zone.grillecards2.subtype2 .grid {
  overflow: visible;
}
.zone.grillecards2.subtype2 .grid .gutter {
  width: 8%;
}
.zone.grillecards2.subtype2 .grid .brick {
  padding: 0;
  max-height: none;
  min-height: auto;
  height: auto;
  width: 28%;
}
.zone.grillecards2.subtype2 .grid .brick:before {
  display: none;
}
.zone.grillecards2.subtype2 .grid .brick .photo {
  position: relative;
  margin-bottom: 3rem;
  left: auto;
  top: auto;
  bottom: auto;
  transform: none;
  opacity: 1 !important;
}
.zone.grillecards2.subtype2 .grid .brick .photo:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 130%;
}
.zone.grillecards2.subtype2 .grid .brick .photo a.document-link,
.zone.grillecards2.subtype2 .grid .brick .photo img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.zone.grillecards2.subtype2 .grid .brick .text {
  position: relative;
  text-align: left;
  opacity: 1;
  left: auto;
  top: auto;
  bottom: auto;
  transform: none;
}
.zone.grillecards2.subtype2 .grid .brick .text em {
  color: #456b60;
  font-size: 1.8rem;
  letter-spacing: 2px;
}
.zone.grillecards2.subtype2 .grid .brick .text .titre {
  margin: 2rem 0;
  font-size: 3rem;
}
.zone.grillecards2.subtype3 .filters {
  display: none;
}
.zone.grillecards2.subtype3 .grid {
  overflow: visible;
}
.zone.grillecards2.subtype3 .grid .gutter {
  width: 8%;
}
.zone.grillecards2.subtype3 .grid .brick {
  padding: 0;
  max-height: none;
  min-height: auto;
  height: auto;
  width: 28%;
}
.zone.grillecards2.subtype3 .grid .brick:before {
  display: none;
}
.zone.grillecards2.subtype3 .grid .brick .photo {
  position: relative;
  left: auto;
  top: auto;
  bottom: auto;
  transform: none;
  opacity: 1 !important;
}
.zone.grillecards2.subtype3 .grid .brick .photo:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 130%;
}
.zone.grillecards2.subtype3 .grid .brick .photo img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.zone.grillecards2.subtype3 .grid .brick .text {
  position: relative;
  text-align: left;
  opacity: 1;
  left: auto;
  top: auto;
  bottom: auto;
  transform: none;
  display: none;
}
.zone.grillecards2.subtype3 .grid .brick .text em {
  color: #456b60;
  font-size: 1.8rem;
  letter-spacing: 2px;
}
.zone.grillecards2.subtype3 .grid .brick .text .titre {
  margin: 2rem 0;
  font-size: 3rem;
}
.zone.grillecards2.subtype1 .grid .brick .text {
  top: 46%;
}
.zone.grillecards2.subtype1 .price {
  font-size: 26px;
  font-family: "Butler";
  margin-top: 16px;
  color: #456b60;
}
.zone.grillecards2.subtype1 .button.more {
  display: block;
  margin: 2.5rem auto 0 auto;
  color: black;
}
.zone.grillecards2.subtype1 .addcart {
  margin: 2.5rem auto 0 auto;
}
@media all and (max-width: 1400px) {
  .zone.grillecards2 .grid .brick .image_zone .img:hover .hover .desc {
    font-size: 1.4rem;
  }
  .zone.grillecards2 .grid .brick .image_zone .img:hover .hover .desc p {
    line-height: 1.2;
  }
  .zone.grillecards2 .grid .brick .titre {
    font-size: 2.5rem;
  }
  .zone.grillecards2 .grid .brick .map {
    right: 0;
  }
  .zone.grillecards2 .filters ul li a,
  .zone.grillecards2 .filters ul li button {
    font-size: 1.5rem;
  }
}
@media all and (max-width: 1200px) {
  .zone.grillecards2 .grid .brick {
    width: 48%;
  }
  .zone.grillecards2 .filters {
    width: 90%;
  }
  .zone.grillecards2 .button {
    color: #000000;
  }
  .zone.grillecards2 .filters ul li a,
  .zone.grillecards2 .filters ul li button {
    font-size: 1.5rem;
    padding: 0 1rem;
    min-width: 200px;
  }
}
@media all and (max-width: 1000px) {
  .zone.grillecards2 .cfluid {
    width: 90%;
  }
  .zone.grillecards2 .grid .brick {
    width: 48%;
  }
  .zone.grillecards2 .grid .brick .map {
    height: calc(80% - 70px);
  }
  .zone.grillecards2 .grid .brick .wrap .panbottom {
    font-size: 1.6rem;
  }
  .zone.grillecards2 .grid .brick .wrap .panbottom .price {
    font-size: 2rem;
  }
  .zone.grillecards2 .grid .gutter {
    width: 4%;
  }
  .zone.grillecards2.subtype2 .grid .gutter,
  .zone.grillecards2.subtype3 .grid .gutter {
    width: 4%;
  }
  .zone.grillecards2.subtype2 .grid .brick,
  .zone.grillecards2.subtype3 .grid .brick {
    width: 48%;
  }
  .zone.grillecards2 .filters ul li a,
  .zone.grillecards2 .filters ul li button {
    font-size: 1.5rem;
    padding: 0 0.5rem;
  }
  .zone.grillecards2 .filters ul {
    height: auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .zone.grillecards2 .filters ul li {
    width: auto;
    margin: 0 1rem;
    margin-bottom: 1.5rem;
  }
  .zone.grillecards2 .filters .cfluid {
    width: 100%;
  }
}
@media all and (max-width: 800px) {
  .zone.grillecards2 .grid .brick {
    width: 100%;
  }
  .zone.grillecards2 .grid .brick .map {
    height: calc(90% - 70px);
  }
  .zone.grillecards2 .grid .brick .text {
    position: relative;
    transform: none;
    opacity: 1;
    left: 50%;
    top: 50%;
    transform: translate(-50%);
  }
  .zone.grillecards2 .grid .brick .swiper-container {
    position: relative;
    margin-bottom: 20px;
    left: 0;
    transform: none;
  }
  .zone.grillecards2 .grid .gutter {
    width: 0%;
  }
  .zone.grillecards2 .filters ul li a,
  .zone.grillecards2 .filters ul li button {
    font-size: 1.5rem;
    padding: 0 2.5rem;
    height: 45px;
    min-width: 0;
  }
  .zone.grillecards2 .filters {
    margin-bottom: 3rem;
  }
  .zone.grillecards2 .filters ul {
    margin: 1rem 0;
    height: auto;
    flex-wrap: wrap;
  }
  .zone.grillecards2 .filters .cfluid {
    width: 100%;
  }
  .zone.grillecards2.subtype1 .grid .brick {
    height: auto;
    max-height: unset;
    display: flex;
    text-align: center;
    flex-direction: column;
    align-items: center;
    padding: 0rem;
    padding-bottom: 40px;
  }
  .zone.grillecards2.subtype1 .grid .brick:before {
    top: 15rem;
    left: 0rem;
    right: 0rem;
    width: unset;
  }
  .zone.grillecards2.subtype1 .grid .brick .photo {
    position: relative;
    left: auto;
    transform: none;
    margin-bottom: 0rem;
    height: 350px;
    bottom: auto;
  }
  .zone.grillecards2.subtype2 .grid .gutter,
  .zone.grillecards2.subtype3 .grid .gutter {
    width: 0%;
  }
  .zone.grillecards2.subtype2 .grid .brick,
  .zone.grillecards2.subtype3 .grid .brick {
    width: 100%;
    margin-bottom: 4rem;
  }
  .zone.grillecards2.subtype2 .grid .brick .photo:before,
  .zone.grillecards2.subtype3 .grid .brick .photo:before {
    padding-top: 70%;
  }
  .zone.grillecards2.subtype2 .grid .brick .images .text,
  .zone.grillecards2.subtype3 .grid .brick .images .text {
    position: relative;
    width: 100%;
    left: auto;
    top: auto;
    transform: none;
  }
  .zone.grillecards2.subtype2 .grid .brick .images .text .title,
  .zone.grillecards2.subtype3 .grid .brick .images .text .title {
    margin-top: 1rem;
  }
  .zone.grillecards2.subtype2 .grid .brick,
  .zone.grillecards2.subtype3 .grid .brick {
    margin-bottom: 4rem;
  }
  .pagetype_blog .zone.grillecards2 .grid .brick .wrap {
    width: 100%;
    height: auto;
    min-height: 0px;
  }
  .pagetype_blog .zone.grillecards2 .grid .brick .wrap .pantop {
    height: 100%;
    padding: 2rem 2rem;
    min-height: 200px;
  }
  .pagetype_blog .zone.grillecards2 .grid .brick .wrap .panbottom {
    height: auto;
    padding: 2rem;
  }
}
@media all and (max-width: 600px) {
  .zone.grillecards2 .filters ul li a,
  .zone.grillecards2 .filters ul li button {
    padding: 0rem 1.5rem;
    font-size: 1.25rem;
    margin: 0rem;
    border: 1px solid !important;
  }
  .zone.grillecards2 .filters {
    width: 100%;
  }
  .zone.grillecards2 .filters ul li {
    width: auto;
    margin: 0 0.5rem;
    margin-bottom: 1rem;
  }
  .zone.grillecards2 .grid .brick .map {
    height: calc(75% - 70px);
  }
  .zone.grillecards2 .grid .brick .titre {
    font-size: 2rem;
  }
  .zone.grillecards2 .grid .brick .wrap .panbottom,
  .zone.grillecards2 .grid .brick .wrap .pantop {
    padding: 1rem 2rem;
  }
  .zone.grillecards2.subtype2 .grid .brick .images,
  .zone.grillecards2.subtype3 .grid .brick .images {
    padding: 0;
  }
  .zone.grillecards2.subtype2 .grid .brick .images .text,
  .zone.grillecards2.subtype3 .grid .brick .images .text {
    position: relative;
    width: 100%;
    left: auto;
    top: auto;
    transform: none;
  }
  .zone.grillecards2.subtype2 .grid .brick .images .text .title,
  .zone.grillecards2.subtype3 .grid .brick .images .text .title {
    font-size: 2.8rem;
    margin-top: 1rem;
  }
}
@media all and (max-width: 450px) {
  .zone.grillecards2 .grid .brick .bigwrap {
    flex-wrap: wrap;
  }
  .zone.grillecards2 .grid .brick .bigwrap .wrap {
    width: 100%;
    order: 2;
  }
  .zone.grillecards2 .grid .brick .bigwrap .wrap .pantop {
    border-top: 1px solid rgba(255, 255, 255, 0.5);
    height: 75px;
  }
  .zone.grillecards2 .grid .brick .bigwrap .wrap .panbottom {
    align-items: center;
    height: 75px;
  }
  .zone.grillecards2 .grid .brick .bigwrap .map {
    width: 100%;
    height: 50vh;
    min-height: 400px;
  }
  .zone.grillecards2 .grid .brick .bigwrap .map img {
    height: 100%;
    object-fit: contain;
  }
  .pagetype_blog .zone.grillecards2 .grid .brick .bigwrap {
    flex-wrap: wrap;
  }
  .pagetype_blog .zone.grillecards2 .grid .brick .bigwrap .wrap {
    width: 100%;
    order: 2;
  }
  .pagetype_blog .zone.grillecards2 .grid .brick .bigwrap .wrap .pantop,
  .pagetype_blog .zone.grillecards2 .grid .brick .bigwrap .wrap .panbottom {
    height: 50%;
  }
}
@media all and (min-width: 1200px) {
  .zone.grillecards2 .grid .brick:hover .swiper-container {
    opacity: 0.05;
    transform: translateX(-52%);
    transition: all 0.3s ease-out;
    pointer-events: none;
    z-index: -1;
  }
  .zone.grillecards2 .grid .brick:hover .text {
    opacity: 1;
    transform: translate(-50%, -50%);
    transition: all 0.3s ease-out;
  }
}
.zone.slider_multiple {
  text-align: center;
}
.zone.slider_multiple .fond {
  position: absolute;
  top: 0rem;
  left: 10%;
  background-repeat: repeat;
  width: 100%;
  height: 100%;
}
.zone.slider_multiple .cs-swiper-controls {
  position: relative;
  display: flex;
  margin: 25px auto 0;
  justify-content: center;
}
.zone.slider_multiple .cs-swiper-controls::after {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  content: '';
  display: block;
  width: 1px;
  background-color: white;
  height: 100%;
}
.zone.slider_multiple .cs-swiper-controls .cs-swiper-button-prev,
.zone.slider_multiple .cs-swiper-controls .cs-swiper-button-next {
  background-color: #456b60;
  color: white;
  width: 32px;
  height: 32px;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}
.zone.slider_multiple .text {
  width: 50%;
  margin: 0 auto;
  margin-top: 25px;
  text-align: center !important;
}
.zone.slider_multiple .text .desc {
  text-align: justify;
  text-align-last: center;
}
.zone.slider_multiple .text .links-container {
  justify-content: center;
}
.zone.slider_multiple .text .swiper-text .swiper-slide {
  transform: scale(0.5);
  transition: 750ms opacity ease-out 0ms, 750ms transform ease-out 0ms;
  opacity: 0;
}
.zone.slider_multiple .text .swiper-text .swiper-slide.swiper-slide-active {
  transform: none;
  opacity: 1;
}
.zone.slider_multiple > .titre-container {
  width: 50%;
}
.zone.slider_multiple .rub {
  margin-left: auto;
  margin-right: auto;
}
.zone.slider_multiple .slider {
  margin-top: 50px;
}
.zone.slider_multiple .slider .swiper-container {
  width: 100%;
}
.zone.slider_multiple .slider .swiper-container .swiper-slide {
  position: relative;
  display: flex;
  flex-direction: column;
}
.zone.slider_multiple .slider .swiper-container .swiper-slide .photo {
  position: relative;
  width: 100%;
  margin-bottom: 12px;
}
.zone.slider_multiple .slider .swiper-container .swiper-slide .photo::after {
  content: '';
  display: block;
  padding-top: 100%;
}
.zone.slider_multiple .slider .swiper-container .swiper-slide .photo img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.1);
  transition: transform 1000ms ease-out;
}
.zone.slider_multiple .slider .swiper-container .swiper-slide .name {
  font-size: 2rem;
  font-family: 'Butler';
  letter-spacing: 1px;
  font-style: italic;
}
.zone.slider_multiple .slider .swiper-container .swiper-slide.swiper-slide-active .photo img {
  transform: none;
}
.zone.slider_multiple .photos-container {
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 50px;
  margin-top: 50px;
  margin-bottom: 25px;
}
.zone.slider_multiple .photos-container .photo {
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  position: relative;
}
.zone.slider_multiple .photos-container .photo::after {
  content: '';
  display: block;
  padding-top: 100%;
}
.zone.slider_multiple .photos-container .photo > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 500ms filter ease-out, 750ms transform ease-out;
}
.zone.slider_multiple .photos-container .photo .titre-container {
  position: absolute;
  opacity: 0;
  transform: scale(1.1);
  transition: 500ms opacity ease-out, 750ms transform ease-out;
  filter: invert(1);
  margin-bottom: 0 !important;
}
.zone.slider_multiple .photos-container .photo .titre-container .titre {
  color: black;
}
.zone.slider_multiple .photos-container .photo:hover > img {
  filter: brightness(0.8);
  transform: scale(1.1);
}
.zone.slider_multiple .photos-container .photo:hover .titre-container {
  transform: none;
  opacity: 1;
}
.zone.slider_multiple .element {
  display: flex;
  flex-direction: column;
}
.zone.slider_multiple .element .sstitre {
  margin-bottom: 0;
}
.zone.slider_multiple .element .background {
  width: 100%;
  height: 700px;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  background-attachment: fixed;
  margin-bottom: 25px;
}
.zone.slider_multiple .element:not(:last-of-type) {
  margin-bottom: 100px;
}
.zone.slider_multiple .element .desc {
  text-align: justify;
  text-align-last: center;
}
.zone.slider_multiple .swiper-slide-shop {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.zone.slider_multiple .swiper-slide-shop .alert,
.zone.slider_multiple .swiper-slide-shop .addcart {
  margin-top: 15px;
  opacity: 1 !important;
  padding: 15px 25px;
  transition: 500ms all ease-in-out;
}
.zone.slider_multiple .swiper-slide-shop .title-wrapper {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
}
.zone.slider_multiple .swiper-slide-shop .title-wrapper .date {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #456b60;
  color: white;
  padding: 8px;
  font-family: 'Butler';
  width: 80px;
  height: 80px;
  min-width: 80px;
}
.zone.slider_multiple .swiper-slide-shop .title-wrapper .date .day {
  font-size: 23px;
  line-height: 23px;
}
.zone.slider_multiple .swiper-slide-shop .title-wrapper .name {
  padding: 8px;
  flex: 1;
}
@media all and (max-width: 1600px) {
  .zone.slider_multiple .slider .swiper-container .swiper-slide .wrap .text {
    padding: 4rem;
  }
}
@media all and (max-width: 1400px) {
  .zone.slider_multiple .slider .swiper-container .swiper-slide .wrap .text {
    padding: 3rem;
  }
  .zone.slider_multiple .slider .swiper-container .swiper-slide .wrap .photo:before {
    padding-top: 80%;
  }
  .zone.slider_multiple {
    padding-left: 0%;
  }
}
@media all and (max-width: 1200px) {
  .zone.slider_multiple .swiper-slide-active .name {
    font-size: 3rem;
  }
  .zone.slider_multiple {
    padding-left: 5%;
    padding-right: 5%;
  }
  .zone.slider_multiple .slider .swiper-container .swiper-slide {
    height: 65vh;
  }
  .zone.slider_multiple .slider .swiper-container .swiper-slide .fotoback {
    top: 50%;
    left: 5rem;
    transform: translateY(-50%);
    height: 80%;
  }
}
@media all and (max-width: 1000px) {
  .zone.slider_multiple {
    padding-left: 0;
    padding-right: 0;
  }
  .zone.slider_multiple .text {
    width: 75%;
  }
  .zone.slider_multiple.subtype2 .slider .swiper-container .swiper-slide .fotoback {
    left: 0;
  }
  .zone.slider_multiple.subtype2 .slider .swiper-container .swiper-slide .wrap .photo {
    width: 70%;
    right: 0rem;
  }
  .zone.slider_multiple.subtype2 .slider .swiper-container .swiper-slide .wrap .photo::before {
    padding-top: 70%;
  }
  .zone.slider_multiple.subtype2 .slider .swiper-container .swiper-slide .wrap .text {
    width: 60%;
    margin-left: 0;
  }
  .zone.slider_multiple .slider {
    margin-top: 50px;
  }
  .zone.slider_multiple .slider .swiper-container .swiper-slide {
    height: auto !important;
  }
  .zone.slider_multiple .slider .swiper-container .swiper-slide .photo {
    height: auto !important;
    position: relative;
    max-height: 400px;
  }
  .zone.slider_multiple .slider .swiper-container .swiper-slide .photo img {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
  }
}
@media all and (max-width: 800px) {
  .zone.slider_multiple {
    padding-left: 5%;
    padding-right: 5%;
    text-align: center;
  }
  .zone.slider_multiple .slider {
    width: 100%;
    margin-right: 0;
  }
}
@media all and (max-width: 600px) {
  .zone.slider_multiple {
    padding-left: 0%;
    padding-right: 0%;
  }
  .zone.slider_multiple.presentation .rub.titre-container {
    width: calc(100% - 50px);
    margin-bottom: 25px;
  }
  .zone.slider_multiple.presentation .rub.titre-container .sstitre {
    width: 100%;
  }
  .zone.slider_multiple .element .background {
    background-attachment: unset;
    margin-bottom: unset;
  }
  .zone.slider_multiple .element:not(:last-of-type) {
    margin-bottom: 50px;
  }
  .zone.slider_multiple .sstitre {
    margin-top: 0;
    text-align: left;
    width: calc(100% - 50px);
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }
  .zone.slider_multiple .text {
    width: calc(100% - 50px);
    margin-left: auto;
    margin-right: auto;
    text-align: justify !important;
  }
  .zone.slider_multiple .rub.titre-container {
    margin: 0 auto;
    width: calc(100% - 50px);
  }
  .zone.slider_multiple .slider {
    margin-top: 25px;
  }
  .zone.slider_multiple .slider .swiper-container .swiper-slide .wrap {
    flex-wrap: wrap;
    align-items: flex-start;
    height: auto !important;
  }
  .zone.slider_multiple .slider .swiper-container .swiper-slide .wrap .photo {
    width: 100% !important;
    position: relative;
    left: 0;
  }
  .zone.slider_multiple .slider .swiper-container .swiper-slide .wrap .text {
    width: 100% !important;
  }
  .zone.slider_multiple .photos-container {
    margin-top: 25px;
    width: calc(100% - 50px);
    margin-left: auto;
    margin-right: auto;
    grid-template-columns: repeat(1, 1fr);
    gap: 25px;
  }
  .zone.slider_multiple .photos-container .photo .titre-container .titre {
    font-size: 24px;
    letter-spacing: 0px;
  }
  .zone.slider_multiple .swiper-slide-shop .title-wrapper .date {
    width: 60px;
    height: 60px;
    min-width: 60px;
  }
  .zone.slider_multiple .swiper-slide-shop .title-wrapper {
    min-height: 80px !important;
  }
  .zone.slider_multiple .swiper-slide-shop .title-wrapper .date .day {
    font-size: 19px;
    line-height: 19px;
  }
  .zone.slider_multiple .swiper-slide-shop:not(.swiper-slide-active) .addcart,
  .zone.slider_multiple .swiper-slide-shop:not(.swiper-slide-active) .alert {
    opacity: 0 !important;
  }
}
@media screen and (max-width: 450px) {
  .zone.slider_multiple .slider .swiper-container .swiper-slide .name {
    font-size: 1.5rem;
  }
}
@media screen and (min-width: 1400px) {
  .zone.slider_multiple .slider .swiper-container .swiper-slide .name {
    padding: 8px 16px;
  }
}
.zone.listing_gift {
  padding: 80px 40px !important;
  width: 100%;
  max-width: 1600px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  padding-top: 0 !important;
}
.zone.listing_gift .list-container {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 80px;
}
.zone.listing_gift .list-item {
  display: flex;
  flex-direction: column;
  position: relative;
}
.zone.listing_gift .list-item.no-stock .media > *:not(.alert),
.zone.listing_gift .list-item.no-stock .title-wrapper > *:not(.alert),
.zone.listing_gift .list-item.no-stock .content .text > *:not(.alert) {
  opacity: 0.5;
}
.zone.listing_gift .list-item.no-stock .alert {
  margin-top: 15px;
  width: 100%;
  opacity: 1 !important;
}
.zone.listing_gift .list-item:hover .media img {
  transform: scale(1.1);
}
.zone.listing_gift .list-item:hover .media .title {
  transition: 250ms transform ease-out 250ms;
  transform: none;
}
.zone.listing_gift .list-item .absolute-link {
  z-index: 1000;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.zone.listing_gift .list-item .media {
  width: 100%;
  max-height: 50vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.zone.listing_gift .list-item .media::after {
  content: '';
  display: block;
  padding-top: 100%;
}
.zone.listing_gift .list-item .media img {
  transition: 250ms filter ease-out, 500ms transform ease-out;
}
.zone.listing_gift .list-item .media .title {
  position: absolute;
  color: #f3f1ed;
  transform: scale(0);
  transition: 250ms transform ease-out;
  display: flex;
  align-items: center;
  justify-content: center;
}
.zone.listing_gift .list-item .content {
  display: flex;
  flex-direction: column;
}
.zone.listing_gift .list-item .content .title-wrapper {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
}
.zone.listing_gift .list-item .content .title-wrapper .date {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #456b60;
  color: white;
  padding: 8px;
  font-family: 'Butler';
  width: 100px;
  height: 100px;
  min-width: 100px;
}
.zone.listing_gift .list-item .content .title-wrapper .date .day {
  font-size: 25px;
  line-height: 25px;
}
.zone.listing_gift .list-item .content .title-wrapper .title {
  text-transform: none;
  text-align: left;
  flex: 1;
  padding: 8px;
  color: #456b60;
  font-size: 2rem;
  letter-spacing: 1px;
}
.zone.listing_gift .list-item .content .text {
  display: flex;
  flex-direction: column;
}
.zone.listing_gift .list-item .content .text .description {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  line-clamp: 4;
  -webkit-box-orient: vertical;
  height: 8rem;
  max-height: 8rem;
  margin-bottom: 12px;
}
.zone.listing_gift .list-item .content .text a.alert-buy {
  display: flex;
  font-style: italic;
  align-items: center;
}
.zone.listing_gift .list-item .content .text a.alert-buy:hover span {
  transform: translateX(4px);
}
.zone.listing_gift .list-item .content .text a.alert-buy span {
  transition: 250ms transform ease-out;
}
.zone.listing_gift .list-item .content .text a.alert-buy i {
  margin-right: 8px;
}
.zone.listing_gift .list-item .content .text a.addcart {
  margin-top: 15px;
  margin-left: 0;
  margin-right: auto;
  z-index: 1001;
}
.zone.listing_gift .pagination {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 25px;
}
.zone.listing_gift .pagination .pagination-item {
  padding: 8px;
  font-family: 'Josefin Sans';
  opacity: 0.25;
  transition: 500ms color ease-out, 250ms opacity ease-out, 500ms background ease-out;
  cursor: pointer;
}
.zone.listing_gift .pagination .pagination-item:hover {
  opacity: 1;
}
.zone.listing_gift .pagination .pagination-item.active {
  opacity: 1;
  color: #456b60;
  background: #f3f1ed;
}
@media screen and (min-width: 600px) {
  .zone.listing_gift {
    padding: 80px 60px !important;
  }
  .zone.listing_gift .list-item .content .title-wrapper {
    margin-bottom: 25px;
  }
}
@media screen and (min-width: 768px) {
  .zone.listing_gift .list-item .content .title-wrapper .title {
    padding: 12px;
  }
  .zone.listing_gift .list-container {
    grid-template-columns: repeat(2, 1fr);
  }
  .zone.listing_gift .pagination {
    margin-top: 50px;
  }
  .zone.listing_gift .pagination .pagination-item {
    padding: 12px;
  }
}
@media screen and (min-width: 1024px) {
  .zone.listing_gift {
    padding: 50px !important;
  }
  .zone.listing_gift .list-container {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (min-width: 1200px) {
  .zone.listing_gift .list-item .content .text .description {
    height: 9rem;
    max-height: 9rem;
  }
  .zone.listing_gift {
    padding: 100px !important;
  }
  .zone.listing_gift .list-item .content .title-wrapper .date {
    margin-top: -25px;
    z-index: 2;
  }
}
@media screen and (min-width: 1600px) {
  .zone.listing_gift .list-container {
    gap: 100px;
  }
  .zone.listing_gift .list-item .content .title-wrapper .date .day {
    font-size: 30px;
    line-height: 30px;
  }
}
@media all and (max-width: 1442px) {
  body {
    font: 1.4rem/1.42 'Montserrat', sans-serif;
  }
}
@media all and (max-width: 1200px) {
  body {
    font: 1.35rem/1.42 'Montserrat', sans-serif;
  }
  .aside {
    display: none;
  }
}
@media all and (max-width: 1000px) {
  body {
    font: 1.4rem/1.42 'Montserrat', sans-serif;
  }
}
@media all and (max-width: 800px) {
  ::-webkit-scrollbar {
    width: 0 !important;
  }
  a.anchor {
    top: -100px;
  }
  .zones {
    margin-top: 0;
  }
  .loading .wiper {
    display: none;
  }
}
@media all and (max-width: 600px) {
  body {
    font-size: 14px;
  }
}
@media all and (max-width: 450px) {
  a.anchor {
    top: -80px;
  }
}
.top-cart {
  margin-top: 150px;
  font-family: 'Butler';
  font-size: 2rem;
}
.top-cart .title {
  text-transform: none;
  font-size: 2.8rem;
}
.top-cart + .desc {
  text-align: center;
}
.alert {
  max-width: 1000px;
  margin: 0 auto;
}
.alert.alert-success {
  color: #155724;
  background-color: #d4edda;
  border-color: #c3e6cb;
}
.alert.alert-error {
  color: #721c24;
  background-color: #f8d7da;
  border-color: #f5c6cb;
}
.bg .content .product-cart .title {
  font-family: 'Butler';
  font-size: 2rem;
  color: #456b60;
  font-style: italic;
  text-transform: initial;
  margin-bottom: 0;
  text-align: center;
}
.bg .content .product-cart .price {
  font-family: 'Butler';
  font-weight: 400;
  font-size: 2rem;
}
.bg .content .product-cart .desc {
  text-align: center;
  width: 100%;
  border-top: 1px solid rgba(133, 133, 133, 0.2);
  padding-top: 15px;
  margin-top: 15px;
}
.cart-content .cart-details .items form table thead,
.cart-content .cart-details .items form table tbody tr {
  border-bottom: 1px solid rgba(133, 133, 133, 0.2);
}
.bg .content .product-cart form .form-group {
  width: 50%;
  max-width: max-content;
  max-width: fit-content;
  margin-right: 10px;
}
.bg .content .product-cart form .input input {
  margin: 0;
  max-width: 42px;
}
.bg .content .close {
  border: none;
}
.cart-content .cart-details .items form table tbody tr td.remove button,
.cart-content .cart-details .items form table tbody tr td.qty .input button,
.bg .content .product-cart form .input button {
  background: #456b60;
  color: white;
  border: none;
  border-radius: 0;
  cursor: pointer;
}
.cart-content .cart-details .items form table tbody tr td.remove button::after,
.cart-content .cart-details .items form table tbody tr td.qty .input button::after,
.bg .content .product-cart form .input button::after {
  color: #456b60;
  font-weight: bold;
  font-size: 16px;
}
.cart-content .cart-details .items form table tbody tr td.remove button::after,
.cart-content .cart-details .items form table tbody tr td.qty .input button::after,
.bg .content .product-cart form .input button::after {
  color: white;
}
.cart-content .cart-details .items form table tbody tr td.remove button {
  color: white;
}
.form-details .table {
  border: transparent;
  padding: 25px 0;
}
.form-details .table table thead,
.form-details .table table tbody tr {
  font-size: 1.5rem;
}
.form-details .recap {
  margin-top: 0;
  width: max-content;
  max-width: 100%;
}
.form-details .recap .hidden {
  display: none;
}
.cart-content .cart-details .recap > a {
  background: #456b60;
  font-size: 2rem;
  letter-spacing: 0;
  font-weight: 400;
  margin-top: 25px;
  font-size: 16px;
  text-transform: none;
  font-style: italic;
}
.cart-content .cart-details .items form table tbody tr td.qty .input input,
.bg .content .product-cart form .input input {
  border: 1px solid #456b60;
  margin: 0;
  max-width: 42px;
}
.cart-content .cart-details .items {
  border: transparent;
  padding: 25px 0;
}
.cart-content .cart-details .items form table thead th {
  font-family: 'Montserrat';
  font-size: 1.5rem;
}
.form-details .form .title {
  font-family: 'Butler';
  font-weight: 400;
  text-transform: none;
  font-size: 2.8rem;
  text-align: center;
}
.form-details .recap > div span {
  color: #456b60;
  font-weight: bold;
}
.form-details .form .form-group.submit {
  width: 100%;
  flex: auto;
  display: flex;
}
.form-details .form .form-group.submit button {
  margin-left: auto;
}
.form-details .form .form-group input {
  border-radius: 0;
}
.form-details .form .form-group.submit button {
  background: #456b60;
  color: white;
  border: none;
  cursor: pointer;
  border-radius: 0;
  font-family: 'Butler';
  font-weight: 400;
  font-size: 16px;
  text-transform: none;
  font-style: italic;
}
.bg .content .product-cart form a {
  z-index: 2;
  font-style: italic;
  font-size: 16.5px;
  font-family: 'Butler';
  font-weight: 400;
  background: #456b60;
  min-width: 100%;
  border-radius: 0 !important;
  transition: 500ms color ease-out 250ms;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #456b60;
}
.bg .content .product-cart form a:before {
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  line-height: 1;
  font-family: 'Font Awesome 5 Pro';
  content: '\f218';
  font-size: 20px;
  margin-right: 8px;
}
.bg .content .product-cart form a::after {
  display: block;
  content: '';
  background: white;
  transform: scaleX(0);
  transform-origin: left;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: 500ms transform ease-out;
  z-index: -1;
}
.bg .content .product-cart form a:hover {
  background: #456b60;
  color: #456b60;
}
.bg .content .product-cart form a:hover::after {
  transform: none;
}
.bg .content {
  width: 100%;
  max-width: 600px;
}
.bg .content .product-cart form {
  padding-top: 25px;
  margin-top: 25px;
}
.bg .content .product-cart form .form-group label {
  font-family: 'Montserrat';
  font-size: 16px;
  margin-bottom: 4px;
}
.bg .content .product-cart form button#add_to_cart_add {
  margin-top: 27px;
  background: transparent;
  border: none;
  color: black;
  font-family: 'Butler';
  font-size: 14px;
  font-weight: 400;
  font-style: italic;
  border: 1px solid rgba(133, 133, 133, 0.2);
  border-radius: 0 !important;
  cursor: pointer;
  padding: 9px 15px;
}
.bg .content .product-cart form button#add_to_cart_add:hover {
  color: #456b60;
  border-color: #456b60;
  background: transparent;
}
.redirect-shipping {
  max-width: fit-content;
  max-width: max-content;
  margin: 25px auto;
  display: block;
}
.cart-message {
  width: 100%;
  padding: 15px;
  text-align: center;
}
.cart-content .cart-details .recap {
  width: max-content;
  max-width: 100%;
}
.cart-content .hidden {
  display: none;
}
.cant-process-payment strong:after {
  display: none;
}
#process-payment.disabled {
  pointer-events: none;
  cursor: not-allowed;
  background: lightgrey;
}
.form-details .form .form-group textarea {
  display: block;
  width: 100%;
  padding: 10px 15px;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #212529;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid #ced4da;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0.25rem;
  height: 45px;
  font-size: 12px;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  border-radius: 0;
  resize: vertical;
  min-height: 80px;
  padding-left: 12px;
}
.form-details .form .form-group textarea:focus,
.form-details .form .form-group textarea:not(:placeholder-shown) {
  padding-top: 20px;
  padding-bottom: 10px;
  padding-left: 12px;
}
.form-details .form .form-group.submit {
  width: 100% !important;
  flex: 1 1 100% !important;
}
@media screen and (min-width: 1024px) {
  .form-details .form .list .form-group.message {
    padding: 0 5px;
  }
  .form-details .form .list .form-group label {
    padding-left: 20px !important
    ;
  }
}
.form-details .shop-mobile-only {
  display: none;
}
@media screen and (max-width: 600px) {
  .top-cart {
    margin-top: 100px;
    padding-bottom: 0;
  }
  .cart-content {
    padding-bottom: 100px;
  }
  .cart-content .cart-message {
    padding: 0 !important;
  }
  .cart-content .cart-details .items form table tbody tr td.qty .input button {
    width: 32px !important;
    height: 32px !important;
    padding: 0;
  }
  .form-details table,
  .cart-content .cart-details .items form table {
    display: flex;
    flex-direction: column;
  }
  .form-details table thead,
  .cart-content .cart-details .items form table thead {
    display: none;
  }
  .form-details table tbody,
  .cart-content .cart-details .items form table tbody {
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .form-details table tbody tr,
  .cart-content .cart-details .items form table tbody tr {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 2px 8px;
    border: 1px solid rgba(133, 133, 133, 0.2);
    padding: 10px 0;
    position: relative;
  }
  .form-details table tbody tr td.price,
  .cart-content .cart-details .items form table tbody tr td.price {
    order: 2;
    text-align: center;
  }
  .form-details table tbody tr td.name,
  .cart-content .cart-details .items form table tbody tr td.name {
    order: 1;
    width: 100%;
    text-align: center;
    font-weight: 600;
    max-width: 270px;
    margin-bottom: 10px;
  }
  .form-details table tbody tr td.qty,
  .cart-content .cart-details .items form table tbody tr td.qty {
    order: 3;
  }
  .form-details table tbody tr td.remove,
  .cart-content .cart-details .items form table tbody tr td.remove {
    order: 4;
    position: absolute;
    top: 0;
    right: 0;
  }
  .form-details table tbody tr td.remove button,
  .cart-content .cart-details .items form table tbody tr td.remove button {
    width: 26px !important;
    height: 26px !important;
  }
  .form-details .table {
    padding-top: 0 !important;
  }
  .form-details .shop-mobile-only {
    display: block;
  }
  .form-details table .name {
    max-width: unset !important;
    text-align: center !important;
    margin: 0 !important;
  }
  .form-details table .price_total {
    order: 4;
  }
  .form-details table .price {
    width: unset !important;
  }
  .cart-content .cart-details .items form table tbody tr td.price {
    font-size: 14px;
  }
}
.shop-access-mobile {
  position: fixed;
  bottom: 0;
  width: 100vw;
  height: 32px;
  background-color: #456b60;
  color: white;
  display: flex;
  gap: 10px;
  align-items: center;
  height: 50px;
  font-size: 16px;
  justify-content: center;
  z-index: 999;
  box-shadow: -2px 0 10px rgba(0, 0, 0, 0.125);
}
.shop-access-mobile i {
  font-size: 20px;
}
@media screen and (min-width: 1024px) {
  .shop-access-mobile {
    display: none;
  }
}
