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

* {
  margin: 0;
}

body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}

input, button, textarea, select {
  font: inherit;
}

p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

header {
  width: 100%;
  position: sticky;
  top: 0;
  z-index: 10;
}
header .main-menu {
  width: 100%;
  background-color: #F28305;
}
header .main-menu .main-menu-wrapper {
  padding: 1.25rem 1.5rem;
  height: 80px;
  margin: 0 auto;
  max-width: 1200px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (min-width: 792px) {
  header .main-menu .main-menu-wrapper {
    padding: 0 2rem;
  }
}
@media screen and (min-width: 1200px) {
  header .main-menu .main-menu-wrapper {
    height: 60px;
  }
}
header .main-menu .main-menu-wrapper .logo {
  height: 50px;
}
@media screen and (min-width: 1200px) {
  header .main-menu .main-menu-wrapper .logo {
    height: 44px;
  }
}
header .main-menu .main-menu-wrapper .logo img {
  height: 100%;
}
header .main-menu .main-menu-wrapper .menu-mobile {
  height: 1.5rem;
  width: 1.875rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
@media screen and (min-width: 792px) {
  header .main-menu .main-menu-wrapper .menu-mobile {
    display: none;
  }
}
header .main-menu .main-menu-wrapper .menu-mobile .barre {
  width: 1.5rem;
  height: 3px;
  background-color: #F2F2F2;
}
header .main-menu .main-menu-wrapper .hide {
  display: none;
}
header .main-menu .main-menu-wrapper .menu-desktop {
  font-family: "Bebas Neue", sans-serif;
  display: none;
}
@media screen and (min-width: 792px) {
  header .main-menu .main-menu-wrapper .menu-desktop {
    display: flex;
  }
}
header .main-menu .main-menu-wrapper .menu-desktop ul {
  font-size: 2rem;
  list-style-type: none;
  display: flex;
}
header .main-menu .main-menu-wrapper .menu-desktop ul a {
  padding: 1rem 3.5rem;
}
@media screen and (min-width: 1200px) {
  header .main-menu .main-menu-wrapper .menu-desktop ul a {
    padding: 0.375rem 3.5rem;
  }
}
header .main-menu .main-menu-wrapper .menu-desktop ul a:hover {
  background-color: #CB671B;
  color: #F2F2F2;
}
header .main-menu .main-menu-wrapper .menu-desktop ul a.selected {
  color: #F28305;
  background-color: #F2F2F2;
}
header .main-menu .main-menu-wrapper .menu-desktop ul a.selected:hover {
  color: #CB671B;
}
header .secondary-menu {
  background-color: #F2F2F2;
  display: none;
}
@media screen and (min-width: 792px) {
  header .secondary-menu {
    display: flex;
  }
}
header .secondary-menu nav {
  margin: 0 auto;
}
header .secondary-menu nav ul {
  display: flex;
  justify-content: center;
  list-style: none;
  gap: 1rem;
}
header .secondary-menu nav ul li a {
  color: #404040;
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.5rem;
  padding: 0.75rem;
  text-align: center;
}
header .secondary-menu nav ul li a:hover {
  color: #CB671B;
}
header .drop-down-menu {
  background: linear-gradient(180deg, #cb671b 0%, #cb671b 50%, rgba(203, 103, 27, 0.8) 100%);
  height: calc(100vh - 80px);
}
header .drop-down-menu .content {
  padding: 2rem;
  background-color: #CB671B;
}
header .drop-down-menu .content a {
  display: inline;
}
header .drop-down-menu .content a:hover {
  color: #262626;
}
header .drop-down-menu .content a.hide {
  display: none;
}
header .drop-down-menu .content h2 {
  padding: 2rem 0 1rem;
  font-size: 2.66rem;
}
header .drop-down-menu .content h2:first-child {
  margin-top: 0;
}
header .drop-down-menu .content h3 {
  padding: 0 2rem;
  font-size: 2rem;
}

@media screen and (min-width: 792px) {
  header.admin h2 {
    font-size: 2rem;
  }
}
header.admin .selected {
  color: #F28305;
}

* {
  transition: all ease-out 0.2s;
}

html {
  font-size: 12px;
}
@media screen and (min-width: 792px) {
  html {
    font-size: 16px;
  }
}

body {
  background-color: #404040;
  color: #F2F2F2;
  font-family: "Manrope", sans-serif;
}
body [v-cloak] {
  display: none;
}
body a:hover {
  color: #CB671B;
}
body h1, body h2, body h3, body h4, body h5, body h6 {
  color: #F28305;
  font-family: "Bebas Neue", sans-serif;
  font-weight: normal;
}
body h1 {
  color: #F2F2F2;
  font-size: 4rem;
}
body h2 {
  color: #F2F2F2;
  font-size: 2rem;
}
body h3 {
  font-size: 1.33rem;
}
body #root, body #__next {
  isolation: isolate;
}
body ul {
  padding: 0;
}
body a {
  display: block;
  text-decoration: none;
  color: #F2F2F2;
}
@media screen and (min-width: 792px) {
  body h1 {
    font-size: 9rem;
  }
  body h2 {
    font-size: 6rem;
  }
  body h3 {
    font-size: 4rem;
  }
  body h4 {
    font-size: 3rem;
  }
  body h5 {
    font-size: 2rem;
  }
  body h6 {
    font-size: 1.5rem;
  }
}
body svg {
  width: 32px;
  height: 32px;
  cursor: pointer;
}
body form {
  width: 100%;
  max-width: 400px;
}
body form div {
  width: 100%;
}
body form h2 {
  padding: 0;
}
@media screen and (min-width: 792px) {
  body form h2 {
    font-size: 1.5rem;
  }
}
body form input[type=text], body form input[type=password], body form input[type=number], body form textarea {
  padding: 0.75rem;
  font-size: 1rem;
  background-color: #F2F2F2;
  border: none;
  margin: 0.25rem 0 2rem;
  width: 100%;
}
body form input[type=number] {
  width: 6rem;
}
body form input[type=submit] {
  padding: 0.75rem 2rem;
  background-color: #F28305;
  border: none;
  border-radius: 0;
  font-family: "Bebas Neue", sans-serif;
  color: #F2F2F2;
  font-size: 1.33rem;
  margin-top: 2rem;
  cursor: pointer;
}
body form input[type=submit]:hover {
  background-color: #CB671B;
}
body form .file {
  width: 100%;
  padding: 0.375rem 0.75rem;
  color: #F2F2F2;
  border: #F2F2F2 2px solid;
  cursor: pointer;
}
body form textarea {
  resize: vertical;
}
body .hide {
  display: none;
}

main {
  margin-top: 2rem;
}
main h1 {
  padding: 0 2rem;
  max-width: 1200px;
  margin: 2rem auto;
}
main h2 {
  padding-bottom: 1rem;
  margin: 0 auto;
  max-width: 1200px;
}
main .content {
  padding: 2rem;
  max-width: 1200px;
  margin: 0 auto;
}
main .img-wrapper {
  width: 100%;
  height: 50vw;
  overflow: hidden;
}
@media screen and (min-width: 792px) {
  main .img-wrapper {
    height: 440px;
  }
}
main .img-wrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
main section:nth-child(even) {
  background-color: #262626;
}
main .section + .section {
  opacity: 0;
}

.menu section {
  padding: 2rem 0;
  scroll-margin-top: 80px;
}
@media screen and (min-width: 792px) {
  .menu section {
    scroll-margin-top: 140px;
  }
}
@media screen and (min-width: 1200px) {
  .menu section {
    scroll-margin-top: 120px;
  }
}
.menu section h2 {
  margin-bottom: 2rem;
  padding: 0 2rem;
}
.menu section .content {
  display: grid;
  grid-template-columns: repeat(1, auto);
  gap: 2rem;
  margin-bottom: 0;
}
@media screen and (min-width: 792px) {
  .menu section .content {
    grid-template-columns: repeat(2, auto);
  }
}
@media screen and (min-width: 1200px) {
  .menu section .content {
    grid-template-columns: repeat(3, auto);
  }
}
.menu section .content article .title-price {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (min-width: 792px) {
  .menu section .content article .title-price h3 {
    font-size: 2rem;
  }
}
.menu section .content article > p {
  margin: 0.33rem 0;
}
.menu section .content article .tags {
  display: flex;
  gap: 1rem;
  list-style-type: none;
}
.menu section .content article .tags li {
  font-style: italic;
}

.about-us section .content h2 {
  color: #F28305;
}
.about-us section .content p {
  margin: 1rem 0;
}
.about-us #reviews {
  background-color: #F28305;
  text-align: center;
}
.about-us #reviews .content {
  max-width: 600px;
}
.about-us #reviews .content h3 {
  color: #F2F2F2;
  font-size: 2rem;
  border-bottom: 1px solid #F2F2F2;
  margin-bottom: 2rem;
}
@media screen and (min-width: 792px) {
  .about-us #reviews .content h3 {
    font-size: 4rem;
  }
}
.about-us #reviews .content .review {
  border-bottom: 1px solid #F2F2F2;
}
.about-us #reviews .content .review:last-child {
  border: none;
}
.about-us #reviews .content .review .grade {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.33rem;
}

