html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  vertical-align: baseline;
  box-sizing: border-box;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

input {
  box-sizing: border-box;
}

.clearfix {
  content: "";
  display: table;
  clear: both;
}

* {
  box-sizing: border-box;
}

p, label, input, textarea, ul, ol {
  color: rgb(34, 31, 33);
  font-family: "Host Grotesk", sans-serif;
  font-optical-sizing: auto;
  font-weight: normal;
  font-style: normal;
  font-size: 1.25rem;
  line-height: 1.4;
  margin-bottom: 1.5rem;
}
p.small, label.small, input.small, textarea.small, ul.small, ol.small {
  font-size: 1rem;
}
@media (min-width: 600px) {
  p, label, input, textarea, ul, ol {
    font-size: 1.45rem;
  }
}
@media (min-width: 1224px) {
  p, label, input, textarea, ul, ol {
    font-size: 1.65rem;
  }
}

label, input, textarea {
  margin-bottom: 0;
}

strong, b {
  font-weight: bold;
}

h1, h2 {
  color: rgb(34, 31, 33);
  font-family: "Host Grotesk", sans-serif;
  font-optical-sizing: auto;
  font-weight: bold;
  font-style: normal;
  text-transform: uppercase;
}

h1 {
  font-size: 2rem;
  line-height: 1.2;
  margin-bottom: 2.5rem;
}
@media (min-width: 600px) {
  h1 {
    font-size: 2.25rem;
  }
}
@media (min-width: 1224px) {
  h1 {
    font-size: 2.5rem;
  }
}

h2 {
  font-size: 1.5rem;
  line-height: 1.2;
  margin-bottom: 2rem;
}
@media (min-width: 600px) {
  h2 {
    font-size: 1.75rem;
  }
}
@media (min-width: 1224px) {
  h2 {
    font-size: 2rem;
  }
}

a {
  scroll-margin-top: 7.5rem;
  color: unset;
  transition: font-weight 0.2s ease-in-out;
  text-decoration: none;
}
a:hover {
  font-weight: bolder;
}

.margin-right-outer-container {
  margin-right: calc((100vw - 1400px) / 2);
}
@media screen and (max-width: 1720px) {
  .margin-right-outer-container {
    margin-right: 2rem;
  }
}

.margin-left-outer-container {
  margin-left: calc((100vw - 1400px) / 2);
}
@media screen and (max-width: 1720px) {
  .margin-left-outer-container {
    margin-left: 2rem;
  }
}

.padding-right-outer-container {
  padding-right: calc((100vw - 1400px) / 2);
}
@media screen and (max-width: 1720px) {
  .padding-right-outer-container {
    padding-right: 2rem;
  }
}

.padding-left-outer-container {
  padding-left: calc((100vw - 1400px) / 2);
}
@media screen and (max-width: 1720px) {
  .padding-left-outer-container {
    padding-left: 2rem;
  }
}

.btn, .button, button {
  box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
  display: inline-block;
  transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
  background: none;
  border: 2px solid rgb(0, 153, 216);
  color: rgb(0, 153, 216);
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: normal;
  font-style: normal;
  font-size: 1.5rem;
  line-height: 1.2;
  position: relative;
  padding: 0.5rem 1rem;
  outline: none;
}
.btn:hover, .button:hover, button:hover {
  font-weight: unset;
  cursor: pointer;
  background: rgb(0, 153, 216);
  color: rgb(222, 241, 251);
}

.btn-primary, .button, button {
  color: rgb(0, 153, 216);
  border-color: rgb(0, 153, 216);
}
.btn-primary:hover, .btn-primary:focus-visible, .button:hover, .button:focus-visible, button:hover, button:focus-visible {
  color: rgb(222, 241, 251);
  background: rgb(0, 153, 216);
}

::selection {
  color: rgb(253, 254, 255);
  background: rgb(0, 153, 216);
}

