/* CSS */

/* GÉNÉRAL */

html,
body {
  height: 100%;
}

body {
  font-family: 'Epilogue', sans-serif;
  font-size: 16px;
  line-height: 32px;
  font-weight: 300;
}

p {
  margin-bottom: 0rem;
  color: #2F2F2F;
}

a {
  color: #000556;
}

a:hover {
  color: #010440;
  text-underline-position: under;
}

.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
  color: #000556;
  font-weight: 700;
}

.h1,
h1 {
  font-size: 45px;
}

.h2,
h2 {
  font-size: 36px;
}

.h3,
h3 {
  font-size: 26px;
}

.h4,
h4 {
  font-size: 24px;
}

.h5,
h5 {
  font-size: 20px;
  line-height: 35px;
  font-weight: 300;
}

.h6,
h6 {
  font-size: 18px;
  line-height: 34px;
  font-weight: 300;
}

b,
strong {
  font-weight: 700;
}

.bg_blue {
  background-color: #000556;
  color: #FFFFFF;
}

.bg_red {
  background-color: #D90B1C;
  color: #FFFFFF;
}

.bg_gris {
  background-color: #F7F7F7;
}

.bg_white {
  background-color: #FFFFFF;
}

.bg_black {
  background-color: #2F2F2F;
}

.bg_blue h2,
.bg_blue p {
  color: #FFFFFF;
}

.btn {
  display: inline-block;
  text-transform: uppercase;
  border-radius: 30px;
  text-align: left;
  padding: 8px 30px;
  font-size: 16px;
  font-weight: 300;
  min-height: 40px;
  line-height: 30px;
  transition: all ease .3s;
  position: relative;
  font-weight: 700;
  min-width: 200px;
  text-align: center;
}

.btn span {
  margin: auto;
}

.btn svg {
  margin-bottom: 2px;
  margin-left: 10px;
}

.btn .txt_small {
  text-transform: none;
}

.btn_red {
  background: #D90B1C;
  color: #FFFFFF;
}

.btn_red:hover {
  color: #FFFFFF;
  background: #EF0E20;
}

.btn_violet{
  background: #7a0185;
  color: #FFFFFF;
}
.txt_violet{
  color: #7a0185;
}

.btn_violet:hover{
  background: #8a098a;
  color: #FFFFFF;
}

.btn_green {
  background: #015756;
  color: #FFFFFF;
  border-color: #015756 !important;
}

.btn_blue {
  background: #000556;
  color: #FFFFFF;
  display: inline-block;
}

.btn_pink {
  background: #F87196;
  color: #FFFFFF;
}

.btn_pink:hover {
  background: #DE567B;
  color: #FFFFFF;
}

.btn_blue:hover {
  color: #FFFFFF;
  background: #D90B1C;
}

.bg_blue .btn_red:hover {
  background: #D90B1C;
}

.btn_gris {
  background: #F7F7F7;
  color: #000556;
}

.btn_gris:hover {
  background: #EFEFEF;
}

.btn_white:hover {
  color: #ffffff;
  background: #D90B1C;
}

.btn_border_red {
  border: solid 2px #D90B1C;
}

.btn_border_blue {
  border: solid 2px #000556;
  color: #000556;
}

.btn_white {
  background: #FFFFFF;
  color: #D90B1C;
  text-transform: uppercase;
}

.btn_large {
  min-width: 366px;
  text-align: center;
  display: inline-block;
}

.btn_arrow .icon_arrow {
  position: absolute;
  right: 10%;
  top: 15px;
}