.connection {
  margin: 4rem auto 0;
  max-width: 735px;
}
@media screen and (min-width: 792px) {
  .connection h1 {
    font-size: 6rem;
    margin-bottom: 0;
  }
}
.connection .content {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 792px) {
  .connection .content {
    padding-top: 0;
  }
}
.connection .content .form-wrapper {
  padding: 4rem 2rem;
  background-color: #262626;
}
.connection .content .form-wrapper form {
  margin: 0 auto;
}
.connection .content .form-wrapper form input[type=submit] {
  font-size: 2rem;
  width: 100%;
}
.connection .content .form-wrapper form input[type=submit]:hover {
  background-color: #CB671B;
}
.connection .content a {
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.5rem;
  text-align: center;
  padding: 4rem 4rem 0;
  color: #F28305;
}
.connection .content a:hover {
  color: #CB671B;
}

main.admin h1 {
  font-size: 4rem;
}
main.admin h2 {
  font-size: 3rem;
}
main.admin .connection_infos {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 2rem;
  max-width: 1200px;
}
@media screen and (min-width: 1200px) {
  main.admin .connection_infos {
    margin: 0 auto;
  }
}
main.admin .connection_infos p {
  max-width: 60%;
}
main.admin .connection_infos a {
  color: #F28305;
  font-family: "Bebas Neue", sans-serif;
  font-size: 1.5rem;
}
main.admin .connection_infos a:hover {
  color: #CB671B;
}
main.admin .content h1 {
  padding: 0;
}
main.admin .content .list .item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #F2F2F2;
  padding: 1rem 0;
}
main.admin .content .list .item h3 {
  color: #F2F2F2;
  font-size: 1.5rem;
  max-width: calc(100% - 80px);
}
main.admin .content .list .item .icons {
  display: flex;
  gap: 2rem;
}
main.admin .content .list .item .icons svg {
  width: 24px;
  height: 24px;
  fill: #F2F2F2;
}
main.admin .content .list .item .icons svg:hover {
  fill: #F28305;
}
main.admin .content #create {
  padding: 5rem 0 1.5rem;
}
main.admin .content #create, main.admin .content #update {
  scroll-margin-top: 80px;
}
@media screen and (min-width: 792px) {
  main.admin .content #create, main.admin .content #update {
    scroll-margin-top: 140px;
  }
}
@media screen and (min-width: 1200px) {
  main.admin .content #create, main.admin .content #update {
    scroll-margin-top: 120px;
  }
}
main.admin .content #create .message, main.admin .content #update .message {
  padding: 1rem 0;
}
main.admin .content #create form div h2, main.admin .content #update form div h2 {
  font-size: 1.5rem;
}
main.admin .content #create form div h3, main.admin .content #update form div h3 {
  color: #F2F2F2;
}
@media screen and (min-width: 792px) {
  main.admin .content #create form div h3, main.admin .content #update form div h3 {
    font-size: 1.5rem;
  }
}
main.admin .content #create form div div, main.admin .content #update form div div {
  margin: 0.5rem 0;
}
main.admin .content #create form div .mention, main.admin .content #update form div .mention {
  font-style: italic;
  font-size: 0.8rem;
  padding: 1rem 0;
}
main.admin .content #create form .categories, main.admin .content #create form .tags, main.admin .content #update form .categories, main.admin .content #update form .tags {
  margin: 0.25rem 0 2rem;
  padding: 0.75rem 0;
}
main.admin .content #create input[type=submit], main.admin .content #update input[type=submit] {
  width: 100%;
}
main.admin .content #update h2 {
  font-size: 1.33rem;
}
main.admin .background-popup {
  position: fixed;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(38, 38, 38, 0.8);
}
main.admin .background-popup .popup {
  background-color: #F28305;
  padding: 4rem;
  margin: 2rem;
  position: relative;
}
main.admin .background-popup .popup svg {
  fill: #F2F2F2;
  position: absolute;
  top: 1rem;
  right: 1rem;
}
main.admin .background-popup .popup h1 {
  font-size: 2rem;
  padding: 0;
  margin: 0;
}
main.admin .background-popup .popup p {
  margin: 2rem 0;
  text-align: center;
}
main.admin .background-popup .popup .confirmation {
  display: flex;
  align-items: center;
  flex-direction: row-reverse;
  justify-content: center;
  gap: 2rem;
  margin-top: 4rem;
}
main.admin .background-popup .popup .confirmation a {
  padding: 0.75rem 2rem;
}
main.admin .background-popup .popup .confirmation .yes {
  background-color: #F2F2F2;
  border: 1px solid #F2F2F2;
  color: #F28305;
}
main.admin .background-popup .popup .confirmation .yes:hover {
  background-color: #CB671B;
  color: #F2F2F2;
}
main.admin .background-popup .popup .confirmation .no {
  border: 1px solid #F2F2F2;
}
main.admin .background-popup .popup .confirmation .no:hover {
  background-color: #CB671B;
  color: #F2F2F2;
}