html {
  font-size: 20px;
  scrollbar-width: none; /* For Firefox */
  -ms-overflow-style: none; /* For Internet Explorer and Edge */
  scroll-behavior: smooth;
}
html::-webkit-scrollbar {
  width: 0px; /* For Chrome, Safari, and Opera */
}
html body {
  background-color: rgb(253, 254, 255);
}
html body header#desktop-header {
  transition: background-color 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
  background-color: rgba(0, 0, 0, 0.2);
  position: fixed;
  padding-top: 1rem;
  padding-bottom: 1rem;
  display: none;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  z-index: 999;
}
html body header#desktop-header #logo a {
  display: block;
}
html body header#desktop-header #logo a img {
  transition: height 0.3s ease-in-out;
  height: 8rem;
  width: auto;
}
html body header#desktop-header nav ul {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  gap: 2rem;
  color: rgb(253, 254, 255);
  margin-bottom: 0;
  transition: font-weight 0.3s ease-in-out;
  text-transform: uppercase;
}
html body header#desktop-header nav ul li {
  position: relative;
}
html body header#desktop-header nav ul li ul {
  clip-path: inset(0 0 100% 0);
  visibility: hidden;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.3rem;
  padding: 0.75rem;
  position: absolute;
  margin-top: 0.5rem;
  color: rgb(34, 31, 33);
  width: 100%;
  background: rgb(253, 254, 255);
  transition: clip-path 0.4s ease-in-out, visibility 0.4s;
}
html body header#desktop-header nav ul li:hover ul {
  clip-path: inset(0 0 0 0);
  visibility: visible;
  transition: clip-path 0.4s ease-in-out, visibility 0s;
}
html body header#desktop-header.scrolled {
  background-color: rgb(253, 254, 255);
  box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;
}
html body header#desktop-header.scrolled #logo a img {
  height: 3rem;
}
html body header#desktop-header.scrolled nav ul {
  color: rgb(162, 118, 67);
  font-weight: lighter;
}
@media (min-width: 1224px) {
  html body header#desktop-header {
    display: flex;
  }
}
html body header#mobile-header {
  transition: background-color 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
  background-color: rgba(0, 0, 0, 0.2);
  position: fixed;
  padding-top: 1rem;
  padding-bottom: 1rem;
  width: 100%;
  z-index: 999;
}
html body header#mobile-header .mobile-header-inner {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}
html body header#mobile-header #logo a {
  display: block;
}
html body header#mobile-header #logo a img {
  transition: height 0.3s ease-in-out;
  height: 5rem;
  width: auto;
}
html body header#mobile-header nav {
  padding-top: 0;
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.4s ease-in-out, padding-top 0.4s ease-in-out;
}
html body header#mobile-header nav ul {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1rem;
  color: rgb(253, 254, 255);
  margin-bottom: 0;
  transition: font-weight 0.3s ease-in-out;
  text-transform: uppercase;
}
html body header#mobile-header nav ul li {
  position: relative;
}
html body header#mobile-header nav ul li ul {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.2rem;
  padding-inline: 0.75rem;
  width: 100%;
}
html body header#mobile-header nav.open {
  max-height: 300px;
  padding-top: 2rem;
}
html body header#mobile-header.scrolled {
  background-color: rgb(253, 254, 255);
  box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;
}
html body header#mobile-header.scrolled #logo a img {
  height: 3rem;
}
html body header#mobile-header.scrolled nav ul {
  color: rgb(162, 118, 67);
  font-weight: lighter;
}
@media (min-width: 1224px) {
  html body header#mobile-header {
    display: none;
  }
}
html body section#image-header {
  padding-top: 5rem;
  width: 100dvw;
  height: 25rem;
  margin-bottom: 5rem;
}
html body section#image-header img {
  width: 100%;
  height: 100%;
  object-position: center center;
  object-fit: cover;
}
html body section#video-header {
  position: relative;
  width: 100dvw;
  height: 100dvh;
  margin-bottom: 5rem;
}
html body section#video-header video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}
html body section#content {
  margin-bottom: 5rem;
}
html body section#content .block {
  margin-bottom: 2.5rem;
}
html body section#content section#login-content {
  padding-top: 5rem;
}
html body section#content section#login-content #login-form {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 5rem;
}
html body section#content section#login-content #login-form form {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 3rem;
}
html body section#content section#login-content #login-form form fieldset {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 1rem;
}
html body section#content section#login-content #login-form form fieldset input {
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
  padding: 0.25rem 0.25rem;
  color: rgb(34, 31, 33);
}
html body section#content .divider {
  margin-top: 5rem;
  margin-bottom: 5rem;
  height: 0.25rem;
  background-color: rgb(0, 153, 216);
  box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
}
html body section#content .divider-sm {
  margin-top: 2.5rem;
  margin-bottom: 5rem;
  height: 0.25rem;
  background-color: rgb(0, 153, 216);
  box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
}
html body section#content .button-container {
  margin-bottom: 2.5rem;
}
html body section#content .references-container.references-slider-container {
  margin-bottom: 0.5rem;
}
html body section#content .references-container.references-slider-container .reference-slider, html body section#content .references-container.references-slider-container .reference-slider-reverse {
  padding: 2rem 8px;
  height: calc(30vh + 4rem);
  min-height: 24rem;
  margin-right: -8px;
  margin-left: -8px;
  background-color: rgb(253, 254, 255);
  margin-top: -2rem;
}
html body section#content .references-container.references-slider-container .reference-slider .swiper-button-prev, html body section#content .references-container.references-slider-container .reference-slider .swiper-button-next, html body section#content .references-container.references-slider-container .reference-slider-reverse .swiper-button-prev, html body section#content .references-container.references-slider-container .reference-slider-reverse .swiper-button-next {
  color: rgb(0, 153, 216);
}
html body section#content .references-container.references-normal-container {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  grid-auto-rows: minmax(30vh, auto);
}
@media (min-width: 600px) {
  html body section#content .references-container.references-normal-container {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1224px) {
  html body section#content .references-container.references-normal-container {
    grid-template-columns: repeat(3, 1fr);
  }
}
html body section#content .references-container .reference-container {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: stretch;
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
}
html body section#content .references-container .reference-container img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-position: center center;
  object-fit: cover;
}
html body section#content .references-container .reference-container a {
  z-index: 1;
}
html body section#content .references-container .reference-container a .infos {
  z-index: 1;
  padding: 0.5rem 3rem 0.5rem 0.5rem;
  background-color: rgba(222, 241, 251, 0.7);
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}
html body section#content .references-container .reference-container a .infos:hover {
  cursor: pointer;
}
html body section#content .references-container .reference-container a .infos:hover p {
  font-weight: bolder;
}
html body section#content .references-container .reference-container a .infos:hover i {
  transform: translateX(2.5rem);
}
html body section#content .references-container .reference-container a .infos i {
  transition: transform 0.2s ease-in-out;
  font-size: 1.65rem;
}
html body section#content .references-container .reference-container a .infos p {
  transition: font-weight 0.2s ease-in-out;
  margin-bottom: 0;
  color: rgb(34, 31, 33);
  font-weight: lighter;
}
html body section#content .reference-detail-gallery-container {
  transition: opacity 1s ease-in-out;
}
html body section#content .reference-detail-gallery-container a {
  display: inline;
}
html body section#content .reference-detail-gallery-container a .reference-detail-gallery-img {
  box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
  width: 100%;
  transition: transform 0.2s ease-in-out;
  height: auto;
}
html body section#content .news-container {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  grid-auto-rows: minmax(30vh, auto);
}
@media (min-width: 600px) {
  html body section#content .news-container {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1224px) {
  html body section#content .news-container {
    grid-template-columns: repeat(3, 1fr);
  }
}
html body section#content .news-container a {
  display: inline-block;
}
html body section#content .news-container a .news-entry {
  height: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: stretch;
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
}
html body section#content .news-container a .news-entry:hover {
  cursor: pointer;
}
html body section#content .news-container a .news-entry:hover .infos p {
  font-weight: bolder;
}
html body section#content .news-container a .news-entry:hover .infos i {
  transform: translateX(2.5rem);
}
html body section#content .news-container a .news-entry img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-position: center center;
  object-fit: cover;
}
html body section#content .news-container a .news-entry .infos {
  z-index: 1;
  padding: 0.5rem 3rem 0.5rem 0.5rem;
  background-color: rgba(222, 241, 251, 0.7);
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}
html body section#content .news-container a .news-entry .infos i {
  transition: transform 0.2s ease-in-out;
  font-size: 1.65rem;
}
html body section#content .news-container a .news-entry .infos p {
  transition: font-weight 0.2s ease-in-out;
  margin-bottom: 0;
  color: rgb(34, 31, 33);
  font-weight: lighter;
}
html body section#content .contacts-block-container .contacts-container {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
@media (min-width: 600px) {
  html body section#content .contacts-block-container .contacts-container {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1224px) {
  html body section#content .contacts-block-container .contacts-container {
    grid-template-columns: repeat(4, 1fr);
  }
}
html body section#content .contacts-block-container .contacts-container .contact-container {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
  padding: 2rem 1rem;
}
html body section#content .contacts-block-container .contacts-container .contact-container img {
  width: 10rem;
  height: 10rem;
  object-fit: cover;
  object-position: center center;
  margin-bottom: 3rem;
}
html body section#content .contacts-block-container .contacts-container .contact-container p {
  margin-bottom: 0.5rem;
}
html body section#content .contacts-block-container .contacts-container .contact-container .links {
  margin-top: 1rem;
  display: flex;
  flex-direction: row;
  justify-content: center;
  gap: 0.5rem;
  align-items: center;
}
html body section#content .contacts-block-container .contacts-container .contact-container .links a {
  display: block;
  background-color: rgb(222, 241, 251);
  padding: 0.5rem;
  transition: background-color 0.2s ease-in-out;
}
html body section#content .contacts-block-container .contacts-container .contact-container .links a i {
  font-size: 1.2rem;
  color: rgb(34, 31, 33);
}
html body section#content .contacts-block-container .contacts-container .contact-container .links a:hover {
  background-color: rgb(0, 153, 216);
}
html body section#content .contact-infos-container {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: stretch;
  gap: 2rem;
}
html body section#content .contact-infos-container #map {
  background-color: rgb(179, 141, 99);
  width: 70%;
}
html body footer #footer-content {
  background-color: rgb(179, 141, 99);
  padding-top: 2rem;
  padding-bottom: 2rem;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  column-gap: 2rem;
}
html body footer #footer-content .footer-contact {
  grid-column-start: 1;
  grid-column-end: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 3rem;
}
html body footer #footer-content .footer-contact .logo {
  width: 100%;
  height: auto;
}
html body footer #footer-content .footer-contact .footer-contact-content p {
  color: rgb(253, 254, 255);
}
html body footer #footer-content .footer-partners {
  grid-column-start: 3;
  grid-column-end: 4;
}
html body footer #footer-content .footer-partners .footer-partners-container {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
html body footer #footer-content .footer-partners .footer-partners-container img {
  width: 100%;
  height: auto;
}
html body footer #footer-content .footer-nav {
  grid-column-start: 5;
  grid-column-end: 6;
}
html body footer #footer-content .footer-nav ul {
  margin-bottom: 0;
  color: rgb(253, 254, 255);
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-end;
  text-transform: uppercase;
}
html body footer #legal {
  background-color: rgb(153, 108, 56);
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}
html body footer #legal ul {
  margin-bottom: 0;
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  gap: 1rem;
  color: rgb(253, 254, 255);
}

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