.btn_arrow:hover:after {
  content: '';
  background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAAAXNSR0IArs4c6QAAADhlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAAqACAAQAAAABAAAAHqADAAQAAAABAAAAHgAAAADpiRU/AAADGklEQVRIDaVW223jMBCUZMCAAb86OJXgDk4dRB2cOrhcBdZ1kBLcQeQKolRgpYI4FUR+AP6wYd8MsRQomXr5CBBLLmdnlk/JdTqU2+02PxwOT4AGqD76vuu6tDlsBl+OdjocDtej0WiLfmtxmxCn08k/n89LYKImXGUsRTJ/J5NJWvGXurXCu90uBvI3SOZGxBozyzhL1Jz+6/UaoM3Zh7AzA7uC+B+NM/z2Jgjm+/3+FfXGigS2sJEdXfZiOwJgUyN2czweF2WUpUdRCG10IIhe6LNAG13geEbNyQP73SoOYCJgBkWN7C2DFDPEP2snAFBMUalWUQZj/KmWpJKMKY64t8qw4/D0ckkoyuW9A4gDGO43l2/TVRz4kDFSwxI3nCsOkLg0UOkAkwlBX/FE+D8LSlk+nVFUDFgagu0tzhXVCcOqWXtY2mL60+l0ZdErXLyTuJsBHB90or8A0Vvbsstr9i4xAa2Hqhqwa9TW8qg4kktIjgeHT68S9tnAQEbbpTwi7nme4kesTw0Pggs24OgsLPheyz4ejwt+7rkHQfW+chYk7FMYwz1H8jvGoc89j2wcJv/lcvG5x/9VeO9BqpJnAoPBILURYmyu/UyCwuq08SujB7pazG4F7C/iRTQwl5R+Xcz3mhgKqyVGFr4GdbF9RMmHxHyxalt4uFJxqGPOdlvpKyp8IS0mmNB6+F1RDTj4exPQ2VQeEeX+ov4U3rTgB1mKymfz/gtSoByHB0lwfKtzc98M2F0T2JhxjGESBKhTjdnGgg4w+CztO4OgBZ2wPL21B8kMZHLgX4qPNyA3xx1ktJKsav8Y5Psad50pZ4eJqD8a2G1JUHcIgnDWJq7xbbYi2rwtMqNci8OGbQK2ceEp/t3AE9lwJZ8EbSku9ZVvawlU0+EscQCXOpaHqU7UtXEIQYIxfQUIS+FP+JXBy/OhDwmvIPw/MB7CBvDPCUb7CwcwrHvJrMIMZEG2JONJJHGnAjxfppfZbBY3BTQK60AmAPEA7zntXRIUg58rlOJrlaCd69g620m4Gsw956eNAnVLWY2p9v8BHnL60TeQNh8AAAAASUVORK5CYII=);
  right: 5%;
  top: 13px;
  width: 20px;
  position: absolute;
  height: 20px;
  background-size: contain;
}

.txt_small {
  font-size: 12px;
  line-height: normal;
}

.txt_red,
.txt_red p,
.txt_red a {
  color: #D90B1C;
}

.txt_blue {
  color: #000556;
}

.txt_white {
  color: #FFFFFF;
}

img {
  max-width: 100%;
}

a i {
  line-height: 28px !important;
  margin-left: 10px;
}

.icon {
  /* Permet de redimensionner en changeant la font-size de l’icône */
  width: 1em;
  height: 1em;
  /* Bel alignement visuel des icônes avec le texte */
  vertical-align: -0.15em;
  /* fill par défaut = valeur de la propriété couleur de son élément parent */
  fill: currentColor;
  /* Les paths et les strokes qui dépassent de la viewBox peuvent apparaître dans IE.
     Si vous utilisez normalize.css, inutile de l’ajouter. */
  overflow: hidden;
}

.box_shadow {
  box-shadow: 1px 1px 8px rgba(0, 0, 0, 0.18);
  border-radius: 10px;
}

.link_red {
  color: #D90B1C;
  text-transform: uppercase;
  text-decoration: none;
  font-weight: 600;
}

.link_red:hover {
  color: #000556;
}

#index section {
  margin-top: 10px;
}

.logo_pass {
  position: absolute;
  height: 80px;
  width: 80px;
  top: -30px;
  left: -30px;
}

@media (max-width: 1200px) {
  .logo_pass {
    position: absolute;
    height: 70px;
    width: 70px;
    top: -15px;
    left: -30px;
    z-index: 1;
  }
}

/* BOOTSTRAP */

@media (min-width: 1200px) {

  .container,
  .container-lg,
  .container-md,
  .container-sm,
  .container-xl {
    max-width: 1640px;
  }
}

/* HEADER TOP */

.header_top {
  font-size: 12px;
  padding: 10px 0px;
  border-top: solid 5px #000556;
}

.header_top .header_top_right {
  text-align: right;
}

.header_top .account_box span {
  text-transform: uppercase;
  font-weight: 700;
  margin-right: 10px;
}

.dropdown {
  position: relative;
  display: inline-block;
}

.dropdown-content {
  display: none;
  position: absolute;
  min-width: 500px;
  z-index: 1;
  right: 1%;
  padding-top: 10px;
}

.dropdown:hover .dropdown-content {
  display: block;
}

.form_rappel {
  position: absolute;
  display: block;
  color: #000556;
  box-shadow: 5px 4px 10px rgba(189, 189, 189, 0.6);
}

.form_rappel:before {
  border-left: solid 10px transparent;
  border-right: solid 10px transparent;
  border-bottom: solid 10px #F7F7F7;
  content: "";
  position: absolute;
  top: -10px;
  right: 15%;
}

.date_choice {
  display: flex;
}

.date_choice select,
.date_choice input[type="time"] {
  width: 35%;
  margin-left: 15px;
}