.alert {
  border-left: 3px solid rgb(241, 64, 64);
  background-color: rgb(95, 6, 6);
  color: rgb(247, 150, 150);
}

.success {
  border-left: 3px solid rgb(83, 196, 83);
  background-color: rgb(5, 65, 5);
  color: rgb(190, 255, 190);
}

.alert, .success {
  padding: 1rem;
}

.message {
  max-width: 1200px;
  padding: 1rem 2rem 0;
}
@media screen and (min-width: 1200px) {
  .message {
    margin: 0 auto;
  }
}

.opened .barre1 {
  animation: close-top 0.5s cubic-bezier(0.83, 0, 0.17, 1) forwards;
}
.opened .barre2 {
  animation: close-middle 0.5s forwards;
}
.opened .barre3 {
  animation: close-bottom 0.5s cubic-bezier(0.83, 0, 0.17, 1) forwards;
}

.closed .barre1 {
  animation: open-top 0.5s cubic-bezier(0.83, 0, 0.17, 1) forwards;
}
.closed .barre2 {
  animation: open-middle 0.5s forwards;
}
.closed .barre3 {
  animation: open-bottom 0.5s cubic-bezier(0.83, 0, 0.17, 1) forwards;
}

.menu, .about-us {
  animation: fade-in 1s ease-out;
}
.menu h1, .about-us h1 {
  animation: slide-in 0.75s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.menu h2, .about-us h2 {
  animation: slide-in 0.75s cubic-bezier(0.7, 1.56, 0.64, 1);
}

.fade-in + .fade-in {
  animation: fade-in 1s ease-in forwards;
}
.fade-in + .fade-in .content {
  transform: translateX(-4rem);
  opacity: 0;
  animation: slide-in 0.75s cubic-bezier(0.34, 1.56, 0.64, 1) 0.5s forwards, fade-in 0.75s ease-in 0.5s forwards;
}

body {
  overflow-x: hidden;
}

@keyframes close-top {
  25% {
    transform: translateY(0.65rem) rotate(0);
    width: 1.5rem;
  }
  100% {
    transform: translateY(0.65rem) rotate(45deg);
    width: 1.875rem;
  }
}
@keyframes close-middle {
  25% {
    scale: 1;
  }
  100% {
    scale: 0;
  }
}
@keyframes close-bottom {
  25% {
    transform: translateY(-0.65rem) rotate(0);
    width: 1.5rem;
  }
  100% {
    transform: translateY(-0.65rem) rotate(-45deg);
    width: 1.875rem;
  }
}
@keyframes open-top {
  0% {
    transform: translateY(0.65rem) rotate(45deg);
    width: 1.875rem;
  }
  75% {
    transform: translateY(0.65rem);
    width: 1.5rem;
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes open-middle {
  0% {
    scale: 0;
  }
  75% {
    scale: 0;
  }
  100% {
    scale: 1;
  }
}
@keyframes open-bottom {
  0% {
    transform: translateY(-0.65rem) rotate(-45deg);
    width: 1.875rem;
  }
  75% {
    transform: translateY(-0.65rem) rotate(0);
    width: 1.5rem;
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes slide-in {
  0% {
    transform: translateX(-44rem);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
footer {
  background-color: #262626;
  border-top: 2px #F28305 solid;
}
footer .content-wrapper {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2.6rem 1.5rem;
}
footer .content-wrapper .content {
  display: flex;
  flex-direction: column;
  gap: 2.6rem;
  list-style-type: none;
}
@media screen and (min-width: 792px) {
  footer .content-wrapper .content {
    flex-direction: row;
    justify-content: space-between;
    gap: 0;
  }
}
@media screen and (min-width: 792px) {
  footer .content-wrapper .content > div {
    max-width: 25%;
  }
}
footer .content-wrapper .content > div .message {
  padding: 0 0 1rem;
}
footer .content-wrapper .content > div h2 {
  margin-bottom: 2rem;
  font-size: 2rem;
  color: #F28305;
}
footer .content-wrapper .content > div h3 {
  font-size: 1.33rem;
  color: #F2F2F2;
}
@media screen and (min-width: 792px) {
  footer .content-wrapper .content > div h3 {
    font-size: 1.5rem;
  }
}
footer .content-wrapper .content > div a:last-child {
  margin-bottom: 0;
}
footer .content-wrapper .content .navigation a {
  margin: 1rem 0;
}
footer .content-wrapper .content .navigation ul {
  list-style-type: none;
  margin: 1.33rem 0;
}
footer .content-wrapper .content #newsletter {
  scroll-margin-top: 80px;
}
@media screen and (min-width: 792px) {
  footer .content-wrapper .content #newsletter {
    scroll-margin-top: 140px;
  }
}
@media screen and (min-width: 1200px) {
  footer .content-wrapper .content #newsletter {
    scroll-margin-top: 120px;
  }
}
footer .content-wrapper .content #newsletter input[type=text] {
  margin: 0.25rem 0;
}
footer .content-wrapper .content #newsletter h3 {
  margin-top: 1rem;
}
footer .content-wrapper .content .contact p {
  margin: 1.33rem 0;
}
footer .content-wrapper .content .contact .logos {
  display: flex;
  gap: 1.33rem;
  align-items: center;
}
footer .content-wrapper .content .contact .logos svg {
  fill: #F2F2F2;
}
footer .content-wrapper .content .address p {
  margin: 1.33rem 0;
}
footer .content-wrapper .content .address div iframe {
  width: 100%;
  height: 200px;
}
footer .content-wrapper > p {
  margin-top: 2rem;
  font-size: 0.75rem;
}/*# sourceMappingURL=style.css.map */