@charset "UTF-8";
/*
Theme Name: Matthieu Demeillat - Enfant de Twenty Twenty-Five
Theme URI: https://www.matthieudemeillat.fr/
Description: Thème enfant basé sur Twenty Twenty-Five, pour site WordPress FSE personnalisé.
Author: Matthieu Demeillat
Author URI: https://www.matthieudemeillat.fr/
Template: twentytwentyfive
Version: 1.0
*/
/* Inter */
@font-face {
  font-family: "Inter";
  src: url("./assets/fonts/Inter-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Inter";
  src: url("./assets/fonts/Inter-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
/* Source Sans Pro */
@font-face {
  font-family: "Source Sans Pro";
  src: url("./assets/fonts/SourceSansPro-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Source Sans Pro";
  src: url("./assets/fonts/SourceSansPro-SemiBold.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
/* Space Grotesk */
@font-face {
  font-family: "Space Grotesk";
  src: url("./assets/fonts/SpaceGrotesk-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Space Grotesk";
  src: url("./assets/fonts/SpaceGrotesk-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
/* Fira Code */
@font-face {
  font-family: "Fira Code";
  src: url("./assets/fonts/FiraCode-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Fira Code";
  src: url("./assets/fonts/FiraCode-Medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
main {
  margin-top: 100px !important;
}

body {
  background: var(--wp--preset--color--blanc);
  color: var(--wp--preset--color--texte);
}

.is-style-tranche-blanc,
.is-style-tranche-sombre {
  -webkit-margin-before: 0 !important;
          margin-block-start: 0 !important;
  -webkit-margin-after: 0 !important;
          margin-block-end: 0 !important;
}

body.page .is-style-tranche-clair {
  -webkit-margin-before: 0 !important;
          margin-block-start: 0 !important;
  -webkit-margin-after: 0 !important;
          margin-block-end: 0 !important;
}

.is-style-tranche-blanc .h2-icon::before,
.is-style-tranche-blanc .h3-icon::before,
.is-style-tranche-clair .h2-icon::before,
.is-style-tranche-clair .h3-icon::before {
  background-color: var(--wp--preset--color--texte);
}

.is-style-tranche-sombre .h2-icon::before,
.is-style-tranche-sombre .h3-icon::before {
  background-color: var(--wp--preset--color--blanc);
}

.is-style-tranche-clair {
  position: relative;
  background: var(--wp--preset--color--beige-clair);
  color: var(--wp--preset--color--texte);
  -webkit-margin-before: 0 !important;
          margin-block-start: 0 !important;
}
.is-style-tranche-clair h1,
.is-style-tranche-clair h2,
.is-style-tranche-clair h3,
.is-style-tranche-clair h4,
.is-style-tranche-clair h5,
.is-style-tranche-clair h6 {
  color: var(--wp--preset--color--texte);
}
.is-style-tranche-clair p {
  color: var(--wp--preset--color--texte);
}
.is-style-tranche-clair a.button,
.is-style-tranche-clair .wp-block-button__link {
  background: var(--wp--preset--color--vert-fonce) !important;
  color: var(--wp--preset--color--blanc) !important;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.is-style-tranche-clair a.button:hover,
.is-style-tranche-clair .wp-block-button__link:hover {
  background: var(--wp--preset--color--ocre) !important;
  color: var(--wp--preset--color--blanc) !important;
}
.is-style-tranche-clair::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100vw;
  height: 100%;
  background: var(--wp--preset--color--beige-clair);
  z-index: -1;
}

.wp-block-group.is-style-default {
  padding-top: 4rem;
  padding-bottom: 4rem;
  -webkit-margin-before: 0 !important;
          margin-block-start: 0 !important;
}

.taxonomy-post_tag.wp-block-post-terms {
  padding-bottom: 4rem;
}

.is-style-tranche-blanc {
  background: var(--wp--preset--color--blanc);
  color: var(--wp--preset--color--texte);
}
.is-style-tranche-blanc h1,
.is-style-tranche-blanc h2,
.is-style-tranche-blanc h3,
.is-style-tranche-blanc h4,
.is-style-tranche-blanc h5,
.is-style-tranche-blanc h6 {
  color: var(--wp--preset--color--texte);
}
.is-style-tranche-blanc p {
  color: var(--wp--preset--color--texte);
}
.is-style-tranche-blanc a.button,
.is-style-tranche-blanc .wp-block-button__link {
  background: var(--wp--preset--color--vert-fonce) !important;
  color: var(--wp--preset--color--blanc) !important;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.is-style-tranche-blanc a.button:hover,
.is-style-tranche-blanc .wp-block-button__link:hover {
  background: var(--wp--preset--color--ocre) !important;
  color: var(--wp--preset--color--blanc) !important;
}

.is-style-tranche-sombre {
  position: relative;
  color: var(--wp--preset--color--blanc);
}
.is-style-tranche-sombre h1,
.is-style-tranche-sombre h2,
.is-style-tranche-sombre h3,
.is-style-tranche-sombre h4,
.is-style-tranche-sombre h5,
.is-style-tranche-sombre h6 {
  color: var(--wp--preset--color--blanc);
}
.is-style-tranche-sombre p {
  color: var(--wp--preset--color--blanc);
}
.is-style-tranche-sombre a.button,
.is-style-tranche-sombre .wp-block-button__link {
  background: var(--wp--preset--color--blanc) !important;
  color: var(--wp--preset--color--vert-fonce) !important;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  border: 0 !important;
}
.is-style-tranche-sombre a.button:hover,
.is-style-tranche-sombre .wp-block-button__link:hover {
  background: var(--wp--preset--color--ocre) !important;
  color: var(--wp--preset--color--blanc) !important;
  border: 0 !important;
}
.is-style-tranche-sombre::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100vw;
  height: 100%;
  z-index: -1;
  pointer-events: none;
  background: var(--wp--preset--color--vert-fonce);
  background-repeat: no-repeat;
}
.is-style-tranche-sombre.hero--accueil::after {
  content: "";
  position: absolute;
  top: -300px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100vw;
  height: 200%;
  z-index: -1;
  pointer-events: none;
  background: var(--wp--preset--color--vert-fonce);
  background-repeat: no-repeat;
  background-image: radial-gradient(circle 700px at 15% 15%, rgba(255, 255, 255, 0.12) 60%, transparent 61%), radial-gradient(circle 500px at 85% 100%, rgba(255, 255, 255, 0.1) 55%, transparent 56%);
  -webkit-animation: floatCircles 15s ease-in-out infinite alternate;
          animation: floatCircles 15s ease-in-out infinite alternate;
}
@-webkit-keyframes floatCircles {
  0% {
    background-position: 0px 0px, 0px 0px;
  }
  100% {
    background-position: 30px 20px, 20px 30px;
  }
}
@keyframes floatCircles {
  0% {
    background-position: 0px 0px, 0px 0px;
  }
  100% {
    background-position: 30px 20px, 20px 30px;
  }
}
.is-style-tranche-sombre.hero--apropos::after {
  content: "";
  position: absolute;
  top: 0xp;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100vw;
  height: 100%;
  z-index: -1;
  pointer-events: none;
  background: var(--wp--preset--color--vert-fonce);
  background-repeat: no-repeat;
  background-image: radial-gradient(circle 650px at 75% 50%, rgba(255, 255, 255, 0.08) 60%, transparent 61%);
  -webkit-animation: floatCircles 20s ease-in-out infinite alternate;
          animation: floatCircles 20s ease-in-out infinite alternate;
}
.is-style-tranche-sombre.hero--services::after {
  overflow: hidden;
  content: "";
  position: absolute;
  top: 0px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100vw;
  height: 100%;
  z-index: -1;
  pointer-events: none;
  background: var(--wp--preset--color--vert-fonce);
  background-repeat: no-repeat;
  background-image: radial-gradient(circle 450px at 20% 80%, rgba(255, 255, 255, 0.07) 55%, transparent 56%), radial-gradient(circle 450px at 80% 90%, rgba(255, 255, 255, 0.06) 55%, transparent 56%);
  -webkit-animation: floatCirclesServices 20s ease-in-out infinite alternate;
          animation: floatCirclesServices 20s ease-in-out infinite alternate;
}
@-webkit-keyframes floatCirclesServices {
  0% {
    background-position: 0px 0px, 0px 0px;
  }
  100% {
    background-position: 25px 15px, 20px 25px;
  }
}
@keyframes floatCirclesServices {
  0% {
    background-position: 0px 0px, 0px 0px;
  }
  100% {
    background-position: 25px 15px, 20px 25px;
  }
}
.is-style-tranche-sombre.hero--realisations::after {
  content: "";
  position: absolute;
  top: 0px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100vw;
  height: 100%;
  z-index: -1;
  pointer-events: none;
  background: var(--wp--preset--color--vert-fonce);
  background-repeat: no-repeat;
  background-image: radial-gradient(circle 600px at 50% 25px, rgba(255, 255, 255, 0.1) 60%, transparent 61%), radial-gradient(circle 300px at 83% 202px, rgba(255, 255, 255, 0.08) 50%, transparent 51%);
  -webkit-animation: floatCirclesrealisations 18s ease-in-out infinite alternate;
          animation: floatCirclesrealisations 18s ease-in-out infinite alternate;
}
@-webkit-keyframes floatCirclesrealisations {
  0% {
    background-position: 0px 0px, 0px 0px;
  }
  100% {
    background-position: -25px -15px, 20px 25px;
  }
}
@keyframes floatCirclesrealisations {
  0% {
    background-position: 0px 0px, 0px 0px;
  }
  100% {
    background-position: -25px -15px, 20px 25px;
  }
}
.is-style-tranche-sombre.hero--contact::after {
  content: "";
  position: absolute;
  top: 0xp;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100vw;
  height: 100%;
  z-index: -1;
  pointer-events: none;
  background: var(--wp--preset--color--vert-fonce);
  background-repeat: no-repeat;
  background-image: radial-gradient(circle 300px at 17% 97%, rgba(255, 255, 255, 0.05) 50%, transparent 51%);
  -webkit-animation: floatCircles 18s ease-in-out infinite alternate;
          animation: floatCircles 18s ease-in-out infinite alternate;
}

section,
.is-style-tranche-clair,
.is-style-tranche-blanc,
.is-style-tranche-sombre {
  padding-top: 4rem;
  padding-bottom: 4rem;
}
section.is-style-tranche-sombre,
.is-style-tranche-clair.is-style-tranche-sombre,
.is-style-tranche-blanc.is-style-tranche-sombre,
.is-style-tranche-sombre.is-style-tranche-sombre {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

h1 {
  margin-bottom: 2rem;
  margin-top: 0;
}

h2 {
  margin-bottom: 1.5rem;
}

h3 {
  margin-top: 3rem;
  margin-bottom: 1rem;
}

h4,
h5,
h6 {
  margin-top: 2rem;
  margin-bottom: 0.75rem;
}

p {
  margin-bottom: 1.25rem;
}

ul {
  max-width: var(--wp--style--global--wide-size) !important;
}

.bloc-intro {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2rem;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.photo-portrait {
  overflow: hidden;
}
.photo-portrait img {
  border-radius: 6px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  -webkit-box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);
          box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);
  height: auto;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.photo-portrait.photo1 img {
  max-width: 250px;
}
.photo-portrait.photo2 img {
  max-width: 250px;
}

.wp-block-cover.image-3 {
  width: 100vw;
  margin-left: calc(-50vw + 50%);
}
ul li::marker {
  color: #c45c48;
  font-size: 1.2em;
}

.cta-section > .wp-block-group {
  max-width: 800px;
  text-align: center;
  border-radius: 12px;
  background-color: var(--wp--preset--color--vert-fonce);
  overflow: hidden;
}
.cta-section > .wp-block-group > * {
  position: relative;
  z-index: 1;
}
.cta-section > .wp-block-group h2 {
  color: var(--wp--preset--color--blanc);
}
.cta-section > .wp-block-group p {
  color: var(--wp--preset--color--blanc);
}
.cta-section > .wp-block-group a.button,
.cta-section > .wp-block-group .wp-block-button__link {
  background: var(--wp--preset--color--blanc) !important;
  color: var(--wp--preset--color--vert-fonce) !important;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  border: 0 !important;
  z-index: 0;
}
.page-id-39 .cta-section > .wp-block-group a.button:after,
.page-id-39 .cta-section > .wp-block-group .wp-block-button__link:after {
  content: none;
}
.cta-section > .wp-block-group a.button:after,
.cta-section > .wp-block-group .wp-block-button__link:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
}
.cta-section > .wp-block-group a.button:hover,
.cta-section > .wp-block-group .wp-block-button__link:hover {
  border: 0 !important;
  background: var(--wp--preset--color--ocre) !important;
  color: var(--wp--preset--color--blanc) !important;
}
.cta-section > .wp-block-group::before, .cta-section > .wp-block-group::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.8);
  z-index: 0;
}
.cta-section > .wp-block-group::before {
  width: 500px;
  height: 500px;
  top: -200px;
  left: -150px;
  -webkit-animation: pulse1 20s ease-in-out infinite alternate;
          animation: pulse1 20s ease-in-out infinite alternate;
}
.cta-section > .wp-block-group::after {
  width: 350px;
  height: 350px;
  bottom: -150px;
  right: -100px;
  -webkit-animation: pulse2 25s ease-in-out infinite alternate;
          animation: pulse2 25s ease-in-out infinite alternate;
}

@-webkit-keyframes pulse1 {
  0% {
    -webkit-transform: scale(1) translate(0, 0);
            transform: scale(1) translate(0, 0);
    opacity: 0.06;
  }
  100% {
    -webkit-transform: scale(1.1) translate(20px, 10px);
            transform: scale(1.1) translate(20px, 10px);
    opacity: 0.1;
  }
}

@keyframes pulse1 {
  0% {
    -webkit-transform: scale(1) translate(0, 0);
            transform: scale(1) translate(0, 0);
    opacity: 0.06;
  }
  100% {
    -webkit-transform: scale(1.1) translate(20px, 10px);
            transform: scale(1.1) translate(20px, 10px);
    opacity: 0.1;
  }
}
@-webkit-keyframes pulse2 {
  0% {
    -webkit-transform: scale(1) translate(0, 0);
            transform: scale(1) translate(0, 0);
    opacity: 0.06;
  }
  100% {
    -webkit-transform: scale(1.15) translate(-15px, -10px);
            transform: scale(1.15) translate(-15px, -10px);
    opacity: 0.1;
  }
}
@keyframes pulse2 {
  0% {
    -webkit-transform: scale(1) translate(0, 0);
            transform: scale(1) translate(0, 0);
    opacity: 0.06;
  }
  100% {
    -webkit-transform: scale(1.15) translate(-15px, -10px);
            transform: scale(1.15) translate(-15px, -10px);
    opacity: 0.1;
  }
}
figure.barre {
  position: relative;
  display: inline-block;
}
figure.barre img {
  display: block;
  max-width: 100%;
  height: auto;
}
figure.barre::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 80%;
  height: 5px;
  background: var(--wp--preset--color--ocre);
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
  border-radius: 5px;
  pointer-events: none;
}

.col-swiper {
  padding: 3rem;
  overflow: hidden;
}

.swiper.mySwiper .swiper-slide {
  visibility: hidden;
  background: #fff;
  border-radius: 8px;
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  padding: 2rem;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.swiper.mySwiper .swiper-slide h3 {
  margin-bottom: 1rem;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--wp--preset--color--texte);
}
.swiper.mySwiper .swiper-slide p {
  margin: 0;
  font-size: 1rem;
  color: var(--wp--preset--color--texte);
}
.swiper.mySwiper .comment-travaille .swiper {
  overflow: visible !important; /* permet aux flèches de dépasser */
  position: relative;
}
.swiper.mySwiper .swiper-slide-active {
  visibility: visible;
}

.comment-travaille .swiper {
  overflow: visible;
  position: relative;
}
.comment-travaille .swiper-button-prev,
.comment-travaille .swiper-button-next {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #fff;
  -webkit-box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
          box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.comment-travaille .swiper-button-prev::after,
.comment-travaille .swiper-button-next::after {
  font-size: 16px;
  font-weight: bold;
  color: var(--wp--preset--color--texte) !important;
}
.comment-travaille .swiper-button-prev {
  left: -45px;
}
.comment-travaille .swiper-button-next {
  right: -45px;
}
.comment-travaille .swiper-pagination {
  bottom: -50px !important;
}
.comment-travaille .swiper-pagination .swiper-pagination-bullet {
  background: var(--wp--preset--color--texte);
  opacity: 0.3;
  width: 12px;
  height: 12px;
  margin: 0 6px !important;
  border-radius: 50%;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.comment-travaille .swiper-pagination .swiper-pagination-bullet-active {
  background: var(--wp--preset--color--ocre);
  opacity: 1;
  -webkit-transform: scale(1.3);
          transform: scale(1.3);
  -webkit-box-shadow: 0 0 0 2px var(--wp--preset--color--beige-clair);
          box-shadow: 0 0 0 2px var(--wp--preset--color--beige-clair);
}

@media (max-width: 768px) {
  .swiper {
    max-width: 100%;
  }
  .swiper-button-prev,
  .swiper-button-next {
    display: none;
  }
}
#woocommerce .wp-block-media-text__media img {
  -webkit-filter: drop-shadow(2px 4px 6px rgba(0, 0, 0, 0.3));
          filter: drop-shadow(2px 4px 6px rgba(0, 0, 0, 0.3));
}
#woocommerce .wp-block-columns .wp-block-column .wp-block-group:hover {
  -webkit-transform: none !important;
          transform: none !important;
}

#seo ul {
  max-width: 640px;
}

.zone-intervention > .wp-block-group {
  position: relative;
  max-width: 870px;
}
.zone-intervention > .wp-block-group .normandie {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 880px) {
  .zone-intervention > .wp-block-group .normandie {
    padding: 200px 0;
  }
}
@media screen and (max-width: 470px) {
  .zone-intervention > .wp-block-group .normandie-local,
  .zone-intervention > .wp-block-group .normandie-distance,
  .zone-intervention > .wp-block-group .normandie-dispo,
  .zone-intervention > .wp-block-group .normandie-contact {
    width: 50% !important;
  }
}
.zone-intervention > .wp-block-group .normandie-local,
.zone-intervention > .wp-block-group .normandie-distance,
.zone-intervention > .wp-block-group .normandie-dispo,
.zone-intervention > .wp-block-group .normandie-contact {
  max-width: 190px;
}
.zone-intervention > .wp-block-group .normandie-local figure,
.zone-intervention > .wp-block-group .normandie-distance figure,
.zone-intervention > .wp-block-group .normandie-dispo figure,
.zone-intervention > .wp-block-group .normandie-contact figure {
  max-width: 50px;
}
.zone-intervention > .wp-block-group .normandie-local p,
.zone-intervention > .wp-block-group .normandie-distance p,
.zone-intervention > .wp-block-group .normandie-dispo p,
.zone-intervention > .wp-block-group .normandie-contact p {
  text-align: center;
  -webkit-margin-before: 0;
          margin-block-start: 0;
}
.zone-intervention > .wp-block-group .normandie-local {
  position: absolute;
  top: 0;
  left: 0;
}
.zone-intervention > .wp-block-group .normandie-distance {
  position: absolute;
  top: 0;
  right: 0;
}
.zone-intervention > .wp-block-group .normandie-dispo {
  position: absolute;
  bottom: 0;
  left: 0;
}
.zone-intervention > .wp-block-group .normandie-contact {
  position: absolute;
  bottom: 0;
  right: 0;
}

#agences .wp-block-columns .wp-block-column img {
  max-height: 85px;
  height: 100%;
  width: auto !important;
}

#budgets .wp-block-group-is-layout-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2rem;
}
@media (max-width: 768px) {
  #budgets .wp-block-group-is-layout-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 768px) {
  .wp-image-166 {
    margin-bottom: 1.5rem !important;
  }
}
html {
  overflow-x: hidden;
}

body {
  width: 100vw;
}
body header.wp-block-template-part .wp-block-group {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
body.scrolled header.wp-block-template-part .wp-block-group {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

body.single-post header.wp-block-template-part:after {
  content: "";
  left: 0;
  bottom: -2px; /* TOUJOURS sous le header */
  height: 2px;
  width: var(--reading-progress, 0%);
  background-color: var(--wp--preset--color--vert-fonce);
  -webkit-transition: width 0.1s linear;
  transition: width 0.1s linear;
  position: absolute;
}

p {
  line-height: 1.7rem !important;
}

.wp-block-site-title {
  font-family: var(--wp--preset--font-family--space-grotesk);
  font-size: 1.6rem;
}

.wp-block-button .wp-block-button__link {
  font-weight: 500;
}

header.wp-block-template-part {
  background-color: var(--wp--preset--color--fonce);
  z-index: 999;
}
header.wp-block-template-part li.current-menu-item > a,
header.wp-block-template-part li.current-menu-ancestor > a {
  font-weight: 600;
  color: var(--wp--preset--color--amande-claire);
}
header.wp-block-template-part a {
  color: var(--wp--preset--color--fond) !important;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}
header.wp-block-template-part a:hover {
  color: var(--wp--preset--color--cta);
}
header.wp-block-template-part a {
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}
header.wp-block-template-part {
  -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08);
          box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08);
  -webkit-transition: background-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: background-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: box-shadow 0.3s ease, background-color 0.3s ease;
  transition: box-shadow 0.3s ease, background-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  position: fixed;
  display: block;
  width: 100vw;
  top: 0;
}
body.admin-bar header.wp-block-template-part {
  top: 32px;
}
header.wp-block-template-part .wp-block-navigation__submenu-container {
  min-width: 300px !important;
}

.vert-op {
  border-radius: 5px;
  height: 100%;
}
.vert-op h3::before {
  -webkit-filter: none !important;
          filter: none !important;
}
.vert-op {
  background-color: #f0f0f1;
  padding: 1rem;
  color: var(--wp--preset--color--fonce) !important;
}
.vert-op > * {
  color: var(--wp--preset--color--fonce) !important;
}

#ca-change ul li {
  font-weight: 400;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
#ca-change ul li::marker {
  color: var(--wp--preset--color--fonce) !important;
}
#ca-change ul li mark {
  color: var(--wp--preset--color--texte) !important;
}
#ca-change ul li.active {
  -webkit-transform: translateX(-1rem);
          transform: translateX(-1rem);
}
#ca-change ul li.active mark {
  color: var(--wp--preset--color--texte) !important;
  text-decoration: underline;
  text-decoration-color: var(--wp--preset--color--ocre);
  text-underline-offset: 8px;
  text-decoration-thickness: 4px;
  font-weight: 600; /* renforce encore */
}
#ca-change ul li.active::marker {
  color: var(--wp--preset--color--ocre) !important;
}
#ca-change .wp-block-column:first-child {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center; /* centre horizontalement */
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center; /* centre verticalement */
}
#ca-change .wp-block-column:first-child > .wp-block-group {
  min-width: 350px;
  position: relative;
  height: 100%;
  min-height: 300px;
}
#ca-change .pictos-benef {
  position: relative;
  margin: 0 auto;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 100% !important;
  height: 100% !important;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