.btn_phone {
  padding: 8px 25px;
  margin-right: 15px;
  display: inline-flex;
}

.btn_phone:hover {
  background: #F2F2F2 !important;
  color: #D90B1C !important;
}

.btn_phone:hover .icon {
  stroke: #D90B1C !important;
}

.btn_phone .phone_number {
  float: right;
  line-height: normal;
  margin: auto;
  font-size: 18px;
  font-weight: 700;
}

.btn_phone .txt_small {
  display: block;
  font-weight: 300;
}

.btn_phone .icon {
  font-size: 30px;
  line-height: 30px;
  margin-right: 10px;
  stroke: #FFFFFF;
}

.content {
  padding-top: 142px;
}

/* HEADER */

.dropdown-item.active,
.dropdown-item:active {
  color: initial;
  text-decoration: none;
  background-color: transparent;
  border: none;
  outline: none;
}

.navbar {
  background-color: #ffffff;
  border: 0px;
  padding: 0px;
  z-index: 10;
  box-shadow: 0px 2px 15px rgba(189, 189, 189, 0.6);
}

.navbar .navbar-nav>li>a {
  color: #000556;
  text-transform: uppercase;
  font-size: 16px;
  font-weight: 700;
  transition: all ease .3s;
}

.navbar .navbar-nav>li>a:before {
  position: absolute;
  -webkit-transition: all 0.35s ease;
  transition: all 0.35s ease;
  bottom: 0;
  display: block;
  height: 3px;
  width: 0%;
  content: "";
  background-color: #D90B1C;
  left: 0;
}

.navbar .navbar-nav>li>a:hover {
  color: #D90B1C;
}

.navbar .navbar-nav>li>a:hover:before,
.navbar .navbar-nav .current a:before {
  opacity: 1;
  width: 100%;
}

.navbar-brand {
  height: auto;
  margin: 0;
  padding: 0;
}

.nav-link {
  position: relative;
}

.navbar .line {
  height: 2px;
  position: absolute;
  bottom: 0px;
  margin: 10px 0 0 0;
  background: #D90B1C;
  width: 60%;
}

.navbar-brand>img {
  padding-top: 5px;
  padding-bottom: 5px;
  width: 200px;
  margin-right: 5px;
}

.dropdown-toggle::after {
  content: none;
}

.navbar-expand-sm .navbar-nav .nav-link {
  margin-right: 1rem;
  margin-left: 1rem;
  padding: 0;
}

.sticky {
  position: fixed;
  top: 0;
  width: 100%;
}

.navbar .navbar-nav>li.contact>a {
  color: #D90B1C;
  font-weight: 700;
}

.dropdown:hover .dropdown-menu {
  display: block;
}

.dropdown-menu {
  margin-top: 0;
  left: -100%;
  top: 100%;
  background: #F7F7F7;
  border: none;
  font-size: 16px;
  column-count: 2;
  min-width: 350px;
}

.dropdown-item {
  display: block;
  width: 100%;
  padding: 1rem 1.5rem;
  clear: both;
  font-weight: 300;
  color: #010440;
  text-align: inherit;
  white-space: nowrap;
  background-color: transparent;
  border: 0;
  border-bottom: solid 1px #D7D7D9;
}

.dropdown-item:nth-child(2n) {
  border-bottom: none;
}

/* SLIDER HOME */

#index {
  background-image: url(../../uploads/bg_slider.svg);
  background-size: 120%;
  background-repeat: no-repeat;
  background-position: bottom center;
  background-attachment: fixed;
  padding-top: 10%;
}

#liste_stages,
#stages,
#reservation,
#p404 {
  background-image: url(../../uploads/bg_slider.svg);
  background-size: 120%;
  background-repeat: no-repeat;
  background-position: bottom center;
  background-attachment: fixed;
  z-index: 0;
  position: relative;
}

.breadcrumb {
  background-image: url(../../uploads/bg_slider.svg);
  background-size: 120%;
  background-repeat: no-repeat;
  background-position: top left;
  background-attachment: fixed;
  background-color: #FFFFFF;
}

#slider_home h1,
#slider_home .intro {
  margin-bottom: 30px;
}

form {
  transition: all 0.5s;
}

.form_search {
  border: solid 3px #C9C9C9;
  border-radius: 60px;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);

}

.finder {
  border: 3px solid #F7F7F7;
  background-color: #FFFFFF;
  border-radius: 40px;
  padding: 5px;
}

.finder__outer {
  display: flex;
  width: 100%;
  padding: 0.3rem 1rem;
  border-radius: 40px;
  /* box-shadow: inset 10px 10px 15px -10px #c3c3c3,
    inset -10px -10px 15px -10px #ffffff; */
}

