@charset "UTF-8";
body {
  color: #666666;
  font-family: Poppins;
  font-size: 16px;
  line-height: 24.8px;
  /* 155% */
}
h1, h2, h3, h4 {
  color: #004F51;
}
h1 a, h2 a, h3 a, h4 a {
  color: #004F51;
}
h1 a:hover, h2 a:hover, h3 a:hover, h4 a:hover {
  color: #002F30;
}
h1, h2, h3, h4, p {
  margin: 0;
}
h1, h1 a {
  font-size: 60px;
  font-weight: 700;
  line-height: 150%;
  /* 90px */
  letter-spacing: -0.66px;
  margin-bottom: 13px;
}
@media (max-width: 1200px) {
  h1, h1 a {
    font-size: 55px;
  }
}
@media (max-width: 768px) {
  h1, h1 a {
    font-size: 40px;
  }
}
h2, h2 a {
  font-size: 42px;
  font-weight: 700;
  line-height: 150%;
  /* 63px */
  letter-spacing: -0.462px;
  margin-bottom: 20px;
}
@media (max-width: 1200px) {
  h2, h2 a {
    font-size: 32px;
  }
}
@media (max-width: 768px) {
  h2, h2 a {
    font-size: 28px;
  }
}
h3, h3 a {
  font-size: 28px;
  font-weight: 600;
  line-height: 150%;
  /* 42px */
  letter-spacing: -0.308px;
}
@media (max-width: 1200px) {
  h3, h3 a {
    font-size: 22px;
  }
}
@media (max-width: 768px) {
  h3, h3 a {
    font-size: 20px;
  }
}
h4, h4 a {
  font-size: 22px;
  font-weight: 600;
  line-height: 150%;
  /* 33px */
  letter-spacing: -0.242px;
}
@media (max-width: 1200px) {
  h4, h4 a {
    font-size: 20px;
  }
}
@media (max-width: 768px) {
  h4, h4 a {
    font-size: 18px;
  }
}
.btn {
  text-align: center;
  font-size: 15px;
  font-weight: 700;
  line-height: 24.8px;
  /* 165.333% */
}
.date-actu {
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}
.is-layout-flex {
  flex-wrap: wrap;
}
.bg-beige {
  background-color: #F8F4F2;
}
header {
  width: calc(100% - 80px);
  margin: 40px;
  background-color: #E63352;
  text-align: center;
  border-radius: 20px;
  padding: 23px 30px 10px 30px;
  position: relative;
  z-index: 2;
}
header .wp-block-group.has-background {
  padding: 0;
}
header * {
  color: #fff;
}
header figure.wp-block-image {
  margin-bottom: 5px;
}
@media (max-width: 792px) {
  header figure.wp-block-image img {
    max-width: 200px;
  }
}
header div.top-header {
  position: absolute;
  top: 3px;
  right: 3px;
  margin-top: 0;
}
header div.top-header > p {
  padding-left: 23px;
  margin-right: 15px;
  padding-top: 6px;
  position: relative;
  font-weight: 500;
}
header div.top-header > p a {
  color: #fff;
}
header div.top-header > p a:hover {
  color: #F8F4F2;
}
header div.top-header > p::before {
  content: "";
  position: absolute;
  font-family: "Font Awesome 6 Pro";
  top: 3px;
  left: 0;
  width: 12px;
  height: 12px;
}
header div.top-header ul.wp-block-social-links {
  gap: 2px;
}
@media (max-width: 1200px) {
  header div.top-header {
    position: relative;
    justify-content: center;
  }
  header div.top-header > p {
    margin-left: unset;
    font-size: 14px;
    margin-right: 6px;
  }
}
header > div.wp-block-group {
  position: relative;
}
header div#bouton-menu {
  background: #2B2122;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
}
header div.bouton-menu {
  position: absolute;
  top: 0;
  left: 0;
  display: none;
  margin-top: 0;
}
header div.bouton-menu a {
  position: relative;
  padding: 0px 0px 0px;
  font-size: 1px;
  width: 24px;
  color: transparent;
  height: 2px;
  background-color: #fff;
  font-size: 2px;
  transition: transform 0.3s ease;
}
header div.bouton-menu a:before, header div.bouton-menu a:after {
  content: "";
  position: absolute;
  width: 24px;
  top: 8px;
  left: 0px;
  height: 2px;
  background-color: #fff;
}
header div.bouton-menu a:after {
  top: unset;
  bottom: 8px;
}
header div.bouton-menu.close a {
  transform: rotate(45deg);
}
header div.bouton-menu.close a:before {
  top: 0;
}
header div.bouton-menu.close a:after {
  bottom: 0px;
  transform: rotate(90deg);
}
@media (max-width: 1200px) {
  header div.bouton-menu {
    display: block;
    z-index: 99;
  }
}
@media (max-width: 1235px) {
  header {
    padding: 23px 23px 10px 23px;
  }
}
@media (max-width: 792px) {
  header {
    width: calc(100% - 0px);
    margin: 0px;
    border-radius: 0;
    padding: 10px;
    position: sticky;
    top: 0;
    margin-bottom: 20px;
  }
}
.wp-block-navigation:not(.has-background) .wp-block-navigation__submenu-container {
  border: 0px solid #00000026 !important;
}
div.menu-mutifolia nav {
  background-color: #E63352;
}
div.menu-mutifolia nav > ul {
  display: flex;
}
div.menu-mutifolia nav > ul > li {
  padding: 1rem;
  list-style: none;
  position: relative;
}
div.menu-mutifolia nav > ul > li:before {
  position: absolute;
  content: "";
  left: 0;
  bottom: 25px;
  width: 1px;
  height: 12px;
  background-color: #F8F4F2;
}
div.menu-mutifolia nav > ul > li a {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.198px;
}
div.menu-mutifolia nav > ul > li > ul.wp-block-navigation:not(.has-background), div.menu-mutifolia nav > ul > li .wp-block-navigation__submenu-container {
  border: none;
  border-bottom-left-radius: 20px;
  border-bottom-right-radius: 20px;
}
div.menu-mutifolia nav > ul > li > ul.wp-block-navigation:not(.has-background) li, div.menu-mutifolia nav > ul > li .wp-block-navigation__submenu-container li {
  border-bottom-left-radius: 20px;
  border-bottom-right-radius: 20px;
}
div.menu-mutifolia nav > ul > li:first-of-type:before {
  content: none;
}
div.menu-mutifolia nav a {
  color: #fff;
}
div.menu-mutifolia nav.menu-header-1 {
  gap: 5px;
}
div.menu-mutifolia nav.menu-header-1 li.li-ressources, div.menu-mutifolia nav.menu-header-1 li.li-contact {
  display: none;
}
@media (max-width: 1235px) {
  div.menu-mutifolia nav.menu-header-1 li.li-ressources, div.menu-mutifolia nav.menu-header-1 li.li-contact {
    display: flex;
  }
}
@media (max-width: 1200px) {
  div.menu-mutifolia nav.menu-header-1 {
    position: fixed;
    top: 0;
    left: 0;
    width: 300px;
    height: 100%;
    overflow-y: auto;
    transform: translateX(-100%);
    transition: transform 0.3s ease;
  }
  div.menu-mutifolia nav.menu-header-1 > ul {
    flex-direction: column;
    align-items: start;
    width: 100%;
    margin-top: 40px;
  }
  div.menu-mutifolia nav.menu-header-1 > ul li {
    flex-direction: column;
    width: 100%;
    align-items: start;
    padding-top: 0.3rem;
    padding-bottom: 0.3rem;
  }
  div.menu-mutifolia nav.menu-header-1 > ul li button {
    display: none;
  }
  div.menu-mutifolia nav.menu-header-1 > ul li:before {
    content: none;
  }
  div.menu-mutifolia nav.menu-header-1 > ul li ul.wp-block-navigation__submenu-container {
    display: flex;
    position: static;
    visibility: visible;
    align-items: start;
    opacity: 1;
    height: unset;
    overflow: visible;
    width: 100%;
  }
  div.menu-mutifolia nav.menu-header-1 > ul li ul.wp-block-navigation__submenu-container li {
    display: flex;
    width: 100%;
    text-align: left;
    padding-top: 0rem;
    padding-bottom: 0rem;
  }
  div.menu-mutifolia nav.menu-header-1 > ul li ul.wp-block-navigation__submenu-container li a {
    padding-top: 0.1rem;
    padding-bottom: 0.1rem;
  }
}
div.menu-mutifolia nav.menu-header-1.show {
  transform: translateX(0);
  z-index: 98;
}
@media (max-width: 792px) {
  div.menu-mutifolia nav.menu-header-1 {
    width: 100%;
  }
}
div.menu-mutifolia nav.menu-header-2 {
  gap: 5px;
}
@media (max-width: 1235px) {
  div.menu-mutifolia nav.menu-header-2 {
    display: none;
  }
}
@media (max-width: 1200px) {
  div.wp-block-group.menu-mutifolia {
    margin-top: 0;
  }
}
footer, .footer {
  width: 100%;
  background-color: #E63352;
  padding: 50px 20px;
}
footer > div, .footer > div {
  max-width: 1440px;
  margin: auto;
}
footer > div > p, .footer > div > p {
  margin-top: 30px;
}
footer > div > hr, .footer > div > hr {
  color: #373737;
  margin-top: 50px;
}
footer .is-layout-flex, .footer .is-layout-flex {
  gap: 24px;
}
@media (max-width: 1024px) {
  footer .is-layout-flex, .footer .is-layout-flex {
    flex-wrap: wrap !important;
  }
}
@media (max-width: 1024px) {
  footer .is-layout-flex .wp-block-column, .footer .is-layout-flex .wp-block-column {
    flex-basis: 46% !important;
  }
}
@media (max-width: 800px) {
  footer .is-layout-flex .wp-block-column, .footer .is-layout-flex .wp-block-column {
    flex-basis: 96% !important;
  }
}
footer div.colonne-logo-footer, .footer div.colonne-logo-footer {
  margin-right: 4%;
}
footer h5, .footer h5 {
  font-size: 21px;
  font-weight: 700;
  line-height: 32.55px;
  /* 155% */
  letter-spacing: 0.16px;
  margin-bottom: 22px;
}
footer h5, footer p, footer a, .footer h5, .footer p, .footer a {
  color: #fff;
}
footer p, .footer p {
  margin-bottom: 16px;
}
footer p, footer a, .footer p, .footer a {
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  /* 142.857% */
  letter-spacing: 0.14px;
}
footer a:where(:not(.wp-element-button)), .footer a:where(:not(.wp-element-button)) {
  color: #fff;
}
footer a:where(:not(.wp-element-button)):hover, .footer a:where(:not(.wp-element-button)):hover {
  color: #004F51;
}
footer a, .footer a {
  display: inline-block;
}
footer a svg, .footer a svg {
  width: auto !important;
  height: 20px !important;
}
footer a:hover, .footer a:hover {
  color: #004F51;
}
body.page.page-template-page_gamme div#breadcrumb {
  margin-bottom: 5px;
}
body.page.page-template-page_gamme div.page-gamme-top {
  max-width: 1920px;
}
body.page.page-template-page_gamme div.page-gamme-top p {
  max-width: 89%;
  margin-left: 0 !important;
}
@media (max-width: 1200px) {
  body.page.page-template-page_gamme div.page-gamme-top p {
    max-width: 99%;
  }
}
body.page.page-template-page_gamme div.title {
  position: absolute;
  top: 100px;
  left: 100px;
}
body.page.page-template-page_gamme div.title h1 {
  color: #fff;
  font-size: 12px;
}
body.page.page-template-page_gamme .content-1100 {
  padding-right: 0;
  padding-left: 0;
}
body.page.page-template-page_gamme .content-medium h2 {
  margin-top: 40px;
}
body.page.page-template-page_gamme main {
  margin-bottom: 0px !important;
}
body.page.page-template-page_gamme nav.menu-gamme {
  background-color: #F8F4F2;
  width: calc(100% - 80px);
  margin: auto;
  margin-bottom: 20px;
  border-radius: 20px;
}
body.page.page-template-page_gamme nav.menu-gamme ul {
  display: flex;
  max-width: 1376px;
  padding: 5px 0px;
  margin: auto;
  align-items: center;
}
body.page.page-template-page_gamme nav.menu-gamme ul li {
  list-style: none;
  padding: 10px;
  position: relative;
  width: -webkit-fill-available;
  text-align: center;
}
body.page.page-template-page_gamme nav.menu-gamme ul li a {
  font-size: 15px;
  font-weight: 700;
  line-height: normal;
  text-transform: uppercase;
  color: #666666;
}
body.page.page-template-page_gamme nav.menu-gamme ul li a:hover {
  color: #004F51;
}
body.page.page-template-page_gamme nav.menu-gamme ul li a.suite {
  margin-top: 0;
  padding: 10px 25px 8px;
  color: #fff;
}
body.page.page-template-page_gamme nav.menu-gamme ul li a.suite:hover {
  color: #fff;
}
body.page.page-template-page_gamme nav.menu-gamme ul li:before {
  content: "";
  position: absolute;
  top: calc(50% - 8px);
  bottom: calc(50% - 7px);
  left: 0px;
  height: 15px;
  width: 1px;
  background-color: rgba(102, 102, 102, 0.25);
}
body.page.page-template-page_gamme nav.menu-gamme ul li:first-of-type:before, body.page.page-template-page_gamme nav.menu-gamme ul li:last-of-type:before {
  content: none;
}
body.page.page-template-page_gamme nav.menu-gamme.sticky {
  position: sticky;
  top: 0;
}
@media (max-width: 792px) {
  body.page.page-template-page_gamme nav.menu-gamme {
    display: none;
  }
}
@media (max-width: 1200px) {
  body.page.page-template-page_gamme div.wp-block-column.is-vertically-aligned-center {
    padding-left: 40px !important;
    padding-right: 40px !important;
  }
}
@media (max-width: 792px) {
  body.page.page-template-page_gamme div.wp-block-column.is-vertically-aligned-center {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}
@media (max-width: 792px) {
  body.page.page-template-page_gamme .wp-block-group.has-background .content-medium, body.page.page-template-page_gamme .wp-block-group.has-background .content-large {
    padding: 0;
  }
}
.gamme.preview > div {
  border-radius: 20px;
  align-items: end;
}
.gamme.preview > div img {
  max-width: 100%;
}
.gamme.preview > div a {
  margin-bottom: 30px;
  margin-top: 20px;
}
.gamme.previewList {
  gap: 0px;
  border: 1px solid #EEE9E7;
  border-radius: 20px;
  flex-wrap: wrap !important;
}
.gamme.previewList > div.wp-block-column {
  display: flex;
  flex-wrap: wrap;
  justify-content: end;
  padding: 18px 0 29px 0;
  position: relative;
  align-self: stretch;
  flex-direction: column;
  border-right: 1px solid #EEE9E7;
}
.gamme.previewList > div.wp-block-column .picture.gamme {
  margin-bottom: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.gamme.previewList > div.wp-block-column .gamme.img.titre a {
  display: block;
  padding: 0 12px;
}
.gamme.previewList > div.wp-block-column p {
  padding: 5px 14px 0px 14px;
}
.gamme.previewList > div.wp-block-column .gamme.img.titre {
  height: 50px;
}
.gamme.previewList > div.wp-block-column:last-of-type {
  border-right: 0;
}
@media (max-width: 1300px) {
  .gamme.previewList > div.wp-block-column {
    flex-basis: unset;
    width: 33.3%;
  }
  .gamme.previewList > div.wp-block-column:first-of-type, .gamme.previewList > div.wp-block-column:nth-of-type(2) {
    width: 50%;
    border-bottom: 1px solid #EEE9E7;
  }
  .gamme.previewList > div.wp-block-column:nth-of-type(2) {
    border-right: 0;
  }
}
body.blog div#breadcrumb {
  margin-bottom: 20px;
}
body.blog div.description {
  margin: 13px 0 100px;
}
@media (max-width: 992px) {
  body.blog div.description {
    margin: 0;
  }
}
body.blog main.wrap.ressources .categorie-ressource {
  padding: 100px 0;
}
body.blog main.wrap.ressources .categorie-ressource:nth-of-type(odd) {
  background-color: #F8F4F2;
}
body.blog div.list-cat {
  margin-top: 20px;
  margin-bottom: 30px;
}
body.blog div.list-cat a {
  font-size: 15px;
  font-weight: 700;
  line-height: normal;
  text-transform: uppercase;
  color: #666666;
  padding-left: 25px;
  position: relative;
}
body.blog div.list-cat a:before {
  font-family: "Font Awesome 6 Pro";
  left: 0px;
  position: absolute;
  top: 3px;
  font-weight: 300;
  font-size: 15px;
}
body.blog div.list-cat a.categorie-5:before {
  content: "";
}
body.blog div.list-cat a.categorie-6:before {
  content: "";
}
body.blog div.list-cat a.categorie-7:before {
  content: "";
}
body.blog div.list-cat a.categorie-8:before {
  content: "";
}
body.blog div.list-cat a:hover {
  color: #002F30;
}
@media (max-width: 992px) {
  body.blog div.list-cat {
    flex-wrap: wrap;
  }
  body.blog div.list-cat a {
    width: 100%;
  }
}
body.blog div.ressource.d-flex {
  width: 125%;
}
body.blog div.ressource.d-flex div.left {
  width: 25%;
}
body.blog div.ressource.d-flex div.left h2 {
  margin: 24px 0;
}
body.blog div.ressource.d-flex div.left div.picto-categorie span svg {
  color: #666;
  opacity: 0.25;
  height: 75px;
}
body.blog div.ressource.d-flex div.left div.voir-tout a {
  border: 0;
  border-bottom: 1px solid #004F51;
  border-radius: 0;
}
@media (max-width: 992px) {
  body.blog div.ressource.d-flex div.left {
    width: 100%;
    flex-wrap: wrap;
    margin-bottom: 40px;
  }
  body.blog div.ressource.d-flex div.left div.voir-tout {
    width: 100%;
    text-align: center;
  }
}
body.blog div.ressource.d-flex div.right {
  width: 75%;
  display: flex;
  padding-left: 5.5%;
}
@media (max-width: 992px) {
  body.blog div.ressource.d-flex div.right {
    width: 100%;
    flex-wrap: wrap;
    padding-left: unset;
    justify-content: center;
  }
}
@media (max-width: 992px) {
  body.blog div.ressource.d-flex {
    width: 100%;
    flex-wrap: wrap;
  }
}
body.category main.wrap, body.tag main.wrap {
  position: relative;
}
body.category .article-loop, body.tag .article-loop {
  margin-bottom: 60px;
}
body.category div.description, body.tag div.description {
  margin: 13px 0 100px;
}
body.category div.content-medium, body.tag div.content-medium {
  padding-left: 0;
}
body.category div.pagination, body.tag div.pagination {
  margin-top: 80px;
  margin-bottom: 100px;
}
body.category div.pagination div.nav-links, body.tag div.pagination div.nav-links {
  text-align: center;
}
body.category div.pagination a.page-numbers, body.category div.pagination span.current, body.tag div.pagination a.page-numbers, body.tag div.pagination span.current {
  display: inline-block;
  width: 41px;
  height: 41px;
  padding: 10px;
  border-radius: 60px;
  text-align: center;
  color: rgba(0, 79, 81, 0.5);
  font-weight: 700;
  font-size: 15px;
}
body.category div.pagination span.current, body.tag div.pagination span.current {
  background: #004F51;
  color: #fff;
}
body.category div.icon-gamme, body.tag div.icon-gamme {
  position: absolute;
  top: 100px;
  right: 20px;
}
body.category div.icon-gamme svg, body.tag div.icon-gamme svg {
  height: 450px;
  opacity: 0.1;
}
@media (max-width: 1550px) {
  body.category div.icon-gamme svg, body.tag div.icon-gamme svg {
    height: 200px;
  }
}
@media (max-width: 1024px) {
  body.category div.icon-gamme, body.tag div.icon-gamme {
    display: none;
  }
}
.article-loop {
  max-width: 416px;
}
.article-loop .article-cat {
  gap: 5px;
  margin-bottom: 10px;
}
.article-loop div.picture {
  margin-bottom: 25px;
  cursor: pointer;
}
.article-loop img {
  border-radius: 20px;
}
.article-loop .picture {
  display: block;
  padding-top: 66%;
  position: relative;
}
.article-loop .picture img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: fill;
  transition: opacity ease 0.3s;
}
.article-loop .picture:hover img {
  opacity: 0.8;
}
.article-loop h4 {
  margin-bottom: 5px;
}
.article-loop .date {
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 20px;
}
@media (max-width: 992px) {
  .article-loop {
    width: 48%;
    margin-bottom: 30px;
  }
}
@media (max-width: 768px) {
  .article-loop {
    width: unset;
    margin-left: auto;
    margin-right: auto;
  }
}
.article.viewList {
  display: flex;
  gap: 24px;
}
.article.viewList > li {
  max-width: 416px;
}
.article.viewList > li h4 {
  margin-top: 12px;
}
.article.viewList > li figure {
  display: block;
  padding-top: 66%;
  position: relative;
}
.article.viewList > li figure img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: fill;
  transition: opacity ease 0.3s;
  border-radius: 20px;
}
.article.viewList > li .wp-block-post-date {
  margin-top: 10px;
  font-size: 12px;
  font-weight: 700;
}
.article.viewList > li .is-layout-flex.is-nowrap {
  gap: 4px;
}
@media (max-width: 992px) {
  .article.viewList > li {
    width: 48%;
    margin-bottom: 30px;
  }
}
@media (max-width: 768px) {
  .article.viewList > li {
    width: unset;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (max-width: 992px) {
  .article.viewList {
    flex-wrap: wrap;
  }
}
div.article div.taxonomy-post_tag a:before, article div.taxonomy-post_tag a:before, li.wp-block-post div.taxonomy-post_tag a:before {
  content: "";
  position: absolute;
  top: 1px;
  left: 0;
  font-family: "Font Awesome 6 Pro";
  font-weight: 400;
  font-size: 13px;
  bottom: 0;
  line-height: normal;
}
div.article.tag-bovifolia div.taxonomy-post_tag a:before, div.article .tag-Bovifolia div.taxonomy-post_tag a:before, article.tag-bovifolia div.taxonomy-post_tag a:before, article .tag-Bovifolia div.taxonomy-post_tag a:before, li.wp-block-post.tag-bovifolia div.taxonomy-post_tag a:before, li.wp-block-post .tag-Bovifolia div.taxonomy-post_tag a:before {
  content: "";
}
div.article.tag-equifolia div.taxonomy-post_tag a:before, div.article .tag-Equifolia div.taxonomy-post_tag a:before, article.tag-equifolia div.taxonomy-post_tag a:before, article .tag-Equifolia div.taxonomy-post_tag a:before, li.wp-block-post.tag-equifolia div.taxonomy-post_tag a:before, li.wp-block-post .tag-Equifolia div.taxonomy-post_tag a:before {
  content: "";
}
div.article.tag-vitifolia div.taxonomy-post_tag a:before, div.article .tag-Vitifolia div.taxonomy-post_tag a:before, article.tag-vitifolia div.taxonomy-post_tag a:before, article .tag-Vitifolia div.taxonomy-post_tag a:before, li.wp-block-post.tag-vitifolia div.taxonomy-post_tag a:before, li.wp-block-post .tag-Vitifolia div.taxonomy-post_tag a:before {
  content: "";
}
div.article.tag-ovifolia div.taxonomy-post_tag a:before, div.article .tag-Ovifolia div.taxonomy-post_tag a:before, article.tag-ovifolia div.taxonomy-post_tag a:before, article .tag-Ovifolia div.taxonomy-post_tag a:before, li.wp-block-post.tag-ovifolia div.taxonomy-post_tag a:before, li.wp-block-post .tag-Ovifolia div.taxonomy-post_tag a:before {
  content: "";
}
div.article.tag-lapifolia div.taxonomy-post_tag a:before, div.article .tag-Lapifolia div.taxonomy-post_tag a:before, article.tag-lapifolia div.taxonomy-post_tag a:before, article .tag-Lapifolia div.taxonomy-post_tag a:before, li.wp-block-post.tag-lapifolia div.taxonomy-post_tag a:before, li.wp-block-post .tag-Lapifolia div.taxonomy-post_tag a:before {
  content: "";
}
div.taxonomy-category, div.taxonomy-post_tag {
  border-radius: 50px;
  border: 1px solid #666;
  padding: 2px 11px 0px;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  color: #666666;
}
div.taxonomy-category a, div.taxonomy-post_tag a {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  color: #666666;
}
div.taxonomy-post_tag {
  border: 1px solid rgba(102, 102, 102, 0.25);
  background-color: rgba(102, 102, 102, 0.25);
}
div.taxonomy-post_tag a {
  position: relative;
  padding-left: 22px;
}
a.suite, a.wp-block-post-excerpt__more-link {
  padding: 10px 20px 8px;
  margin-top: 25px;
  color: #fff;
  background-color: #004F51;
  border-radius: 50px;
  font-size: 18px;
  font-weight: 500;
  line-height: normal;
  display: inline-block;
}
a.suite:hover, a.wp-block-post-excerpt__more-link:hover {
  background-color: #002F30;
}
a.wp-block-post-excerpt__more-link {
  position: relative;
  padding-right: 50px;
  margin-top: 0;
}
a.wp-block-post-excerpt__more-link:after {
  content: "";
  font-family: "Font Awesome 6 Pro";
  right: 23px;
  position: absolute;
  top: 15px;
  font-weight: 400;
  font-size: 16px;
}
body.single main {
  margin-bottom: 130px;
}
body.single div.date {
  margin-top: 20px;
  margin-bottom: 50px;
  font-size: 22px;
  font-weight: 600;
}
body.single p, body.single h2 {
  max-width: 856px;
  margin-left: auto;
  margin-right: auto;
}
body.single h2 {
  margin-bottom: 12px;
}
@media (max-width: 768px) {
  body.single h1 {
    font-size: 24px;
    text-align: left !important;
  }
  body.single div.date {
    margin-bottom: 25px;
    font-size: 18px;
  }
}
* {
  box-sizing: border-box;
}
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
img {
  max-width: 100%;
  height: auto;
}
.d-flex {
  display: flex;
}
.flex-wrap {
  flex-wrap: wrap;
}
.align-items-center {
  align-items: center;
}
.justify-content-center {
  justify-content: center;
}
.justify-content-between, .is-content-justification-space-between {
  justify-content: space-between;
}
.align-self-end {
  align-self: end;
}
.h-100 {
  height: 100%;
}
.text-center {
  text-align: center;
}
div#breadcrumb {
  margin-bottom: 50px;
  flex-wrap: wrap;
}
div#breadcrumb div.breadcrumb {
  color: #2B2122;
  margin-bottom: 25px;
  margin-right: 30px;
}
div#breadcrumb div.breadcrumb a {
  color: #666666;
}
div#breadcrumb div.breadcrumb a:hover {
  color: #002F30;
}
@media (max-width: 792px) {
  div#breadcrumb {
    margin-bottom: 20px;
  }
}
div.share-block {
  position: relative;
  cursor: pointer;
  background-color: #fff;
  align-self: end;
  margin-bottom: 25px;
}
div.share-block div.reseaux {
  position: absolute;
  top: 4px;
  left: 0;
  opacity: 0;
  z-index: -1;
  transition: all ease-in 0.3s;
}
div.share-block div.reseaux a .svg-inline--fa {
  padding-left: 0px;
  padding-right: 8px;
}
div.share-block div.reseaux.show {
  bottom: 0;
  left: 0;
  top: 24px;
  opacity: 1;
  z-index: 1;
}
a {
  text-decoration: none;
  transition: all ease-in-out 0.2s;
}
a .svg-inline--fa {
  padding-left: 8px;
}
a img {
  transition: all ease-in-out 0.2s;
}
a:hover img {
  opacity: 0.8;
}
.wp-element-button, .wp-block-button__link {
  padding: 10px 20px 8px;
  font-size: 18px;
  font-weight: 500;
}
.wp-element-button.has-secondary-background-color:hover, .wp-block-button__link.has-secondary-background-color:hover {
  background-color: #002F30 !important;
}
.wp-element-button.has-primary-background-color:hover, .wp-block-button__link.has-primary-background-color:hover {
  background-color: #BA223D !important;
}
a:where(:not(.wp-element-button)) {
  color: #002F30;
  text-decoration: none;
}
.content-area, .content-medium, .content-large, .content-xlarge, .content-half {
  display: block;
  margin: auto;
}
.content-medium, .content-large, .content-xlarge, .content-1767, .content-1100 {
  width: 100%;
  padding: 0 40px;
}
@media (max-width: 792px) {
  .content-medium, .content-large, .content-xlarge, .content-1767, .content-1100 {
    padding: 0 20px;
  }
}
.content-medium {
  max-width: 1080px;
}
.content-large {
  max-width: 1376px;
}
.content-xlarge {
  max-width: 1920px;
}
.content-1767 {
  max-width: 1767px;
  margin: auto;
}
.content-1235 {
  max-width: 1235px;
}
.content-1100 {
  max-width: 1100px;
  margin: auto;
}
.content-1063 {
  max-width: 1063px;
}
.content-350 {
  max-width: 350px;
  margin: auto;
}
.content-half {
  margin-left: calc((100vw - 1310px) / 2);
  overflow: hidden;
}
@media (max-width: 1390px) {
  .content-half {
    width: 100%;
    padding: 0 40px;
    margin-left: auto;
  }
}
@media (max-width: 1390px) and (max-width: 792px) {
  .content-half {
    padding: 0 20px;
  }
}
.content-full-width {
  width: 100%;
}
div.voir-tout a {
  padding: 10px 20px 8px 45px;
  margin-top: 25px;
  color: #004F51;
  border-radius: 50px;
  font-size: 18px;
  font-weight: 500;
  line-height: normal;
  display: inline-block;
  position: relative;
  border: 1px solid #004F51;
  background-color: transparent;
}
div.voir-tout a:before {
  content: "";
  /* this is your text. You can also use UTF-8 character codes as I do here */
  font-family: "Font Awesome 6 Pro";
  left: 17px;
  position: absolute;
  top: 16px;
  font-weight: 400;
  font-size: 16px;
}
div.voir-tout a:hover {
  color: #002F30;
  border: 1px solid #002F30;
}
body.page:not(.home) main {
  margin-bottom: 130px;
}
body.page:not(.home) .wp-block-group .content-1063 {
  margin-left: 0 !important;
  padding-left: 0 !important;
}
body.home {
  --swiper-pagination-bullet-size:10px;
  --swiper-pagination-bullet-width: 10px;
  --swiper-pagination-bullet-border-radius: 50px;
  --swiper-pagination-bullet-inactive-opacity: 0.5;
  --swiper-pagination-color: #004F51;
  --swiper-pagination-bullet-inactive-color: #004F51;
  --swiper-pagination-bullet-inactive-opacity: 0.25;
}
body.home header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 3;
}
@media (max-width: 792px) {
  body.home header {
    position: fixed;
  }
}
body.home .accueil-ressources {
  padding: 100px 0;
}
body.home .accueil-ressources h2 {
  margin-bottom: 20px;
}
body.home .accueil-ressources div.description {
  margin-bottom: 50px;
}
@media (max-width: 792px) {
  body.home main.wrap {
    margin-top: 60px;
  }
}
body.home div.carousel-homepage {
  --swiper-pagination-color: #fff;
  --swiper-pagination-bullet-inactive-color: #fff;
  --swiper-pagination-bullet-inactive-opacity: 0.5;
}
body.home div.carousel-homepage .swiper-horizontal {
  max-height: 100vh;
}
body.home div.carousel-homepage .swiper-horizontal img {
  width: 100%;
}
body.home div.carousel-homepage .swiper-horizontal .swiper-slide {
  max-height: 100vh;
}
@media (max-width: 792px) {
  body.home div.carousel-homepage .swiper-horizontal {
    height: auto;
  }
}
body.home div.carousel-homepage .text-carousel-homepage {
  position: absolute;
  bottom: 10%;
  right: 0;
  left: 0;
  color: #FFF;
  text-align: center;
  font-size: 50px;
  font-weight: 700;
  line-height: 150%;
  letter-spacing: -0.55px;
}
body.home div.carousel-homepage .text-carousel-homepage a {
  color: #fff;
  transition: all ease-in 0.2s;
}
body.home div.carousel-homepage .text-carousel-homepage span {
  position: relative;
  display: inline-block;
  z-index: 3;
}
body.home div.carousel-homepage .text-carousel-homepage span:after {
  content: "";
  position: absolute;
  top: 19px;
  left: -3px;
  right: 0;
  bottom: 3px;
  background: #e63352;
  z-index: -1;
}
body.home div.carousel-homepage .text-carousel-homepage a:hover {
  color: #F8F4F2;
}
@media (max-width: 1200px) {
  body.home div.carousel-homepage .text-carousel-homepage {
    font-size: 42px;
  }
}
@media (max-width: 900px) {
  body.home div.carousel-homepage .text-carousel-homepage {
    font-size: 32px;
  }
}
@media (max-width: 792px) {
  body.home div.carousel-homepage .text-carousel-homepage {
    font-size: 20px;
    bottom: 60px;
  }
}
body.home div.carousel-homepage .swiper-button-prev::after {
  content: "";
}
body.home div.carousel-homepage .swiper-button-next::after {
  content: "";
}
body.home div.carousel-homepage .swiper-button-prev, body.home div.carousel-homepage .swiper-button-next {
  top: 57%;
  color: #2B2122;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background-color: #fff;
}
body.home div.carousel-homepage .swiper-button-prev span, body.home div.carousel-homepage .swiper-button-next span {
  width: 18px;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 792px) {
  body.home div.carousel-homepage .swiper-button-prev, body.home div.carousel-homepage .swiper-button-next {
    display: none;
  }
}
body.home div.carousel-homepage .swiper-button-prev {
  left: 40px;
}
body.home div.carousel-homepage .swiper-button-next {
  right: 40px;
}
body.home div.carousel-homepage .swiper-horizontal > .swiper-pagination-bullets, body.home div.carousel-homepage .swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: var(--swiper-pagination-bottom, 19px);
}
body.home div.carousel-homepage .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, body.home div.carousel-homepage .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 2px);
}
body.home .swiper-pagination-bullet-active {
  --swiper-pagination-bullet-width: 20px;
}
body.home .description-safouin {
  max-width: 1088px;
  margin-left: 0 !important;
}
body.home div.wp-block-group.bloc-safouin {
  width: calc((100% / 1.054) + 40px);
  margin-left: auto;
}
body.home div.carousel-safouin {
  margin-top: 40px;
  margin-bottom: 100px;
  width: calc(100% / 1.054);
  margin-left: auto;
}
@media (min-width: 1920px) {
  body.home div.carousel-safouin {
    width: auto;
    margin-left: calc((100vw - 1735px) / 2);
  }
}
body.home div.carousel-safouin div.swifer {
  overflow: visible;
}
body.home div.carousel-safouin .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, body.home div.carousel-safouin .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 3px);
}
body.home div.carousel-safouin .swiper-horizontal > .swiper-pagination-bullets, body.home div.carousel-safouin .swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: var(--swiper-pagination-bottom, 0px);
  text-align: left;
}
@media (max-width: 992px) {
  body.home div.carousel-safouin .swiper-slide {
    width: 100%;
  }
}
body.home div.swiper-safouin {
  padding-bottom: 35px;
}
body.home div.swiper-safouin div.picture {
  position: relative;
}
body.home div.swiper-safouin div.picture img {
  border-radius: 20px;
}
body.home div.swiper-safouin div.text {
  position: absolute;
  bottom: 54px;
  left: 40px;
  right: 84px;
}
body.home div.swiper-safouin div.text h2, body.home div.swiper-safouin div.text div.description, body.home div.swiper-safouin div.text p, body.home div.swiper-safouin div.text a {
  color: #fff;
}
body.home div.swiper-safouin div.text h2 {
  margin-bottom: 6px;
}
body.home div.swiper-safouin div.text a:hover {
  color: #E63352;
}
@media (max-width: 992px) {
  body.home div.swiper-safouin div.text {
    bottom: 20px;
    left: 15px;
    right: 15px;
  }
  body.home div.swiper-safouin div.text h2, body.home div.swiper-safouin div.text div.description, body.home div.swiper-safouin div.text p, body.home div.swiper-safouin div.text a {
    font-size: 14px;
    line-height: 1.4;
  }
  body.home div.swiper-safouin div.text img {
    width: 32px;
  }
}
body.home div.voir-tout a {
  margin-top: 50px;
  border: 0;
  border-bottom: 1px solid #004F51;
  border-radius: 0;
}
.acf-postbox > .inside {
  display: flex !important;
  flex-wrap: wrap;
}
div.acf-fields > .acf-field {
  width: 33%;
}
.persona.previewList {
  padding: 20px 0px;
  margin: auto;
}
.persona.previewList > div {
  max-width: 1437px;
  justify-content: space-between;
  width: 100%;
  margin: auto;
}
.persona.preview {
  position: relative;
  padding: 30px;
}
.persona.preview img {
  border-radius: 50%;
}
.persona.preview div.wp-block-buttons {
  position: absolute;
  bottom: -40px;
  left: 0;
  right: 0;
}
@media (max-width: 792px) {
  .persona.preview div.wp-block-buttons {
    position: static;
  }
}
.persona.preview p {
  max-width: 350px;
  margin: auto;
}
.persona.preview:after {
  position: absolute;
  top: calc(50% - 65px);
  right: 0;
  bottom: calc(50% - 65px);
  content: "";
  width: 1px;
  height: 129px;
  background-color: #C6B8AF;
}
@media (max-width: 781px) {
  .persona.preview:after {
    content: none;
  }
}
.persona.preview:last-of-type:after {
  content: none;
}
@media (max-width: 960px) {
  .persona.preview {
    padding: 30px 10px;
  }
}
body.page.page-template-page-pleine-largeur main {
  margin-bottom: 0px;
}
body.page.page-template-page-pleine-largeur main .wp-block-group.has-background {
  padding: 0em 0em;
}
@media (max-width: 792px) {
  body.page.page-template-page-pleine-largeur .wp-block-group.has-background .content-medium, body.page.page-template-page-pleine-largeur .wp-block-group.has-background .content-large {
    padding: 0;
  }
  body.page.page-template-page-pleine-largeur .wp-block-column.is-vertically-aligned-center {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}
@media (max-width: 1024px) {
  body.page-template-page-3-colonnes .wp-block-columns {
    flex-wrap: wrap !important;
  }
  body.page-template-page-3-colonnes .wp-block-columns div.wp-block-column.picto {
    display: none;
  }
  body.page-template-page-3-colonnes .wp-block-columns div.wp-block-column.texte {
    padding-right: 40px;
    padding-left: 40px !important;
    flex-basis: 100% !important;
  }
  body.page-template-page-3-colonnes .wp-block-columns div.wp-block-column.image {
    padding-right: 40px !important;
    padding-left: 40px !important;
    flex-basis: 100% !important;
    margin: auto;
    margin-top: 20px;
  }
  body.page-template-page-3-colonnes .wp-block-columns div.wp-block-column.image figure {
    text-align: center;
  }
  body.page-template-page-3-colonnes .wp-block-columns.reverse {
    flex-direction: column-reverse !important;
  }
}
@media (max-width: 700px) {
  body.page-template-page-3-colonnes .wp-block-columns div.wp-block-column.texte, body.page-template-page-3-colonnes .wp-block-columns div.wp-block-column.image {
    padding-right: 20px !important;
    padding-left: 20px !important;
  }
}
div.contact-form {
  margin-top: 40px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
div.contact-form p {
  width: 48%;
  margin: 1%;
  margin-bottom: 20px;
}
@media (max-width: 600px) {
  div.contact-form p {
    width: 98%;
  }
}
div.contact-form label {
  width: 100%;
  display: block;
}
div.contact-form .form-text {
  margin-top: 8px;
  border: none;
  background-color: rgba(0, 79, 81, 0.1);
  width: 100%;
  padding: 16px 25px;
  border-radius: 8px;
}
div.contact-form div.textarea {
  width: 100%;
}
div.contact-form div.textarea p {
  width: 98%;
}
div.contact-form div.button {
  width: 100%;
}
div.contact-form div.button p {
  width: 98%;
}
div.contact-form div.button input {
  text-align: center;
  padding: 10px 20px 8px;
  font-size: 16px;
  border-radius: 50px;
  font-weight: 700;
  line-height: 24.8px;
  color: #fff;
  background-color: #004F51;
  transition: all ease-in-out 0.2s;
  border: 1px solid #004F51;
}
div.contact-form div.button input:hover {
  background-color: #002F30;
  border: 1px solid #002F30;
}