#ca-change .pictos-benef figure {
  position: absolute;
  left: 0;
  width: 100%;
  height: 100%;
  max-width: 300px;
  max-height: 300px;
  -webkit-margin-before: 0;
          margin-block-start: 0;
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(-100px);
          transform: translateY(-100px); /* départ au-dessus */
  -webkit-transition: all 0.6s ease;
  transition: all 0.6s ease;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center; /* centre horizontalement */
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center; /* centre verticalement */
}
#ca-change .pictos-benef figure.active {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
          transform: translateY(0); /* arrive en place */
  z-index: 2;
}
#ca-change .pictos-benef figure.exit {
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(100px);
          transform: translateY(100px); /* sort vers le bas */
  z-index: 1;
}
#ca-change .pictos-benef figure img {
  width: 90% !important;
  max-width: 250px;
  height: auto !important;
  -webkit-filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.3));
          filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.3));
}

.prestations {
  max-width: var(--wp--style--global--wide-size);
}
.prestations h2 {
  max-width: var(--wp--style--global--wide-size);
}
.prestations .wp-block-columns {
  max-width: var(--wp--style--global--wide-size);
  gap: 2rem;
  -webkit-margin-before: 2rem;
          margin-block-start: 2rem;
}
.prestations .wp-block-columns .wp-block-column .wp-block-group figure {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.prestations .wp-block-columns .wp-block-column .wp-block-group figure img {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  padding: 0 1rem 0.5rem;
  width: 120px !important;
}
.prestations .wp-block-columns .wp-block-column .wp-block-group h3 {
  -webkit-margin-before: 0;
          margin-block-start: 0;
  margin-bottom: 0.5rem;
}
.prestations .wp-block-columns .wp-block-column .wp-block-group h3 a {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  text-decoration: none;
}
.prestations .wp-block-columns .wp-block-column .wp-block-group h3 a:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.prestations .wp-block-columns .wp-block-column .wp-block-group p {
  -webkit-margin-before: 0;
          margin-block-start: 0;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.prestations .wp-block-columns .wp-block-column .wp-block-group {
  padding: 1rem;
  background: var(--wp--preset--color--blanc);
  color: var(--wp--preset--color--texte);
  border-radius: 5px;
  -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08);
          box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08);
  -webkit-margin-before: 0 !important;
          margin-block-start: 0 !important;
  -webkit-margin-after: 0 !important;
          margin-block-end: 0 !important;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: top;
      -ms-flex-pack: top;
          justify-content: top;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.prestations .wp-block-columns .wp-block-column .wp-block-group:hover {
  -webkit-transform: translateY(-4px);
          transform: translateY(-4px);
  -webkit-box-shadow: 0 6px 14px rgba(0, 0, 0, 0.08);
          box-shadow: 0 6px 14px rgba(0, 0, 0, 0.08);
  border-color: rgba(0, 0, 0, 0.12);
}
.prestations .closing {
  margin-top: 2rem;
  padding-top: 1rem;
  text-align: center;
  font-size: 1rem;
  color: var(--wp--preset--color--texte);
  border-top: 1px solid var(--wp--preset--color--ocre);
}
.prestations .closing strong {
  color: var(--wp--preset--color--ocre);
  font-weight: 600;
}

.carte {
  padding: 1rem;
  background-color: #f0f0f1;
  border-radius: 5px;
  -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08);
          box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08);
}