.finder__inner {
  display: flex;
  align-items: center;
  position: relative;
  flex: 1;
}

.finder__form {
  flex: 1;
}

.finder__input {
  border: none;
  background-color: transparent;
  outline: none;
  font-size: 1rem;
  line-height: 2rem;
}

.finder__icon {
  width: 55px;
  height: 55px;
  margin-right: 0rem;
  transition: all 0.2s;
  background: #D90B1C;
  border-radius: 50px;
  border: none;
  right: 21px;
  position: absolute;
  color: #FFFFFF;
  font-size: 25px;
  text-transform: uppercase;
  margin-top: -57px;
}

.finder__icon:hover {
  color: #FFFFFF;
  background: #000556;
}

#img_map {
  width: 500px;
  margin-bottom: 3rem;
}

/* REASSURANCE */

#reassurance {
  margin-top: 2% !important;
  box-shadow: 9px 9px 16px rgba(189, 189, 189, 0.6), -9px -9px 16px rgba(255, 255, 255, 0.5);
}

.icon_box {
  text-align: center;
  padding: 20px;
}

.icon_box img {
  width: 100px;
  height: 100px;
}

.icon_box h5 {
  margin-top: 20px;
  font-weight: 700;
}

/* INFOS UTILES */

.btn_infos {
  column-count: 2;
}

.btn_infos .btn {
  width: 100%;
  margin-bottom: 10px;
  text-transform: uppercase;
  text-align: center;
  display: block;
}

.img_fullheight img {
  height: 100%;
  object-fit: cover;
}

.owl-theme .owl-dots .owl-dot span {
  background: #D90B1C !important;
  opacity: .2;
}

.owl-theme .owl-dots .owl-dot.active span,
.owl-theme .owl-dots .owl-dot:hover span {
  opacity: 1;
  background: #D90B1C !important;
}

/* STAGES HOME */

.bloc_stage .date,
.bloc_stage .ville,
.bloc_stage .prix {
  text-transform: uppercase;
  font-weight: 700;
}

.bloc_stage .ville img {
  width: 20px !important;
  margin-right: 10px;
  display: inline !important;
}

.bloc_stage .adresse {
  font-size: 12px;
}

.bloc_stage .footer_box .btn {
  position: absolute;
  right: 15px;
  bottom: 15px;
}

.owl-prev,
.owl-next {
  position: absolute;
  bottom: 40%;
}

#carouselInfos img {
  width: 70%;
  margin: auto;
}

#carouselStages .owl-prev {
  left: -30px;
}

#carouselStages .owl-next {
  right: -30px;
}

#testimonial {
  background-image: url(../../uploads/bg_slider.svg);
  background-size: 120%;
  background-repeat: no-repeat;
  background-position: bottom center;
}

#carouselTesti.owl-carousel .owl-stage {
  display: flex;
}

#carouselTesti.owl-carousel .owl-item .item {
  width: auto;
  height: 100%;
}

#carouselTesti .item {
  opacity: 0.4;
  transition: .4s ease all;
  margin: 0 20px;
  transform: scale(.8);
}

.testimonial_item .content {
  padding: 0;
  width: 100%;
  height: 100%;
}

@media(max-width:1000px) {
  #carouselTesti .item {
    margin: 0;
    transform: scale(.9)
  }
}

#carouselTesti .active .item {
  opacity: 1;
  transform: scale(1);
}

#carouselTesti .owl-item {
  -webkit-backface-visibility: hidden;
  -webkit-transform: translateZ(0) scale(1.0, 1.0);
}

.item.testimonial_item {
  background: #FFFFFF;
  height: 100%;
  padding: 30px 80px;
  display: flex;
  align-items: center;
  text-align: center;
}

.testimonial_item .rates {
  font-size: 20px;
  color: #F9C4A2;
  margin-bottom: 20px;
}

.testimonial_item .rates i {
  margin: 0px 5px;
}

.testimonial_item .nom_testi {
  font-weight: 700;
  margin-top: 40px;
}

#carouselTesti .owl-prev {
  left: 24%;
}

#carouselTesti .owl-next {
  right: 24%;
}

/* ACTUS HP */

.img-overlay-70 {
  position: relative;
}

