@charset "UTF-8";
/*************************************
Page d'accueil Header
*************************************/
/**********************************************************
Page d'accueil section fonctionnement
**********************************************************/
/***************************************************************
Page d'accueil section restaurants
***************************************************************/
/*****************************************
Pages des menus restaurants
*****************************************/
/*************************************
icons
*************************************/
/*************************************
Lodear spinner page d'accueil
*************************************/
@keyframes loader {
  100% {
    opacity: 0;
    z-index: -10;
  }
}
@keyframes popcorn {
  0% {
    transform: translateY(0);
  }
  25% {
    transform: translateY(0.7rem);
  }
  75% {
    transform: translateY(-0.7rem);
  }
  100% {
    transform: translateY(0);
  }
}
/**************************************
Apparition des menus en décalés
**************************************/
@keyframes ico-menus {
  0% {
    transform: scale(0);
  }
  100% {
    transform: scale(1);
  }
}
/****************************************
Rotation du chevron
****************************************/
@keyframes chevron {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.menus-icon, .menus-choix, .logo-menus, .icon-coeur .icon-j-aime, .icon-coeur .icon, .icon-coeur .btn-menu, .icon-coeur .btn-coeur {
  display: flex;
  justify-content: center;
  align-items: center;
}

.footer-restaurants .footer-container, .footer-accueil .footer-container {
  display: flex;
  flex-direction: column;
  text-align: start;
}

body {
  width: 100%;
  align-content: center;
  margin: auto;
  height: auto;
}

.container-restaurants {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.img-menus {
  width: 100%;
  height: 60vw;
  object-fit: cover;
}

.carte-restaurant {
  margin-top: -1.8rem;
  position: relative;
  background-color: white;
  border-radius: 2rem 2rem 0 0;
}

header, .carte-restaurant {
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
  align-items: center;
}

#logo {
  margin: 1rem 0 1rem 0rem;
  border-radius: 0;
  width: 12rem;
  position: relative;
}

.container {
  display: flex;
  background-color: #fff;
  justify-content: space-between;
}

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

.container .menus-prix {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
}

.footer-menus a .footer-contact, .footer-menus a .footer-legal, .footer-menus a .footer-part, .footer-menus a .footer-rest, .footer-menus .footer-contact, .footer-menus .footer-legal, .footer-menus .footer-part, .footer-menus .footer-rest {
  color: white;
  padding: 0.3rem;
  text-decoration: none;
}

/***********************************
header accueil
***********************************/
.header-accueil {
  text-align: center;
}

/***********************************
Section ville
***********************************/
.ville-section {
  font-size: 1.2rem;
  background-color: #dbdadaf2;
  width: 100%;
  display: flex;
  justify-content: center;
}
.ville-section .mappy {
  padding: 1rem 0;
}
.ville-section .mappy-description {
  font-size: 1.2rem;
  padding: 1rem;
}

/************************************
Exploration des restaurants
************************************/
.explore-section {
  background-color: #f3f2f2f2;
  width: 100%;
  height: 30vh;
  justify-content: center;
  text-align: center;
  padding: 1.2rem 0 0 0;
}
.explore-section .explore-titre {
  font-size: 1.5rem;
  justify-content: center;
  padding: 1rem 0 1rem 0;
  font-style: normal;
}
.explore-section .explore-texte {
  font-size: 1.1rem;
  margin: 0 0 3rem 0;
}
.explore-section .explore {
  font-size: 1rem;
  padding: 1rem;
  margin: 5rem 0rem 5rem 0rem;
  border-radius: 100px;
  color: white;
  text-decoration: none;
  background-image: linear-gradient(to top, #9356DC, #FF79DA);
  box-shadow: 5px 5px 10px #cecdcd, -5px -5px 10px #cfcece;
  cursor: pointer;
  transform: translateX(-5%);
  transition: opacity 0.4s;
}
.explore-section .explore:hover {
  opacity: 0.9;
}

.fct-section {
  display: flex;
  flex-direction: column;
  width: 100%;
}
.fct-section .fct-titre {
  padding: 3rem 0rem 1rem 1rem;
  text-align: left;
  font-size: 1.5rem;
}

.fct-container {
  background-color: white;
  margin: 0 0 3rem 0;
  width: 100%;
}
.fct-container .btns {
  list-style: none;
  font-size: 1.3rem;
  background-color: white;
  margin: 1rem 0 1rem 0;
  transition: opacity 0.4s;
}
.fct-container .btn:hover {
  color: #9356DC;
  background: #cbc1d8;
  opacity: 0.9;
}
.fct-container .btn1 {
  position: relative;
  background-color: white;
  border: 2px solid transparent;
  padding: 0 0.5rem 0 0;
  margin: 1rem 0.5rem 1rem 1rem;
  border-radius: 20px;
  box-shadow: 5px 5px 10px #cecdcd, -5px -5px 10px #cfcece;
}
.fct-container .btn1::before {
  position: absolute;
  content: "";
  width: 30px;
  height: 30px;
  color: white;
  font-size: 1rem;
  background-color: #9356DC;
  border-radius: 25px;
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: 5px 5px 10px #cecdcd, -5px -5px 10px #cfcece;
  left: 0;
  bottom: 0;
  transform: translate(-50%, -60%);
  content: "1";
}
.fct-container .btn2 {
  position: relative;
  background-color: white;
  border: 2px solid transparent;
  padding: 0 0.5rem 0 0;
  margin: 1rem 0.5rem 1rem 1rem;
  border-radius: 20px;
  box-shadow: 5px 5px 10px #cecdcd, -5px -5px 10px #cfcece;
}
.fct-container .btn2::before {
  position: absolute;
  content: "";
  width: 30px;
  height: 30px;
  color: white;
  font-size: 1rem;
  background-color: #9356DC;
  border-radius: 25px;
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: 5px 5px 10px #cecdcd, -5px -5px 10px #cfcece;
  left: 0;
  bottom: 0;
  transform: translate(-50%, -60%);
  content: "2";
}
.fct-container .btn3 {
  position: relative;
  background-color: white;
  border: 2px solid transparent;
  padding: 0 0.5rem 0 0;
  margin: 1rem 0.5rem 1rem 1rem;
  border-radius: 20px;
  box-shadow: 5px 5px 10px #cecdcd, -5px -5px 10px #cfcece;
}
.fct-container .btn3::before {
  position: absolute;
  content: "";
  width: 30px;
  height: 30px;
  color: white;
  font-size: 1rem;
  background-color: #9356DC;
  border-radius: 25px;
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: 5px 5px 10px #cecdcd, -5px -5px 10px #cfcece;
  left: 0;
  bottom: 0;
  transform: translate(-50%, -60%);
  content: "3";
}
.fct-container .btn-descpt {
  text-decoration: none;
  font-size: 1rem;
  color: black;
}

.icon-fct {
  padding: 1.5rem 1rem 1.5rem 2.5rem;
}
.icon-fct:hover {
  color: #9356DC;
  opacity: 0.9;
}

/***********************************
Section restaurants
***********************************/
.section-restaurants {
  width: 100%;
  position: relative;
  background-color: #f2f2f2f2;
}
.section-restaurants .section-titre {
  text-align: left;
  justify-content: flex-start;
  padding: 0 0 0 1rem;
}

.container-restaurants {
  display: grid;
}

.diapos-restaurants {
  border-radius: 15px;
  background-color: white;
  padding: 0 0 1rem 0;
  margin: 1rem;
}

.restaurant {
  text-decoration: none;
}

.contenu-restaurants .rest-img {
  width: 90vw;
  height: 60vw;
  min-width: 35vw;
  object-fit: cover;
  border-top-left-radius: 15px;
  border-top-right-radius: 15px;
}

.nouveau {
  position: absolute;
  background-color: #99e2d0;
  padding: 0.3rem;
  font-size: 1rem;
  margin: 1rem 0 0rem -6rem;
  color: darkgreen;
}

.icon-coeur .description {
  width: 80%;
}
.icon-coeur .description .rest-titre {
  font-size: 1.2rem;
  color: black;
  padding: 0.3rem 0.5rem;
  font-style: normal;
  font-weight: normal;
}
.icon-coeur .description .rest-description {
  font-size: 1.1rem;
  color: black;
  padding: 0rem 1rem;
}
.icon-coeur .btn-coeur {
  width: 15%;
  margin: 0.5rem;
  background-color: transparent;
  border: 0 solid transparent;
  padding: 0;
  color: #000;
}
.icon-coeur .btn-menu {
  height: 2rem;
  background-color: transparent;
  border: 0 solid transparent;
  padding: 0;
  cursor: pointer;
  position: relative;
  background-color: #000;
}
.icon-coeur .btn-menu::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.icon-coeur .btn-menu:hover::before {
  opacity: 1;
}
.icon-coeur .btn-menu::before {
  opacity: 0;
  transition: 0.5s;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(0deg, #9356DC, #FF79DA);
}
.icon-coeur .icon {
  font-size: 1.8rem;
  transition-duration: 0.25s;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  mix-blend-mode: lighten;
  background-color: white;
}
.icon-coeur .icon-j-aime {
  font-size: 1.8rem;
  transition-duration: 0.25s;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  mix-blend-mode: lighten;
  background-color: white;
}
.icon-coeur .btn-menu:hover .icon-j-aime {
  opacity: 0;
}

/********************************
Footer de la page d'accueil
********************************/
.footer-accueil {
  background-color: black;
  width: 100%;
}
.footer-accueil .footer-container {
  padding: 1.5rem 1.5rem;
}

.footer-menus {
  color: white;
  list-style: none;
  text-decoration: none;
}
.footer-menus .footer-logo {
  color: white;
  text-decoration: none;
  font-family: "Shrikhand", Roboto;
  font-size: 1.5rem;
}
.footer-menus .footer-liens {
  padding: 0.2rem;
}
.footer-menus .footer-icon1 {
  padding: 0.3rem;
  font-size: 1rem;
}
.footer-menus .footer-icon2 {
  padding: 0.3rem;
  font-size: 0.7rem;
}
/***********************************************************************
Page d'accueil des restaurants
***********************************************************************/
@media screen and (min-width: 280px) and (max-width: 767.98px) {
  .explore-section {
    height: 20rem;
  }
  .explore-section .explore-texte {
    margin: 0 0 3rem 0;
  }
}
@media screen and (min-width: 767.98px) and (max-width: 1024px) {
  .explore-section {
    height: 20rem;
  }
  .explore-section .explore-texte {
    margin: 0 0 3rem 0;
  }

  .fct-section .fct-titre {
    padding: 3rem 7rem 1rem 1.5rem;
    text-align: left;
    font-size: 1.5rem;
  }

  .section-restaurants {
    width: auto;
    background-color: #f2f2f2f2;
  }
  .section-restaurants .section-titre {
    text-align: left;
    padding: 0 0 0 1rem;
  }
  .section-restaurants .container-restaurants {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 50px 1fr 1fr;
    margin: 0rem 0 0 0;
  }
  .section-restaurants .contenu-restaurants {
    grid-row-start: 2 span;
  }
  .section-restaurants .diapos1 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos2 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos3 {
    grid-row-start: 3;
  }
  .section-restaurants .diapos4 {
    grid-row-start: 5;
  }
  .section-restaurants .diapos-restaurants {
    margin: 0.5rem 1rem 3rem 1rem;
  }
  .section-restaurants .contenu-restaurants .rest-img {
    width: 46vw;
    height: 20vw;
  }
}
@media screen and (min-width: 1024px) and (max-width: 1600px) {
  .explore-section {
    height: 20rem;
  }
  .explore-section .explore-texte {
    margin: 0 0 3rem 0;
  }

  .fct-section {
    display: block;
    align-items: center;
    width: 100%;
  }
  .fct-section .fct-titre {
    padding: 3rem 7rem 1rem 7rem;
    text-align: center;
  }

  .fct-container {
    display: contents;
    flex-direction: column;
    margin: 0 0 0 0;
  }
  .fct-container .btns {
    display: flex;
    justify-content: space-evenly;
    margin: 0rem 0rem 1rem 0rem;
    padding: 0 0 0 1.5rem;
  }
  .fct-container .btn1 {
    padding: 0 2rem 0 0;
    margin: 1rem 1.5rem 1rem 1rem;
  }
  .fct-container .btn2 {
    padding: 0 3rem 0 0;
    margin: 1rem 1.5rem 1rem 1rem;
  }
  .fct-container .btn3 {
    padding: 0 3rem 0 0;
    margin: 1rem 1.5rem 1rem 1rem;
  }

  .section-restaurants {
    width: auto;
    background-color: #f2f2f2f2;
  }
  .section-restaurants .section-titre {
    text-align: left;
    padding: 0 0 0 1rem;
  }
  .section-restaurants .container-restaurants {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 50px 1fr 1fr;
    margin: 5rem 0 0 0;
  }
  .section-restaurants .contenu-restaurants {
    grid-row-start: 2 span;
  }
  .section-restaurants .diapos1 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos2 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos3 {
    grid-row-start: 3;
  }
  .section-restaurants .diapos4 {
    grid-row-start: 5;
  }
  .section-restaurants .diapos-restaurants {
    margin: 0.5rem 1rem 3rem 1rem;
  }
  .section-restaurants .contenu-restaurants .rest-img {
    width: 47vw;
    height: 20vw;
  }
}
/*/ X-Large devices (large desktops)*/
@media screen and (min-width: 1600px) and (max-width: 2000px) {
  .explore-section {
    height: 20rem;
  }
  .explore-section .explore-texte {
    margin: 0 0 3rem 0;
  }

  .fct-section {
    display: block;
    align-items: center;
    width: 100%;
  }
  .fct-section .fct-titre {
    padding: 3rem 7rem 1rem 7rem;
    text-align: center;
  }

  .fct-container {
    display: contents;
    flex-direction: column;
    margin: 0 0 0 0;
  }
  .fct-container .btns {
    display: flex;
    justify-content: space-evenly;
    margin: 0rem 0rem 1rem 0rem;
    padding: 0 0 0 3rem;
  }
  .fct-container .btn1 {
    padding: 0 2rem 0 0;
    margin: 1rem 2.5rem 1rem 1rem;
  }
  .fct-container .btn2 {
    padding: 0 3rem 0 0;
    margin: 1rem 2.5rem 1rem 1rem;
  }
  .fct-container .btn3 {
    padding: 0 3rem 0 0;
    margin: 1rem 2.5rem 1rem 1rem;
  }

  .section-restaurants {
    width: auto;
    margin: 0rem;
    border-radius: 0px;
  }
  .section-restaurants .section-titre {
    text-align: left;
    padding: 0 0 0 1rem;
  }
  .section-restaurants .container-restaurants {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 50px 1fr 1fr;
    margin: 5rem 0 0 0;
  }
  .section-restaurants .contenu-restaurants {
    grid-row-start: 2 span;
  }
  .section-restaurants .diapos1 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos2 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos3 {
    grid-row-start: 3;
  }
  .section-restaurants .diapos4 {
    grid-row-start: 5;
  }
  .section-restaurants .diapos-restaurants {
    margin: 0.5rem 1rem 3rem 1rem;
  }
  .section-restaurants .contenu-restaurants .rest-img {
    width: 48vw;
    height: 20vw;
  }
}
/*/ X-Large devices (large desktops)*/
@media screen and (min-width: 2000px) {
  .explore-section {
    height: 20vh;
  }
  .explore-section .explore-texte {
    margin: 0 0 3rem 0;
  }

  .fct-section {
    display: block;
    align-items: center;
    width: 100%;
  }
  .fct-section .fct-titre {
    padding: 3rem 7rem 1rem 7rem;
    text-align: center;
  }

  .fct-container {
    display: contents;
    flex-direction: column;
    margin: 0 0 0 0;
  }
  .fct-container .btns {
    display: flex;
    margin: 0rem 0rem 1rem 0rem;
    padding: 0 0 0 3rem;
    justify-content: space-evenly;
  }
  .fct-container .btn1 {
    padding: 0 2rem 0 0;
    margin: 1rem 2.5rem 1rem 1rem;
  }
  .fct-container .btn2 {
    padding: 0 3rem 0 0;
    margin: 1rem 2.5rem 1rem 1rem;
  }
  .fct-container .btn3 {
    padding: 0 3rem 0 0;
    margin: 1rem 2.5rem 1rem 1rem;
  }

  .section-restaurants {
    width: auto;
    margin: 0rem;
    border-radius: 0px;
  }
  .section-restaurants .section-titre {
    text-align: left;
    padding: 0 0 0 1rem;
  }
  .section-restaurants .contenu-restaurants {
    grid-row-start: 2 span;
  }
  .section-restaurants .diapos1 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos2 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos3 {
    grid-row-start: 3;
  }
  .section-restaurants .diapos4 {
    grid-row-start: 5;
  }
  .section-restaurants .container-restaurants {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 50px 1fr 1fr;
    margin: 5rem 0 0 0;
  }
  .section-restaurants .container-restaurants .rest-img {
    width: 48vw;
    height: 20vw;
  }
  .section-restaurants .diapos-restaurants {
    margin: 0.5rem 1rem 3rem 1rem;
  }
}
/***********************************************************************
Pages des cartes des restaurants
***********************************************************************/
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .img-menus {
    height: 50vw;
    object-position: center;
  }

  .carte-restaurant {
    width: 80%;
    background-color: white;
    margin-top: -6.8rem;
    border-radius: 2rem 2rem 0 0;
  }

  .footer-restaurants {
    width: 80%;
  }
}
@media screen and (min-width: 1024px) and (max-width: 1315px) {
  .img-menus {
    height: 40vw;
    object-position: center;
  }

  .carte-restaurant {
    width: 100%;
    background-color: white;
    margin-top: -6.8rem;
    border-radius: 2rem 2rem 0 0;
  }
  .carte-restaurant .entete .cartes-titre {
    padding: 2rem 0 0 0.5rem;
    text-align: center;
  }
  .carte-restaurant .entete .coeur {
    justify-content: flex-end;
    margin: 2.5rem 0;
  }

  .menus {
    flex-direction: row;
    max-width: 95%;
    min-width: 95%;
  }
  .menus .section-menus {
    max-width: 30%;
    min-width: 30%;
    padding: 0 0 0 0;
  }
  .menus .entrees {
    max-width: 90%;
  }
  .menus .plats {
    max-width: 90%;
  }
  .menus .desserts {
    max-width: 90%;
  }

  .footer-restaurants {
    width: 100%;
  }
}
@media screen and (min-width: 1315px) and (max-width: 1715px) {
  .img-menus {
    height: 40vw;
    object-position: center;
  }

  .carte-restaurant {
    width: 100%;
    background-color: white;
    margin-top: -6.8rem;
    border-radius: 2rem 2rem 0 0;
  }
  .carte-restaurant .entete .cartes-titre {
    padding: 2rem 0 0 0.5rem;
    text-align: center;
  }
  .carte-restaurant .entete .coeur {
    justify-content: flex-end;
    margin: 2.5rem 0;
  }

  .menus {
    flex-direction: row;
    max-width: 90%;
    min-width: 90%;
  }
  .menus .section-menus {
    max-width: 30%;
    min-width: 30%;
  }
  .menus .entrees {
    max-width: 90%;
  }
  .menus .plats {
    max-width: 90%;
  }
  .menus .desserts {
    max-width: 90%;
  }
}
@media screen and (min-width: 1715px) and (max-width: 3500px) {
  .img-menus {
    width: 100%;
    height: 40vw;
    object-position: center;
  }

  .carte-restaurant {
    width: 100%;
    flex-direction: row;
    position: relative;
    margin-top: -8.8rem;
    background-color: white;
    border-radius: 2rem 2rem 0 0;
    max-width: 1715px;
  }
  .carte-restaurant .entete {
    flex-direction: column;
    width: 10%;
  }
  .carte-restaurant .entete .cartes-titre {
    padding: 3.5rem 0 0 0.5rem;
    text-align: center;
    font-size: 1.3rem;
    margin: 0 1rem 0 0;
  }
  .carte-restaurant .entete .btn-coeur {
    width: 20%;
    display: flex;
    justify-content: center;
    font-size: 1.3rem;
    margin: 1rem auto;
  }

  .menus {
    max-width: 65%;
    min-width: 65%;
    display: flex;
    flex-direction: row;
    padding-bottom: 15px;
  }
  .menus .section-menus {
    max-width: 30%;
    min-width: 30%;
  }
  .menus .entrees {
    max-width: 90%;
  }
  .menus .plats {
    max-width: 90%;
  }
  .menus .desserts {
    max-width: 90%;
  }

  .cmd {
    margin: 7rem 1.5rem 5rem 1.5rem;
  }

  .footer-restaurants {
    max-width: 1715px;
  }
}
/*************************************
En tête des restaurants
*************************************/
header .page {
  max-width: 2000px;
}

.logo-menus .fleche {
  position: absolute;
  font-size: 1.2rem;
  left: 1.2rem;
}
.logo-menus .fa-arrow-left {
  align-self: start;
  color: black;
}
.logo-menus .ohmy {
  width: 70%;
}

/***********************************
Header des cartes de menus 
***********************************/
/**********************************
Titre du menus et bouton "j'aime"
**********************************/
.entete {
  display: flex;
  justify-content: space-between;
  width: 95%;
}
.entete .cartes-titre {
  width: 100%;
  font-size: 1.4rem;
  padding: 1.5rem 0 0 1rem;
}
.entete .btn-coeur {
  width: 20%;
  display: flex;
  justify-content: flex-end;
  font-size: 1.3rem;
  margin: 1.5rem 0.5rem;
}
.entete .btn-menu {
  width: 2rem;
  height: 2rem;
  border: 0 solid transparent;
  padding: 0;
  cursor: pointer;
  position: relative;
  background-color: #000;
}
.entete .btn-menu::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.entete .btn-menu:hover::before {
  opacity: 1;
}
.entete .btn-menu::before {
  opacity: 0;
  transition: 0.5s;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(0deg, #9356DC, #FF79DA);
}
.entete .icon {
  font-size: 1.8rem;
  transition-duration: 0.25s;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  mix-blend-mode: lighten;
  background-color: white;
}
.entete .icon-j-aime {
  font-size: 1.8rem;
  transition-duration: 0.25s;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  mix-blend-mode: lighten;
  background-color: white;
}
.entete .btn-menu:hover .icon-j-aime {
  opacity: 0;
}

/***************************************
Section menus
***************************************/
.menus {
  max-width: 100%;
  min-width: 100%;
  display: flex;
  flex-direction: column;
}
.menus .section-menus {
  max-width: 100%;
  padding: 0 0.5rem;
  margin: 0 1rem;
}
.menus .carte-titre {
  font-size: 1rem;
  font-weight: inherit;
  margin-top: 20px;
}
.menus .separateur {
  width: 4rem;
  height: 4px;
  background-color: #99E2D0;
  margin: 0.5rem 0 0 0;
}

/*****************************************
Container des menus
*****************************************/
.container {
  border-radius: 0.9rem;
  box-shadow: 0.2rem 0.2rem 1rem;
  padding: 0.5rem 1rem;
  margin: 1rem 0;
  overflow: hidden;
  cursor: pointer;
}
.container .menus-header {
  flex: 1;
  overflow: hidden;
  white-space: nowrap;
}
.container .menus-titre {
  font-weight: inherit;
  font-size: 1rem;
  text-overflow: ellipsis;
  overflow: hidden;
}
.container .menus-description {
  font-size: 1rem;
  text-overflow: ellipsis;
  overflow: hidden;
}
.container .menus-prix {
  font-family: "roboto";
  padding-bottom: 6px;
  padding-left: 0.5rem;
  font-weight: bold;
}

.entrees {
  animation-delay: 0s;
  animation: ico-menus 0.5s;
  animation-fill-mode: both;
  transform: scale(0);
  max-width: 100%;
}

.plats {
  animation-delay: 0.5s;
  animation: ico-menus 1s;
  animation-fill-mode: both;
  transform: scale(0);
  max-width: 100%;
}

.desserts {
  animation-delay: 1s;
  animation: ico-menus 1.5s;
  animation-fill-mode: both;
  transform: scale(0);
  max-width: 100%;
}

.menus-choix {
  width: 4rem;
  height: 5rem;
  margin: -1rem -5rem -1rem 1rem;
  border-bottom-right-radius: 0.9rem;
  border-top-right-radius: 0.9rem;
  transition-duration: 0.5s;
  background-color: #99e2d0;
  position: relative;
  animation: ico-menus 1s;
}

.menus-icon {
  width: 1.5rem;
  height: 1.5rem;
  background-color: #fff;
  border-radius: 100px;
  transition-duration: 0.5s;
  transition-property: transform;
  color: #99e2d0;
  animation-fill-mode: both;
  cursor: pointer;
}

.menu:hover {
  animation-fill-mode: both;
  transform: scale(0);
  max-width: 100%;
}
.menu:hover .menus-choix {
  margin-right: -1rem;
}
.menu:hover .menus-choix .menus-icon {
  animation: chevron 1s;
}

/*************************************
Bouton commander
*************************************/
.cmd {
  font-size: 1rem;
  padding: 1rem 5rem;
  margin: 3rem 3rem 5rem 3rem;
  border-radius: 100px;
  color: white;
  border: #9356DC;
  background-image: linear-gradient(to top, #9356DC, #FF79DA);
  box-shadow: 5px 5px 10px #cecdcd, -5px -5px 10px #cfcece;
  cursor: pointer;
  transition: opacity 0.8s;
}
.cmd:hover {
  background-color: #cc00ff;
  border: transparent;
  opacity: 0.9;
}
.cmd:active {
  box-shadow: inset -2px -2px 3px rgba(255, 255, 255, 0.6), inset 2px 2px 3px rgba(0, 0, 0, 0.6);
  border: transparent;
}

/****************************************************
Footer des restaurants
****************************************************/
.footer-restaurants {
  background-color: black;
  width: 100%;
}
.footer-restaurants .footer-container {
  padding: 1rem;
}

.footer-menus a {
  color: white;
  list-style: none;
  text-decoration: none;
}
.footer-menus a .footer-logo {
  color: white;
  text-decoration: none;
  font-family: "Shrikhand", Roboto;
  font-size: 1.5rem;
}
.footer-menus a .footer-liens {
  padding: 0.2rem;
}
.footer-menus a .footer-icon1 {
  padding: 0.3rem;
  font-size: 1rem;
}
.footer-menus a .footer-icon2 {
  padding: 0.3rem;
  font-size: 0.7rem;
}
/***********************************************************************
Page d'accueil des restaurants
***********************************************************************/
@media screen and (min-width: 280px) and (max-width: 767.98px) {
  .explore-section {
    height: 20rem;
  }
  .explore-section .explore-texte {
    margin: 0 0 3rem 0;
  }
}
@media screen and (min-width: 767.98px) and (max-width: 1024px) {
  .explore-section {
    height: 20rem;
  }
  .explore-section .explore-texte {
    margin: 0 0 3rem 0;
  }

  .fct-section .fct-titre {
    padding: 3rem 7rem 1rem 1.5rem;
    text-align: left;
    font-size: 1.5rem;
  }

  .section-restaurants {
    width: auto;
    background-color: #f2f2f2f2;
  }
  .section-restaurants .section-titre {
    text-align: left;
    padding: 0 0 0 1rem;
  }
  .section-restaurants .container-restaurants {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 50px 1fr 1fr;
    margin: 0rem 0 0 0;
  }
  .section-restaurants .contenu-restaurants {
    grid-row-start: 2 span;
  }
  .section-restaurants .diapos1 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos2 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos3 {
    grid-row-start: 3;
  }
  .section-restaurants .diapos4 {
    grid-row-start: 5;
  }
  .section-restaurants .diapos-restaurants {
    margin: 0.5rem 1rem 3rem 1rem;
  }
  .section-restaurants .contenu-restaurants .rest-img {
    width: 46vw;
    height: 20vw;
  }
}
@media screen and (min-width: 1024px) and (max-width: 1600px) {
  .explore-section {
    height: 20rem;
  }
  .explore-section .explore-texte {
    margin: 0 0 3rem 0;
  }

  .fct-section {
    display: block;
    align-items: center;
    width: 100%;
  }
  .fct-section .fct-titre {
    padding: 3rem 7rem 1rem 7rem;
    text-align: center;
  }

  .fct-container {
    display: contents;
    flex-direction: column;
    margin: 0 0 0 0;
  }
  .fct-container .btns {
    display: flex;
    justify-content: space-evenly;
    margin: 0rem 0rem 1rem 0rem;
    padding: 0 0 0 1.5rem;
  }
  .fct-container .btn1 {
    padding: 0 2rem 0 0;
    margin: 1rem 1.5rem 1rem 1rem;
  }
  .fct-container .btn2 {
    padding: 0 3rem 0 0;
    margin: 1rem 1.5rem 1rem 1rem;
  }
  .fct-container .btn3 {
    padding: 0 3rem 0 0;
    margin: 1rem 1.5rem 1rem 1rem;
  }

  .section-restaurants {
    width: auto;
    background-color: #f2f2f2f2;
  }
  .section-restaurants .section-titre {
    text-align: left;
    padding: 0 0 0 1rem;
  }
  .section-restaurants .container-restaurants {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 50px 1fr 1fr;
    margin: 5rem 0 0 0;
  }
  .section-restaurants .contenu-restaurants {
    grid-row-start: 2 span;
  }
  .section-restaurants .diapos1 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos2 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos3 {
    grid-row-start: 3;
  }
  .section-restaurants .diapos4 {
    grid-row-start: 5;
  }
  .section-restaurants .diapos-restaurants {
    margin: 0.5rem 1rem 3rem 1rem;
  }
  .section-restaurants .contenu-restaurants .rest-img {
    width: 47vw;
    height: 20vw;
  }
}
/*/ X-Large devices (large desktops)*/
@media screen and (min-width: 1600px) and (max-width: 2000px) {
  .explore-section {
    height: 20rem;
  }
  .explore-section .explore-texte {
    margin: 0 0 3rem 0;
  }

  .fct-section {
    display: block;
    align-items: center;
    width: 100%;
  }
  .fct-section .fct-titre {
    padding: 3rem 7rem 1rem 7rem;
    text-align: center;
  }

  .fct-container {
    display: contents;
    flex-direction: column;
    margin: 0 0 0 0;
  }
  .fct-container .btns {
    display: flex;
    justify-content: space-evenly;
    margin: 0rem 0rem 1rem 0rem;
    padding: 0 0 0 3rem;
  }
  .fct-container .btn1 {
    padding: 0 2rem 0 0;
    margin: 1rem 2.5rem 1rem 1rem;
  }
  .fct-container .btn2 {
    padding: 0 3rem 0 0;
    margin: 1rem 2.5rem 1rem 1rem;
  }
  .fct-container .btn3 {
    padding: 0 3rem 0 0;
    margin: 1rem 2.5rem 1rem 1rem;
  }

  .section-restaurants {
    width: auto;
    margin: 0rem;
    border-radius: 0px;
  }
  .section-restaurants .section-titre {
    text-align: left;
    padding: 0 0 0 1rem;
  }
  .section-restaurants .container-restaurants {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 50px 1fr 1fr;
    margin: 5rem 0 0 0;
  }
  .section-restaurants .contenu-restaurants {
    grid-row-start: 2 span;
  }
  .section-restaurants .diapos1 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos2 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos3 {
    grid-row-start: 3;
  }
  .section-restaurants .diapos4 {
    grid-row-start: 5;
  }
  .section-restaurants .diapos-restaurants {
    margin: 0.5rem 1rem 3rem 1rem;
  }
  .section-restaurants .contenu-restaurants .rest-img {
    width: 48vw;
    height: 20vw;
  }
}
/*/ X-Large devices (large desktops)*/
@media screen and (min-width: 2000px) {
  .explore-section {
    height: 20vh;
  }
  .explore-section .explore-texte {
    margin: 0 0 3rem 0;
  }

  .fct-section {
    display: block;
    align-items: center;
    width: 100%;
  }
  .fct-section .fct-titre {
    padding: 3rem 7rem 1rem 7rem;
    text-align: center;
  }

  .fct-container {
    display: contents;
    flex-direction: column;
    margin: 0 0 0 0;
  }
  .fct-container .btns {
    display: flex;
    margin: 0rem 0rem 1rem 0rem;
    padding: 0 0 0 3rem;
    justify-content: space-evenly;
  }
  .fct-container .btn1 {
    padding: 0 2rem 0 0;
    margin: 1rem 2.5rem 1rem 1rem;
  }
  .fct-container .btn2 {
    padding: 0 3rem 0 0;
    margin: 1rem 2.5rem 1rem 1rem;
  }
  .fct-container .btn3 {
    padding: 0 3rem 0 0;
    margin: 1rem 2.5rem 1rem 1rem;
  }

  .section-restaurants {
    width: auto;
    margin: 0rem;
    border-radius: 0px;
  }
  .section-restaurants .section-titre {
    text-align: left;
    padding: 0 0 0 1rem;
  }
  .section-restaurants .contenu-restaurants {
    grid-row-start: 2 span;
  }
  .section-restaurants .diapos1 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos2 {
    grid-row-start: 2;
  }
  .section-restaurants .diapos3 {
    grid-row-start: 3;
  }
  .section-restaurants .diapos4 {
    grid-row-start: 5;
  }
  .section-restaurants .container-restaurants {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 50px 1fr 1fr;
    margin: 5rem 0 0 0;
  }
  .section-restaurants .container-restaurants .rest-img {
    width: 48vw;
    height: 20vw;
  }
  .section-restaurants .diapos-restaurants {
    margin: 0.5rem 1rem 3rem 1rem;
  }
}
/***********************************************************************
Pages des cartes des restaurants
***********************************************************************/
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .img-menus {
    height: 50vw;
    object-position: center;
  }

  .carte-restaurant {
    width: 80%;
    background-color: white;
    margin-top: -6.8rem;
    border-radius: 2rem 2rem 0 0;
  }

  .footer-restaurants {
    width: 80%;
  }
}
@media screen and (min-width: 1024px) and (max-width: 1315px) {
  .img-menus {
    height: 40vw;
    object-position: center;
  }

  .carte-restaurant {
    width: 100%;
    background-color: white;
    margin-top: -6.8rem;
    border-radius: 2rem 2rem 0 0;
  }
  .carte-restaurant .entete .cartes-titre {
    padding: 2rem 0 0 0.5rem;
    text-align: center;
  }
  .carte-restaurant .entete .coeur {
    justify-content: flex-end;
    margin: 2.5rem 0;
  }

  .menus {
    flex-direction: row;
    max-width: 95%;
    min-width: 95%;
  }
  .menus .section-menus {
    max-width: 30%;
    min-width: 30%;
    padding: 0 0 0 0;
  }
  .menus .entrees {
    max-width: 90%;
  }
  .menus .plats {
    max-width: 90%;
  }
  .menus .desserts {
    max-width: 90%;
  }

  .footer-restaurants {
    width: 100%;
  }
}
@media screen and (min-width: 1315px) and (max-width: 1715px) {
  .img-menus {
    height: 40vw;
    object-position: center;
  }

  .carte-restaurant {
    width: 100%;
    background-color: white;
    margin-top: -6.8rem;
    border-radius: 2rem 2rem 0 0;
  }
  .carte-restaurant .entete .cartes-titre {
    padding: 2rem 0 0 0.5rem;
    text-align: center;
  }
  .carte-restaurant .entete .coeur {
    justify-content: flex-end;
    margin: 2.5rem 0;
  }

  .menus {
    flex-direction: row;
    max-width: 90%;
    min-width: 90%;
  }
  .menus .section-menus {
    max-width: 30%;
    min-width: 30%;
  }
  .menus .entrees {
    max-width: 90%;
  }
  .menus .plats {
    max-width: 90%;
  }
  .menus .desserts {
    max-width: 90%;
  }
}
@media screen and (min-width: 1715px) and (max-width: 3500px) {
  .img-menus {
    width: 100%;
    height: 40vw;
    object-position: center;
  }

  .carte-restaurant {
    width: 100%;
    flex-direction: row;
    position: relative;
    margin-top: -8.8rem;
    background-color: white;
    border-radius: 2rem 2rem 0 0;
    max-width: 1715px;
  }
  .carte-restaurant .entete {
    flex-direction: column;
    width: 10%;
  }
  .carte-restaurant .entete .cartes-titre {
    padding: 3.5rem 0 0 0.5rem;
    text-align: center;
    font-size: 1.3rem;
    margin: 0 1rem 0 0;
  }
  .carte-restaurant .entete .btn-coeur {
    width: 20%;
    display: flex;
    justify-content: center;
    font-size: 1.3rem;
    margin: 1rem auto;
  }

  .menus {
    max-width: 65%;
    min-width: 65%;
    display: flex;
    flex-direction: row;
    padding-bottom: 15px;
  }
  .menus .section-menus {
    max-width: 30%;
    min-width: 30%;
  }
  .menus .entrees {
    max-width: 90%;
  }
  .menus .plats {
    max-width: 90%;
  }
  .menus .desserts {
    max-width: 90%;
  }

  .cmd {
    margin: 7rem 1.5rem 5rem 1.5rem;
  }

  .footer-restaurants {
    max-width: 1715px;
  }
}
* {
  margin: 0;
  padding: 0;
}

header {
  box-shadow: 0.2rem 0.2rem 1rem;
  position: relative;
  width: 100%;
  text-align: center;
  z-index: 1000;
  font-family: "Shrikhand", Roboto;
}

main {
  height: auto;
}

section {
  display: block;
}

.logo-accueil {
  font-size: 1rem;
}

h1, h2, h3, h4 {
  font-family: "Shrikhand", cursive;
  font-style: normal;
  font-weight: normal;
  font-size: 1.5rem;
  text-decoration: none;
}

p {
  font-family: "Roboto", sans-serif;
}

/*******************************************
Positionnement du site en milieu de page
*******************************************/
html, header, main, body {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: left;
  background-color: #f2f2f2;
  width: 100%;
  height: auto;
  margin: 0;
}

/*************************************************
Loader page d'accueil
*************************************************/
.loader {
  position: fixed;
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
  background-color: rgba(255, 255, 255, 0.9);
  animation: loader 0.06s;
  animation-delay: 3.75s;
  animation-fill-mode: both;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.loader__pins {
  height: 1rem;
  width: 1rem;
  font-size: 2rem;
  border-radius: 1rem;
  animation: popcorn 1s;
  animation-iteration-count: 4;
}
.loader__pinsContainer {
  display: flex;
  width: 50%;
  height: 5rem;
  justify-content: space-around;
  justify-items: center;
  margin: 0 2rem 0 0;
}
.loader__pins--2 {
  animation-delay: 0.55s;
}
.loader__pins--3 {
  animation-delay: 0.25s;
}

/****************************************************/

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