.exemples::before {
  bottom: 2px;
  border-top: 2px solid var(--wp--preset--color--terra);
  border-bottom: 2px solid var(--wp--preset--color--terra);
}
.exemples .wp-block-columns {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 2rem;
  /* ✅ breakpoint à 900px */
}
@media (max-width: 900px) {
  .exemples .wp-block-columns {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 1250px) {
  .exemples .wp-block-columns .carte-2 figure {
    bottom: 70% !important;
  }
}
@media (max-width: 900px) {
  .exemples .wp-block-columns .carte-1 figure {
    left: 46% !important;
  }
  .exemples .wp-block-columns .carte-1 figure img {
    max-width: 450px !important;
  }
  .exemples .wp-block-columns .carte-2 figure {
    bottom: 46% !important;
  }
  .exemples .wp-block-columns .carte-2 figure img {
    max-width: 450px !important;
  }
  .exemples .wp-block-columns .carte-3 figure {
    left: 10% !important;
    top: 34% !important;
  }
  .exemples .wp-block-columns .carte-3 figure img {
    max-width: 700px !important;
  }
}
.exemples .wp-block-columns {
  /* Colonnes par défaut */
}
.exemples .wp-block-columns .wp-block-column {
  -webkit-transition: -webkit-transform 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: -webkit-transform 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  transition: transform 0.3s ease, box-shadow 0.3s ease, -webkit-transform 0.3s ease, -webkit-box-shadow 0.3s ease;
}
.exemples .wp-block-columns .wp-block-column:hover {
  -webkit-transform: translateY(-8px);
          transform: translateY(-8px);
  -webkit-box-shadow: 0 12px 25px rgba(0, 0, 0, 0.15);
          box-shadow: 0 12px 25px rgba(0, 0, 0, 0.15);
}
.exemples .wp-block-columns .wp-block-column {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  border-radius: 5px;
  background-color: #f0f0f1;
  overflow: hidden;
}
.exemples .wp-block-columns .wp-block-column h3 {
  margin: 0 0 0.5rem 0;
  text-align: left;
}
.exemples .wp-block-columns .wp-block-column p {
  margin: 0;
  font-size: 1.1rem;
  text-align: left;
}
.exemples .wp-block-columns {
  /* Figures/images */
}
.exemples .wp-block-columns figure {
  margin: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.exemples .wp-block-columns figure img {
  border-radius: 40px;
  width: auto;
  border: 3px solid var(--wp--preset--color--fonce);
  -webkit-filter: drop-shadow(0 6px 12px rgba(0, 0, 0, 0.4));
          filter: drop-shadow(0 6px 12px rgba(0, 0, 0, 0.4));
}
.exemples .wp-block-columns {
  /* Boutons */
}
.exemples .wp-block-columns .wp-block-button__link {
  z-index: 1;
  position: static;
  color: #fff;
  border-radius: 4px;
  padding: 0.6rem 1.2rem;
  font-size: 0.9rem;
}
.exemples .wp-block-columns .wp-block-button__link::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
}
.exemples .wp-block-columns {
  /* Cartes (règle commune) */
}
.exemples .wp-block-columns .carte-1,
.exemples .wp-block-columns .carte-2,
.exemples .wp-block-columns .carte-3 {
  height: 450px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
  position: relative;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.exemples .wp-block-columns .carte-1 .wp-block-buttons .wp-block-button__link.wp-element-button,
.exemples .wp-block-columns .carte-2 .wp-block-buttons .wp-block-button__link.wp-element-button,
.exemples .wp-block-columns .carte-3 .wp-block-buttons .wp-block-button__link.wp-element-button {
  z-index: 1;
}
.exemples .wp-block-columns .carte-1 .wp-block-buttons .wp-block-button__link.wp-element-button:before,
.exemples .wp-block-columns .carte-2 .wp-block-buttons .wp-block-button__link.wp-element-button:before,
.exemples .wp-block-columns .carte-3 .wp-block-buttons .wp-block-button__link.wp-element-button:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
}
.exemples .wp-block-columns .carte-1:hover .wp-block-buttons .wp-block-button__link.wp-element-button,
.exemples .wp-block-columns .carte-2:hover .wp-block-buttons .wp-block-button__link.wp-element-button,
.exemples .wp-block-columns .carte-3:hover .wp-block-buttons .wp-block-button__link.wp-element-button {
  background-color: var(--wp--preset--color--beige-clair) !important;
  color: var(--wp--preset--color--texte) !important;
}
.exemples .wp-block-columns {
  /* Carte 1 : texte gauche, image droite */
}
.exemples .wp-block-columns .carte-1 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto 1fr auto;
  background-color: var(--wp--preset--color--vert-fonce);
  color: var(--wp--preset--color--blanc) !important;
  border-radius: 8px;
  padding: 2rem;
}
.exemples .wp-block-columns .carte-1 figure {
  position: absolute;
  width: 50%;
  top: 40%;
  left: 50%;
}
.exemples .wp-block-columns .carte-1 figure img {
  max-width: 300px;
  -o-object-fit: contain;
     object-fit: contain;
}
.exemples .wp-block-columns .carte-1 .wp-block-group {
  grid-column: 1;
  grid-row: 1;
  align-self: start;
}
.exemples .wp-block-columns .carte-1 .wp-block-group h3,
.exemples .wp-block-columns .carte-1 .wp-block-group p {
  color: var(--wp--preset--color--blanc) !important;
}
.exemples .wp-block-columns .carte-1 .wp-block-buttons {
  grid-column: 1;
  grid-row: 3;
  align-self: end;
}
.exemples .wp-block-columns .carte-1 .wp-block-buttons .wp-block-button__link.wp-element-button {
  background-color: var(--wp--preset--color--blanc) !important;
  color: var(--wp--preset--color--texte) !important;
}
.exemples .wp-block-columns .carte-1 .wp-block-buttons .wp-block-button__link.wp-element-button:hover {
  background-color: var(--wp--preset--color--beige-clair) !important;
  color: var(--wp--preset--color--texte) !important;
}
.exemples .wp-block-columns .carte-1:hover {
  background-color: #f0f0f1 !important;
  color: var(--wp--preset--color--texte) !important;
}
.exemples .wp-block-columns .carte-1:hover h3,
.exemples .wp-block-columns .carte-1:hover p {
  color: var(--wp--preset--color--texte) !important;
}
.exemples .wp-block-columns {
  /* Carte 2 : image au-dessus, texte en dessous */
}
.exemples .wp-block-columns .carte-2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  text-align: center;
  padding: 1rem;
}
.exemples .wp-block-columns .carte-2 .wp-block-group {
  margin-top: auto;
}
.exemples .wp-block-columns .carte-2 figure {
  position: absolute;
  width: 50%;
  left: 40px;
  bottom: 50%;
}
.exemples .wp-block-columns .carte-2 figure img {
  max-width: 300px;
  -o-object-fit: contain;
     object-fit: contain;
}
.exemples .wp-block-columns {
  /* Carte 3 : image en fond, texte superposé */
}
.exemples .wp-block-columns .carte-3 {
  padding: 1rem;
}
.exemples .wp-block-columns .carte-3 figure {
  position: absolute;
  width: 50%;
  left: 13px;
  top: 44%;
}
.exemples .wp-block-columns .carte-3 figure img {
  border-radius: 0;
  border: none;
  max-width: 540px;
  -o-object-fit: contain;
     object-fit: contain;
}