.img-overlay-70:before,
.breadcrumb_actu:before {
  opacity: .7;
  background-image: -webkit-linear-gradient(#000000, #000556);
  background-image: -moz-linear-gradient(#000000, #000556);
  background-image: -o-linear-gradient(#000000, #000556);
  background-image: linear-gradient(#000000, #000556);
  content: "";
  height: 100%;
  bottom: 0;
  left: 0;
  right: 0;
  position: absolute;
  width: 100%;
  z-index: 1;
}

.img-scale-animate {
  overflow: hidden;
}

.mask-content {
  position: absolute;
  z-index: 7;
  bottom: 20px;
  left: 20px;
}

.topic-box-sm {
  position: absolute;
  top: 15px;
  left: 20px;
  z-index: 7;
  font-size: 12px;
  font-weight: 700;
}

.actu_item {
  position: relative;
  overflow: hidden;
}

.content_actu {
  position: absolute;
  bottom: 0;
}

.img_actu {
  height: 100%;
  object-fit: cover;
}

.right_col .actu_item,
.right_col .actu_item img {
  max-height: 288px;
  min-height: 288px;
  width: auto;
  min-width: 100%;
}

.left_col .actu_item,
.left_col .actu_item img {
  max-height: 600px;
  min-height: 600px;
  width: auto;
  min-width: 100%;
}

.title-medium-light {
  line-height: normal;
}

.title-medium-light .txt_white {
  font-size: 16px;
  line-height: normal;
  transition: all ease .3s;
}

.title-medium-light a:hover {
  color: #ffffff;
  text-decoration: none;
}

.post-date-light {
  margin-bottom: 20px;
  text-transform: uppercase;
}

/* TOP VILLE */

.icon_pin {
  width: 20px;
}

.list_topville ul {
  list-style: none;
  padding: 0;
  margin: 0;
  column-count: 4;
}

.list_topville ul li {
  margin-bottom: 10px;
}

/* FOOTER */

#footer_top .icon_arrow {
  position: absolute;
  right: 20px;
  top: 13px;
}

footer h6 {
  font-weight: 700;
}

footer ul {
  list-style: none;
  padding: 0;
  font-size: 14px;
  line-height: 2rem;
  margin: 0;
}

.menu_footer ul {
  column-count: 3;
}

.contact_info {
  font-size: 14px;
}

.contact_info p {
  float: left;
}

.contact_info .btn_phone {
  padding: 8px 25px;
  margin-left: 30px;
  line-height: 16px;
  margin-top: 35px;
}

#footer_bottom img {
  max-width: 180px;
}

#footer_bottom .img_paiement {
  max-width: 250px;
  margin-top: 30px;
}

/* LISTE STAGE */

.form_recherche,
.form_ville,
#sidebar .infos {
  border-radius: 10px;
}

.sticky-top {
  top: 200px;
}

.form_recherche .btn {
  width: 100%;
  text-align: center;
  display: inline;
}

.input_shadow {
  background: #FFFFFF;
  border: none;
  width: 100%;
  padding: 10px 20px;
  border-radius: 40px;
  color: #000556;
  box-shadow: 5px 5px 10px rgba(189, 189, 189, 0.3), -5px -5px 10px rgba(255, 255, 255, 0.5);
  margin-bottom: 20px;
  font-weight: 300;
  -webkit-appearance: none;
}

.input_shadow[type="date"] {
  min-height: 52px;
}

.search.bs-example,
.search span {
  width: 100%;
}

select {
  -moz-appearance: none;
  /* Firefox */
  -webkit-appearance: none;
  /* Safari and Chrome */
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background: transparent;
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABUAAAAVCAYAAACpF6WWAAAAAXNSR0IArs4c6QAAADhlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAAqACAAQAAAABAAAAFaADAAQAAAABAAAAFQAAAAAr0zA0AAABNElEQVQ4Ee2TMVLDMBBFd6V4hjJXoE4TTsAVXGC1OB0d3AQ4AUkLBblJJgX3SB8myn45FnIsSwaGjp2xvfv1942kWRPlYlI9UWGseybmPWfHuhphmnsPU+nzRDIGmmiPL/1D4/fyG/UP71Sbkorq/se7Q782t22/Il3VMq0y1CxDXr20C6O/bb+iJeFHkVCkOABx/S2wAwb9zHLacqrI2ufurgC+eehqkeoc2FhWROudos83AKQIQz26awmlMB8C7l9r2Nh7C7OU3F+20w92IY6amK+9b2+vqOCNr5tkRScgyi8oqhjY2p1Ap1h2cV7jlAEQHt04T+/Dx5r07FKqudeZL3yOpFv3gLB0oVBiYOj9iAJh60Oh5sGDwGFoGpwEpqFxcBaYh7ZgNZMpsVuZ6TtIuTgCpDlYdsEpWYMAAAAASUVORK5CYII=) !important;
  background-repeat: no-repeat !important;
  background-position-x: 90% !important;
  background-position-y: 50% !important;
}

select.no_arrow {
  background-image: none !important;
}

.input_shadow::placeholder {
  color: #000556;
}

.rangeslider__fill {
  background: #010737;
}