.page-id-33 .exemples .wp-block-columns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 1024px) {
  .page-id-33 .exemples .wp-block-columns {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr); /* 2 colonnes */
    grid-template-rows: repeat(2, auto); /* 2 lignes */
  }
}
@media screen and (max-width: 800px) {
  .page-id-33 .exemples .wp-block-columns {
    grid-template-columns: 1fr;
    display: grid !important;
  }
}
.page-id-33 .exemples .wp-block-columns .wp-block-column:hover {
  color: var(--wp--preset--color--fonce);
  background-color: #f0f0f1;
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-transform: none;
          transform: none;
}
.page-id-33 .exemples .wp-block-columns .wp-block-column {
  height: 600px;
}
.page-id-33 .exemples .wp-block-columns .wp-block-column .wp-block-group {
  z-index: 1;
}
.page-id-33 .exemples .wp-block-columns .wp-block-column figure {
  z-index: 0;
}
.page-id-33 .exemples .wp-block-columns .wp-block-column img {
  border: none !important;
  max-width: 100%;
  border-radius: 0;
}
@media screen and (max-width: 900px) {
  .page-id-33 .exemples .wp-block-columns .wp-block-column img {
    max-width: 100% !important;
  }
}
.page-id-33 .exemples .wp-block-columns .wp-block-column.carte-2 figure {
  left: auto;
  right: -20px;
  bottom: auto;
  width: 85%;
  top: 10px;
}
.page-id-33 .exemples .wp-block-columns .wp-block-column.presta figure {
  rotate: -2deg;
  top: -10px;
  left: 23%;
}
.page-id-33 .exemples .wp-block-columns .wp-block-column.presta figure img {
  border-radius: 20px;
}
.page-id-33 .exemples .wp-block-columns .wp-block-column.drupal figure {
  width: 130% !important;
  rotate: -5deg;
  top: auto !important;
  bottom: 49px;
  right: -30px;
}
.page-id-33 .exemples .wp-block-columns .wp-block-column.fse {
  display: block;
}
.page-id-33 .exemples .wp-block-columns .wp-block-column.fse figure {
  width: 100%;
  rotate: -5deg;
  top: auto !important;
  bottom: -66px;
  left: -13%;
}
.page-id-33 .exemples .wp-block-columns .wp-block-column.fse:hover H3,
.page-id-33 .exemples .wp-block-columns .wp-block-column.fse:hover p {
  color: var(--wp--preset--color--blanc) !important;
}
.page-id-33 .exemples .wp-block-columns .wp-block-column.fse:hover {
  background-color: var(--wp--preset--color--vert-fonce) !important;
}