.rangeslider__handle {
  background: #F2F2F2;
  border: 1px solid #010737;
  width: 18px;
  height: 18px;
  box-shadow: none;
}

.rangeslider__handle:after {
  content: none;
}

.rangeslider--horizontal {
  height: 3px;
  width: 100%;
}

.rangeslider {
  background: #010737;
}

.rangeslider__value-bubble {
  padding: 5px 7px;
  line-height: normal;
  position: absolute;
  margin-bottom: 0;
  width: 40px;
  margin-left: 0;
  text-align: center;
  margin-top: 22px;
  background: #D90B1C;
  color: #ffffff;
  margin-left: -11px;
  font-size: 12px;
}

.rangeslider__value-bubble:before {
  content: '';
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-bottom: 10px solid #D90B1C;
  position: absolute;
  top: -10px;
  left: 5px;
}

.rangeslider--horizontal .rangeslider__handle {
  top: -8px;
}

.checkbox_effect:not(:checked),
.checkbox_effect:checked {
  position: absolute;
  left: -9999px;
}

.checkbox_effect+label {
  cursor: pointer;
  position: relative;
  display: flex;
  align-items: center;
}

.checkbox_effect:not(:checked)+label:before,
.checkbox_effect:checked+label:before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background: #ffffff;
  border: 2px solid #ffffff;
  box-sizing: border-box;
  border-radius: 0px;
  margin-right: 20px;
}

.checkbox_effect:not(:checked)+label:after,
.checkbox_effect:checked+label:after {
  content: "\f00c";
  font-family: fontawesome;
  font-size: 16px;
  display: flex;
  height: 15px;
  align-items: center;
  position: absolute;
  left: 0px;
  top: 0px;
  transform-origin: center center;
  opacity: 0;
  color: #000556;
}

.checkbox_effect:not(:checked)+label:after {
  transform: scale(0);
}

.checkbox_effect:checked+label:before {
  transform: scale(0);
  opacity: 0;
}

.checkbox_effect:checked+label:after {
  transform: scale(1);
  opacity: 1;
  transition: all .2s cubic-bezier(0.57, 1.9, 0, 1.52);
}

.item_liste {
  margin-top: 35px;
  position: relative;
  border-radius: 20px;
  border: solid 2px #F7F7F7;
  transition: border ease .5s;
}

.item_liste:hover {
  border-color: #000556;
}

.item_liste.item_promo:hover {
  border-color: #F24822;
}

.item_liste.item_mpg:hover {
  border-color: #48bf88;
}

.item_liste.item_conf:hover {
  border-color: #015756;
}
.item_liste.item_partenaire:hover {
  border-color: #54016d;
}

.item_liste.item_partenaire {
  border-color: #a714d4;

  /* solid 2px rgb(138 9 202) */
}

.item_liste .label {
  top: -25px;
  ;
  z-index: -1;
  left: 2%;
  border-radius: 8px;
  padding: 5px 5px 10px;
  width: 180px;
  text-align: center;
  text-transform: uppercase;
  font-weight: 700;
  font-size: 15px;
  line-height: normal;
}

.item_liste .label.promo {
  background: #F24822;
  color: #ffffff;
}

.item_liste .label.mpg {
  background: #48bf88;
  color: #ffffff;
}

.item_liste .label.conf {
  background: #015756;
  color: #ffffff;
}
.item_liste .label.partenaire {
  background: #7a0185;
  color: #ffffff;
}

#liste_stages #stages #reserver .btn {
  max-width: 100%;
  min-width: 100%;
}

#price {
  font-size: 30px;
  font-weight: 700;
  text-align: right;
  color: #000556;
}

.item_promo #price {
  color: #F24822;
}

.item_mpg #price {
  color: #48bf88;
}

.item_conf #price {
  color: #015756;
}

#price .icon {
  margin-right: 10px;
}

#ville img {
  width: 30px;
  float: left;
  margin: 0px 15px;
}

#ville .infos h5 {
  color: #D90B1C;
  text-transform: uppercase;
  margin-bottom: 5px;
  font-weight: 700;
}

#ville .infos p {
  font-weight: 700;
}

.rates {
  font-size: 14px;
  color: #F9C4A2;
}

.rates i {
  margin: 0px 2px;
}

#dates h5 {
  margin: 0;
}

/* DETAIL */

ul#tab {
  border-bottom: solid 1px #D1D1D4;
}

.nav-pills .nav-link {
  padding: 0.5rem 4.2rem;
  border-radius: 0;
  font-weight: 600
}

.nav-pills .nav-link.active,
.nav-pills .show>.nav-link {
  color: #000556;
  background-color: transparent;
  border-bottom: solid 2px #D90B1C;
}