.page-id-35 .exemples .wp-block-columns .wp-block-column {
  min-height: 545px;
}

.temoignages-slider {
  width: 100% !important;
  max-width: 600px;
}
.temoignages-slider .swiper-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  width: 100% !important;
  max-width: 600px;
  margin: 0 auto;
}
.temoignages-slider .swiper-wrapper .swiper-slide {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 auto;
          flex: 1 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: auto;
  background: #fff;
  border-radius: 8px;
  padding: 2rem;
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  margin: 0 auto;
  font-style: italic;
  line-height: 1.6;
  position: relative;
  width: 100% !important;
  max-width: 600px;
  margin: 0 auto;
}
.temoignages-slider .swiper-wrapper .swiper-slide blockquote {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  max-width: 600px;
  margin: 0 auto;
  position: relative;
  padding-left: 1.5rem;
  width: 100% !important;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  min-height: 180px;
}
.temoignages-slider .swiper-wrapper .swiper-slide blockquote::before {
  content: "“";
  font-size: 3rem;
  color: var(--wp--preset--color--ocre) !important;
  position: absolute;
  top: -10px;
  left: 0;
  opacity: 0.3;
  line-height: 1;
}
.temoignages-slider .swiper-wrapper .swiper-slide blockquote p {
  margin: 0 0 1rem 0;
}
.temoignages-slider .swiper-wrapper .swiper-slide blockquote cite {
  display: block;
  width: 100%;
  font-style: normal;
  font-weight: 600;
  color: var(--wp--preset--color--texte);
  font-size: 0.95rem;
  text-align: right;
}
.temoignages-slider .swiper-pagination .swiper-pagination-bullet {
  background: var(--wp--preset--color--vert-fonce);
  opacity: 0.3;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.temoignages-slider .swiper-pagination .swiper-pagination-bullet-active {
  opacity: 1;
}

.prefooter-home h2::before {
  -webkit-filter: none !important;
          filter: none !important;
}
.prefooter-home {
  background-color: var(--wp--preset--color--beige-clair) !important;
}
.prefooter-home * {
  color: var(--wp--preset--color--fonce) !important;
}
.prefooter-home::before {
  background-color: var(--wp--preset--color--beige-clair) !important;
}
.prefooter-home p {
  max-width: var(--wp--style--global--wide-size);
}
.prefooter-home .wp-block-columns .wp-block-column:nth-child(2) img, .prefooter-home .wp-block-columns .wp-block-column:nth-child(3) img {
  width: 80px !important;
}
.prefooter-home .wp-block-columns .wp-block-column h3 {
  margin-bottom: 1rem;
}
.prefooter-home .wp-block-columns .wp-block-column figure {
  -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08);
          box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08);
  padding: 0.4rem;
  -webkit-margin-before: 0;
          margin-block-start: 0;
  background-color: var(--wp--preset--color--cta);
  border-radius: 50%;
  width: 100px;
  height: 100px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.prefooter-home .wp-block-columns .wp-block-column figure img {
  -webkit-filter: brightness(0) saturate(100%) invert(99%) sepia(2%) saturate(118%) hue-rotate(30deg) brightness(101%) contrast(100%);
          filter: brightness(0) saturate(100%) invert(99%) sepia(2%) saturate(118%) hue-rotate(30deg) brightness(101%) contrast(100%);
}

main > .wp-block-group {
  margin: 0 auto !important;
  padding: 0 !important;
}

footer.wp-block-template-part {
  background-color: var(--wp--preset--color--fonce);
  color: var(--wp--preset--color--fond);
  -webkit-margin-before: 0 !important;
          margin-block-start: 0 !important;
}
footer.wp-block-template-part a.wp-block-button__link {
  padding: 10px 15px;
  font-size: 17px;
}
footer.wp-block-template-part a[href^="mailto:"] {
  font-size: 15px;
}
footer.wp-block-template-part .wp-block-navigation {
  gap: 0.2rem;
}
footer.wp-block-template-part .wp-block-navigation li.wp-block-navigation-item .wp-block-site-logo {
  display: none;
}
footer.wp-block-template-part .wp-block-navigation li.current-menu-ancestor > a,
footer.wp-block-template-part .wp-block-navigation li.current-menu-item > a {
  font-weight: 600;
  text-decoration: underline;
}
@media screen and (max-width: 600px) {
  footer.wp-block-template-part .bottom-links {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.tech-pattern-4 {
  z-index: 0;
}
.tech-pattern-4::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 50%;
  width: 100vw;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background-image: url("assets/img/motif-tech-4.png");
  background-repeat: repeat;
  background-size: 18rem;
  -webkit-filter: brightness(300%);
          filter: brightness(300%);
  -webkit-mask-image: linear-gradient(170deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 60%, rgba(0, 0, 0, 0.5) 100%);
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: cover;
  mask-image: linear-gradient(170deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 60%, rgba(0, 0, 0, 0.5) 100%);
  mask-repeat: no-repeat;
  mask-size: cover;
  z-index: -1;
}

p strong {
  font-weight: 500;
}

.alignwide p {
  max-width: var(--wp--style--global--wide-size);
}

blockquote {
  position: relative;
  background-color: #f9f9f6;
  border-left: 4px solid var(--wp--preset--color--terra) !important;
  padding: 1.5rem 2rem 1.5rem 3rem;
  margin: 1rem 0;
  font-style: italic;
  font-size: 1rem;
  line-height: 1.6;
  border-radius: 6px;
  color: var(--wp--preset--color--fonce);
}
blockquote::before {
  content: "“";
  font-size: 2.5rem;
  color: var(--wp--preset--color--terra);
  position: absolute;
  top: -0.5rem;
  left: 0.5rem;
}
blockquote cite {
  display: block;
  margin-top: 1rem;
  font-size: 0.85rem;
  font-style: normal;
  text-align: right;
  color: var(--wp--preset--color--contrast-2);
}

/* CTA Principal (noir -> hover vert) */
.is-style-cta-principal .wp-block-button__link {
  background-color: var(--wp--preset--color--fonce);
  color: var(--wp--preset--color--fond);
  border-radius: 6px;
  font-weight: 500;
  border: 1px solid transparent;
}
.is-style-cta-principal .wp-block-button__link:hover {
  background-color: var(--wp--preset--color--cta);
  color: var(--wp--preset--color--fond);
  border: 1px solid transparent;
}

/* CTA Secondaire (blanc + bordure terra -> hover terra) */
.is-style-cta-secondaire .wp-block-button__link {
  background-color: var(--wp--preset--color--terra); /* rouge terra */
  color: var(--wp--preset--color--fond); /* blanc */
  border-radius: 2px;
  font-weight: 500;
}
.is-style-cta-secondaire .wp-block-button__link:hover {
  background-color: var(--wp--preset--color--fond); /* blanc */
  color: var(--wp--preset--color--terra); /* rouge terra */
}

/* CTA Tertiaire (vert -> hover blanc) */
.is-style-cta-tertiaire .wp-block-button__link {
  /* Variante bouton clair avec texte vert foncé */
  background: var(--wp--preset--color--blanc) !important;
  color: var(--wp--preset--color--vert-fonce) !important;
  border: 1px solid var(--wp--preset--color--vert-fonce) !important;
  font-weight: 600;
  padding: 0.75rem 1.5rem;
  border-radius: Opx;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
.is-style-cta-tertiaire .wp-block-button__link:hover {
  background: var(--wp--preset--color--vert-fonce) !important;
  color: var(--wp--preset--color--blanc) !important;
  border-color: var(--wp--preset--color--vert-fonce) !important;
}

/* CTA Inverse (fonce -> fond) */
.is-style-cta-inverse .wp-block-button__link {
  background-color: var(--wp--preset--color--fonce);
  color: var(--wp--preset--color--fond);
  border-radius: 6px;
  font-weight: 600;
}

.carte-blanche-2 {
  padding: 1rem;
  background: var(--wp--preset--color--blanc);
  color: var(--wp--preset--color--texte);
  border-radius: 5px;
  -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08);
  -webkit-margin-before: 0 !important;
  margin-block-start: 0 !important;
  -webkit-margin-after: 0 !important;
  margin-block-end: 0 !important;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: top;
  -ms-flex-pack: top;
  justify-content: top;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

/* Carte blanche générique */
.carte-blanche {
  background: var(--wp--preset--color--blanc);
  color: var(--wp--preset--color--texte);
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 0.5rem;
  padding: 1.5rem;
  -webkit-box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
          box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
  -webkit-transition: border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  height: 100%;
  /* Typo interne */
}
.carte-blanche h3,
.carte-blanche h4 {
  margin: 0 0 0.5rem;
  color: var(--wp--preset--color--texte);
  font-weight: 600;
}
.carte-blanche p {
  margin: 0;
}
.carte-blanche {
  /* Icône au-dessus du titre (optionnelle) */
}
.carte-blanche .carte-icone {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 44px;
  height: 44px;
  margin-bottom: 0.75rem;
  /* icône monochrome, pas de fond ni de bulle */
}
.carte-blanche .carte-icone svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
  color: var(--wp--preset--color--texte);
}
.carte-blanche {
  /* Effet focus/hover accessible mais discret */
}
.carte-blanche:hover, .carte-blanche:focus-within {
  -webkit-box-shadow: 0 6px 14px rgba(0, 0, 0, 0.08);
          box-shadow: 0 6px 14px rgba(0, 0, 0, 0.08);
  border-color: rgba(0, 0, 0, 0.12);
}

/* Variantes utilitaires */
.carte-blanche--no-shadow {
  -webkit-box-shadow: none;
          box-shadow: none;
}

.carte-blanche--compact {
  padding: 1rem;
  border-radius: 0.375rem;
}

/* Variante verticale de carte blanche avec icône au-dessus */
.carte-blanche.carte-icone-top {
  text-align: center;
  padding: 2rem 1.5rem;
  background: var(--wp--preset--color--blanc);
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 0.5rem;
  -webkit-box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
          box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
  -webkit-transition: border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
}
.carte-blanche.carte-icone-top h3,
.carte-blanche.carte-icone-top h4 {
  margin: 0 0 1rem 0 !important;
  font-weight: 600;
  color: var(--wp--preset--color--texte);
  position: relative;
  padding-top: 72px;
}
.carte-blanche.carte-icone-top h3::before,
.carte-blanche.carte-icone-top h4::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 56px;
  height: 56px;
  background-color: var(--wp--preset--color--texte);
  mask-size: contain;
  -webkit-mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-position: center;
  -webkit-mask-position: center;
}
.carte-blanche.carte-icone-top p {
  margin: 0;
  color: var(--wp--preset--color--texte);
}
.carte-blanche.carte-icone-top:hover {
  -webkit-box-shadow: 0 6px 14px rgba(0, 0, 0, 0.08);
          box-shadow: 0 6px 14px rgba(0, 0, 0, 0.08);
  border-color: rgba(0, 0, 0, 0.12);
}