#detail_stages #infos_utiles .btn {
  width: 100%;
  text-align: center;
  display: inherit;
}

/* PAGE TEXTE */

#sidebar .infos .btn {
  width: 100%;
}

#sidebar .separator_white {
  border-top: solid;
  width: 30%;
  margin-left: 0;
}

.separator_white {
  border-color: #FFFFFF;
}

.separator_red {
  border-color: #D90B1C;
}

/* FAQ */

#faq .form_recherche input {
  padding-left: 40px;
}

#faq .form_recherche .search {
  position: relative;
}

#faq .form_recherche .icon {
  position: absolute;
  top: 20%;
  left: 15px;
}

.item_faq div {
  padding: 1.5rem;
  text-align: center;
  border-radius: 70px;
}

.item_faq a:hover {
  text-decoration: none;
}

#faq .categorie_faq {
  border-radius: 10px;
  box-shadow: 5px 5px 10px rgba(189, 189, 189, 0.3), -5px -5px 10px rgba(255, 255, 255, 0.5);
  font-weight: 700;
  font-size: 20px;
}

#faq .categorie_faq img {
  width: 140px;
  max-height: 120px;
  height: 120px;
}

#faq #sidebar .categorie_liste ul {
  list-style: none;
  padding: 0;
}

#faq #sidebar .categorie_liste li {
  padding: 10px 0;
  border-bottom: solid 1px #F7F7F7;
}

#faq #sidebar .categorie_liste li:last-child {
  border-bottom: none;
}

#faq #sidebar .categorie_liste li.active {
  font-weight: 700;
}

#faq .item_faq .icon_arrow {
  position: absolute;
  right: 5%;
  color: #D90B1C;
  top: 28px;
}

/* ACTUS */

.navbar_actus {
  border-radius: 100px;
  margin-top: -5rem;
}

.navbar_actus ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.navbar_actus li {
  display: inline-flex;
  padding: 0px 50px;
  text-transform: uppercase;
  font-weight: 700;
  font-size: 20px;
  color: #FFFFFF;
  border-right: solid 1px #FFFFFF;
}

.navbar_actus li a {
  color: #FFFFFF;
}

.navbar_actus li:last-child {
  border-right: none;
}

#actus .img_actu {
  height: 250px;
  object-fit: cover;
  width: 100%;
}

#actu .img_actu {
  height: 150px;
  object-fit: cover;
  width: 100%;
}

.breadcrumb_actu {
  position: relative;
  padding: 100px 0px;
}

#detail_actu #actu {
  margin-top: -100px;
  background: #FFFFFF;
  position: relative;
  z-index: 3;
  border-radius: 20px;
}

.breadcrumb_actu h1,
.breadcrumb_actu p,
.breadcrumb_actu a {
  color: #ffffff;
  z-index: 2;
  position: relative;
}

.categorie_actu {
  font-size: 14px;
}

.date_actu {
  margin-bottom: 10px;
}

.share_actu {
  float: right;
}

.share_actu a {
  margin-right: 10px;
}

a.titre_actu {
  text-transform: uppercase;
  font-weight: 700;
  font-size: 20px;
  margin: 20px 0;
}

/* AUTOCOMPLETE */

.tt-menu {
  background-color: #FFFFFF;
  border: none;
  border-radius: 0px;
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.1);
  margin-top: 10px;
  padding: 8px 0;
  width: 300px;
}

.bs-example {
  position: relative;
}

.tt-suggestion p {
  margin: 0;
  color: initial
}

.tt-suggestion {
  padding: 5px 20px;
  color: initial;
}

.tt-suggestion:hover {
  cursor: pointer;
  background-color: #000556;
  color: #FFFFFF;
}

/* CONTACT */

.coordonnees li {
  margin-bottom: 20px;
  display: inline-flex;
  align-items: center;
}

.coordonnees ul {
  padding: 0;
  list-style: none;
  display: inline-flex;
}

.coordonnees .icon {
  font-size: 30px;
  margin-right: 10px;
}

.coordonnees .icon_phone,
.coordonnees .icon_adresse {
  stroke: #D90B1C;
}

.coordonnees .icon_mail {
  fill: #D90B1C;
}

.coordonnees p {
  line-height: normal;
}

#contact_form .input {
  background: #FFFFFF;
  border: none;
  width: 100%;
  padding: 10px 20px;
  border-radius: 40px;
  color: #000556;
  margin-bottom: 20px;
  font-weight: 300;
}

#contact_form .input::placeholder {
  color: #000556;
}

#contact_form .checkbox_effect:checked+label:after {
  color: #FFFFFF;
}

/* RESERVATION */

.form-card {
  text-align: left
}

#msform input.next {
  float: right;
}

#msform fieldset:not(:first-of-type) {
  display: none
}