.bloc-faq {
  margin-top: 4rem;
}
.bloc-faq .faq-list {
  max-width: 900px;
  margin-inline: auto;
}
.bloc-faq .faq-item {
  padding: 2rem 2.5rem;
  border-radius: 8px;
  background: #fff;
}
.bloc-faq .faq-item + .faq-item {
  margin-top: 1.75rem;
  border-top: 1px solid rgba(0, 0, 0, 0.05);
  padding-top: 2.5rem;
}
.bloc-faq .faq-question {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 0.75rem;
  margin: 0 0 1rem;
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1.4;
  color: #1a1a1a;
}
.bloc-faq .faq-question::before {
  content: "•";
  font-size: 1.4rem;
  line-height: 1;
  color: var(--wp--preset--color--primary);
  margin-top: 0.15rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.bloc-faq .faq-reponse {
  font-size: 0.95rem;
  line-height: 1.7;
  color: #444;
}
.bloc-faq .faq-reponse p {
  margin: 0 0 0.75rem;
}
.bloc-faq .faq-reponse p:last-child {
  margin-bottom: 0;
}
.bloc-faq .faq-reponse ul {
  margin: 0.75rem 0 0.75rem 1.25rem;
  padding: 0;
  list-style: none;
}
.bloc-faq .faq-reponse ul li {
  position: relative;
  padding-left: 1.1rem;
  margin-bottom: 0.35rem;
}
.bloc-faq .faq-reponse ul li::before {
  content: "–";
  position: absolute;
  left: 0;
  color: var(--wp--preset--color--primary);
  font-weight: 600;
}
@media (max-width: 640px) {
  .bloc-faq .faq-item {
    padding: 1.5rem;
  }
  .bloc-faq .faq-question {
    font-size: 1rem;
  }
}

.wp-block-media-text.has-media-on-the-right .wp-block-media-text__content {
  padding-left: 0;
}

.wpcf7-form {
  max-width: 600px;
  margin: 0 auto;
  font-family: var(--wp--preset--font-family--inter, sans-serif);
  color: var(--wp--preset--color--texte);
}
.wpcf7-form label {
  display: block;
  font-weight: 500;
  margin-bottom: 0.5rem;
  color: var(--wp--preset--color--vert-fonce);
}
.wpcf7-form input[type=text],
.wpcf7-form input[type=email],
.wpcf7-form input[type=tel],
.wpcf7-form textarea {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--wp--preset--color--beige-clair);
  background-color: #fff;
  font-size: 1rem;
  color: var(--wp--preset--color--texte);
  -webkit-transition: border-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: border-color 0.3s ease, -webkit-box-shadow 0.3s ease;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  transition: border-color 0.3s ease, box-shadow 0.3s ease, -webkit-box-shadow 0.3s ease;
}
.wpcf7-form input[type=text]:focus,
.wpcf7-form input[type=email]:focus,
.wpcf7-form input[type=tel]:focus,
.wpcf7-form textarea:focus {
  border-color: var(--wp--preset--color--ocre);
  -webkit-box-shadow: 0 0 0 3px rgba(162, 71, 44, 0.2);
          box-shadow: 0 0 0 3px rgba(162, 71, 44, 0.2);
  outline: none;
}
.wpcf7-form input[type=checkbox] {
  scale: 1.6;
  margin-right: 8px;
}
.wpcf7-form textarea {
  min-height: 150px;
  resize: vertical;
}
.wpcf7-form input[type=submit] {
  background-color: var(--wp--preset--color--vert-fonce);
  color: var(--wp--preset--color--blanc);
  border: none;
  padding: 0.8rem 1.5rem;
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  -webkit-transition: background-color 0.3s ease, -webkit-transform 0.2s ease;
  transition: background-color 0.3s ease, -webkit-transform 0.2s ease;
  transition: background-color 0.3s ease, transform 0.2s ease;
  transition: background-color 0.3s ease, transform 0.2s ease, -webkit-transform 0.2s ease;
  width: 100%;
}
.wpcf7-form input[type=submit]:hover {
  background-color: var(--wp--preset--color--ocre);
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}
.wpcf7-form .wpcf7-response-output {
  margin-top: 1rem;
  padding: 0.75rem 1rem;
  border-radius: 6px;
  font-size: 0.9rem;
}
.wpcf7 .wpcf7-form .wpcf7-response-output.invalid, .wpcf7 .wpcf7-form .wpcf7-response-output.unaccepted {
  background-color: #fff4f4;
  color: #b70000;
  border: 1px solid #b70000;
}
.wpcf7 .wpcf7-form .wpcf7-response-output.sent {
  background-color: #f0fff4;
  color: #006b35;
  border: 1px solid #00a651;
}

@media screen and (max-width: 900px) {
  .chiffres .wp-block-group-is-layout-grid {
    grid-template-columns: 1fr 1fr !important;
  }
}
@media screen and (max-width: 550px) {
  .chiffres .wp-block-group-is-layout-grid {
    grid-template-columns: 1fr !important;
  }
}

figure.shadow img {
  -webkit-filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.4)) !important;
          filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.4)) !important;
}

.wp-block-media-text.shadow figure.wp-block-media-text__media img {
  -webkit-filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.4));
          filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.4));
}

.wp-block-navigation__responsive-container.has-modal-open.is-menu-open {
  background-color: var(--wp--preset--color--beige-clair) !important;
}
.wp-block-navigation__responsive-container.has-modal-open.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation-item,
.wp-block-navigation__responsive-container.has-modal-open.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation__container,
.wp-block-navigation__responsive-container.has-modal-open.is-menu-open .wp-block-navigation__responsive-container-content {
  width: 100%;
  -webkit-box-align: center !important;
      -ms-flex-align: center !important;
          align-items: center !important;
}

.is-mobile {
  display: none;
}
@media screen and (max-width: 900px) {
  .is-mobile {
    display: block;
  }
}

@media screen and (max-width: 900px) {
  footer.wp-block-template-part .wp-block-columns {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

@media (max-width: 900px) {
  .wp-block-navigation__responsive-container-open,
  .wp-block-navigation__responsive-container-close {
    display: block !important;
  }
  /* par défaut caché */
  .wp-block-navigation__responsive-container {
    display: none !important;
  }
  /* état ouvert → WordPress ajoute .is-menu-open */
  .wp-block-navigation__responsive-container.is-menu-open {
    display: block !important;
  }
}
@media (min-width: 901px) {
  .wp-block-navigation__responsive-container-open,
  .wp-block-navigation__responsive-container-close {
    display: none !important;
  }
  .wp-block-navigation__responsive-container {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
}
/* 1) On cache les SVG par défaut (sans toucher au bouton) */
.wp-block-navigation__responsive-container-open svg {
  display: none !important;
}

/* 2) Gabarit commun des boutons */
.wp-block-navigation__responsive-container-open {
  position: relative;
  width: 44px; /* adapte à ton design */
  height: 44px;
  line-height: 0;
}

.wp-block-navigation__responsive-container-close {
  position: absolute;
  top: 25px;
  right: 10px;
}

/* 3) Icône injectée en pseudo-élément, colorisable via currentColor */
.wp-block-navigation__responsive-container-open::before {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 24px; /* taille de l’icône */
  height: 24px;
  background-color: currentColor; /* hérite de la couleur du texte */
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  pointer-events: none; /* ne bloque pas le clic */
}

/* 4) Icône burger (ouvrir) */
.wp-block-navigation__responsive-container-open::before {
  -webkit-mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 6h16M4 12h16M4 18h16" stroke="black" stroke-width="2" stroke-linecap="round"/></svg>');
  mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 6h16M4 12h16M4 18h16" stroke="black" stroke-width="2" stroke-linecap="round"/></svg>');
}

/* (Optionnel) États focus/hover accessibles */
.wp-block-navigation__responsive-container-open:focus-visible {
  outline: 2px solid var(--wp--preset--color--ocre, currentColor);
  outline-offset: 2px;
}

.h2-icon::after {
  background-color: var(--wp--preset--color--fond);
  border-radius: 50%;
  width: 52px;
  height: 52px;
  content: "";
  position: absolute;
  position: absolute;
  left: -2px;
  z-index: -1;
  top: -2px;
}

.h2-icon,
.h3-icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
}
.h2-icon::before,
.h3-icon::before {
  content: "";
  display: block;
  width: 48px;
  height: 48px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  mask-size: contain !important;
  -webkit-mask-size: contain !important;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-position: center;
  -webkit-mask-position: center;
}
.h2-icon.agences::before,
.h3-icon.agences::before {
  -webkit-mask: url("/wp-content/uploads/2025/09/agence.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/09/agence.png") no-repeat center;
}
.h2-icon.independants::before,
.h3-icon.independants::before {
  -webkit-mask: url("/wp-content/uploads/2025/09/entreprise.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/09/entreprise.png") no-repeat center;
}
.h2-icon.presta::before,
.h3-icon.presta::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-tech.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-tech.png") no-repeat center;
}
.h2-icon.discus::before,
.h3-icon.discus::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-discus.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-discus.png") no-repeat center;
}
.h2-icon.mains::before,
.h3-icon.mains::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-mains.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-mains.png") no-repeat center;
}
.h2-icon.valise::before,
.h3-icon.valise::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-valise.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-valise.png") no-repeat center;
}
.h2-icon.pers::before,
.h3-icon.pers::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-pers.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-pers.png") no-repeat center;
}
.h2-icon.up::before,
.h3-icon.up::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-up.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-up.png") no-repeat center;
}
.h2-icon.limite::before,
.h3-icon.limite::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-limite.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-limite.png") no-repeat center;
}
.h2-icon.metier::before,
.h3-icon.metier::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-metier.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-metier.png") no-repeat center;
}
.h2-icon.parcours::before,
.h3-icon.parcours::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-parcours.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-parcours.png") no-repeat center;
}
.h2-icon.woo::before,
.h3-icon.woo::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-woo.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-woo.png") no-repeat center;
}
.h2-icon.seo::before,
.h3-icon.seo::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-seo.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-seo.png") no-repeat center;
}
.h2-icon.agence::before,
.h3-icon.agence::before {
  -webkit-mask: url("/wp-content/uploads/2025/09/agence.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/09/agence.png") no-repeat center;
}
.h2-icon.budget::before,
.h3-icon.budget::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-budget.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-budget.png") no-repeat center;
}
.h2-icon.crayon::before,
.h3-icon.crayon::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-crayon.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-crayon.png") no-repeat center;
}
.h2-icon.maintenant::before,
.h3-icon.maintenant::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-maintenant.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-maintenant.png") no-repeat center;
}
.h2-icon.local::before,
.h3-icon.local::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-local.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-local.png") no-repeat center;
}
.h2-icon.inspi::before,
.h3-icon.inspi::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/inspiration.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/inspiration.png") no-repeat center;
}
.h2-icon.contact::before,
.h3-icon.contact::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-contact.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-contact.png") no-repeat center;
}
.h2-icon.form::before,
.h3-icon.form::before {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-form.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-form.png") no-repeat center;
}
.h2-icon.phone::after,
.h3-icon.phone::after {
  -webkit-mask: url("/wp-content/uploads/2025/06/picto-phone.png") no-repeat center;
  mask: url("/wp-content/uploads/2025/06/picto-phone.png") no-repeat center;
  background-color: var(--wp--preset--color--terra) !important; /* idem pour garder la teinte */
}

.wp-block-group.is-style-section-5 .h2-icon::before,
.wp-block-group.is-style-section-5 .h3-icon::before {
  -webkit-filter: brightness(0) saturate(100%) invert(99%) sepia(2%) saturate(118%) hue-rotate(30deg) brightness(101%) contrast(100%);
          filter: brightness(0) saturate(100%) invert(99%) sepia(2%) saturate(118%) hue-rotate(30deg) brightness(101%) contrast(100%);
}