#progressbar {
  margin-bottom: 30px;
  overflow: hidden;
  color: #F2F2F2;
  padding-left: 0;
}

#progressbar .active {
  color: #D90B1C;
}

#progressbar li {
  list-style-type: none;
  font-size: 15px;
  width: 31%;
  float: left;
  position: relative;
  font-weight: 400
}

#progressbar li:after {
  content: " ";
  width: 5px;
  height: 5px;
  line-height: 45px;
  display: block;
  font-size: 20px;
  color: #ffffff;
  background: #D90B1C;
  border-radius: 50%;
  padding: 2px;
  position: absolute;
  top: 5px;
}

#progressbar:before {
  content: '';
  width: 90%;
  height: 15px;
  background: #F2F2F2;
  position: absolute;
  left: 2%;
  top: 24px;
  z-index: -1;
  border-radius: 30px;
  margin: auto;
}

#progressbar li:last-child {
  width: 5%;
}

#progressbar li.active:before {
  content: "";
  background: #000556;
  width: 110%;
  position: absolute;
  left: -106%;
  height: 15px;
  top: 0px;
  border-radius: 60px;
}

#progressbar li.active:last-child:before {
  width: 640%;
  left: -620%;
}

#progressbar li.active:after {
  top: 0px;
  width: 15px;
  height: 15px;
  background: #D90B1C;
}

#progressbar .info_top {
  position: absolute;
  top: -30px;
  color: #000556;
  font-size: 12px;
  text-transform: uppercase;
}

#progressbar .active .info_top {
  color: #D90B1C;
}

#progressbar .info_bottom {
  line-height: 60px;
  font-size: 12px;
  color: #000556;
}

#progressbar #recap .info_bottom {
  margin-left: -20%;
}

.progress-bar {
  background-color: #D90B1C;
}

input:focus {
  outline: none;
}

input.radio_none[type="radio"] {
  display: none;
}

label.radio_img {
  display: block;
  position: relative;
  cursor: pointer;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

label.radio_img img {
  height: 100px;
  width: 100%;
  object-fit: contain;
  transition-duration: 0.2s;
  padding: 40px 10px;
  border-radius: 10px;
  background: #FFFFFF;
  border: solid 2px #FFFFFF;
}

:checked+label.radio_img img {
  border: solid 2px #000556;
}

#reservation .infos_box {
  border-radius: 20px;
}

#reservation .infos_box .icon_cross {
  font-size: 4rem;
}

#reservation .infos_box p,
#reservation .infos_box a {
  color: #FFFFFF;
}

#reservation .box_shadow {
  height: 100%;
  width: 100%;

}

.recap_stage {
  display: inline-block;
}

.recap_stage h4 {
  position: relative;
  margin-bottom: 20px;
  margin-top: 50px;
}

.recap_stage h4:after {
  content: " ";
  width: 50px;
  height: 3px;
  background: #D90B1C;
  position: absolute;
  left: 0;
  bottom: -5px;
}

.recap_stage .price p {
  font-size: 35px;
  font-weight: 700;
  color: #000556;
  margin-top: 50px;
}

.btn_back {
  background: #CBCBCB;
  color: #2F2F2F;
}

.btn_next {
  background: #2F2F2F;
  color: #FFFFFF;
}

.btn_back:hover,
.btn_next:hover {
  background: #626260;
  color: #ffffff;
}

.link_form {
  background: none;
  outline: none;
  border: none;
  color: #446EA6;
  font-size: 16px;
  text-decoration: underline;
  text-underline-position: under;
}

.icon_resa {
  font-size: 70px;
  line-height: normal;
  margin-bottom: 20px;
}

/* PAGE 404 */

#p404 h1 {
  color: #D90B1C;
  margin-top: 30px;
  margin-bottom: 20px;
}

/* RAJOUT VINCE THXX */
.hide {
  display: none;
}

/* PAIEMENT PLUSIEURS FOIS */

#reassurance {
  position: relative;
}

#reassurance:before {
  content: '';
  background: url(/uploads/paiement-plusieurs-fois-home.png);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  width: 630px;
  height: 130px;
  top: -120px;
  z-index: 1;
}

@media (max-width: 768px) {
  .form_line:before {
    content: '';
    background: url(/uploads/mobile-resultats-recherche-paiement-plusieurs-fois.png);
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    z-index: 1;
    width: 88%;
    height: 79px;
    bottom: -73px;
  }

  div#stages {
    margin-top: 110px;
  }
  .small_label {
    font-size: 13px;
  }
}

.header-list {
  margin-bottom: -46px;
}

label img.svg_payment {
  padding: 0px ;
  cursor:pointer;
  max-width: none;
}