ul.wp-block-post-template {
  gap: 1.8rem;
}
ul.wp-block-post-template li.wp-block-post {
  border-radius: 0.5rem;
  position: relative;
  overflow: hidden;
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  height: 100%;
  padding: 0 !important;
}
ul.wp-block-post-template li.wp-block-post img {
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
ul.wp-block-post-template li.wp-block-post {
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
ul.wp-block-post-template li.wp-block-post:hover {
  background-color: color-mix(in srgb, var(--hover-color) 15%, white);
}
ul.wp-block-post-template li.wp-block-post:hover img {
  -webkit-transform: scale(1.02);
          transform: scale(1.02); /* Zoom doux */
}
ul.wp-block-post-template li.wp-block-post .wp-block-group .wp-block-demeillat-post-thumbnail {
  aspect-ratio: 16/9;
  width: 100%;
  /* height: auto; */
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
ul.wp-block-post-template li.wp-block-post .wp-block-group .wp-block-demeillat-post-thumbnail img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover; /* remplit le cadre, coupe si nécessaire */
  -o-object-position: center center;
     object-position: center center; /* centre le focus */
}
ul.wp-block-post-template li.wp-block-post .wp-block-group > .wp-block-group {
  position: initial;
  padding: 0.5rem 1.5rem;
}
ul.wp-block-post-template li.wp-block-post .wp-block-group h3 a:hover {
  text-decoration: none;
}
ul.wp-block-post-template li.wp-block-post .wp-block-group h3 a:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
ul.wp-block-post-template li.wp-block-post.type-didactique {
  --accent-color: #e8b45b;
}
ul.wp-block-post-template li.wp-block-post.type-didactique::before {
  content: "Didactique";
}
ul.wp-block-post-template li.wp-block-post.type-technique {
  --accent-color: #1a5951;
}
ul.wp-block-post-template li.wp-block-post.type-technique::before {
  content: "Technique";
}
ul.wp-block-post-template li.wp-block-post.type-mixte {
  --accent-color: #0d4b75;
}
ul.wp-block-post-template li.wp-block-post.type-mixte::before {
  content: "Mixte: Didactique & Technique";
}
ul.wp-block-post-template li.wp-block-post.type-lab {
  --accent-color: #c45c48;
}
ul.wp-block-post-template li.wp-block-post.type-lab::before {
  content: "Lab";
}
ul.wp-block-post-template li.wp-block-post::before {
  z-index: 1;
  position: absolute;
  top: 10px;
  left: 10px;
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 600;
  color: #fff;
  background: var(--accent-color, #ccc);
  letter-spacing: 0.3px;
  content: "";
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
ul.wp-block-post-template li.wp-block-post:hover::before {
  -webkit-filter: brightness(1.1);
          filter: brightness(1.1);
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}
ul.wp-block-post-template li.wp-block-post {
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  border-top: 4px solid var(--accent-color, transparent);
}
ul.wp-block-post-template li.wp-block-post:hover {
  border-top: 6px solid var(--accent-color, #ccc);
  -webkit-box-shadow: 0 12px 40px rgba(0, 0, 0, 0.22);
          box-shadow: 0 12px 40px rgba(0, 0, 0, 0.22);
}

.liste-cat .wp-block-columns .wp-block-column {
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  overflow: hidden;
  padding: 0 !important;
  border-radius: 0.5rem;
}
.liste-cat .wp-block-columns .wp-block-column figure {
  overflow: hidden;
}
.liste-cat .wp-block-columns .wp-block-column img {
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
.liste-cat .wp-block-columns .wp-block-column:hover {
  -webkit-box-shadow: 0 8px 30px rgba(0, 0, 0, 0.18), 0 2px 6px rgba(0, 0, 0, 0.06);
          box-shadow: 0 8px 30px rgba(0, 0, 0, 0.18), 0 2px 6px rgba(0, 0, 0, 0.06); /* petite ombre de surface */
}
.liste-cat .wp-block-columns .wp-block-column:hover img {
  -webkit-transform: scale(1.02);
          transform: scale(1.02); /* Zoom doux */
}
.liste-cat .wp-block-columns .wp-block-column .wp-block-group .wp-block-group {
  position: initial;
  padding: 0.5rem 1.5rem;
}
.liste-cat .wp-block-columns .wp-block-column .wp-block-group .wp-block-group h3 a {
  text-decoration: none;
}
.liste-cat .wp-block-columns .wp-block-column .wp-block-group .wp-block-group h3 a:hover {
  text-decoration: none;
}
.liste-cat .wp-block-columns .wp-block-column .wp-block-group .wp-block-group h3 a:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

body.archive ul.wp-block-post-template > li .wp-block-demeillat-post-thumbnail {
  aspect-ratio: 4/3 !important;
}

.wp-block-query-pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
  margin: 3rem auto;
  padding: 1rem 0;
  border-top: 1px solid rgba(0, 0, 0, 0.05);
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  font-size: 0.95rem;
  font-family: inherit;
  color: #1a1a1a;
  position: relative;
}
.wp-block-query-pagination .wp-block-query-pagination-numbers {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.4rem;
}
.wp-block-query-pagination .wp-block-query-pagination-numbers .page-numbers {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 6px;
  font-weight: 500;
  line-height: 1;
  color: #1a1a1a;
  background: transparent;
  -webkit-transition: all 0.25s ease;
  transition: all 0.25s ease;
}
.wp-block-query-pagination .wp-block-query-pagination-numbers .page-numbers:hover {
  background: #1a5951;
  color: #fff;
}
.wp-block-query-pagination .wp-block-query-pagination-numbers .page-numbers.current {
  background: #1a5951;
  color: #fff;
  font-weight: 600;
  pointer-events: none;
}
.wp-block-query-pagination .wp-block-query-pagination-numbers .page-numbers.dots {
  color: #999;
  pointer-events: none;
}
.wp-block-query-pagination .wp-block-query-pagination-previous,
.wp-block-query-pagination .wp-block-query-pagination-next {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  font-weight: 500;
  color: #1a5951;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.4em;
  -webkit-transition: color 0.2s ease;
  transition: color 0.2s ease;
}
.wp-block-query-pagination .wp-block-query-pagination-previous:hover,
.wp-block-query-pagination .wp-block-query-pagination-next:hover {
  color: #c45c48;
}
.wp-block-query-pagination .wp-block-query-pagination-previous {
  left: 0;
}
.wp-block-query-pagination .wp-block-query-pagination-next {
  right: 0;
}
.wp-block-query-pagination .wp-block-query-pagination-previous-arrow,
.wp-block-query-pagination .wp-block-query-pagination-next-arrow {
  font-weight: 600;
  font-size: 1.1em;
  color: currentColor;
}
@media (max-width: 600px) {
  .wp-block-query-pagination {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0.6rem;
  }
  .wp-block-query-pagination .wp-block-query-pagination-previous,
  .wp-block-query-pagination .wp-block-query-pagination-next {
    position: static;
    -webkit-transform: none;
            transform: none;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .wp-block-query-pagination .wp-block-query-pagination-numbers {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}

.article-tags {
  margin-top: 1.25rem;
  margin-bottom: 0.5rem;
  font-size: 0.9rem;
}
.article-tags__label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 500;
  font-style: italic;
  color: rgba(255, 255, 255, 0.75);
}
.article-tags__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.4rem;
}
.article-tags__item {
  padding: 0.25rem 0.65rem;
  border-radius: 2px;
  background-color: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.9);
  line-height: 1.2;
  white-space: nowrap;
  font-size: 0.75rem;
  line-height: 1.2;
  cursor: default;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.cols3-posts-lies ul {
  padding: 0;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media screen and (max-width: 600px) {
  .cols3-posts-lies ul {
    grid-template-columns: 1fr;
  }
}

.wp-block-group[aria-label="Navigation des publications"] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2rem;
  border-top: 1px solid var(--wp--preset--color--accent-6, #ddd);
  padding-top: var(--wp--preset--spacing--40, 2rem);
  padding-bottom: var(--wp--preset--spacing--40, 2rem);
  margin-top: 4rem;
  font-size: 1rem;
}
.wp-block-group[aria-label="Navigation des publications"] .wp-block-post-navigation-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.6rem;
  font-weight: 500;
  line-height: 1.4;
}
.wp-block-group[aria-label="Navigation des publications"] .wp-block-post-navigation-link a {
  color: var(--wp--preset--color--foreground, #1a1a1a);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  -webkit-transition: color 0.25s ease, border-color 0.25s ease;
  transition: color 0.25s ease, border-color 0.25s ease;
}
.wp-block-group[aria-label="Navigation des publications"] .wp-block-post-navigation-link a:hover {
  color: var(--wp--preset--color--accent-4, #c45c48);
  border-color: currentColor;
}
.wp-block-group[aria-label="Navigation des publications"] .wp-block-post-navigation-link .wp-block-post-navigation-link__arrow-previous,
.wp-block-group[aria-label="Navigation des publications"] .wp-block-post-navigation-link .wp-block-post-navigation-link__arrow-next {
  font-weight: 600;
  font-size: 1.2rem;
  color: var(--wp--preset--color--accent-3, #1a5951);
  -webkit-transition: color 0.25s ease;
  transition: color 0.25s ease;
}
.wp-block-group[aria-label="Navigation des publications"] .wp-block-post-navigation-link:hover .wp-block-post-navigation-link__arrow-previous, .wp-block-group[aria-label="Navigation des publications"] .wp-block-post-navigation-link:hover .wp-block-post-navigation-link__arrow-next {
  color: var(--wp--preset--color--accent-4, #c45c48);
}
.wp-block-group[aria-label="Navigation des publications"] .post-navigation-link-previous {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  text-align: left;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.wp-block-group[aria-label="Navigation des publications"] .post-navigation-link-previous a {
  text-align: left;
}
.wp-block-group[aria-label="Navigation des publications"] .post-navigation-link-next {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  text-align: right;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.wp-block-group[aria-label="Navigation des publications"] .post-navigation-link-next a {
  text-align: right;
}
.wp-block-group[aria-label="Navigation des publications"]:hover a {
  text-decoration: none;
}
@media (max-width: 768px) {
  .wp-block-group[aria-label="Navigation des publications"] {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    gap: 1.5rem;
  }
  .wp-block-group[aria-label="Navigation des publications"] .wp-block-post-navigation-link {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    font-size: 0.95rem;
  }
  .wp-block-group[aria-label="Navigation des publications"] .post-navigation-link-next {
    text-align: right;
  }
}

.yoast-breadcrumbs {
  font-weight: 600;
  max-width: var(--wp--style--global--wide-size);
  margin: 1.5rem auto;
}

body.single-post .yoast-breadcrumbs {
  max-width: var(--wp--style--global--content-size);
}/*# sourceMappingURL=style.css.map */