@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes dotPulseVertical {
  0%, 6% {
    background: #FFFFFF;
    border-color: #A9CBB7;
    transform: scale(1);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  }
  8% {
    background: #FFFFFF;
    border-color: #A9CBB7;
    transform: scale(1.05);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  }
  10%, 14% {
    background: #7EBF8D;
    border-color: #7EBF8D;
    transform: scale(1.15);
    box-shadow: rgba(126, 191, 141, 0.4) 0px 0px 0px 8px, rgba(0, 0, 0, 0.15) 0px 6px 12px -2px;
  }
  16% {
    background: #7EBF8D;
    border-color: #7EBF8D;
    transform: scale(1.05);
    box-shadow: rgba(126, 191, 141, 0.2) 0px 0px 0px 4px, rgba(0, 0, 0, 0.12) 0px 5px 10px -2px;
  }
  18%, 100% {
    background: #FFFFFF;
    border-color: #A9CBB7;
    transform: scale(1);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  }
}
@keyframes lineProgress {
  0%, 10% {
    height: 0%;
  }
  24%, 91.66% {
    height: 100%;
  }
  91.67%, 100% {
    height: 0%;
  }
}
@keyframes numberPulseVertical {
  0%, 8% {
    transform: scale(1);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  }
  11% {
    transform: scale(1.05);
    box-shadow: rgba(169, 203, 183, 0.2) 0px 0px 0px 4px, rgba(0, 0, 0, 0.12) 0px 5px 8px -2px;
  }
  13%, 18% {
    transform: scale(1.15);
    box-shadow: rgba(169, 203, 183, 0.4) 0px 0px 0px 8px, rgba(0, 0, 0, 0.15) 0px 6px 12px -2px;
  }
  20% {
    transform: scale(1.05);
    box-shadow: rgba(169, 203, 183, 0.2) 0px 0px 0px 4px, rgba(0, 0, 0, 0.12) 0px 5px 8px -2px;
  }
  22%, 100% {
    transform: scale(1);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  }
}
@keyframes lineProgressRecrutement {
  0%, 13% {
    height: 0%;
  }
  32%, 88.88% {
    height: 100%;
  }
  88.89%, 100% {
    height: 0%;
  }
}
*, ::before, ::after {
  margin: 0;
  padding: 0;
  outline: none;
  box-sizing: border-box;
}

body {
  overflow-x: hidden;
}

select {
  cursor: pointer;
}

@font-face {
  font-family: "BebasNeue";
  src: url("../../assets/fonts/font_h1/BebasNeue-Regular.ttf");
}
@font-face {
  font-family: "Poppins";
  src: url("../../assets/fonts/font_h2_h3_p/Poppins-Black.ttf");
}
@font-face {
  font-family: "Poppins_texte";
  src: url("../../assets/fonts/font_h2_h3_p/Poppins-Light.ttf");
}
@font-face {
  font-family: "Material Symbols Outlined";
  src: url("../../assets/fonts/MaterialSymbolsOutlined[FILL,GRAD,opsz,wght].woff2") format("woff2");
  font-weight: 100 700;
  font-style: normal;
  font-display: swap;
}
.material-symbols-outlined {
  font-family: "Material Symbols Outlined";
  font-weight: 200;
  font-style: normal;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  direction: ltr;
  -webkit-font-smoothing: antialiased;
  font-variation-settings: "FILL" 0, "wght" 200, "GRAD" 0, "opsz" 24;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
}
@media (max-width: 1024px) {
  .material-symbols-outlined {
    font-size: 26px;
  }
}
@media (max-width: 768px) {
  .material-symbols-outlined {
    font-size: 24px;
  }
}

h1 {
  font-family: "Microsoft JhengHei UI", sans-serif;
  font-size: 3.7rem;
}
@media (max-width: 1024px) {
  h1 {
    font-size: 3rem;
  }
}
@media (max-width: 768px) {
  h1 {
    font-size: 2.2rem;
  }
}

h1 {
  margin-bottom: 44px;
}
@media (max-width: 1024px) {
  h1 {
    margin-bottom: 42px;
  }
}
@media (max-width: 768px) {
  h1 {
    margin-bottom: 40px;
  }
}

h2 {
  font-family: "Microsoft JhengHei UI", sans-serif;
  font-size: 2.5rem;
}
@media (max-width: 1024px) {
  h2 {
    font-size: 2rem;
  }
}
@media (max-width: 768px) {
  h2 {
    font-size: 1.5rem;
  }
}

h2 {
  margin-bottom: 20px;
}
@media (max-width: 1024px) {
  h2 {
    margin-bottom: 16px;
  }
}
@media (max-width: 768px) {
  h2 {
    margin-bottom: 12px;
  }
}

h3 {
  font-family: "Microsoft JhengHei UI", sans-serif;
  font-size: 2rem;
}
@media (max-width: 1024px) {
  h3 {
    font-size: 1.5rem;
  }
}
@media (max-width: 768px) {
  h3 {
    font-size: 1rem;
  }
}

h3 {
  margin-bottom: 16px;
}
@media (max-width: 1024px) {
  h3 {
    margin-bottom: 12px;
  }
}
@media (max-width: 768px) {
  h3 {
    margin-bottom: 10px;
  }
}

h4 {
  font-family: "Microsoft JhengHei UI", sans-serif;
  font-size: 1.5rem;
}
@media (max-width: 1024px) {
  h4 {
    font-size: 1.2rem;
  }
}
@media (max-width: 768px) {
  h4 {
    font-size: 0.9rem;
  }
}

h4 {
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  h4 {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  h4 {
    margin-bottom: 8px;
  }
}

p, a, label, input, button, li, select, span {
  font-family: "Poppins_texte", sans-serif;
  font-size: 1.2rem;
}
@media (max-width: 1024px) {
  p, a, label, input, button, li, select, span {
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  p, a, label, input, button, li, select, span {
    font-size: 0.95rem;
  }
}

ul {
  list-style: disc outside;
  padding-inline-start: 2.5rem;
}

ol {
  list-style: decimal outside;
  padding-inline-start: 2.5rem;
}

@media (max-width: 1024px) {
  ul, ol {
    padding-inline-start: 2.25rem;
  }
}
@media (max-width: 768px) {
  ul, ol {
    padding-inline-start: 2rem;
  }
}
table {
  font-family: "Poppins_texte", sans-serif;
  font-size: 0.8rem;
  border: unset !important;
}
@media (max-width: 1024px) {
  table {
    font-size: 0.7rem;
  }
}
@media (max-width: 768px) {
  table {
    font-size: 0.6rem;
  }
}

label {
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  label {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  label {
    margin-bottom: 8px;
  }
}

input {
  margin-bottom: 16px;
}
@media (max-width: 1024px) {
  input {
    margin-bottom: 12px;
  }
}
@media (max-width: 768px) {
  input {
    margin-bottom: 10px;
  }
}

table {
  border-collapse: separate;
  border-spacing: 0;
  width: max-content;
  min-width: 100%;
  max-width: 100%;
  background: #FFFFFF;
  border-radius: 12px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  overflow: auto;
}

thead th {
  background: #f8fafc;
  font-weight: 600;
}

th,
td {
  padding: 12px 14px;
  border-right: 1px solid #eaeef2;
  border-bottom: 1px solid #eaeef2;
  text-align: left;
  vertical-align: top;
  line-height: 1.45;
  word-break: break-word;
}

tr > *:last-child {
  border-right: 0;
}

tr:last-child > * {
  border-bottom: 0;
}

tbody tr:nth-child(odd) td {
  background: #fbfdff;
}

tbody tr:hover td {
  background: #f1f5f9;
}

thead tr:first-child th:first-child {
  border-top-left-radius: 12px;
}

thead tr:first-child th:last-child {
  border-top-right-radius: 12px;
}

tbody tr:last-child td:first-child {
  border-bottom-left-radius: 12px;
}

tbody tr:last-child td:last-child {
  border-bottom-right-radius: 12px;
}

caption {
  caption-side: bottom;
  text-align: left;
  padding: 8px 10px;
  font-size: 0.95rem;
}

@media (max-width: 1024px) {
  th, td {
    padding: 10px 12px;
    font-size: 0.98rem;
  }
}
@media (max-width: 768px) {
  th, td {
    padding: 8px 10px;
    font-size: 0.95rem;
  }
}
*::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

*::-webkit-scrollbar-track {
  background: transparent;
}

*::-webkit-scrollbar-thumb {
  background: linear-gradient(135deg, #4C4C4C, #A9CBB7);
  border-radius: 12px;
  transition: background 0.3s ease;
}

*:hover::-webkit-scrollbar-thumb {
  background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
}

* {
  scrollbar-width: thin;
}

section {
  padding: 100px 5%;
}
@media (max-width: 1024px) {
  section {
    padding: 70px 5%;
  }
}
@media (max-width: 768px) {
  section {
    padding: 50px 5%;
  }
}

.container {
  padding: 40px;
}
@media (max-width: 1024px) {
  .container {
    padding: 30px;
  }
}
@media (max-width: 768px) {
  .container {
    padding: 20px;
  }
}

.container__links {
  display: flex;
  flex-direction: column;
  gap: 35px;
  margin-bottom: 40px;
}
@media (max-width: 1024px) {
  .container__links {
    gap: 32.5px;
    margin-bottom: 35px;
  }
}
@media (max-width: 768px) {
  .container__links {
    gap: 20px;
    margin-bottom: 25px;
  }
}

.container__links a {
  transition: color ease-in-out 0.2s ease;
  font-size: 1.5rem;
}
@media (max-width: 1024px) {
  .container__links a {
    font-size: 1.2rem;
  }
}
@media (max-width: 768px) {
  .container__links a {
    font-size: 0.9rem;
  }
}

.content {
  max-width: 1280px;
  margin: 0 auto;
}

.content {
  padding: 150px 25px;
}
@media (max-width: 1024px) {
  .content {
    padding: 125px 22.5px;
  }
}
@media (max-width: 768px) {
  .content {
    padding: 100px 20px;
  }
}

.container_button {
  display: flex;
  align-items: center;
  justify-content: center;
}

.container_button_left {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.container_button_right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.container_button button, .container_button a {
  display: flex;
  border: none;
  align-items: center;
  justify-content: center;
  color: #4C4C4C;
  border-radius: 50px;
  outline: none;
  cursor: pointer;
  font-weight: 700;
}

.container_button .login_btn {
  background-image: linear-gradient(120deg, #A9CBB7, #F7E1D7);
  color: white;
  transition: background-image 0.2s ease-in-out;
}

.container_button .login_btn:hover {
  background-image: linear-gradient(120deg, #87AC9B, #e3c4b7);
}

.container_button .signup_btn {
  background-image: linear-gradient(135deg, #F2C288, #EFCFD1);
  color: white;
  transition: background-image 0.2s ease-in-out;
}

.container_button .signup_btn:hover {
  background-image: linear-gradient(135deg, #d5a569, #d5b3b5);
}

.logout-page {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
}

.logout-card {
  width: 100%;
  max-width: 460px;
}
@media (max-width: 768px) {
  .logout-card {
    max-width: 100%;
  }
}

.logout-card__body {
  padding: 40px 40px 35px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 10px;
}
@media (max-width: 768px) {
  .logout-card__body {
    padding: 35px 25px;
  }
}

.logout-card__icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 10px;
}
.logout-card__icon .material-symbols-outlined {
  font-size: 2.4rem;
  color: #FFFFFF;
}

.logout-card__title {
  font-size: 2rem;
  color: #4C4C4C;
  margin: 0;
}

.logout-card__subtitle {
  font-size: 0.95rem;
  color: #4C4C4C;
  font-weight: 500;
  margin: 0;
}

.logout-card__text {
  font-size: 0.8rem;
  color: grey;
  margin: 0;
}

.logout-card__actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
  margin-top: 25px;
}

.logout-card__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 12px 15px;
  border-radius: 50px;
  font-size: 0.95rem;
  font-weight: 600;
  text-decoration: none;
  transition: opacity 0.15s ease-in-out;
}
.logout-card__btn:hover {
  opacity: 0.88;
}
.logout-card__btn .material-symbols-outlined {
  font-size: 1.1rem;
}
.logout-card__btn--primary {
  background: linear-gradient(120deg, #A9CBB7, #F7E1D7);
  color: #FFFFFF;
}
.logout-card__btn--secondary {
  background: #f5f5f5;
  color: #4C4C4C;
}

.container_button button, .container_button a {
  padding: 15px;
}
@media (max-width: 1024px) {
  .container_button button, .container_button a {
    padding: 12px;
  }
}
@media (max-width: 768px) {
  .container_button button, .container_button a {
    padding: 10px;
  }
}

.container_button button, .container_button a {
  margin-top: 24px;
}
@media (max-width: 1024px) {
  .container_button button, .container_button a {
    margin-top: 22px;
  }
}
@media (max-width: 768px) {
  .container_button button, .container_button a {
    margin-top: 20px;
  }
}

.container_button button, .container_button a {
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .container_button button, .container_button a {
    margin-bottom: 45px;
  }
}
@media (max-width: 768px) {
  .container_button button, .container_button a {
    margin-bottom: 40px;
  }
}

a {
  text-decoration: none;
  color: #4C4C4C;
  transition: 0.3s ease color;
}

.container__link-button {
  display: flex;
  align-items: center;
  justify-content: center;
}

.container__link-button a {
  border-radius: 50px;
  outline: none;
  color: #FFFFFF;
  background-color: #A9CBB7;
  padding: 45px;
}
@media (max-width: 1024px) {
  .container__link-button a {
    padding: 42.5px;
  }
}
@media (max-width: 768px) {
  .container__link-button a {
    padding: 40px;
  }
}

.container__link_left {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.container__link_right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.link_login_style, .link_signup_style {
  border-radius: 15px;
  border: solid 1px #4C4C4C;
  color: #4C4C4C;
  font-weight: 700;
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 15px;
  margin-bottom: 15px;
}
@media (max-width: 1024px) {
  .link_login_style, .link_signup_style {
    padding: 12.5px;
    margin-bottom: 12.5px;
  }
}
@media (max-width: 768px) {
  .link_login_style, .link_signup_style {
    padding: 10px;
    margin-bottom: 10px;
  }
}

.link_create_article_style {
  border-radius: 15px;
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  color: #FFFFFF;
  font-weight: 700;
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 15px;
  margin-bottom: 15px;
}
@media (max-width: 1024px) {
  .link_create_article_style {
    padding: 12.5px;
    margin-bottom: 12.5px;
  }
}
@media (max-width: 768px) {
  .link_create_article_style {
    padding: 10px;
    margin-bottom: 10px;
  }
}

.link_create_categorie_style {
  border-radius: 15px;
  border: solid 2px unset;
  background: linear-gradient(135deg, #4C4C4C, #A9CBB7);
  color: white;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: space-around;
  padding: 15px;
  margin-bottom: 15px;
}
@media (max-width: 1024px) {
  .link_create_categorie_style {
    padding: 12.5px;
    margin-bottom: 12.5px;
  }
}
@media (max-width: 768px) {
  .link_create_categorie_style {
    padding: 10px;
    margin-bottom: 10px;
  }
}

.dashboard_form .container_button {
  gap: 35px;
  margin-top: 24px;
}
@media (max-width: 1024px) {
  .dashboard_form .container_button {
    gap: 32.5px;
    margin-top: 22px;
  }
}
@media (max-width: 768px) {
  .dashboard_form .container_button {
    gap: 20px;
    margin-top: 20px;
  }
}

.dashboard_form .container_button a {
  color: #FFFFFF;
  background-color: #D16464;
  transition: background-color 0.3s ease;
}

.dashboard_form .container_button a:hover {
  background-color: #c53d3d;
}

.dashboard_form .container_button .submit-button {
  background-color: #7EBF8D;
  color: #FFFFFF;
  transition: background-color 0.3s ease;
}

.dashboard_form .container_button .submit-button:hover {
  background-color: #5cae6f;
}

.section-header .container_button {
  margin-top: 0;
}

.section-header .container_button button,
.section-header .container_button a {
  margin-top: 0;
  margin-bottom: 0;
}

.dashboard_form .container_button .cancel_button {
  color: #4C4C4C;
  background-color: #ececec;
  align-self: center;
  transition: background-color 0.3s ease;
  margin: unset;
}

.modale_container .button-link,
.btn--rouge {
  background-color: #D16464;
  color: #FFFFFF;
  -webkit-text-fill-color: #FFFFFF;
  border: none;
  border-radius: 50px;
  font-weight: 700;
  cursor: pointer;
  transition: background-color 0.15s ease-in-out;
}
.modale_container .button-link:hover,
.btn--rouge:hover {
  background-color: #c25050;
  color: #FFFFFF;
  -webkit-text-fill-color: #FFFFFF;
}

label {
  font-weight: 700;
  letter-spacing: 1.5px;
  display: inline-block;
  color: #A9CBB7;
}

input {
  color: #A9CBB7;
  display: block;
  outline: none;
  border: solid 1px #AAC8CE;
  border-radius: 50px;
  width: 100%;
  padding: 15px;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  input {
    padding: 12px;
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  input {
    padding: 10px;
    margin-bottom: 8px;
  }
}

textarea {
  color: #A9CBB7;
  display: block;
  outline: none;
  border: solid 1px #AAC8CE;
  border-radius: 15px;
  width: 100%;
  padding: 15px;
  margin-bottom: 12px;
  resize: vertical;
}
@media (max-width: 1024px) {
  textarea {
    padding: 12px;
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  textarea {
    padding: 10px;
    margin-bottom: 8px;
  }
}

select {
  display: block;
  outline: none;
  background-color: #FFFFFF;
  border: solid 1px #A9CBB7;
  border-radius: 15px;
  margin-bottom: 12px;
  padding: 15px;
}
@media (max-width: 1024px) {
  select {
    margin-bottom: 10px;
    padding: 12px;
  }
}
@media (max-width: 768px) {
  select {
    margin-bottom: 8px;
    padding: 10px;
  }
}

select option {
  text-align: center;
}

form {
  margin: 0 auto;
  max-width: 700px;
  margin-top: 70px;
}
@media (max-width: 1024px) {
  form {
    margin-top: 60px;
    max-width: 450px;
  }
}
@media (max-width: 768px) {
  form {
    margin-top: 50px;
    max-width: 300px;
  }
}

.form-group {
  margin-bottom: 24px;
}
@media (max-width: 1024px) {
  .form-group {
    margin-bottom: 20px;
  }
}
@media (max-width: 768px) {
  .form-group {
    margin-bottom: 16px;
  }
}

.text_error {
  color: #D16464;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .text_error {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .text_error {
    margin-bottom: 8px;
  }
}

.articles {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  justify-items: center;
  gap: 40px;
}
@media (max-width: 1024px) {
  .articles {
    gap: 25px;
  }
}
@media (max-width: 768px) {
  .articles {
    gap: 20px;
  }
}

.articles__card {
  display: block;
  position: relative;
  overflow: hidden;
  border-radius: 15px;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
  height: 500px;
  flex-basis: 350px;
  transition: transform 0.2s ease-in-out;
}
.articles__card:hover {
  transform: scale(1.02);
}
@media (max-width: 1024px) {
  .articles__card {
    height: 450px;
    flex-basis: 325px;
  }
}
@media (max-width: 768px) {
  .articles__card {
    height: 400px;
    flex-basis: 300px;
    max-width: 300px;
    margin: 0 auto 25px auto;
  }
}

.articles__card__action_links {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 10;
  display: flex;
  gap: 8px;
}

.articles__card__action_links a {
  background-color: #FFFFFF;
  border-radius: 50%;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  cursor: pointer;
  height: 40px;
  width: 40px;
}
@media (max-width: 1024px) {
  .articles__card__action_links a {
    height: 35px;
    width: 35px;
  }
}
@media (max-width: 768px) {
  .articles__card__action_links a {
    height: 30px;
    width: 30px;
  }
}

.articles__card__action_links a:hover {
  background-color: #f1f1f1;
}

.articles__card__action_links a span {
  color: #000000;
}

.articles__card__categorie_container {
  position: absolute;
  top: 30%;
  right: 5px;
  z-index: 10;
  display: flex;
  gap: 8px;
}

.articles__card__categorie {
  font-weight: 700;
  border-radius: 50px;
  color: #FFFFFF;
  background-color: rgba(196, 196, 196, 0.42);
  font-size: 0.7rem;
}

.articles__card__categorie_container .articles__card__categorie {
  padding: 10px;
}
@media (max-width: 1024px) {
  .articles__card__categorie_container .articles__card__categorie {
    padding: 8px;
  }
}
@media (max-width: 768px) {
  .articles__card__categorie_container .articles__card__categorie {
    padding: 6px;
  }
}

.articles__card__img-container {
  position: relative;
  height: 40%;
}
.articles__card__img-container img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.articles__card__content {
  height: 60%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-self: stretch;
  gap: 15px;
  padding: 15px;
}
@media (max-width: 1024px) {
  .articles__card__content {
    gap: 12.5px;
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .articles__card__content {
    gap: 10px;
    padding: 10px;
  }
}

.articles__card__content__text h3 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.articles__card__content__text p {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.articles__card__content_bottom {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.articles__card__content__date {
  color: grey;
  font-style: italic;
  font-weight: 400;
}

.articles__card__content__user {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
}
@media (max-width: 1024px) {
  .articles__card__content__user {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .articles__card__content__user {
    gap: 6px;
  }
}

.articles__card__content__user-icon {
  border-radius: 50%;
  overflow: hidden;
}
.articles__card__content__user-icon img {
  object-fit: cover;
}

.categories {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 40px;
}
@media (max-width: 1024px) {
  .categories {
    gap: 25px;
  }
}
@media (max-width: 768px) {
  .categories {
    gap: 20px;
    display: block;
  }
}

.categories .category--card {
  position: relative;
  overflow: hidden;
  border-radius: 15px;
  height: 300px;
}
@media (max-width: 1024px) {
  .categories .category--card {
    height: 250px;
  }
}
@media (max-width: 768px) {
  .categories .category--card {
    height: 90px;
    max-width: 500px;
    margin: 0 auto 25px auto;
  }
}

.categories .category--card__action_links {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 13;
  display: flex;
  gap: 8px;
}

.categories .category--card__action_links a {
  background-color: #FFFFFF;
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  cursor: pointer;
  height: 40px;
  width: 40px;
}
@media (max-width: 1024px) {
  .categories .category--card__action_links a {
    height: 35px;
    width: 35px;
  }
}
@media (max-width: 768px) {
  .categories .category--card__action_links a {
    height: 30px;
    width: 30px;
  }
}

.categories .category--card__action_links a:hover {
  background-color: #f1f1f1;
}

.categories .category--card__main {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  text-decoration: none;
  color: inherit;
  border-radius: 15px;
}
@media (max-width: 768px) {
  .categories .category--card__main {
    max-width: 500px;
  }
}

.categories .category--card__image {
  position: absolute;
  inset: 0;
  z-index: 10;
}
.categories .category--card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.categories .category--card__image::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.3);
  z-index: 11;
}

.categories .category--card__content {
  position: relative;
  z-index: 12;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 1rem;
  color: #FFFFFF;
  font-weight: bold;
  font-size: 1.5rem;
  text-align: center;
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .breadcrumb {
    gap: 8px;
    margin-bottom: 45px;
  }
}
@media (max-width: 768px) {
  .breadcrumb {
    gap: 6px;
    margin-bottom: 40px;
  }
}

.container__links .breadcrumb__link,
.container__links .breadcrumb__item {
  white-space: nowrap;
}

.container__links .breadcrumb__link {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #DADADA;
  transition: color 0.2s ease-in-out;
  font-size: 1.2rem;
}
.container__links .breadcrumb__link:hover {
  color: #7EBF8D;
}
@media (max-width: 1024px) {
  .container__links .breadcrumb__link {
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .container__links .breadcrumb__link {
    font-size: 0.95rem;
  }
}

.breadcrumb__separator,
.breadcrumb__item {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #4C4C4C;
}

.dropzone-container {
  border: 2px dashed #AAC8CE;
  border-radius: 15px;
  text-align: center;
  position: relative;
  width: 100%;
  max-width: 700px;
  margin-bottom: 20px;
  transition: border-color 0.3s ease;
  background-color: #FAFAF9;
  padding: 40px;
}
@media (max-width: 1024px) {
  .dropzone-container {
    padding: 30px;
  }
}
@media (max-width: 768px) {
  .dropzone-container {
    padding: 20px;
  }
}
.dropzone-container.dragover {
  border-color: #A9CBB7;
  background-color: rgba(169, 203, 183, 0.2);
}

.dropzone-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  cursor: pointer;
  font-size: 1.5rem;
  gap: 20px;
}
@media (max-width: 1024px) {
  .dropzone-label {
    font-size: 1rem;
    gap: 15px;
  }
}
@media (max-width: 768px) {
  .dropzone-label {
    font-size: 0.95rem;
    gap: 10px;
  }
}

.upload-button {
  border-color: #A9CBB7;
  background-color: #A9CBB7;
  color: #FFFFFF;
  border-radius: 15px;
  text-align: center;
  transition: background-color 0.3s ease;
  padding: 15px;
}
@media (max-width: 1024px) {
  .upload-button {
    padding: 12px;
  }
}
@media (max-width: 768px) {
  .upload-button {
    padding: 10px;
  }
}
.upload-button:hover {
  opacity: 0.8;
}

.preview-image {
  border-radius: 50%;
  object-fit: cover;
  width: 200px;
  height: 200px;
  margin-left: auto;
  margin-right: auto;
  display: block;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .preview-image {
    margin-bottom: 10px;
    width: 175px;
    height: 175px;
  }
}
@media (max-width: 768px) {
  .preview-image {
    margin-bottom: 8px;
    width: 150px;
    height: 150px;
  }
}

.preview-image--rect {
  border-radius: 15px;
  object-fit: cover;
  display: block;
  width: 100%;
  height: auto;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  max-width: 450px;
}
@media (max-width: 1024px) {
  .preview-image--rect {
    max-width: 400px;
  }
}
@media (max-width: 768px) {
  .preview-image--rect {
    max-width: 350px;
  }
}

.hidden-input {
  display: none;
}

.hidden-input-modal {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
}

.dropzone-container--article {
  border: 2px dashed #AAC8CE;
  border-radius: 15px;
  text-align: center;
  position: relative;
  width: 100%;
  max-width: 100%;
  margin-bottom: 20px;
  transition: border-color 0.3s ease;
  padding: 40px;
}
@media (max-width: 1024px) {
  .dropzone-container--article {
    padding: 30px;
  }
}
@media (max-width: 768px) {
  .dropzone-container--article {
    padding: 20px;
  }
}
.dropzone-container--article.dragover {
  background-color: #F7E1D7;
  border-color: #A9CBB7;
}
.dropzone-container--article:focus-within {
  outline: 2px dashed #AAC8CE;
  outline-offset: 4px;
}
.dropzone-container--article .dropzone-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  cursor: pointer;
  gap: 20px;
}
@media (max-width: 1024px) {
  .dropzone-container--article .dropzone-label {
    gap: 15px;
  }
}
@media (max-width: 768px) {
  .dropzone-container--article .dropzone-label {
    gap: 10px;
  }
}
.dropzone-container--article .upload-button {
  background-color: #A9CBB7;
  color: #FFFFFF;
  border-radius: 8px;
  text-align: center;
  transition: background-color 0.3s ease;
  padding: 15px;
}
@media (max-width: 1024px) {
  .dropzone-container--article .upload-button {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .dropzone-container--article .upload-button {
    padding: 10px;
  }
}
.dropzone-container--article .upload-button:hover {
  opacity: 0.9;
}
.dropzone-container--article .preview-image--rect {
  border-radius: 15px;
  object-fit: contain;
  display: block;
  width: 100%;
  max-width: 500px;
  height: auto;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}
.dropzone-container--article .preview-files {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 18px;
  max-height: 220px;
  overflow: auto;
  padding-right: 4px;
}
@media (max-width: 768px) {
  .dropzone-container--article .preview-files {
    gap: 8px;
    margin-bottom: 14px;
  }
}
.dropzone-container--article .preview-files::-webkit-scrollbar {
  height: 6px;
  width: 6px;
}
.dropzone-container--article .preview-files::-webkit-scrollbar-thumb {
  background: #AAC8CE;
  border-radius: 10px;
}
.dropzone-container--article .preview-files::-webkit-scrollbar-track {
  background: transparent;
}
.dropzone-container--article .file-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border: 1px dashed #AAC8CE;
  background: #FFFFFF;
  border-radius: 10px;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}
.dropzone-container--article .file-chip:hover {
  border-color: #A9CBB7;
  background: #F9FAFB;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}
@media (max-width: 768px) {
  .dropzone-container--article .file-chip {
    padding: 7px 9px;
  }
}
.dropzone-container--article .file-chip__icon {
  font-size: 18px;
  line-height: 1;
}
.dropzone-container--article .file-chip__name {
  display: inline-block;
  max-width: clamp(120px, 32vw, 360px);
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 768px) {
  .dropzone-container--article .file-chip__name {
    max-width: clamp(100px, 48vw, 240px);
  }
}
.dropzone-container--article .file-chip__remove {
  margin-left: 2px;
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  color: #B94A48;
  padding: 0 4px;
  border-radius: 6px;
  transition: background-color 0.2s ease, color 0.2s ease;
}
.dropzone-container--article .file-chip__remove:hover, .dropzone-container--article .file-chip__remove:focus {
  background: rgba(185, 74, 72, 0.08);
  outline: none;
}

.modale_container {
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100%;
  background-color: rgba(76, 76, 76, 0.18);
  z-index: 100;
  overflow-y: auto;
  padding: 40px;
}
@media (max-width: 1024px) {
  .modale_container {
    padding: 30px;
  }
}
@media (max-width: 768px) {
  .modale_container {
    padding: 20px;
  }
}

.modale_container__window {
  border-radius: 15px;
  background-color: #FFFFFF;
  max-width: 700px;
  margin-top: 30px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 30px;
  padding: 40px;
}
@media (max-width: 1024px) {
  .modale_container__window {
    margin-top: 25px;
    margin-bottom: 25px;
    padding: 30px;
  }
}
@media (max-width: 768px) {
  .modale_container__window {
    margin-top: 20px;
    margin-bottom: 20px;
    padding: 20px;
  }
}

.modale_container__window_cross {
  background-color: transparent;
  color: #DADADA;
  border: none;
  cursor: pointer;
  margin-bottom: 30px;
}
@media (max-width: 1024px) {
  .modale_container__window_cross {
    margin-bottom: 28.5px;
  }
}
@media (max-width: 768px) {
  .modale_container__window_cross {
    margin-bottom: 26px;
  }
}

.modale_container .btn--danger,
.modale_container button {
  margin: unset;
}

.modale_container .btn--danger {
  border-radius: 50px;
  background-color: #D16464;
  color: #FFFFFF;
}
.modale_container .btn--danger:hover {
  background-color: #c53d3d;
}

.modale_container .button-link,
.modale_container .cancel_button,
.modale_container .btn--rouge {
  background-color: #ececec;
  color: #4C4C4C;
  -webkit-text-fill-color: #4C4C4C;
}
.modale_container .button-link:hover,
.modale_container .cancel_button:hover,
.modale_container .btn--rouge:hover {
  background-color: #d8d8d8;
  color: #4C4C4C;
  -webkit-text-fill-color: #4C4C4C;
}

.modale_container.unactive {
  display: none;
}

.messages_container {
  position: fixed;
  color: #FFFFFF;
  z-index: 105;
  width: 100%;
  display: flex;
  flex-direction: column;
  top: 85px;
  padding: 20px;
  gap: 15px;
}
@media (max-width: 1024px) {
  .messages_container {
    top: 80px;
    padding: 17.5px;
    gap: 12px;
  }
}
@media (max-width: 768px) {
  .messages_container {
    top: 75px;
    padding: 20px;
    gap: 10px;
  }
}

.messages_container--hidden {
  display: none;
}

.messages_container .message {
  position: relative;
  display: flex;
  align-items: center;
  border-radius: 15px;
  transform: translateX(-150%);
  opacity: 0;
  transition: transform 0.4s ease, opacity 0.4s ease;
  gap: 30px;
  max-width: 400px;
  padding: 20px;
}
@media (max-width: 1024px) {
  .messages_container .message {
    gap: 25px;
    max-width: 350px;
    padding: 17.5px;
  }
}
@media (max-width: 768px) {
  .messages_container .message {
    gap: 20px;
    max-width: 300px;
    padding: 20px;
  }
}

.messages_container .message.visible {
  transform: translateX(0);
  opacity: 1;
}

.messages_container .message.hide {
  transform: translateX(-150%);
  opacity: 0;
}

.messages_container .message .close-btn {
  background-color: transparent;
  border: unset;
  outline: none;
  cursor: pointer;
}

.carrousel_wrapper {
  position: relative;
}

.carrousel_wrapper .carrousel_track {
  display: flex;
  flex-shrink: 0;
  flex-wrap: nowrap;
  max-width: 1400px;
  scroll-behavior: smooth;
  overflow-x: auto;
  scrollbar-width: none;
  scroll-snap-type: x mandatory;
  scroll-padding-left: 0;
  gap: 50px;
}
@media (max-width: 1024px) {
  .carrousel_wrapper .carrousel_track {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .carrousel_wrapper .carrousel_track {
    gap: 25px;
  }
}

.carrousel_wrapper .carrousel_track::-webkit-scrollbar {
  display: none;
}

.carrousel_wrapper .carrousel_item {
  scroll-snap-align: start;
  flex: 0 0 100%;
}

.carrousel_wrapper .carrousel_dots {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
}

.carrousel_wrapper .carrousel_dots .dot {
  border-radius: 50%;
  background-color: #FFFFFF;
  cursor: pointer;
  opacity: 0.5;
  transition: transform 0.3s ease, opacity 0.3s ease;
  height: 12px;
  width: 12px;
}
@media (max-width: 1024px) {
  .carrousel_wrapper .carrousel_dots .dot {
    height: 10px;
    width: 10px;
  }
}
@media (max-width: 768px) {
  .carrousel_wrapper .carrousel_dots .dot {
    height: 8px;
    width: 8px;
  }
}

.carrousel_wrapper .carrousel_dots .dot_active {
  transform: scale(1.5);
  opacity: 1;
}

.logo {
  height: 80px;
  width: 80px;
}
@media (max-width: 1024px) {
  .logo {
    height: 50px;
    width: 50px;
  }
}
@media (max-width: 768px) {
  .logo {
    height: 40px;
    width: 40px;
  }
}

.logo img {
  object-fit: contain;
  width: 100%;
  height: 100%;
}

.icon {
  height: 40px;
  width: 40px;
}
@media (max-width: 1024px) {
  .icon {
    height: 35px;
    width: 35px;
  }
}
@media (max-width: 768px) {
  .icon {
    height: 30px;
    width: 30px;
  }
}

.icon img {
  object-fit: contain;
  width: 100%;
  height: 100%;
}

.icon .icon__user_pp {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.arrow-icon {
  transition: transform 0.3s ease-in-out;
}

.arrow-icon.active {
  transform: rotateZ(90deg);
}

.search-container {
  position: relative;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-bottom: 50px;
}
@media (max-width: 768px) {
  .search-container {
    display: block;
  }
}

.search-input {
  position: relative;
  display: flex;
  align-items: center;
  background-color: #FAFAF9;
  box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
  border-radius: 50px;
  font-size: 1.2rem;
  flex-basis: 450px;
  padding: 7px;
}
@media (max-width: 1024px) {
  .search-input {
    font-size: 1rem;
    padding: 6px;
    flex-basis: 445px;
  }
}
@media (max-width: 768px) {
  .search-input {
    font-size: 0.95rem;
    padding: 5px;
    flex-basis: 440px;
    max-width: 100%;
  }
}

.search-input__filter {
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  width: 60px;
  color: #4C4C4C;
}
.search-input__filter:hover {
  opacity: 0.8;
}
@media (max-width: 1024px) {
  .search-input__filter {
    height: 52.5px;
    width: 52.5px;
  }
}
@media (max-width: 768px) {
  .search-input__filter {
    height: 45px;
    width: 45px;
  }
}

.search-input__form {
  margin: unset;
  max-width: unset;
  display: flex;
  justify-content: space-between;
  align-items: center;
  align-self: stretch;
  flex-grow: 1;
  font-size: 28px;
}
@media (max-width: 1024px) {
  .search-input__form {
    font-size: 26px;
  }
}
@media (max-width: 768px) {
  .search-input__form {
    font-size: 24px;
  }
}

.search-input__form__field {
  border: none;
  background: transparent;
  outline: none;
  margin: unset;
  width: 85%;
  font-size: 1.2rem;
}
@media (max-width: 1024px) {
  .search-input__form__field {
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .search-input__form__field {
    font-size: 0.95rem;
  }
}

.search-input__submit {
  border: none;
  border-radius: 50px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #A9CBB7;
  color: #FFFFFF;
  height: 60px;
  width: 60px;
  transition: opacity 0.2s ease;
}
.search-input__submit:hover {
  opacity: 0.9;
}
@media (max-width: 1024px) {
  .search-input__submit {
    height: 52.5px;
    width: 52.5px;
  }
}
@media (max-width: 768px) {
  .search-input__submit {
    height: 45px;
    width: 45px;
  }
}

.search-input .search-filters {
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  background-color: #FFFFFF;
  box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
  border-radius: 15px;
  max-width: 400px;
  z-index: 20;
  opacity: 0;
  transition: opacity 0.2s ease, transform 0.2s ease;
  padding: 15px;
}
@media (max-width: 1024px) {
  .search-input .search-filters {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .search-input .search-filters {
    padding: 10px;
  }
}
.search-input .search-filters.active {
  display: block;
  opacity: 1;
}

.search-input .filters-form {
  display: flex;
  flex-direction: column;
  margin: unset;
  justify-content: flex-start;
  gap: 10px;
}
@media (max-width: 1024px) {
  .search-input .filters-form {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .search-input .filters-form {
    gap: 6px;
  }
}

.search-input .filters-form .filter-item {
  display: flex;
  flex-direction: column;
}

.search-input .filters-form .filter-item input,
select {
  padding: 7px;
}
@media (max-width: 1024px) {
  .search-input .filters-form .filter-item input,
select {
    padding: 6px;
  }
}
@media (max-width: 768px) {
  .search-input .filters-form .filter-item input,
select {
    padding: 5px;
  }
}

.search-input .filters-form .filter-item input[type=checkbox] {
  width: unset;
  margin: unset;
  cursor: pointer;
}

.search-input .filters-form .filters-apply {
  background-color: #A9CBB7;
  color: #FFFFFF;
  font-weight: 700;
  border: none;
  padding: 10px;
  border-radius: 50px;
  cursor: pointer;
  margin-top: 15px;
  transition: background-color 0.2s ease;
}
.search-input .filters-form .filters-apply:hover {
  opacity: 0.9;
}

.container_empty {
  margin: 0 auto;
  height: 70vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 25px;
}
@media (max-width: 1024px) {
  .container_empty {
    gap: 20px;
  }
}
@media (max-width: 768px) {
  .container_empty {
    gap: 15px;
  }
}

.container_empty__image {
  border-radius: 10px;
  overflow: hidden;
  height: 150px;
  width: 150px;
}
@media (max-width: 1024px) {
  .container_empty__image {
    height: 125px;
    width: 125px;
  }
}
@media (max-width: 768px) {
  .container_empty__image {
    height: 100px;
    width: 100px;
  }
}

.container_empty__image img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.container_empty__text {
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #4C4C4C;
}

.switch-checkbox {
  display: none;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .switch-checkbox {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .switch-checkbox {
    margin-bottom: 8px;
  }
}

.switch-label {
  display: flex;
  align-items: center;
  cursor: pointer;
  font-weight: 500;
}

.switch-label .switch-slider {
  position: relative;
  width: 40px;
  height: 22px;
  background-color: #e3e3e3;
  border-radius: 20px;
  margin-right: 12px;
  transition: background 0.3s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.07);
  flex-shrink: 0;
}

.switch-label .switch-slider::before {
  content: "";
  position: absolute;
  left: 2px;
  top: 2px;
  width: 18px;
  height: 18px;
  background: #FFFFFF;
  border-radius: 50%;
  transition: transform 0.2s ease cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.13);
}

.switch-checkbox:checked + .switch-label .switch-slider {
  background-color: #A9CBB7;
}

.switch-checkbox:checked + .switch-label .switch-slider::before {
  transform: translateX(18px);
}

.pagination {
  display: flex;
  justify-content: center;
  font-family: inherit;
  user-select: none;
  margin-top: 70px;
}
@media (max-width: 1024px) {
  .pagination {
    margin-top: 60px;
  }
}
@media (max-width: 768px) {
  .pagination {
    margin-top: 50px;
  }
}

.pagination__list {
  display: flex;
  list-style: none;
  gap: 10px;
}
@media (max-width: 1024px) {
  .pagination__list {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .pagination__list {
    gap: 6px;
  }
}

.pagination__item {
  display: flex;
  align-items: center;
}

.pagination__link {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 6px;
  border-radius: 50px;
  background: #FAFAF9;
  color: #A9CBB7;
  font-weight: 500;
  text-decoration: none;
  box-shadow: 0 1px 8px rgba(100, 100, 111, 0.09);
  transition: background 0.15s ease-in-out, color 0.15s ease-in-out, box-shadow 0.2s ease;
  border: none;
  outline: none;
  font-size: 1.15rem;
  min-height: 38px;
  min-width: 38px;
}
@media (max-width: 1024px) {
  .pagination__link {
    min-height: 36px;
    min-width: 36px;
  }
}
@media (max-width: 768px) {
  .pagination__link {
    min-height: 34px;
    min-width: 34px;
  }
}
.pagination__link:hover, .pagination__link:focus {
  background: #A9CBB7;
  color: #FFFFFF;
  box-shadow: 0 2px 10px rgba(100, 100, 111, 0.17);
}

.blog_presentation .pagination__link {
  color: #EFCFD1;
}

.pagination__link--active {
  background: #A9CBB7;
  color: #FFFFFF;
  font-weight: 700;
  box-shadow: 0 2px 10px rgba(100, 100, 111, 0.15);
  pointer-events: none;
}

.pagination__link--prev,
.pagination__link--next {
  padding: 0;
  font-size: 1.3rem;
  min-height: 38px;
  min-width: 38px;
}
@media (max-width: 1024px) {
  .pagination__link--prev,
.pagination__link--next {
    min-height: 36px;
    min-width: 36px;
  }
}
@media (max-width: 768px) {
  .pagination__link--prev,
.pagination__link--next {
    min-height: 34px;
    min-width: 34px;
  }
}
.pagination__link--prev .material-symbols-outlined,
.pagination__link--next .material-symbols-outlined {
  font-size: 2rem;
  vertical-align: middle;
}

.pagination__ellipsis {
  color: #DADADA;
  font-size: 1.4rem;
  padding: 0 4px;
  user-select: none;
}

.quill-field-container {
  margin-bottom: 24px;
}

.quill-wrapper {
  border: 1px solid #DADADA;
  border-radius: 15px;
  cursor: text;
  margin-bottom: 0;
}

.quill-wrapper .ql-toolbar {
  border-top-left-radius: 12px;
  border-top-right-radius: 12px;
  background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
}

.quill-wrapper .ql-container {
  flex: 1;
  display: flex;
  flex-direction: column;
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
  min-height: 300px;
}

.quill-wrapper .ql-editor {
  flex: 1;
  min-height: 300px;
  height: 100%;
}

.article__content {
  margin-bottom: 150px;
}
@media (max-width: 1024px) {
  .article__content {
    margin-bottom: 125px;
  }
}
@media (max-width: 768px) {
  .article__content {
    margin-bottom: 100px;
  }
}

.article__content img {
  max-width: 100%;
  max-height: 400px;
  width: auto;
  height: auto;
  margin: 0 auto;
  display: block;
  border-radius: 8px;
  object-fit: contain;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.article__content iframe,
.article__content video {
  max-width: 100%;
}

.article__content p img {
  display: block;
}

.article__content p[style*="text-align: center"] img {
  margin-left: auto;
  margin-right: auto;
}

.quill-content {
  color: #4C4C4C;
}

.quill-content img {
  border-radius: 8px;
}

.quill-wrapper .ql-editor img {
  border-radius: 8px;
}

.text_information {
  margin-top: 70px;
}
@media (max-width: 1024px) {
  .text_information {
    margin-top: 60px;
  }
}
@media (max-width: 768px) {
  .text_information {
    margin-top: 50px;
  }
}

#cancel_button {
  background-color: #D16464;
  color: #FFFFFF;
  padding: 15px;
}
@media (max-width: 1024px) {
  #cancel_button {
    padding: 12px;
  }
}
@media (max-width: 768px) {
  #cancel_button {
    padding: 10px;
  }
}
#cancel_button:hover {
  background-color: #c53d3d;
}

#next_button {
  background-color: #AAC8CE;
  color: #FFFFFF;
  padding: 15px;
}
@media (max-width: 1024px) {
  #next_button {
    padding: 12px;
  }
}
@media (max-width: 768px) {
  #next_button {
    padding: 10px;
  }
}
#next_button:hover {
  background-color: #8ab3bb;
}

#return_button {
  background-color: #F2C288;
  color: #4C4C4C;
}
#return_button:hover {
  background-color: #edaa5a;
}

#terminate_button {
  background-color: #7EBF8D;
  color: #FFFFFF;
}
#terminate_button:hover {
  background-color: #5cae6f;
}

.qr_code {
  display: flex;
  align-items: center;
  justify-content: center;
}

.backup-tokens-list {
  list-style: none;
  padding: 0;
  margin: 2rem 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1rem;
  max-width: 900px;
}

.backup-tokens-list li {
  position: relative;
  padding: 1.25rem 1.5rem;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  border-radius: 16px;
  font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: 1.1rem;
  font-weight: 600;
  color: #FFFFFF;
  letter-spacing: 0.5px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1), 0 1px 3px rgba(0, 0, 0, 0.08);
  transition: all 0.3s ease cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
  overflow: hidden;
  animation: fadeInUp 0.5s ease-out backwards;
}

.backup-tokens-list li::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
  transition: left 0.5s;
}

.backup-tokens-list li:hover::before {
  left: 100%;
}

.backup-tokens-list li:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(102, 126, 234, 0.3), 0 6px 12px rgba(118, 75, 162, 0.2);
}

.backup-tokens-list li:nth-child(1) {
  animation-delay: 0.05s;
}

.backup-tokens-list li:nth-child(2) {
  animation-delay: 0.1s;
}

.backup-tokens-list li:nth-child(3) {
  animation-delay: 0.15s;
}

.backup-tokens-list li:nth-child(4) {
  animation-delay: 0.2s;
}

.backup-tokens-list li:nth-child(5) {
  animation-delay: 0.25s;
}

.backup-tokens-list li:nth-child(6) {
  animation-delay: 0.3s;
}

.backup-tokens-list li:nth-child(7) {
  animation-delay: 0.35s;
}

.backup-tokens-list li:nth-child(8) {
  animation-delay: 0.4s;
}

.backup-tokens-list + p,
.backup-tokens-list ~ p:first-of-type {
  color: #64748b;
  font-size: 0.95rem;
  margin-bottom: 1.5rem;
  padding: 1rem 1.25rem;
  background: #f8fafc;
  border-left: 4px solid #667eea;
  border-radius: 8px;
}

@media (max-width: 640px) {
  .backup-tokens-list {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

  .backup-tokens-list li {
    font-size: 1rem;
    padding: 1rem 1.25rem;
  }
}
.backup-tokens-list.glass-style li {
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #1e293b;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.container_navbar_public {
  position: fixed;
  top: 0;
  color: #4C4C4C;
  backdrop-filter: blur(5px);
  display: flex;
  align-items: center;
  z-index: 99;
  width: 100%;
  height: 85px;
  transition: transform 0.3s ease-in-out;
  padding: 0 25px;
  margin-bottom: 100px;
}
@media (max-width: 1024px) {
  .container_navbar_public {
    padding: 0 22.5px;
    width: 100%;
    height: 80px;
    margin-bottom: 75px;
  }
}
@media (max-width: 768px) {
  .container_navbar_public {
    padding: 0 20px;
    width: 100%;
    height: 75px;
    margin-bottom: 50px;
  }
}
.container_navbar_public.navbar--hidden {
  transform: translateY(-100%);
}

.navbar_public {
  flex-grow: 1;
  max-width: 1500px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.navbar_public__logo {
  display: flex;
  align-items: center;
}

.navbar_public__toggle {
  border: none;
  cursor: pointer;
  display: none;
  margin: unset;
  background-color: unset;
}
@media (max-width: 1530px) {
  .navbar_public__toggle {
    display: block;
  }
}

.navbar_public__links_desktop {
  display: flex;
  align-items: center;
  gap: 35px;
}
@media (max-width: 1024px) {
  .navbar_public__links_desktop {
    gap: 32.5px;
  }
}
@media (max-width: 768px) {
  .navbar_public__links_desktop {
    gap: 30px;
  }
}
@media (max-width: 1530px) {
  .navbar_public__links_desktop {
    display: none;
  }
}

.navbar_public__links_desktop.navbar__links__single-page a {
  font-weight: 500;
  text-decoration: none;
  border-radius: 50px;
  transition: background-color 0.15s ease-in-out, color 0.15s ease-in-out;
  text-shadow: 0 0 2px rgba(255, 255, 255, 0.9), 0 0 6px rgba(255, 255, 255, 0.6);
  padding: 15px;
}
@media (max-width: 1024px) {
  .navbar_public__links_desktop.navbar__links__single-page a {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .navbar_public__links_desktop.navbar__links__single-page a {
    padding: 10px;
  }
}
.navbar_public__links_desktop.navbar__links__single-page a:hover {
  color: #FFFFFF;
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  text-shadow: unset;
}

.navbar_public .navbar__links__contact a {
  color: #FFFFFF;
  background: linear-gradient(90deg, #ffb700, #ffd500);
  background-size: cover;
  font-weight: 700;
  border-radius: 50px;
  transition: background 0.2s ease, color 0.2s ease;
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 15px;
}
@media (max-width: 1024px) {
  .navbar_public .navbar__links__contact a {
    padding: 12.5px;
    gap: 12.5px;
  }
}
@media (max-width: 768px) {
  .navbar_public .navbar__links__contact a {
    padding: 10px;
    gap: 10px;
  }
}
.navbar_public .navbar__links__contact a:hover, .navbar_public .navbar__links__contact a:focus {
  background: #FFFFFF;
  color: #ffb700;
}

.navbar_public .menu-item {
  position: relative;
}

.navbar_public .submenu-toggle {
  background: none;
  border: 0;
  cursor: pointer;
  border-radius: 50px;
  font-weight: 500;
  align-items: stretch;
  color: #4C4C4C;
  display: flex;
  gap: 15px;
  transition: background-color 0.15s ease-in-out, color 0.15s ease-in-out;
  text-shadow: 0 0 2px rgba(255, 255, 255, 0.9), 0 0 6px rgba(255, 255, 255, 0.6);
  padding: 15px;
}
@media (max-width: 1024px) {
  .navbar_public .submenu-toggle {
    gap: 12.5px;
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .navbar_public .submenu-toggle {
    gap: 10px;
    padding: 10px;
  }
}
.navbar_public .submenu-toggle:hover, .navbar_public .submenu-toggle:focus {
  color: #FFFFFF;
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  text-shadow: unset;
}
.navbar_public .submenu-toggle .material-symbols-outlined {
  transition: transform 0.2s ease;
}
.navbar_public .submenu-toggle.is-open .material-symbols-outlined {
  transform: rotate(180deg);
}

.navbar_public .navbar_public__links_desktop .submenu-links {
  position: absolute;
  left: 0;
  top: 150%;
  min-width: 100%;
  background-color: #FFFFFF;
  border-radius: 50px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  z-index: 100;
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  transition: opacity 0.15s ease-in-out, transform 0.15s ease-in-out, visibility 0s 0.15s;
  gap: 35px;
  padding: 25px;
}
@media (max-width: 1024px) {
  .navbar_public .navbar_public__links_desktop .submenu-links {
    gap: 32.5px;
    padding: 22.5px;
  }
}
@media (max-width: 768px) {
  .navbar_public .navbar_public__links_desktop .submenu-links {
    gap: 30px;
    padding: 20px;
  }
}
.navbar_public .navbar_public__links_desktop .submenu-links.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity 0.15s ease-in-out, transform 0.15s ease-in-out;
}
.navbar_public .navbar_public__links_desktop .submenu-links a {
  display: block;
  white-space: nowrap;
  text-decoration: none;
  border-radius: 50px;
  transition: background-color 0.15s ease-in-out, color 0.15s ease-in-out;
  padding: 15px;
}
@media (max-width: 1024px) {
  .navbar_public .navbar_public__links_desktop .submenu-links a {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .navbar_public .navbar_public__links_desktop .submenu-links a {
    padding: 10px;
  }
}
.navbar_public .navbar_public__links_desktop .submenu-links a:hover, .navbar_public .navbar_public__links_desktop .submenu-links a:focus {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
  -webkit-text-fill-color: transparent;
}

.navbar_public__links_general_side_nav {
  display: none;
}
@media (max-width: 1530px) {
  .navbar_public__links_general_side_nav {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    position: absolute;
    background-color: #FFFFFF;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
    transition: right 0.3s ease cubic-bezier(0.77, 0, 0.18, 1);
    z-index: 99;
    right: -400px;
    width: 400px;
    top: 85px;
    height: calc(100vh - 85px);
    padding: 25px;
    overflow-y: auto;
  }
}
@media (max-width: 1024px) {
  .navbar_public__links_general_side_nav {
    right: -350px;
    width: 350px;
    top: 80px;
    height: calc(100vh - 80px);
    padding: 22.5px;
  }
}
@media (max-width: 768px) {
  .navbar_public__links_general_side_nav {
    right: -300px;
    width: 300px;
    top: 75px;
    height: calc(100vh - 75px);
    padding: 20px;
  }
}
.navbar_public__links_general_side_nav.active {
  right: 0;
}
.navbar_public__links_general_side_nav .navbar_public__links {
  display: flex;
  flex-direction: column;
  align-self: stretch;
  align-items: flex-start;
}
.navbar_public__links_general_side_nav .navbar_public__links a {
  background: none;
  text-decoration: none;
  font-weight: 500;
  border-radius: 50px;
  transition: background-color 0.15s ease-in-out, color 0.15s ease-in-out;
  border: none;
  padding: 15px;
  margin-bottom: 15px;
}
@media (max-width: 1024px) {
  .navbar_public__links_general_side_nav .navbar_public__links a {
    padding: 12.5px;
    margin-bottom: 12.5px;
  }
}
@media (max-width: 768px) {
  .navbar_public__links_general_side_nav .navbar_public__links a {
    padding: 10px;
    margin-bottom: 10px;
  }
}
.navbar_public__links_general_side_nav .navbar_public__links a:focus, .navbar_public__links_general_side_nav .navbar_public__links a:hover {
  color: #FFFFFF;
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
}
.navbar_public__links_general_side_nav .navbar__links__contact {
  align-self: center;
}
.navbar_public__links_general_side_nav .navbar__links__contact a {
  color: #FFFFFF;
  border: solid 2px #FFFFFF;
  background: linear-gradient(90deg, #ffcb49, #ffe356);
  background-size: cover;
  font-weight: 700;
  border-radius: 50px;
  transition: background 0.2s ease, color 0.2s ease;
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 15px;
}
@media (max-width: 1024px) {
  .navbar_public__links_general_side_nav .navbar__links__contact a {
    padding: 12.5px;
    gap: 12.5px;
  }
}
@media (max-width: 768px) {
  .navbar_public__links_general_side_nav .navbar__links__contact a {
    padding: 10px;
    gap: 10px;
  }
}
.navbar_public__links_general_side_nav .navbar__links__contact a:hover, .navbar_public__links_general_side_nav .navbar__links__contact a:focus {
  align-self: stretch;
  border: solid 2px #ffcb49;
  background: #FFFFFF;
  color: #ffcb49;
}
.navbar_public__links_general_side_nav .submenu-toggle {
  margin-bottom: 15px;
}
@media (max-width: 1024px) {
  .navbar_public__links_general_side_nav .submenu-toggle {
    margin-bottom: 12.5px;
  }
}
@media (max-width: 768px) {
  .navbar_public__links_general_side_nav .submenu-toggle {
    margin-bottom: 10px;
  }
}
.navbar_public__links_general_side_nav .submenu-toggle:hover, .navbar_public__links_general_side_nav .submenu-toggle:focus {
  color: #FFFFFF;
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
}
.navbar_public__links_general_side_nav .submenu-links {
  position: static;
  box-shadow: none;
  border-radius: 0;
  display: none;
  margin-left: 0;
  margin-bottom: 15px;
  padding: 0 15px;
}
@media (max-width: 1024px) {
  .navbar_public__links_general_side_nav .submenu-links {
    margin-bottom: 12.5px;
    padding: 0 12.5px;
  }
}
@media (max-width: 768px) {
  .navbar_public__links_general_side_nav .submenu-links {
    margin-bottom: 10px;
    padding: 0 10px;
  }
}
.navbar_public__links_general_side_nav .submenu-links.active {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
@media (max-width: 1024px) {
  .navbar_public__links_general_side_nav .submenu-links.active {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .navbar_public__links_general_side_nav .submenu-links.active {
    gap: 6px;
  }
}
.navbar_public__links_general_side_nav .submenu-links a {
  margin-bottom: unset;
  border-radius: 8px;
  padding: 15px;
}
@media (max-width: 1024px) {
  .navbar_public__links_general_side_nav .submenu-links a {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .navbar_public__links_general_side_nav .submenu-links a {
    padding: 10px;
  }
}
.navbar_public__links_general_side_nav .submenu-links a:hover, .navbar_public__links_general_side_nav .submenu-links a:focus {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
  -webkit-text-fill-color: transparent;
}

#menu-icon.active {
  display: none;
}

#close-icon {
  display: none;
}

#close-icon.active {
  display: inline;
}

html, body {
  height: 100%;
}

.user_container {
  position: absolute;
  top: 0;
  z-index: 98;
  width: 100%;
  background-color: #FAFAF9;
  transition: transform 0.3s ease-in-out;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding: 25px;
}
@media (max-width: 1024px) {
  .user_container {
    padding: 22.5px;
  }
}
@media (max-width: 768px) {
  .user_container {
    padding: 20px;
  }
}
.user_container.user_container--hidden {
  transform: translateY(-100%);
}
.user_container .user_presentation {
  display: flex;
  align-items: center;
  gap: 35px;
}
@media (max-width: 1024px) {
  .user_container .user_presentation {
    gap: 30px;
  }
}
@media (max-width: 768px) {
  .user_container .user_presentation {
    gap: 25px;
  }
}
.user_container .user_presentation .icon {
  border-radius: 50%;
  overflow: hidden;
}
.user_container .user_presentation .full-name_container {
  font-weight: 700;
}

.main-container-dashboard {
  display: flex;
  height: 100vh;
  overflow: hidden;
  position: relative;
}

.navbar_dashboard {
  position: relative;
  z-index: 99;
  flex-shrink: 0;
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
  background-color: #FAFAF9;
  transition: width 0.3s ease;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  align-self: stretch;
  gap: 75px;
  padding: 25px;
}
@media (max-width: 1024px) {
  .navbar_dashboard {
    gap: 65px;
    padding: 22.5px;
  }
}
@media (max-width: 768px) {
  .navbar_dashboard {
    gap: 55px;
    padding: 20px;
  }
}

.navbar_dashboard--expanded {
  width: 300px;
}
@media (max-width: 1024px) {
  .navbar_dashboard--expanded {
    width: 200px;
  }
}
@media (max-width: 768px) {
  .navbar_dashboard--expanded {
    width: 180px;
  }
}

.navbar_dashboard--hidden {
  display: none;
}

.navbar_dashboard.collapsed {
  width: 80px;
}
@media (max-width: 1024px) {
  .navbar_dashboard.collapsed {
    width: 70px;
  }
}
@media (max-width: 768px) {
  .navbar_dashboard.collapsed {
    width: 60px;
  }
}
.navbar_dashboard.collapsed .navbar_dashboard__label {
  display: none;
}
.navbar_dashboard.collapsed .navbar_dashboard__links a,
.navbar_dashboard.collapsed .navbar_dashboard__form-logout button {
  justify-content: center;
}
.navbar_dashboard.collapsed .navbar_dashboard__links {
  align-items: center;
}
.navbar_dashboard.collapsed ~ .navbar_dashboard__trigger {
  top: 70px;
  left: calc(80px - 40px / 2);
}
@media (max-width: 1024px) {
  .navbar_dashboard.collapsed ~ .navbar_dashboard__trigger {
    top: 60px;
    left: calc(70px - 35px / 2);
  }
}
@media (max-width: 768px) {
  .navbar_dashboard.collapsed ~ .navbar_dashboard__trigger {
    top: 50px;
    left: calc(60px - 30px / 2);
  }
}
.navbar_dashboard.collapsed .nav-badge {
  left: -4px;
  top: -4px;
}

.navbar_dashboard__trigger {
  position: fixed;
  background-color: #FFFFFF;
  color: #4C4C4C;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: width 0.3s ease, left 0.3s ease;
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.1);
  z-index: 99;
  height: 40px;
  width: 40px;
  top: 70px;
  left: calc(300px - 40px / 2);
}
@media (max-width: 1024px) {
  .navbar_dashboard__trigger {
    height: 35px;
    width: 35px;
    top: 60px;
    left: calc(200px - 35px / 2);
  }
}
@media (max-width: 768px) {
  .navbar_dashboard__trigger {
    height: 30px;
    width: 30px;
    top: 50px;
    left: calc(180px - 30px / 2);
  }
}

.content_dashboard {
  flex-grow: 1;
  background-color: #FFFFFF;
  overflow-y: auto;
  transition: margin-left 0.3s ease;
}

.navbar_dashboard__links {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  align-self: stretch;
  gap: 35px;
}
@media (max-width: 1024px) {
  .navbar_dashboard__links {
    gap: 32.5px;
  }
}
@media (max-width: 768px) {
  .navbar_dashboard__links {
    gap: 30px;
  }
}

.navbar_dashboard__links a {
  display: flex;
  align-items: center;
  gap: 15px;
}
@media (max-width: 1024px) {
  .navbar_dashboard__links a {
    gap: 12.5px;
  }
}
@media (max-width: 768px) {
  .navbar_dashboard__links a {
    gap: 10px;
  }
}
.navbar_dashboard__links a:hover {
  color: #7f7f7f;
}

.navbar_dashboard__form-logout {
  margin: unset;
}

.navbar_dashboard__form-logout button {
  color: #FFFFFF;
  border: 1px solid #FAFAF9;
  background: linear-gradient(135deg, #E57373, #F28B82);
  transition: all 0.3s ease;
}
.navbar_dashboard__form-logout button:hover {
  border: 1px solid #F28B82;
  background: #FAFAF9;
  color: #E57373;
  /* rouge doux au hover */
}

.nav-icon-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.nav-badge {
  position: absolute;
  left: -6px;
  top: -6px;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: 50px;
  background: #ff4040;
  color: #FFFFFF;
  font-size: 11px;
  font-weight: 700;
  line-height: 18px;
  text-align: center;
  pointer-events: none;
}

.dashboard {
  display: flex;
  flex-direction: column;
}

.dashboard__section {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.dashboard__grid {
  display: grid;
  gap: 50px;
}
@media (max-width: 1024px) {
  .dashboard__grid {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .dashboard__grid {
    gap: 25px;
  }
}

.dashboard__grid--stats {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.dashboard__grid--infos {
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.dashboard__chart canvas {
  width: 100%;
  height: auto;
}

.card {
  background-color: #FAFAF9;
  box-shadow: rgba(14, 63, 126, 0.06) 0px 0px 0px 1px, rgba(42, 51, 70, 0.03) 0px 1px 1px -0.5px, rgba(42, 51, 70, 0.04) 0px 2px 2px -1px, rgba(42, 51, 70, 0.04) 0px 3px 3px -1.5px, rgba(42, 51, 70, 0.03) 0px 5px 5px -2.5px, rgba(42, 51, 70, 0.03) 0px 10px 10px -5px, rgba(42, 51, 70, 0.03) 0px 24px 24px -8px;
  border-radius: 12px;
  padding: 30px;
}
@media (max-width: 1024px) {
  .card {
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .card {
    padding: 30px;
  }
}

.card--highlight {
  text-align: center;
}

.card__stat-value {
  font-weight: bold;
  color: #A9CBB7;
}

.card__text {
  display: flex;
  align-items: center;
  gap: 10px;
}
@media (max-width: 1024px) {
  .card__text {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .card__text {
    gap: 6px;
  }
}

.card__text_connect-icon {
  background-color: #7EBF8D;
  border-radius: 50%;
  height: 10px;
  width: 10px;
}
@media (max-width: 1024px) {
  .card__text_connect-icon {
    height: 8px;
    width: 8px;
  }
}
@media (max-width: 768px) {
  .card__text_connect-icon {
    height: 6px;
    width: 6px;
  }
}

.form-page-separator {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 44px 0 24px;
}
.form-page-separator::before, .form-page-separator::after {
  content: "";
  flex: 1;
  height: 1px;
  background: rgba(170, 200, 206, 0.45);
}
.form-page-separator__label {
  font-size: 0.8rem;
  font-weight: 700;
  color: #4C4C4C;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  white-space: nowrap;
  padding: 4px 10px;
  border: 1px solid rgba(170, 200, 206, 0.4);
  border-radius: 50px;
  background: #FFFFFF;
}

.container_user_personal_information_grid {
  display: grid;
  grid-template-columns: 0.7fr 0.3fr;
  align-items: center;
  gap: 50px;
  margin-top: 70px;
}
@media (max-width: 1024px) {
  .container_user_personal_information_grid {
    gap: 35px;
    margin-top: 60px;
  }
}
@media (max-width: 768px) {
  .container_user_personal_information_grid {
    gap: 25px;
    margin-top: 50px;
    display: flex;
    flex-direction: column-reverse;
  }
  .container_user_personal_information_grid .text_information_container {
    width: 100%;
  }
}

.container_user_personal_information_grid .text_information_container {
  grid-column: 1/2;
  display: flex;
  flex-direction: column;
  gap: 35px;
}
@media (max-width: 1024px) {
  .container_user_personal_information_grid .text_information_container {
    gap: 32.5px;
  }
}
@media (max-width: 768px) {
  .container_user_personal_information_grid .text_information_container .container__link_left {
    justify-content: center;
    gap: 30px;
  }
}

.container_user_personal_information_grid .text_information_container .user_first_name_last_name_information {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 35px;
}
@media (max-width: 1024px) {
  .container_user_personal_information_grid .text_information_container .user_first_name_last_name_information {
    gap: 32.5px;
  }
}
@media (max-width: 768px) {
  .container_user_personal_information_grid .text_information_container .user_first_name_last_name_information {
    gap: 30px;
  }
}
.container_user_personal_information_grid .text_information_container .user_first_name_last_name_information p {
  border-radius: 15px;
  width: 100%;
  border: solid 2px #AAC8CE;
  color: #AAC8CE;
  font-weight: 700;
  padding: 20px;
}
@media (max-width: 1024px) {
  .container_user_personal_information_grid .text_information_container .user_first_name_last_name_information p {
    padding: 17.5px;
  }
}
@media (max-width: 768px) {
  .container_user_personal_information_grid .text_information_container .user_first_name_last_name_information p {
    padding: 20px;
  }
}

.container_user_personal_information_grid .text_information_container p {
  border-radius: 15px;
  border: solid 2px #AAC8CE;
  color: #AAC8CE;
  font-weight: 700;
  padding: 20px;
}
@media (max-width: 1024px) {
  .container_user_personal_information_grid .text_information_container p {
    padding: 17.5px;
  }
}
@media (max-width: 768px) {
  .container_user_personal_information_grid .text_information_container p {
    padding: 20px;
  }
}

.container_user_personal_information_grid .text_information_container .container__link_left #update_user_information {
  border-radius: 50px;
  background: linear-gradient(90deg, #7EBF8D, #A9CBB7);
  color: #FFFFFF;
  font-weight: 700;
  padding: 20px;
}
@media (max-width: 1024px) {
  .container_user_personal_information_grid .text_information_container .container__link_left #update_user_information {
    padding: 17.5px;
  }
}
@media (max-width: 768px) {
  .container_user_personal_information_grid .text_information_container .container__link_left #update_user_information {
    padding: 20px;
  }
}

.pp_container_personal_information {
  position: relative;
  justify-self: center;
  grid-column: 2/3;
}

.pp_container_personal_information .user_pp {
  border-radius: 50%;
  overflow: hidden;
  height: 250px;
  width: 250px;
}
@media (max-width: 1024px) {
  .pp_container_personal_information .user_pp {
    height: 225px;
    width: 225px;
  }
}
@media (max-width: 768px) {
  .pp_container_personal_information .user_pp {
    height: 200px;
    width: 200px;
  }
}
.pp_container_personal_information .user_pp img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.pp_container_personal_information .update_user_pp {
  position: absolute;
  background: linear-gradient(90deg, #7EBF8D, #A9CBB7);
  color: #FFFFFF;
  font-weight: 700;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  bottom: 15px;
  right: 30px;
  height: 10px;
  width: 10px;
  padding: 15px;
}
@media (max-width: 1024px) {
  .pp_container_personal_information .update_user_pp {
    padding: 12.5px;
    height: 8px;
    width: 8px;
  }
}
@media (max-width: 768px) {
  .pp_container_personal_information .update_user_pp {
    padding: 10px;
    height: 6px;
    width: 6px;
  }
}

.up_pp_page_container {
  border-radius: 50%;
  margin: 70px auto 40px;
  overflow: hidden;
  height: 250px;
  width: 250px;
}
@media (max-width: 1024px) {
  .up_pp_page_container {
    margin-top: 60px;
    height: 225px;
    width: 225px;
  }
}
@media (max-width: 768px) {
  .up_pp_page_container {
    margin-top: 50px;
    height: 200px;
    width: 200px;
  }
}
.up_pp_page_container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.user-extra-info {
  margin-top: 70px;
}
@media (max-width: 1024px) {
  .user-extra-info {
    margin-top: 60px;
  }
}
@media (max-width: 768px) {
  .user-extra-info {
    margin-top: 50px;
  }
}

.group_user {
  border-radius: 20px;
  color: #FFFFFF;
  padding: 7px;
}
@media (max-width: 1024px) {
  .group_user {
    padding: 6px;
  }
}
@media (max-width: 768px) {
  .group_user {
    padding: 5px;
  }
}

#group_directrice {
  background: linear-gradient(135deg, #EFCFD1, #F2C288, #D8A7A7);
}

#group_adminstration {
  background: linear-gradient(135deg, #A9CBB7, #AAC8CE, #F7E1D7);
}

.user-extra-info__list {
  display: flex;
  flex-direction: column;
  gap: 35px;
  list-style-type: none;
  padding: 10px;
}
@media (max-width: 1024px) {
  .user-extra-info__list {
    gap: 30px;
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .user-extra-info__list {
    gap: 25px;
    padding: 30px;
  }
}

.requests-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
@media (max-width: 1024px) {
  .requests-list {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .requests-list {
    gap: 6px;
  }
}

.card--request {
  display: grid;
  grid-template-columns: 0.2fr 0.6fr 0.2fr;
  gap: 25px;
}
@media (max-width: 1024px) {
  .card--request {
    gap: 22.5px;
  }
}
@media (max-width: 768px) {
  .card--request {
    gap: 20px;
    display: block;
    margin-bottom: 25px;
  }
}

.card--request__user-icon-container {
  grid-column: 1/2;
  display: flex;
  align-items: center;
  justify-content: center;
}

.card--request__user-icon-container__user-icon {
  border-radius: 50%;
  overflow: hidden;
  height: 75px;
  width: 75px;
}
@media (max-width: 1024px) {
  .card--request__user-icon-container__user-icon {
    height: 70px;
    width: 70px;
  }
}
@media (max-width: 768px) {
  .card--request__user-icon-container__user-icon {
    height: 65px;
    width: 65px;
  }
}
.card--request__user-icon-container__user-icon img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.card--request__user-information-container {
  grid-column: 2/3;
  display: flex;
  flex-direction: column;
  align-self: stretch;
}
@media (max-width: 768px) {
  .card--request__user-information-container {
    margin-bottom: 10px;
  }
}

.card--request__user-information-container__user-information-nom-prenom {
  font-weight: 700;
}
@media (max-width: 768px) {
  .card--request__user-information-container__user-information-nom-prenom {
    text-align: center;
    margin-bottom: 15px;
  }
}

.card--request__user-information-container__user-information-email {
  font-style: italic;
}
@media (max-width: 768px) {
  .card--request__user-information-container__user-information-email {
    text-align: center;
  }
}

.card--request__user-information-container__user-information-date {
  color: #6C757D;
}
@media (max-width: 768px) {
  .card--request__user-information-container__user-information-date {
    text-align: center;
  }
}

.card--request__user-information-container__user-information-role {
  display: flex;
  align-items: center;
  justify-content: center;
}

.card--request__actions {
  grid-column: 3/4;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 8px;
}
@media (max-width: 1024px) {
  .card--request__actions {
    gap: 6px;
  }
}
@media (max-width: 768px) {
  .card--request__actions {
    gap: 4px;
  }
}
.card--request__actions form {
  margin-top: unset;
}

.card--request__actions .action-button {
  display: inline-block;
  color: #FFFFFF;
  border-radius: 15px;
  border: none;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  text-align: center;
  min-width: 100px;
  transition: background 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  padding: 15px;
}
@media (max-width: 1024px) {
  .card--request__actions .action-button {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .card--request__actions .action-button {
    padding: 10px;
  }
}

.card--request__actions .action-button--agree {
  background-color: #7EBF8D;
}
.card--request__actions .action-button--agree:hover, .card--request__actions .action-button--agree:focus {
  box-shadow: 0 0 0 2px rgba(20, 180, 90, 0.18);
}

.card--request__actions .action-button--disagree {
  background-color: #D16464;
}
.card--request__actions .action-button--disagree:hover, .card--request__actions .action-button--disagree:focus {
  box-shadow: 0 0 0 2px rgba(200, 40, 40, 0.18);
}

.create_article_form {
  max-width: 900px;
}

.create_article_form #id_description {
  width: 100%;
  max-width: 100%;
  min-height: 200px;
  border: solid 1px #AAC8CE;
  border-radius: 15px;
  color: #A9CBB7;
  padding: 15px;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .create_article_form #id_description {
    padding: 12.5px;
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .create_article_form #id_description {
    padding: 10px;
    margin-bottom: 8px;
  }
}

.create_article_form #id_categorie {
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .create_article_form #id_categorie {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .create_article_form #id_categorie {
    margin-bottom: 8px;
  }
}

.create_article_form input,
.create_article_form #id_description:focus {
  outline: none;
}

.create_article_form #id_contenu {
  min-height: 200px;
  border-radius: 15px;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .create_article_form #id_contenu {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .create_article_form #id_contenu {
    margin-bottom: 8px;
  }
}

.create_article_form .container_button {
  gap: 35px;
  margin-top: 24px;
}
@media (max-width: 1024px) {
  .create_article_form .container_button {
    gap: 32.5px;
    margin-top: 22px;
  }
}
@media (max-width: 768px) {
  .create_article_form .container_button {
    gap: 30px;
    margin-top: 20px;
  }
}

.create_article_form .container_button a {
  background-color: #D16464;
  color: #FFFFFF;
}

.create_article_form .container_button .submit-button {
  background-color: #7EBF8D;
  color: #FFFFFF;
}

.article_presentation {
  position: relative;
  display: flex;
  align-items: flex-end;
  z-index: 0;
  overflow: hidden;
  border-radius: 25px;
  min-height: 600px;
  margin-bottom: 50px;
}

.article_presentation__elements {
  position: relative;
  display: flex;
  flex-grow: 1;
  z-index: 2;
  gap: 50px;
}
.article_presentation__elements > * {
  flex: 1 1 0;
  min-width: 0;
}
@media (max-width: 1024px) {
  .article_presentation__elements {
    gap: 35px;
    display: block;
  }
}
@media (max-width: 768px) {
  .article_presentation__elements {
    gap: 25px;
  }
}

.article_presentation__elements_information-left {
  position: relative;
  z-index: 2;
  color: #FFFFFF;
  flex-grow: 1;
}
@media (max-width: 1024px) {
  .article_presentation__elements_information-left {
    margin-bottom: 40px;
  }
  .article_presentation__elements_information-left .article_presentation__elements_information-left__titre {
    text-align: center;
  }
  .article_presentation__elements_information-left .article_presentation__elements_information-left__description {
    line-height: 30px;
  }
}
@media (max-width: 768px) {
  .article_presentation__elements_information-left {
    margin-bottom: 30px;
  }
}

.article_presentation__elements_information-right {
  position: relative;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  align-self: stretch;
  justify-content: center;
  color: #FFFFFF;
  z-index: 2;
  gap: 35px;
}
@media (max-width: 1024px) {
  .article_presentation__elements_information-right {
    gap: 32.5px;
    align-items: flex-start;
  }
}
@media (max-width: 768px) {
  .article_presentation__elements_information-right {
    gap: 30px;
  }
}
.article_presentation__elements_information-right .user_presentation {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.article_presentation__elements_information-right .user_presentation .icon {
  height: 40px;
  width: 40px;
}
@media (max-width: 1024px) {
  .article_presentation__elements_information-right .user_presentation .icon {
    height: 35px;
    width: 35px;
  }
}
@media (max-width: 768px) {
  .article_presentation__elements_information-right .user_presentation .icon {
    height: 30px;
    width: 30px;
  }
}
.article_presentation__elements_information-right .user_presentation .icon .icon__user_pp {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}
.article_presentation__elements_information-right .user_presentation .full-name_container {
  font-weight: 700;
}

.article_presentation__elements_information-right__date-time {
  display: flex;
  align-items: center;
}

.article_presentation__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.article_presentation__image::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: rgba(0, 0, 0, 0.45);
}
.article_presentation__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.article_categorie {
  font-weight: 700;
  border-radius: 50px;
  color: #FFFFFF;
  background-color: rgba(196, 196, 196, 0.42);
  padding: 15px;
}
@media (max-width: 1024px) {
  .article_categorie {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .article_categorie {
    padding: 10px;
  }
}

.articles_suggestions {
  padding: 60px 0;
  color: #4C4C4C;
}

.articles_suggestions__title {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 40px;
  text-align: center;
  letter-spacing: -0.02em;
}
@media (max-width: 768px) {
  .articles_suggestions__title {
    font-size: 1rem;
    margin-bottom: 30px;
  }
}

.articles_suggests_grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}
@media (max-width: 968px) {
  .articles_suggests_grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}

.article_suggest_card {
  display: flex;
  flex-direction: row;
  background: #FFFFFF;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  transition: all 0.3s ease cubic-bezier(0.4, 0, 0.2, 1);
  text-decoration: none;
  color: inherit;
  border: 1px solid #e5e5e5;
  height: 200px;
  animation: fadeInUp 0.5s ease-out backwards;
}
.article_suggest_card:hover {
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
  transform: translateY(-2px);
  border-color: #d0d0d0;
}
@media (max-width: 640px) {
  .article_suggest_card {
    flex-direction: column;
    height: auto;
  }
}

.article_suggest_card:nth-child(1) {
  animation-delay: 0.05s;
}

.article_suggest_card:nth-child(2) {
  animation-delay: 0.1s;
}

.article_suggest_card:nth-child(3) {
  animation-delay: 0.15s;
}

.article_suggest_card:nth-child(4) {
  animation-delay: 0.2s;
}

.article_suggest_card:nth-child(5) {
  animation-delay: 0.25s;
}

.article_suggest_card:nth-child(6) {
  animation-delay: 0.3s;
}

.article_suggest_card__image {
  position: relative;
  width: 30%;
  flex-shrink: 0;
  overflow: hidden;
  background: #f5f5f5;
}
.article_suggest_card__image::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 40%;
  height: 100%;
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.8) 70%, white 100%);
  pointer-events: none;
  z-index: 1;
}
.article_suggest_card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 640px) {
  .article_suggest_card__image {
    width: 100%;
    height: 140px;
  }
  .article_suggest_card__image::after {
    top: auto;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 50%;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.6) 60%, white 100%);
  }
}
@media (min-width: 641px) and (max-width: 968px) {
  .article_suggest_card__image {
    width: 35%;
  }
}

.article_suggest_card__category {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 3;
}

.category_badge {
  display: inline-block;
  padding: 6px 14px;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(8px);
  border-radius: 20px;
  font-size: 0.7rem;
  font-weight: 600;
  color: #2c3e50;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
  transition: all 0.2s ease;
  cursor: pointer;
}
.category_badge:hover {
  background: #FFFFFF;
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.article_suggest_card__content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 20px;
  flex: 1;
  min-width: 0;
  width: 70%;
}
@media (max-width: 640px) {
  .article_suggest_card__content {
    width: 100%;
    padding: 16px;
  }
}
@media (min-width: 641px) and (max-width: 968px) {
  .article_suggest_card__content {
    width: 65%;
    padding: 18px;
  }
}

.article_suggest_card__main {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.article_suggest_card__title {
  font-size: 1.1rem;
  font-weight: 600;
  line-height: 1.4;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 640px) {
  .article_suggest_card__title {
    font-size: 1rem;
  }
}
@media (min-width: 641px) and (max-width: 968px) {
  .article_suggest_card__title {
    font-size: 1.05rem;
  }
}

.article_suggest_card__description {
  font-size: 0.9rem;
  color: #666;
  line-height: 1.5;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 640px) {
  .article_suggest_card__description {
    font-size: 0.85rem;
  }
}
@media (min-width: 641px) and (max-width: 968px) {
  .article_suggest_card__description {
    font-size: 0.88rem;
  }
}

.article_suggest_card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 16px;
  gap: 12px;
}
@media (max-width: 640px) {
  .article_suggest_card__footer {
    margin-top: 12px;
  }
}

.article_suggest_card__author {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 0;
}

.author_avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  border: 2px solid #e5e5e5;
}
.author_avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.author_name {
  font-size: 0.85rem;
  font-weight: 500;
  color: #4a5568;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.article_suggest_card__date {
  font-size: 0.8rem;
  color: #999;
  font-weight: 400;
  white-space: nowrap;
  flex-shrink: 0;
}

.site-sections__grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 50px;
}
@media (max-width: 1024px) {
  .site-sections__grid {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .site-sections__grid {
    gap: 25px;
  }
}

.site-sections__card {
  width: 100%;
  max-width: 320px;
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border-radius: 15px;
  background-image: linear-gradient(90deg, #7EBF8D, #A9CBB7);
  color: #FFFFFF;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
  transition: box-shadow 0.3s ease;
  gap: 10px;
  padding: 30px;
}
@media (max-width: 1024px) {
  .site-sections__card {
    gap: 8px;
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .site-sections__card {
    gap: 6px;
    padding: 30px;
  }
}
.site-sections__card:hover {
  opacity: 0.9;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.site-sections__label {
  font-weight: 500;
  text-align: center;
}

.quick-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-start;
  margin-top: 20px;
  margin-bottom: 20px;
}

.quick-links__item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 15px;
  border-radius: 50px;
  background: linear-gradient(90deg, #7EBF8D, #A9CBB7);
  color: #FFFFFF;
  font-size: 0.8rem;
  font-weight: 500;
  text-decoration: none;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  transition: opacity 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
.quick-links__item .material-symbols-outlined {
  font-size: 1rem;
}
.quick-links__item:hover {
  opacity: 0.85;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
  color: #FFFFFF;
}
@media (max-width: 768px) {
  .quick-links__item {
    font-size: 0.7rem;
    padding: 5px 10px;
  }
}

.contact_form-container {
  display: grid;
  grid-template-columns: 0.65fr 0.35fr;
  gap: 50px;
}
@media (max-width: 1024px) {
  .contact_form-container {
    gap: 35px;
    display: block;
  }
}
@media (max-width: 768px) {
  .contact_form-container {
    gap: 25px;
  }
}

.contact_form-container-titre {
  text-align: center;
  color: #4C4C4C;
}

.contact_form-container .contact_form {
  grid-column: 1/2;
  width: 100%;
}
@media (max-width: 1024px) {
  .contact_form-container .contact_form {
    width: unset;
    margin-bottom: 50px;
  }
}

.contact_form-container .contact_form #id_message {
  max-width: 100%;
  min-width: 100%;
  min-height: 100px;
  max-height: 250px;
  overflow: auto;
  border-radius: 15px;
  border: solid 1px #A9CBB7;
  color: #A9CBB7;
  padding: 15px;
}
@media (max-width: 1024px) {
  .contact_form-container .contact_form #id_message {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .contact_form-container .contact_form #id_message {
    padding: 10px;
  }
}
.contact_form-container .contact_form #id_message:focus {
  outline: none;
}

.contact_form-container .contact_form .container_button button {
  background-image: linear-gradient(90deg, #A9CBB7, #7EBF8D);
  color: #FFFFFF;
  gap: 15px;
}
@media (max-width: 1024px) {
  .contact_form-container .contact_form .container_button button {
    gap: 12.5px;
  }
}
@media (max-width: 768px) {
  .contact_form-container .contact_form .container_button button {
    gap: 10px;
  }
}
.contact_form-container .contact_form .container_button button:hover {
  opacity: 0.9;
}

.contact_form-container .contact-map_container {
  grid-column: 2/3;
  height: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 50px;
}
@media (max-width: 1024px) {
  .contact_form-container .contact-map_container {
    gap: 35px;
    display: block;
    margin-bottom: 50px;
  }
}
@media (max-width: 768px) {
  .contact_form-container .contact-map_container {
    gap: 25px;
  }
}

.contact_form-container .contact-map_container .contact-container {
  color: #4C4C4C;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
@media (max-width: 1024px) {
  .contact_form-container .contact-map_container .contact-container {
    gap: 8px;
    margin-bottom: 50px;
  }
}
@media (max-width: 768px) {
  .contact_form-container .contact-map_container .contact-container {
    gap: 6px;
  }
}
.contact_form-container .contact-map_container .contact-container p {
  display: flex;
  align-items: center;
  gap: 15px;
}
@media (max-width: 1024px) {
  .contact_form-container .contact-map_container .contact-container p {
    gap: 12.5px;
  }
}
@media (max-width: 768px) {
  .contact_form-container .contact-map_container .contact-container p {
    gap: 10px;
  }
}

.contact_form-container .contact-map_container .map-container {
  flex-grow: 0.6;
  position: relative;
  z-index: 1;
}

.contact_form-container .contact-map_container .map-container #map {
  border-radius: 15px;
  height: 100%;
  width: 100%;
  overflow: hidden;
}
@media (max-width: 1024px) {
  .contact_form-container .contact-map_container .map-container #map {
    margin: 0 auto;
    max-width: 600px;
    height: 250px;
    margin-bottom: 50px;
  }
}
@media (max-width: 768px) {
  .contact_form-container .contact-map_container .map-container #map {
    height: 200px;
  }
}

.message-grid-container {
  overflow-x: auto;
  width: 100%;
}
@media (max-width: 1024px) {
  .message-grid-container {
    overflow-x: scroll;
  }
}

.message-grid-container .message-grid {
  min-width: 1024px;
  border-radius: 8px;
}

.message-grid-container .message-grid .grid-header {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  border-radius: 15px 15px 0 0;
  background-image: linear-gradient(90deg, #A9CBB7, #7EBF8D);
  color: #FFFFFF;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 30px;
}
@media (max-width: 1024px) {
  .message-grid-container .message-grid .grid-header {
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .message-grid-container .message-grid .grid-header {
    padding: 30px;
  }
}
.message-grid-container .message-grid .grid-header .grid-cell {
  margin: unset;
  text-align: center;
}

.message-grid-container .message-grid .grid-row {
  display: grid;
  align-items: center;
  grid-template-columns: repeat(6, 1fr);
  border-bottom: 1px solid #A9CBB7;
  transition: background-color 0.2s ease;
}
.message-grid-container .message-grid .grid-row:last-child {
  border-radius: 0 0 15px 15px;
  border-bottom: none;
}
.message-grid-container .message-grid .grid-row:hover {
  background-color: #f5f5f5;
}
.message-grid-container .message-grid .grid-row .grid-cell {
  text-align: center;
  padding: 30px;
}
.message-grid-container .message-grid .grid-row .grid-cell:last-child {
  text-align: right;
}

@media (max-width: 1024px) {
  .message-grid-container .message-grid .grid-row .grid-cell {
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .message-grid-container .message-grid .grid-row .grid-cell {
    padding: 30px;
  }
}
.message-grid-container .message-grid .grid-row .grid-cell-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
@media (max-width: 1024px) {
  .message-grid-container .message-grid .grid-row .grid-cell-actions {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .message-grid-container .message-grid .grid-row .grid-cell-actions {
    gap: 6px;
  }
}
.message-grid-container .message-grid .grid-row .grid-cell-actions button {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50px;
  font-weight: 700;
  padding: 15px;
}
@media (max-width: 1024px) {
  .message-grid-container .message-grid .grid-row .grid-cell-actions button {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .message-grid-container .message-grid .grid-row .grid-cell-actions button {
    padding: 10px;
  }
}

.message-grid-container .message-grid .grid-row .grid-cell-statut {
  display: flex;
  align-items: center;
  justify-content: center;
}
.message-grid-container .message-grid .grid-row .grid-cell-statut p {
  font-size: 0.8rem;
}
@media (max-width: 1024px) {
  .message-grid-container .message-grid .grid-row .grid-cell-statut p {
    font-size: 0.7rem;
  }
}
@media (max-width: 768px) {
  .message-grid-container .message-grid .grid-row .grid-cell-statut p {
    font-size: 0.6rem;
  }
}

.message-grid-container .message-grid .grid-row .grid-cell-statut .statut-nouveau {
  border-radius: 50px;
  background-image: linear-gradient(135deg, #f6d365, #fda085);
  font-weight: 700;
  color: #FFFFFF;
  padding: 8px;
}
@media (max-width: 1024px) {
  .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-nouveau {
    padding: 7px;
  }
}
@media (max-width: 768px) {
  .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-nouveau {
    padding: 6px;
  }
}

.message-grid-container .message-grid .grid-row .grid-cell-statut .statut-lu {
  border-radius: 50px;
  background-image: linear-gradient(135deg, #a1c4fd, #c2e9fb);
  font-weight: 700;
  color: #FFFFFF;
  padding: 8px;
}
@media (max-width: 1024px) {
  .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-lu {
    padding: 7px;
  }
}
@media (max-width: 768px) {
  .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-lu {
    padding: 6px;
  }
}

.message-grid-container .message-grid .grid-row .grid-cell-statut .statut-traite {
  border-radius: 50px;
  background-image: linear-gradient(135deg, #d4fc79, #96e6a1);
  font-weight: 700;
  color: #FFFFFF;
  padding: 8px;
}
@media (max-width: 1024px) {
  .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-traite {
    padding: 7px;
  }
}
@media (max-width: 768px) {
  .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-traite {
    padding: 6px;
  }
}

.message-grid-container .message-grid .action-button {
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.8rem;
  padding: 8px;
}
@media (max-width: 1024px) {
  .message-grid-container .message-grid .action-button {
    font-size: 0.7rem;
    padding: 7px;
  }
}
@media (max-width: 768px) {
  .message-grid-container .message-grid .action-button {
    font-size: 0.6rem;
    padding: 6px;
  }
}
.message-grid-container .message-grid .action-button.view {
  background-color: unset;
  color: #7EBF8D;
}
.message-grid-container .message-grid .action-button.view:hover {
  opacity: 0.9;
}
.message-grid-container .message-grid .action-button.delete {
  background-color: unset;
  color: #D16464;
}
.message-grid-container .message-grid .action-button.delete:hover {
  opacity: 0.9;
}

.contact-cta {
  background: linear-gradient(180deg, #ffffff 0%, #ffffff 80%, #f2fbe9 90%, #daefd9 100%);
  padding: 100px 5%;
}
@media (max-width: 1024px) {
  .contact-cta {
    padding: 70px 5%;
  }
}
@media (max-width: 768px) {
  .contact-cta {
    padding: 50px 5%;
  }
}

.contact-cta__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 50px;
}
@media (max-width: 1024px) {
  .contact-cta__container {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .contact-cta__container {
    gap: 6px;
  }
}

.contact-cta__content {
  max-width: 700px;
}

.contact-cta__title {
  color: #4C4C4C;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .contact-cta__title {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .contact-cta__title {
    margin-bottom: 8px;
  }
}

.contact-cta__text {
  color: #4C4C4C;
}

.contact-cta__faq {
  color: #4C4C4C;
}
.contact-cta__faq a {
  color: #7EBF8D;
  text-decoration: underline dotted #7EBF8D;
  text-underline-offset: 3px;
  transition: color 0.15s ease-in-out;
}
.contact-cta__faq a:hover {
  color: #4C4C4C;
  text-decoration-color: #4C4C4C;
}

.contact-cta__action {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1024px) {
  .contact-cta__action {
    margin-top: 24px;
  }
}
@media (max-width: 768px) {
  .contact-cta__action {
    margin-top: 20px;
  }
}

.contact-cta__button {
  color: #4C4C4C;
  background: rgba(218, 218, 218, 0.5);
  backdrop-filter: blur(45px);
  background-size: cover;
  font-weight: 700;
  border-radius: 50px;
  transition: background 0.2s ease, color 0.2s ease;
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 15px;
}
@media (max-width: 1024px) {
  .contact-cta__button {
    padding: 12.5px;
    gap: 12.5px;
  }
}
@media (max-width: 768px) {
  .contact-cta__button {
    padding: 10px;
    gap: 10px;
  }
}
.contact-cta__button:hover {
  opacity: 0.8;
}

.leaflet-popup-content a {
  font-size: inherit;
}

.articles_recents {
  color: #4C4C4C;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  justify-items: center;
  gap: 40px;
}
@media (max-width: 1024px) {
  .articles_recents {
    gap: 30px;
  }
}
@media (max-width: 768px) {
  .articles_recents {
    gap: 20px;
  }
}

.articles-recents__intro {
  color: #4C4C4C;
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .articles-recents__intro {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .articles-recents__intro {
    margin-bottom: 30px;
  }
}

.articles-recents__text {
  opacity: 0.85;
}

.articles_recents__title {
  color: #4C4C4C;
}

.articles_recents__card {
  display: block;
  position: relative;
  overflow: hidden;
  border-radius: 15px;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
  height: 500px;
  flex-basis: 350px;
}
@media (max-width: 1024px) {
  .articles_recents__card {
    height: 450px;
    flex-basis: 325px;
  }
}
@media (max-width: 768px) {
  .articles_recents__card {
    height: 400px;
    flex-basis: 300px;
    max-width: 300px;
    margin: 0 auto 25px auto;
  }
}

.articles_recents__card__content__text h3 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.articles_recents__card__content__text p {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.articles_recents__card__content__date {
  color: grey;
  font-style: italic;
  font-weight: 400;
}

.articles_recents__card__content__user {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
}
@media (max-width: 1024px) {
  .articles_recents__card__content__user {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .articles_recents__card__content__user {
    gap: 6px;
  }
}

.articles_recents_more_articles_link {
  font-weight: 700;
  display: flex;
  align-items: center;
  border-radius: 50px;
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  color: #FFFFFF;
  gap: 20px;
  padding: 15px;
  margin-top: 50px;
  transition: color 0.3s ease-in-out, background 0.3s ease-in-out;
}
@media (max-width: 1024px) {
  .articles_recents_more_articles_link {
    gap: 12.5px;
    padding: 12px;
    margin-top: 45px;
  }
}
@media (max-width: 768px) {
  .articles_recents_more_articles_link {
    gap: 10px;
    padding: 10px;
    margin-top: 40px;
  }
}
.articles_recents_more_articles_link .material-symbols-outlined {
  transition: transform 0.3s ease-in-out, color 0.3s ease-in-out;
}
.articles_recents_more_articles_link:hover .material-symbols-outlined {
  transform: rotateZ(90deg);
}
.articles_recents_more_articles_link:hover, .articles_recents_more_articles_link:hover .material-symbols-outlined {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.accueil {
  padding: unset;
}

.accueil__hero-banner {
  position: relative;
  height: 100dvh;
  min-height: 700px;
  display: flex;
  text-align: center;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  gap: 40px;
}
@media (max-width: 1024px) {
  .accueil__hero-banner {
    gap: 30px;
  }
}
@media (max-width: 768px) {
  .accueil__hero-banner {
    gap: 20px;
  }
}
.accueil__hero-banner::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 1;
}
.accueil__hero-banner > *:not(.accueil__hero-banner__video) {
  position: relative;
  z-index: 2;
}

.accueil__hero-banner__video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  filter: saturate(1.35) contrast(1.12) brightness(1.03) hue-rotate(-2deg);
}

.accueil__hero-banner__titre {
  color: #FFFFFF;
  font-weight: bold;
}

.accueil__hero-banner__titre--accent {
  display: block;
  background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
  -webkit-background-clip: text;
  font-size: unset;
  -webkit-text-fill-color: transparent;
}

.accueil__hero-banner__texte {
  font-size: 1.2rem;
  color: #FAFAF9;
}
@media (max-width: 1024px) {
  .accueil__hero-banner__texte {
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .accueil__hero-banner__texte {
    font-size: 0.95rem;
  }
}

.accueil__hero-banner__cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 50px;
}
@media (max-width: 1024px) {
  .accueil__hero-banner__cta {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .accueil__hero-banner__cta {
    gap: 25px;
  }
}
.accueil__hero-banner__cta a {
  height: 100%;
  border-radius: 15px;
  font-weight: 700;
  transition: color 0.3s ease-in-out, background-image 0.3s ease-in-out, border 0.3s ease-in-out;
  padding: 20px;
  font-size: 1.2rem;
}
@media (max-width: 1024px) {
  .accueil__hero-banner__cta a {
    padding: 17.5px;
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .accueil__hero-banner__cta a {
    padding: 15px;
    font-size: 0.95rem;
  }
}
.accueil__hero-banner__cta .btn--secondary {
  border: 2px solid #FFFFFF;
  color: #FFFFFF;
  background-color: transparent;
  background-image: none;
}
.accueil__hero-banner__cta .btn--secondary:hover {
  color: #ffcb49;
  border: 2px solid #ffcb49;
}
.accueil__hero-banner__cta .btn--primary {
  color: #FFFFFF;
  background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
  display: flex;
  align-items: center;
  transition: background-image 0.3s ease-in-out;
}
.accueil__hero-banner__cta .btn--primary:hover {
  background: linear-gradient(90deg, #a9ccb8, #8dd99f);
}

.accueil__presentation {
  height: 80dvh;
  min-height: 800px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #FFFFFF;
}

.accueil__presentation__conteneur {
  position: relative;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: nowrap;
  gap: 50px;
}
@media (max-width: 1024px) {
  .accueil__presentation__conteneur {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .accueil__presentation__conteneur {
    gap: 25px;
  }
}
.accueil__presentation__conteneur .accueil__presentation__image-mobile {
  display: none;
}
@media (max-width: 1024px) {
  .accueil__presentation__conteneur .accueil__presentation__image-desktop {
    display: none;
  }
  .accueil__presentation__conteneur .accueil__presentation__image-mobile {
    position: absolute;
    border-radius: unset;
    display: block;
    z-index: 1;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    overflow: hidden;
  }
  .accueil__presentation__conteneur .accueil__presentation__image-mobile::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.45);
    z-index: 2;
  }
  .accueil__presentation__conteneur .accueil__presentation__image-mobile img {
    height: 100%;
    width: 100%;
    object-fit: cover;
  }
}

.accueil__presentation__texte {
  flex: 1 1 50%;
  text-align: left;
  gap: 50px;
}
@media (max-width: 1024px) {
  .accueil__presentation__texte {
    gap: 35px;
    position: relative;
    z-index: 3;
    text-align: center;
  }
}
@media (max-width: 768px) {
  .accueil__presentation__texte {
    gap: 25px;
  }
}

.accueil__presentation__titre {
  color: #4C4C4C;
}
@media (max-width: 1024px) {
  .accueil__presentation__titre {
    color: #FFFFFF;
  }
}

.accueil__presentation__description {
  font-family: "Poppins_texte", sans-serif;
  opacity: 0.85;
  color: #4C4C4C;
}
@media (max-width: 1024px) {
  .accueil__presentation__description {
    color: #FFFFFF;
  }
}

.accueil__presentation__lien {
  border-radius: 50px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  color: #FFFFFF;
  background-image: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  gap: 15px;
  margin-top: 50px;
  padding: 20px;
  transition: color 0.3s ease-in-out, background 0.3s ease-in-out;
}
@media (max-width: 1024px) {
  .accueil__presentation__lien {
    gap: 12.5px;
    margin-top: 45px;
    padding: 17.5px;
    position: relative;
    z-index: 3;
    margin-left: auto;
  }
}
@media (max-width: 768px) {
  .accueil__presentation__lien {
    gap: 10px;
    margin-top: 40px;
    padding: 15px;
  }
}
.accueil__presentation__lien span {
  transition: transform 0.3s ease-in-out, color 0.3s ease-in-out;
}
.accueil__presentation__lien:hover {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}
.accueil__presentation__lien:hover span {
  transform: translateX(5px);
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.accueil__presentation__image {
  flex-grow: 1;
  flex-shrink: 1;
  text-align: center;
  border-radius: 50px;
  overflow: hidden;
  height: 450px;
  width: 450px;
}
@media (max-width: 1024px) {
  .accueil__presentation__image {
    display: none;
  }
}
.accueil__presentation__image img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.accueil .accueil-services {
  min-height: 900px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #fffdff;
  text-align: center;
  color: #4C4C4C;
}

.accueil .accueil-services__title {
  font-size: 2.5rem;
  margin-bottom: 2rem;
}
@media (max-width: 1024px) {
  .accueil .accueil-services__title {
    font-size: 2rem;
  }
}
@media (max-width: 768px) {
  .accueil .accueil-services__title {
    font-size: 1.5rem;
  }
}

.accueil .accueil-services__grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 50px;
}
@media (max-width: 1024px) {
  .accueil .accueil-services__grid {
    gap: 35px;
    flex-wrap: wrap;
    justify-content: center;
    align-items: stretch;
  }
}
@media (max-width: 768px) {
  .accueil .accueil-services__grid {
    gap: 25px;
  }
}

.accueil .accueil-services__item {
  position: relative;
  background-color: #FFFFFF;
  border-radius: 12px;
  box-shadow: 0 2px 10px rgba(196, 196, 196, 0.42);
  width: 280px;
  max-width: 500px;
  transition: transform 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  padding: 40px;
}
@media (max-width: 1024px) {
  .accueil .accueil-services__item {
    gap: 30px;
    padding: 30px;
  }
}
@media (max-width: 768px) {
  .accueil .accueil-services__item {
    gap: 20px;
    padding: 20px;
  }
}
.accueil .accueil-services__item:hover {
  transform: scale(1.01);
}
.accueil .accueil-services__item::after {
  content: "";
  position: absolute;
  bottom: 24px;
  right: 12px;
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
  opacity: 0.9;
}

.accueil .accueil-services__item-top {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.accueil .accueil-services__item-top .icon_container {
  height: 80px;
  width: 80px;
}
@media (max-width: 1024px) {
  .accueil .accueil-services__item-top .icon_container {
    height: 70px;
    width: 70px;
    margin: 0 auto;
  }
}
@media (max-width: 768px) {
  .accueil .accueil-services__item-top .icon_container {
    height: 60px;
    width: 60px;
  }
}
.accueil .accueil-services__item-top .icon_container img {
  object-fit: contain;
  width: 100%;
  height: 100%;
}
@media (max-width: 1024px) {
  .accueil .accueil-services__item-top .icon_container img {
    object-position: center;
  }
}

.accueil .accueil-services__subtitle {
  font-weight: bold;
}

.accueil__presentation__texte {
  opacity: 0;
  transform: translateX(-28px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.accueil__presentation__texte.is-visible {
  opacity: 1;
  transform: translateX(0);
}

.accueil__presentation__image-desktop {
  opacity: 0;
  transform: translateX(28px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.accueil__presentation__image-desktop.is-visible {
  opacity: 1;
  transform: translateX(0);
}

.services-carousel__intro {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1), transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.services-carousel__intro.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.accueil .tarifs__intro {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1), transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.accueil .tarifs__intro.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.accueil .tarifs-card {
  opacity: 0;
  transition: opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1), transform 0.18s ease, box-shadow 0.18s ease;
}
.accueil .tarifs-card.is-visible {
  opacity: 1;
}

.accueil .doc-accueil__intro {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1), transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.accueil .doc-accueil__intro.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.accueil .doc-accueil__card {
  opacity: 0;
  transition: opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1), transform 0.18s ease, box-shadow 0.18s ease;
}
.accueil .doc-accueil__card.is-visible {
  opacity: 1;
}

.accueil .recrutement__intro {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1), transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.accueil .recrutement__intro.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.accueil .recrutement__step {
  opacity: 0;
  transform: translateX(-20px);
  transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1), transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.accueil .recrutement__step.is-visible {
  opacity: 1;
  transform: translateX(0);
}

.accueil .articles-recents__intro {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1), transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.accueil .articles-recents__intro.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.accueil .articles__card {
  opacity: 0;
  transition: opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1), transform 0.2s ease-in-out;
}
.accueil .articles__card.is-visible {
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  .accueil__presentation__texte,
.accueil__presentation__image-desktop,
.services-carousel__intro,
.accueil .tarifs__intro,
.accueil .tarifs-card,
.accueil .doc-accueil__intro,
.accueil .doc-accueil__card,
.accueil .recrutement__intro,
.accueil .recrutement__step,
.accueil .articles-recents__intro,
.accueil .articles__card {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
.blog-intro {
  position: relative;
  height: 70dvh;
  border-radius: 0 0 50px 50px;
  background-image: linear-gradient(60deg, #F7E1D7, #FFFFFF);
  min-height: 550px;
  width: 100%;
  display: flex;
  align-items: flex-end;
  padding: 40px;
  margin-bottom: 100px;
}
@media (max-width: 1024px) {
  .blog-intro {
    padding: 30px;
    margin-bottom: 75px;
  }
}
@media (max-width: 768px) {
  .blog-intro {
    padding: 20px;
    margin-bottom: 50px;
  }
}

.blog-intro__container {
  width: 100%;
  margin: 0 auto;
  padding-bottom: unset;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.blog-intro__title {
  text-align: center;
  font-weight: 700;
  line-height: 1.2;
}

.blog-intro__description {
  text-align: center;
  max-width: 900px;
  margin: 0 auto;
  line-height: 1.6;
}

.blog-intro .search-container_blog {
  position: relative;
  max-width: 900px;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 768px) {
  .blog-intro .search-container_blog {
    display: block;
  }
}

.blog-intro .search-input-blog {
  position: relative;
  display: flex;
  align-items: center;
  background-color: #FFFFFF;
  box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
  border-radius: 50px;
  font-size: 1.2rem;
  flex-basis: 750px;
  padding: 7px;
}
@media (max-width: 1024px) {
  .blog-intro .search-input-blog {
    font-size: 1rem;
    padding: 6px;
    flex-basis: 650px;
  }
}
@media (max-width: 768px) {
  .blog-intro .search-input-blog {
    font-size: 0.95rem;
    padding: 5px;
    flex-basis: 550px;
    max-width: 100%;
  }
}

.blog-intro .search-input-blog__filter {
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  width: 60px;
  color: #4C4C4C;
}
@media (max-width: 1024px) {
  .blog-intro .search-input-blog__filter {
    height: 52.5px;
    width: 52.5px;
  }
}
@media (max-width: 768px) {
  .blog-intro .search-input-blog__filter {
    height: 45px;
    width: 45px;
  }
}
.blog-intro .search-input-blog__filter:hover {
  opacity: 0.8;
}

.blog-intro .search-input-blog__form {
  margin: unset;
  max-width: unset;
  display: flex;
  justify-content: space-between;
  align-items: center;
  align-self: stretch;
  flex-grow: 1;
  font-size: 28px;
}
@media (max-width: 1024px) {
  .blog-intro .search-input-blog__form {
    font-size: 26px;
  }
}
@media (max-width: 768px) {
  .blog-intro .search-input-blog__form {
    font-size: 24px;
  }
}

.blog-intro .search-input-blog__form__field {
  border: none;
  background: transparent;
  outline: none;
  margin: unset;
  color: #EFCFD1;
  width: 85%;
  font-size: 1.2rem;
}
@media (max-width: 1024px) {
  .blog-intro .search-input-blog__form__field {
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .blog-intro .search-input-blog__form__field {
    font-size: 0.95rem;
  }
}

.blog-intro .search-input-blog__submit {
  border: none;
  border-radius: 50px;
  cursor: pointer;
  background-color: #EFCFD1;
  color: #FFFFFF;
  transition: opacity 0.2s ease;
  height: 60px;
  width: 60px;
}
@media (max-width: 1024px) {
  .blog-intro .search-input-blog__submit {
    height: 52.5px;
    width: 52.5px;
  }
}
@media (max-width: 768px) {
  .blog-intro .search-input-blog__submit {
    height: 45px;
    width: 45px;
  }
}
.blog-intro .search-input-blog__submit:hover {
  opacity: 0.9;
}

.blog-intro .search-input-blog .search-filters {
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  background-color: #FFFFFF;
  box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
  border-radius: 15px;
  max-width: 400px;
  z-index: 13;
  opacity: 0;
  transition: opacity 0.2s ease, transform 0.2s ease;
  padding: 15px;
}
@media (max-width: 1024px) {
  .blog-intro .search-input-blog .search-filters {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .blog-intro .search-input-blog .search-filters {
    padding: 10px;
  }
}
.blog-intro .search-input-blog .search-filters.active {
  display: block;
  opacity: 1;
}

.blog-intro .search-input-blog .filters-form {
  display: flex;
  flex-direction: column;
  margin: unset;
  justify-content: flex-start;
  gap: 10px;
}
@media (max-width: 1024px) {
  .blog-intro .search-input-blog .filters-form {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .blog-intro .search-input-blog .filters-form {
    gap: 6px;
  }
}
.blog-intro .search-input-blog .filters-form .filter-item {
  display: flex;
  flex-direction: column;
}
.blog-intro .search-input-blog .filters-form .filter-item input[type=checkbox] {
  width: unset;
  margin: unset;
  cursor: pointer;
}
.blog-intro .search-input-blog .filters-form #filter-category {
  background-color: #FAFAF9;
}
.blog-intro .search-input-blog .filters-form .filters-apply {
  background-color: #EFCFD1;
  color: #FFFFFF;
  font-weight: 700;
  border: none;
  padding: 10px;
  border-radius: 50px;
  cursor: pointer;
  margin-top: 15px;
  transition: background-color 0.2s ease;
}
.blog-intro .search-input-blog .filters-form .filters-apply:hover {
  opacity: 0.9;
}

.blog-intro .switch-label {
  color: #EFCFD1;
}

.blog-intro .switch-label .switch-slider {
  position: relative;
  width: 40px;
  height: 22px;
  background-color: #e3e3e3;
  border-radius: 20px;
  margin-right: 12px;
  transition: background 0.3s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.07);
  flex-shrink: 0;
}

.blog-intro .switch-label .switch-slider::before {
  content: "";
  position: absolute;
  left: 2px;
  top: 2px;
  width: 18px;
  height: 18px;
  background: #FFFFFF;
  border-radius: 50%;
  transition: transform 0.2s ease cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.13);
}

.blog-intro .switch-checkbox:checked + .switch-label .switch-slider {
  background-color: #EFCFD1;
}

.blog-intro label {
  font-weight: 700;
  color: #EFCFD1;
}

.blog-intro select {
  border: solid 1px #EFCFD1;
  color: #EFCFD1;
}

.blog-articles {
  padding-top: unset;
}

.container__links_categories {
  display: flex;
  gap: 15px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 25px;
}
@media (max-width: 1024px) {
  .container__links_categories {
    gap: 12.5px;
    margin-bottom: 22.5px;
  }
}
@media (max-width: 768px) {
  .container__links_categories {
    gap: 10px;
    margin-bottom: 20px;
  }
}
.container__links_categories p {
  cursor: pointer;
  padding: 10px;
}
@media (max-width: 1024px) {
  .container__links_categories p {
    padding: 8px;
  }
}
@media (max-width: 768px) {
  .container__links_categories p {
    padding: 6px;
  }
}

.dashboard-inner-form {
  margin: 0 auto 24px;
  max-width: 700px;
}
@media (max-width: 1024px) {
  .dashboard-inner-form {
    max-width: 450px;
    margin-bottom: 20px;
  }
}
@media (max-width: 768px) {
  .dashboard-inner-form {
    max-width: 300px;
    margin-bottom: 16px;
  }
}

.dashboard-inner-form .section-dynamique {
  margin-top: 86px;
}
@media (max-width: 1024px) {
  .dashboard-inner-form .section-dynamique {
    margin-top: 84px;
  }
}
@media (max-width: 768px) {
  .dashboard-inner-form .section-dynamique {
    margin-top: 82px;
  }
}
.dashboard-inner-form .section-dynamique .section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .dashboard-inner-form .section-dynamique .section-header {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .dashboard-inner-form .section-dynamique .section-header {
    margin-bottom: 8px;
  }
}
.dashboard-inner-form .section-dynamique .section-header .container_button button {
  background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
  color: #FFFFFF;
  margin: unset;
}
.dashboard-inner-form .section-dynamique .section-header .container_button button:hover {
  opacity: 0.9;
}
.dashboard-inner-form .section-dynamique .section-header .container_button button,
.dashboard-inner-form .section-dynamique .section-header .container_button span {
  font-size: 0.8rem;
}
@media (max-width: 1024px) {
  .dashboard-inner-form .section-dynamique .section-header .container_button button,
.dashboard-inner-form .section-dynamique .section-header .container_button span {
    font-size: 0.7rem;
  }
}
@media (max-width: 768px) {
  .dashboard-inner-form .section-dynamique .section-header .container_button button,
.dashboard-inner-form .section-dynamique .section-header .container_button span {
    font-size: 0.6rem;
  }
}
.dashboard-inner-form .section-dynamique label {
  margin: unset;
}
.dashboard-inner-form .section-dynamique .content-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}
@media (max-width: 1024px) {
  .dashboard-inner-form .section-dynamique .content-grid {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .dashboard-inner-form .section-dynamique .content-grid {
    gap: 6px;
    display: block;
  }
}
.dashboard-inner-form .section-dynamique .content-cell {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: 50px;
  background-image: linear-gradient(90deg, rgba(169, 203, 183, 0.3), rgba(126, 191, 141, 0.38));
  color: #4C4C4C;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
  transition: background-color 0.2s ease;
  flex-shrink: 0;
  gap: 10px;
  font-size: 0.8rem;
  padding: 15px;
}
@media (max-width: 1024px) {
  .dashboard-inner-form .section-dynamique .content-cell {
    gap: 8px;
    font-size: 0.7rem;
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .dashboard-inner-form .section-dynamique .content-cell {
    gap: 6px;
    font-size: 0.6rem;
    padding: 10px;
    margin: 0 auto;
    margin-bottom: 12px;
  }
}
.dashboard-inner-form .section-dynamique .cell-actions {
  display: flex;
  gap: 10px;
}
@media (max-width: 1024px) {
  .dashboard-inner-form .section-dynamique .cell-actions {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .dashboard-inner-form .section-dynamique .cell-actions {
    gap: 6px;
  }
}
.dashboard-inner-form .section-dynamique .cell-actions button {
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  cursor: pointer;
  border-radius: 50%;
  background-color: #FFFFFF;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
  transition: background-color 0.2s ease;
  height: 40px;
  width: 40px;
  padding: 8px;
}
@media (max-width: 1024px) {
  .dashboard-inner-form .section-dynamique .cell-actions button {
    height: 35px;
    width: 35px;
    padding: 7px;
  }
}
@media (max-width: 768px) {
  .dashboard-inner-form .section-dynamique .cell-actions button {
    height: 30px;
    width: 30px;
    padding: 6px;
  }
}
.dashboard-inner-form .section-dynamique .cell-actions button:hover {
  background-color: #f1f1f1;
}
.dashboard-inner-form .section-dynamique .cell-body {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.dashboard-inner-form .section-dynamique .cell-body p, .dashboard-inner-form .section-dynamique .cell-body span {
  font-size: 0.8rem;
  margin: unset;
}
@media (max-width: 1024px) {
  .dashboard-inner-form .section-dynamique .cell-body p, .dashboard-inner-form .section-dynamique .cell-body span {
    font-size: 0.7rem;
  }
}
@media (max-width: 768px) {
  .dashboard-inner-form .section-dynamique .cell-body p, .dashboard-inner-form .section-dynamique .cell-body span {
    font-size: 0.6rem;
  }
}
.dashboard-inner-form .section-dynamique .content-grid--galerie {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 20px;
}
@media (max-width: 1024px) {
  .dashboard-inner-form .section-dynamique .content-grid--galerie {
    gap: 10px;
  }
}
@media (max-width: 768px) {
  .dashboard-inner-form .section-dynamique .content-grid--galerie {
    gap: 8px;
  }
}
.dashboard-inner-form .section-dynamique .content-cell--galerie {
  flex-direction: column;
  align-items: stretch;
  width: 160px;
  padding: 10px;
  gap: 8px;
  border-radius: 15px;
}
@media (max-width: 1024px) {
  .dashboard-inner-form .section-dynamique .content-cell--galerie {
    width: 140px;
  }
}
@media (max-width: 768px) {
  .dashboard-inner-form .section-dynamique .content-cell--galerie {
    width: 120px;
  }
}
.dashboard-inner-form .section-dynamique .content-cell--galerie .cell-actions {
  justify-content: flex-end;
  gap: 8px;
}
.dashboard-inner-form .section-dynamique .cell-body--galerie {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0 6px;
}
.dashboard-inner-form .section-dynamique .cell-body--galerie .cell-title {
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dashboard-inner-form .section-dynamique .cell-image-stack {
  position: relative;
  width: 100%;
  height: 90px;
  margin-top: 6px;
  flex-shrink: 0;
}
.dashboard-inner-form .section-dynamique .stack-layer {
  position: absolute;
  width: 85%;
  height: 100%;
  object-fit: cover;
  border-radius: 15px;
  left: 50%;
  transform: translateX(-50%);
}
.dashboard-inner-form .section-dynamique .stack-layer--front {
  z-index: 3;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.22);
  transform: translateX(-50%);
}
.dashboard-inner-form .section-dynamique .stack-layer--mid {
  z-index: 2;
  transform: translateX(-50%) rotate(-5deg) translate(-6px, 2px);
  filter: brightness(0.6) saturate(0.5);
}
.dashboard-inner-form .section-dynamique .stack-layer--back {
  z-index: 1;
  transform: translateX(-50%) rotate(5deg) translate(6px, 2px);
  filter: brightness(0.4) saturate(0.35);
}
.dashboard-inner-form .section-dynamique .stack-ghost {
  background-color: rgba(126, 191, 141, 0.3);
}
.dashboard-inner-form .section-dynamique .cell-count {
  font-size: 0.8rem;
  color: #4C4C4C;
  opacity: 0.6;
}
@media (max-width: 1024px) {
  .dashboard-inner-form .section-dynamique .cell-count {
    font-size: 0.7rem;
  }
}
@media (max-width: 768px) {
  .dashboard-inner-form .section-dynamique .cell-count {
    font-size: 0.6rem;
  }
}

.apropos-intro {
  background-color: #FFFFFF;
}

.apropos-intro__container {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: nowrap;
  gap: 50px;
}
@media (max-width: 1024px) {
  .apropos-intro__container {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .apropos-intro__container {
    gap: 25px;
  }
}
.apropos-intro__container .apropos-intro__image-mobile {
  display: none;
}
@media (max-width: 1200px) {
  .apropos-intro__container {
    flex-direction: column;
    align-items: stretch;
  }
  .apropos-intro__container .apropos-intro__image-desktop {
    display: none;
  }
  .apropos-intro__container .apropos-intro__image-mobile {
    position: absolute;
    inset: 0;
    display: block;
    z-index: 0;
    border-radius: 15px;
    overflow: hidden;
  }
  .apropos-intro__container .apropos-intro__image-mobile::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(2px);
    z-index: 1;
  }
  .apropos-intro__container .apropos-intro__image-mobile img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }
}

.apropos-intro__col--media {
  flex: 0 0 auto;
}

.apropos-intro__col--content {
  position: relative;
  z-index: 2;
}
@media (max-width: 1024px) {
  .apropos-intro__col--content {
    padding: 70px;
  }
}
@media (max-width: 768px) {
  .apropos-intro__col--content {
    padding: 50px;
  }
}

.apropos-intro__figure {
  display: block;
  border-radius: 15px;
  overflow: hidden;
}

.apropos-intro__image {
  display: block;
  object-fit: cover;
  object-position: center;
  height: 450px;
  width: 450px;
}
@media (max-width: 1024px) {
  .apropos-intro__image {
    height: 400px;
    width: 400px;
  }
}
@media (max-width: 768px) {
  .apropos-intro__image {
    height: 400px;
    width: 400px;
  }
}

.apropos-intro__header {
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .apropos-intro__header {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .apropos-intro__header {
    margin-bottom: 8px;
  }
}

.apropos-intro__title {
  color: #4C4C4C;
}

.apropos-intro__richtext {
  opacity: 0.85;
  color: #4C4C4C;
}

@media (max-width: 1200px) {
  .apropos-intro__title,
.apropos-intro__richtext {
    color: #FFFFFF;
  }
}
.apropos-intro__stats {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  gap: 50px;
}
@media (max-width: 1024px) {
  .apropos-intro__stats {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .apropos-intro__stats {
    gap: 25px;
  }
}

.apropos-intro__stat {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  min-inline-size: 0;
  flex: 1 1 auto;
  background-color: #FFFFFF;
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  padding: 25px;
}
@media (max-width: 1024px) {
  .apropos-intro__stat {
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .apropos-intro__stat {
    padding: 15px;
  }
}
@media (max-width: 1200px) {
  .apropos-intro__stat {
    background-color: rgba(255, 255, 255, 0.12);
  }
}

.apropos-intro__stat-value {
  font-weight: 700;
  color: #A9CBB7;
  font-size: 2.5rem;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .apropos-intro__stat-value {
    font-size: 2rem;
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .apropos-intro__stat-value {
    font-size: 1.5rem;
    margin-bottom: 8px;
  }
}

.apropos-intro__stat-label {
  color: #4C4C4C;
  opacity: 0.9;
}
@media (max-width: 1200px) {
  .apropos-intro__stat-label {
    color: #FFFFFF;
    opacity: 1;
  }
}

.values__header {
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .values__header {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .values__header {
    margin-bottom: 30px;
  }
}

.values__title {
  color: #4C4C4C;
}

.values__intro {
  max-inline-size: 90ch;
  margin-inline: auto;
  color: #4C4C4C;
  opacity: 0.85;
}

.values__grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  gap: 50px;
}
@media (max-width: 1024px) {
  .values__grid {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .values__grid {
    gap: 25px;
  }
}

.values__item {
  width: 100%;
  max-width: 320px;
  display: flex;
  flex: 0 0 auto;
}

.value-card {
  backdrop-filter: blur(5px);
  background-color: #FFFFFF;
  border-radius: 15px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  border: 1px solid rgba(255, 255, 255, 0.3);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
  gap: 10px;
  padding: 25px;
}
@media (max-width: 1024px) {
  .value-card {
    padding: 20px;
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .value-card {
    padding: 15px;
    gap: 6px;
  }
}

.value-card__title {
  color: #A9CBB7;
  font-weight: 700;
}

.value-card__text {
  color: #4C4C4C;
}

.org {
  background-color: #FFFFFF;
}

.org__header {
  text-align: center;
  margin-bottom: 50px;
}

.org__title {
  color: #4C4C4C;
}

.org__intro {
  max-inline-size: 90ch;
  margin-inline: auto;
  color: #4C4C4C;
  opacity: 0.85;
}

.org__figure {
  display: block;
  text-align: center;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 10px;
  margin-top: 100px;
}
@media (max-width: 1024px) {
  .org__figure {
    margin-top: 75px;
    border-radius: 8px;
  }
}
@media (max-width: 768px) {
  .org__figure {
    margin-top: 50px;
    border-radius: 6px;
  }
}

.org__image {
  display: inline-block;
  vertical-align: top;
  object-fit: contain;
  object-position: center;
  max-inline-size: 100%;
  inline-size: auto;
  block-size: auto;
}

.org__caption {
  color: #4C4C4C;
  text-align: center;
  margin-top: 12px;
}
@media (max-width: 1024px) {
  .org__caption {
    margin-top: 10px;
  }
}
@media (max-width: 768px) {
  .org__caption {
    margin-top: 8px;
  }
}

.org__figure--fit-height {
  overflow: auto;
}

.org__figure--fit-height .org__image {
  inline-size: auto;
  max-inline-size: 100%;
}

.equipes {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 50px;
  margin-top: 100px;
}
@media (max-width: 1024px) {
  .equipes {
    gap: 35px;
    margin-top: 75px;
  }
}
@media (max-width: 768px) {
  .equipes {
    gap: 25px;
    margin-top: 50px;
    grid-template-columns: 1fr;
  }
}

.equipe-card {
  background-color: #FFFFFF;
  border-radius: 15px;
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: 360px;
}
@media (max-width: 1024px) {
  .equipe-card {
    height: 320px;
  }
}
@media (max-width: 768px) {
  .equipe-card {
    height: 300px;
  }
}

.equipe-card__header {
  background-image: linear-gradient(90deg, #A9CBB7, #7EBF8D);
  padding: 20px 25px;
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .equipe-card__header {
    padding: 15px 20px;
  }
}
@media (max-width: 768px) {
  .equipe-card__header {
    padding: 10px 15px;
  }
}

.equipe-card__title {
  color: #FFFFFF;
  font-weight: 700;
  margin: 0;
  font-size: 1.5rem;
}
@media (max-width: 1024px) {
  .equipe-card__title {
    font-size: 1.2rem;
  }
}
@media (max-width: 768px) {
  .equipe-card__title {
    font-size: 0.9rem;
  }
}

.equipe-card__members {
  list-style: none;
  padding: 25px;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: #A9CBB7 transparent;
}
.equipe-card__members::-webkit-scrollbar {
  width: 4px;
}
.equipe-card__members::-webkit-scrollbar-track {
  background: transparent;
}
.equipe-card__members::-webkit-scrollbar-thumb {
  background-color: #A9CBB7;
  border-radius: 50px;
}
@media (max-width: 1024px) {
  .equipe-card__members {
    padding: 20px;
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .equipe-card__members {
    padding: 15px;
    gap: 6px;
  }
}

.equipe-card__member {
  color: #4C4C4C;
  font-size: 1.2rem;
  padding: 8px 10px;
  border-radius: 10px;
  background-color: rgba(169, 203, 183, 0.3);
  line-height: 1.4;
  flex-shrink: 0;
}
@media (max-width: 1024px) {
  .equipe-card__member {
    font-size: 1rem;
    padding: 6px 8px;
  }
}
@media (max-width: 768px) {
  .equipe-card__member {
    font-size: 0.95rem;
    padding: 6px 6px;
  }
}

.transition-footer {
  height: 300px;
  width: 100%;
  background: linear-gradient(180deg, #ffffff 0%, #ffffff 80%, #f2fbe9 90%, #daefd9 100%);
}

.site-footer {
  color: #4C4C4C;
  background: linear-gradient(180deg, #daefd9 0%, #d4e9d3 25%, #cce3cd 50%, #c0dcc4 75%, #b5d6bc 100%);
}
.site-footer ul {
  padding-inline-start: unset;
}
.site-footer a {
  color: #4C4C4C;
}

.site-footer__top {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 50px;
}
@media (max-width: 1024px) {
  .site-footer__top {
    gap: 35px;
    flex-direction: column;
  }
}
@media (max-width: 768px) {
  .site-footer__top {
    gap: 25px;
  }
}

.site-footer__col {
  display: flex;
  flex-direction: column;
  gap: 20px;
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: 0;
}
@media (max-width: 1024px) {
  .site-footer__col {
    min-inline-size: 0;
    gap: 18.5px;
  }
}
@media (max-width: 768px) {
  .site-footer__col {
    gap: 15px;
  }
}

.site-footer__col--links ul,
.site-footer__list,
.site-footer__social {
  list-style-type: none;
}

.site-footer__title {
  font-weight: 700;
  margin-bottom: 20px;
}
@media (max-width: 1024px) {
  .site-footer__title {
    margin-bottom: 16px;
  }
}
@media (max-width: 768px) {
  .site-footer__title {
    margin-bottom: 12px;
  }
}

.site-footer__list {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (max-width: 1024px) {
  .site-footer__list {
    gap: 15px;
  }
}
@media (max-width: 768px) {
  .site-footer__list {
    gap: 10px;
  }
}

.site-footer__address {
  font-style: normal;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (max-width: 1024px) {
  .site-footer__address {
    gap: 15px;
  }
}
@media (max-width: 768px) {
  .site-footer__address {
    gap: 10px;
  }
}

.site-footer__link {
  position: relative;
  display: inline-block;
  text-decoration: none;
  color: #4C4C4C;
}
.site-footer__link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 2px;
  width: 100%;
  background-color: #4C4C4C;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease-in-out;
}
.site-footer__link:hover::after {
  transform: scaleX(1);
}

.site-footer__link--highlight {
  font-weight: 700;
}

.site-footer__social {
  display: flex;
  align-items: center;
  gap: 10px;
}
@media (max-width: 1024px) {
  .site-footer__social {
    gap: 8px;
    padding: 30px;
  }
}
@media (max-width: 768px) {
  .site-footer__social {
    gap: 6px;
    padding: 20px;
  }
}

.site-footer__icon {
  border-radius: 50px;
  background-color: #FFFFFF;
  height: 40px;
  width: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 15px;
}
@media (max-width: 1024px) {
  .site-footer__icon {
    padding: 12.5px;
    height: 35px;
    width: 35px;
  }
}
@media (max-width: 768px) {
  .site-footer__icon {
    padding: 10px;
    height: 30px;
    width: 30px;
  }
}
.site-footer__icon:hover {
  background-color: rgba(255, 255, 255, 0.8);
}
.site-footer__icon img {
  object-fit: contain;
  height: 100%;
  width: 100%;
}

.site-footer__bottom {
  position: relative;
  padding: 100px 5%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
@media (max-width: 1024px) {
  .site-footer__bottom {
    padding: 70px 5%;
  }
}
@media (max-width: 768px) {
  .site-footer__bottom {
    padding: 50px 5%;
  }
}
.site-footer__bottom::before {
  content: "";
  display: block;
  inline-size: 100%;
  opacity: 0.6;
  position: absolute;
  inset-inline-start: 0;
  inset-block-start: 0;
}

.site-footer__hotline {
  font-weight: 700;
}

.site-footer__copyright {
  opacity: 0.9;
}

.hebergement-intro__container {
  position: relative;
  display: flex;
  border-radius: 15px;
  overflow: hidden;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 50px;
}
.hebergement-intro__container .hebergement-intro__image-mobile {
  display: none;
}
@media (max-width: 1024px) {
  .hebergement-intro__container {
    gap: 35px;
    flex-direction: column;
    align-items: stretch;
  }
  .hebergement-intro__container .hebergement-intro__image-desktop {
    display: none;
  }
  .hebergement-intro__container .hebergement-intro__image-mobile {
    position: absolute;
    inset: 0;
    display: block;
    z-index: 0;
    overflow: hidden;
  }
  .hebergement-intro__container .hebergement-intro__image-mobile::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(2px);
    z-index: 11;
  }
  .hebergement-intro__container .hebergement-intro__image-mobile img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }
}
@media (max-width: 768px) {
  .hebergement-intro__container {
    gap: 25px;
  }
}

.hebergement-intro__col--media {
  flex-grow: 0;
  flex-shrink: 0;
  flex-basis: auto;
}

.hebergement-intro__col--content {
  position: relative;
  z-index: 12;
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: 0;
}
@media (max-width: 1024px) {
  .hebergement-intro__col--content {
    inline-size: 100%;
    background-color: transparent;
    border-radius: 0;
    padding: 70px;
  }
}
@media (max-width: 768px) {
  .hebergement-intro__col--content {
    padding: 50px;
  }
}

.hebergement-intro__figure {
  display: block;
  overflow: hidden;
  border-radius: 15px;
}

.hebergement-intro__image {
  display: block;
  object-fit: cover;
  object-position: center;
  height: 450px;
  width: 450px;
}
@media (max-width: 1024px) {
  .hebergement-intro__image {
    height: 400px;
    width: 400px;
  }
}
@media (max-width: 768px) {
  .hebergement-intro__image {
    height: 400px;
    width: 400px;
  }
}

.hebergement-intro__header {
  text-align: start;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .hebergement-intro__header {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .hebergement-intro__header {
    margin-bottom: 8px;
  }
}

.hebergement-intro__title {
  color: #4C4C4C;
}

.hebergement-intro__body {
  color: #4C4C4C;
}

.hebergement-intro__text {
  color: #4C4C4C;
}

@media (max-width: 1024px) {
  .hebergement-intro__header,
.hebergement-intro__body {
    text-align: start;
  }

  .hebergement-intro__title,
.hebergement-intro__text {
    color: #FFFFFF;
  }
}
.espaces {
  padding: 100px 5%;
}
@media (max-width: 1024px) {
  .espaces {
    padding: 70px 5%;
  }
}
@media (max-width: 768px) {
  .espaces {
    padding: 50px 5%;
  }
}

.espaces__container {
  display: flex;
  flex-direction: column;
  gap: 50px;
}
@media (max-width: 1024px) {
  .espaces__container {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .espaces__container {
    gap: 25px;
  }
}

.espaces__header {
  color: #4C4C4C;
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .espaces__header {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .espaces__header {
    margin-bottom: 30px;
  }
}

.espaces__text {
  max-inline-size: 90ch;
  margin-inline: auto;
  opacity: 0.85;
}

.espaces__list {
  display: flex;
  flex-direction: column;
  gap: 50px;
}
@media (max-width: 1024px) {
  .espaces__list {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .espaces__list {
    gap: 25px;
  }
}

.espaces-card {
  position: relative;
  display: flex;
  align-items: stretch;
  border-radius: 50px;
  overflow: hidden;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
  min-block-size: 350px;
}

.espaces-card__image-mobile {
  display: none;
}

.espaces-card__media .espaces-card__image-desktop {
  display: block;
}

.espaces-card__media {
  position: relative;
  overflow: hidden;
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: 0;
  min-block-size: unset;
}

.espaces-card__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.espaces-card__content {
  background-color: #FFFFFF;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 20px;
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: 0;
  padding: 25px;
}
@media (max-width: 1024px) {
  .espaces-card__content {
    gap: 15px;
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .espaces-card__content {
    gap: 10px;
    padding: 15px;
  }
}

.espaces-card__title {
  color: #4C4C4C;
}

.espaces-card__description {
  color: #4C4C4C;
}

.espaces-card__bottom h4 {
  color: #4C4C4C;
}

@media (max-width: 1024px) {
  .espaces-card__bottom h3 {
    color: #FFFFFF;
  }
}
.espaces-card__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  font-weight: 700;
  border-radius: 50px;
}
.espaces-card__actions a {
  color: #FFFFFF;
  background: linear-gradient(90deg, #7EBF8D, #A9CBB7);
  border-radius: 50px;
  margin-top: 24px;
  padding: 15px;
}
@media (max-width: 1024px) {
  .espaces-card__actions a {
    margin-top: 22px;
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .espaces-card__actions a {
    margin-top: 20px;
    padding: 10px;
  }
}
.espaces-card__actions a:hover {
  opacity: 0.8;
}

@media (max-width: 1024px) {
  .espaces-card .espaces-card {
    position: relative;
    display: block;
    inline-size: 100%;
    min-inline-size: 0;
  }

  .espaces-card .espaces-card__media {
    border-radius: 0;
    display: none;
  }

  .espaces-card .espaces-card__image-mobile {
    position: absolute;
    inset: 0;
    display: block;
    z-index: 0;
    overflow: hidden;
  }
  .espaces-card .espaces-card__image-mobile::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(2px);
    z-index: 11;
  }
  .espaces-card .espaces-card__image-mobile img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }

  .espaces-card .espaces-card__content {
    min-height: 300px;
    position: relative;
    z-index: 12;
    background: unset;
    gap: 15px;
    padding: 20px;
  }

  .espaces-card .espaces-card__title,
.espaces-card .espaces-card__description {
    color: #FFFFFF;
  }

  .espaces-card .espaces-card__description {
    display: -webkit-box;
    -webkit-line-clamp: 5;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .espaces-card .espaces-card__actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
  }

  .espaces-card .espaces-card__actions a {
    border-radius: 50px;
  }
}
.prestations__header {
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .prestations__header {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .prestations__header {
    margin-bottom: 30px;
  }
}

.prestations__title {
  color: #4C4C4C;
}

.prestations__intro {
  max-inline-size: 90ch;
  margin-inline: auto;
  color: #4C4C4C;
  opacity: 0.85;
}

.prestations__group {
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .prestations__group {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .prestations__group {
    margin-bottom: 30px;
  }
}

.prestations__group-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 35px;
}
@media (max-width: 1024px) {
  .prestations__group-title {
    font-size: 1.5rem;
    margin-bottom: 25px;
  }
}
@media (max-width: 768px) {
  .prestations__group-title {
    font-size: 1rem;
    margin-bottom: 20px;
  }
}
.prestations__group-title--included {
  color: #A9CBB7;
}
.prestations__group-title--extra {
  color: #A9CBB7;
}

.prestations__list {
  display: flex;
  flex-direction: column;
  gap: 50px;
}
@media (max-width: 1024px) {
  .prestations__list {
    gap: 40px;
  }
}
@media (max-width: 768px) {
  .prestations__list {
    gap: 35px;
  }
}

.prestation-item {
  padding-left: 35px;
  border-left: 3px solid #A9CBB7;
}
@media (max-width: 1024px) {
  .prestation-item {
    padding-left: 25px;
  }
}
@media (max-width: 768px) {
  .prestation-item {
    padding-left: 20px;
  }
}
.prestation-item--extra {
  border-left-color: #A9CBB7;
}

.prestation-item__title {
  font-weight: 700;
  font-size: 1.5rem;
  color: #4C4C4C;
  margin: 0 0 10px;
}
@media (max-width: 1024px) {
  .prestation-item__title {
    font-size: 1.2rem;
  }
}
@media (max-width: 768px) {
  .prestation-item__title {
    font-size: 0.9rem;
  }
}

.prestation-item__body {
  color: #4C4C4C;
  opacity: 0.85;
}
.prestation-item__body > *:first-child {
  margin-top: 0;
}
.prestation-item__body > *:last-child {
  margin-bottom: 0;
}

.prestations-note {
  display: flex;
  align-items: flex-start;
  gap: 25px;
  background-color: rgba(169, 203, 183, 0.08);
  border-radius: 15px;
  padding: 35px 40px;
}
@media (max-width: 1024px) {
  .prestations-note {
    padding: 25px 35px;
    gap: 20px;
  }
}
@media (max-width: 768px) {
  .prestations-note {
    padding: 20px 25px;
    flex-direction: column;
    gap: 10px;
  }
}

.prestations-note__icon {
  font-size: 24px;
  color: #A9CBB7;
  flex-shrink: 0;
  margin-top: 2px;
}
@media (max-width: 768px) {
  .prestations-note__icon {
    margin-top: 0;
  }
}

.prestations-note__text {
  color: #4C4C4C;
  display: flex;
  flex-direction: column;
  gap: 10px;
  opacity: 0.9;
}
.prestations-note__text p {
  margin: 0;
  line-height: 1.7;
}

.galerie-hebergement {
  background-color: #FFFFFF;
  padding: 100px 5%;
}
@media (max-width: 1024px) {
  .galerie-hebergement {
    padding: 70px 5%;
  }
}
@media (max-width: 768px) {
  .galerie-hebergement {
    padding: 50px 5%;
  }
}

.galerie-hebergement__header {
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .galerie-hebergement__header {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .galerie-hebergement__header {
    margin-bottom: 30px;
  }
}

.galerie-hebergement__title {
  color: #4C4C4C;
}

.galerie-hebergement__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(420px, 1fr));
  gap: 50px;
}
@media (max-width: 1024px) {
  .galerie-hebergement__grid {
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .galerie-hebergement__grid {
    grid-template-columns: 1fr;
    gap: 25px;
  }
}

.galerie-card {
  background-color: #FFFFFF;
  border-radius: 15px;
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
  overflow: visible;
  display: flex;
  flex-direction: column;
  position: relative;
  margin-top: 20px;
}
@media (max-width: 1024px) {
  .galerie-card {
    margin-top: 16px;
  }
}
@media (max-width: 768px) {
  .galerie-card {
    margin-top: 14px;
  }
}

.galerie-card__title-pill {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 12;
  background-color: #FFFFFF;
  color: #4C4C4C;
  border-radius: 2rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: 1.2rem;
  padding: 5px 20px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  white-space: nowrap;
  max-width: 90%;
  overflow: hidden;
  text-overflow: ellipsis;
  margin: 0;
  pointer-events: none;
}
@media (max-width: 1024px) {
  .galerie-card__title-pill {
    padding: 3.75px 15px;
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .galerie-card__title-pill {
    padding: 2.5px 10px;
    font-size: 0.95rem;
  }
}

.galerie-card__count {
  position: absolute;
  bottom: 10px;
  right: 10px;
  z-index: 2;
  color: #FFFFFF;
  font-size: 0.8rem;
  background-color: rgba(0, 0, 0, 0.4);
  border-radius: 50px;
  padding: 2px 8px;
  backdrop-filter: blur(4px);
  pointer-events: none;
}
@media (max-width: 1024px) {
  .galerie-card__count {
    font-size: 0.7rem;
  }
}

.galerie-card__carousel {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/9;
  border-radius: 15px;
}

.galerie-card__track {
  display: flex;
  height: 100%;
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

.galerie-card__slide {
  min-width: 100%;
  height: 100%;
  margin: 0;
  flex-shrink: 0;
}

.galerie-card__image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.galerie-card__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: none;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.85);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.2s ease;
  backdrop-filter: blur(4px);
}
@media (max-width: 768px) {
  .galerie-card__btn {
    width: 30px;
    height: 30px;
  }
}
.galerie-card__btn:hover {
  background-color: #FFFFFF;
  transform: translateY(-50%) scale(1.08);
}
.galerie-card__btn .material-symbols-outlined {
  font-size: 20px;
  color: #4C4C4C;
}
.galerie-card__btn--prev {
  left: 10px;
}
.galerie-card__btn--next {
  right: 10px;
}

.galerie-card__indicators {
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 6px;
  z-index: 2;
}

.galerie-card__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: none;
  background-color: rgba(255, 255, 255, 0.45);
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.2s ease;
  padding: 0;
}
.galerie-card__dot--active {
  background-color: #FFFFFF;
  transform: scale(1.25);
}
.galerie-card__dot:hover {
  background-color: rgba(255, 255, 255, 0.8);
}

.galerie-card__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  aspect-ratio: 16/9;
  border-radius: 15px;
  color: #4C4C4C;
  opacity: 0.35;
  gap: 8px;
}
.galerie-card__empty .material-symbols-outlined {
  font-size: 48px;
}

.cell-badge {
  display: inline-block;
  border-radius: 50px;
  font-size: 0.8rem;
  padding: 2px 8px;
  font-weight: 600;
}
.cell-badge--included {
  background-color: rgba(169, 203, 183, 0.3);
  color: #4C4C4C;
}
.cell-badge--extra {
  background-color: rgba(126, 191, 141, 0.2);
  color: #4C4C4C;
}

.services-carousel {
  --offset: 0%;
  --scale: 1;
  --opacity: 1;
  --z: 1;
  --pe: none;
}

.services-soins {
  --bg-image: none;
}

.services-hebergements {
  --bg-image: none;
}

.services-instances {
  --bg-image: none;
}

.services-activites {
  --bg-image: none;
}

.services-carousel {
  color: #4C4C4C;
  overflow-y: auto;
  overflow-x: hidden;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .services-carousel {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .services-carousel {
    margin-bottom: 30px;
  }
}

.services-carousel__intro {
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .services-carousel__intro {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .services-carousel__intro {
    margin-bottom: 30px;
  }
}

.services-carousel__text {
  opacity: 0.85;
  max-inline-size: 72ch;
  margin-inline: auto;
}

.services-carousel__viewport {
  position: relative;
  overflow: visible;
  gap: 50px;
}
@media (max-width: 1024px) {
  .services-carousel__viewport {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .services-carousel__viewport {
    gap: 25px;
  }
}

.services-carousel__track {
  position: relative;
}

.services-carousel__track::before {
  content: "";
  display: block;
  width: 100%;
  height: 450px;
  aspect-ratio: 4/5;
  visibility: hidden;
  pointer-events: none;
}
@media (max-width: 1024px) {
  .services-carousel__track::before {
    height: 400px;
  }
}
@media (max-width: 768px) {
  .services-carousel__track::before {
    height: 350px;
  }
}

.services-carousel__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 12;
  border: none;
  cursor: pointer;
  background-color: #FFFFFF;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #4C4C4C;
  border-radius: 50px;
  box-shadow: 0 0.6em 1.4em rgba(0, 0, 0, 0.12);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  padding: 15px;
}
@media (max-width: 1024px) {
  .services-carousel__arrow {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .services-carousel__arrow {
    padding: 10px;
  }
}
.services-carousel__arrow:hover {
  transform: translateY(-50%) scale(1.06);
}

.services-carousel__arrow--prev {
  left: 0.25rem;
}

.services-carousel__arrow--next {
  right: 0.25rem;
}

.services-carousel__arrow-ico {
  display: inline-block;
  line-height: 1;
}

.services-card {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(calc(-50% + var(--offset, 0%))) scale(var(--scale, 1));
  opacity: var(--opacity, 1);
  z-index: var(--z, 1);
  pointer-events: var(--pe, none);
  border-radius: 1rem;
  overflow: hidden;
  isolation: isolate;
  height: 450px;
  aspect-ratio: 4/5;
  background-image: var(--bg-image, none);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transition: transform 0.6s cubic-bezier(0.25, 0.8, 0.25, 1), opacity 0.6s ease;
  will-change: transform;
}
@media (max-width: 1024px) {
  .services-card {
    height: 400px;
  }
}
@media (max-width: 768px) {
  .services-card {
    height: 350px;
  }
}
.services-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}
.services-card:hover, .services-card:focus-visible {
  transform: translateX(calc(-50% + var(--offset, 0%))) translateY(-0.25em) scale(calc(var(--scale, 1) + 0.02));
}
.services-card:hover .services-card__cta-ico, .services-card:focus-visible .services-card__cta-ico {
  transform: translateX(0.35em);
  opacity: 0.95;
}
.services-card:hover::before, .services-card:focus-visible::before {
  opacity: 1;
  transform: translate3d(8%, -8%, 0);
}

.services-card__cta-ico {
  transition: transform 0.2s ease-in-out;
}

.services-card__content {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-end;
  position: relative;
  z-index: 1;
  padding: 25px;
}
@media (max-width: 1024px) {
  .services-card__content {
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .services-card__content {
    padding: 15px;
  }
}

.services-card__title {
  margin-block: auto;
  align-self: center;
  color: #FFFFFF;
  background: rgba(0, 0, 0, 0.25);
  border-radius: 0.8em;
  backdrop-filter: blur(0.2em);
  text-align: center;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1;
  padding: 15px;
}
@media (max-width: 1024px) {
  .services-card__title {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .services-card__title {
    padding: 10px;
  }
}

.services-card__cta {
  align-self: flex-end;
  color: #FFFFFF;
  border-radius: 50px;
  display: flex;
  gap: 15px;
  text-decoration: none;
  padding: 15px;
}
@media (max-width: 1024px) {
  .services-card__cta {
    gap: 12.5px;
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .services-card__cta {
    gap: 10px;
    padding: 10px;
  }
}

.soins-intro__container {
  position: relative;
  display: flex;
  border-radius: 15px;
  overflow: hidden;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 50px;
}
.soins-intro__container .soins-intro__image-mobile {
  display: none;
}
@media (max-width: 1024px) {
  .soins-intro__container {
    gap: 35px;
    flex-direction: column;
    align-items: stretch;
  }
  .soins-intro__container .soins-intro__image-desktop {
    display: none;
  }
  .soins-intro__container .soins-intro__image-mobile {
    position: absolute;
    inset: 0;
    display: block;
    z-index: 0;
    overflow: hidden;
  }
  .soins-intro__container .soins-intro__image-mobile::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(2px);
    z-index: 11;
  }
  .soins-intro__container .soins-intro__image-mobile img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }
}
@media (max-width: 768px) {
  .soins-intro__container {
    gap: 25px;
  }
}

.soins-intro__col--content {
  position: relative;
  z-index: 12;
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: 0;
}
@media (max-width: 1024px) {
  .soins-intro__col--content {
    inline-size: 100%;
    background-color: transparent;
    border-radius: 0;
    padding: 70px;
  }
}
@media (max-width: 768px) {
  .soins-intro__col--content {
    padding: 50px;
  }
}

.soins-intro__col--media {
  flex-grow: 0;
  flex-shrink: 0;
  flex-basis: auto;
}

.soins-intro__figure {
  display: block;
  overflow: hidden;
  border-radius: 15px;
}

.soins-intro__image {
  display: block;
  object-fit: cover;
  object-position: center;
  height: 450px;
  width: 450px;
}
@media (max-width: 1024px) {
  .soins-intro__image {
    height: 400px;
    width: 400px;
  }
}
@media (max-width: 768px) {
  .soins-intro__image {
    height: 400px;
    width: 400px;
  }
}

.soins-intro__header {
  text-align: start;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .soins-intro__header {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .soins-intro__header {
    margin-bottom: 8px;
  }
}

.soins-intro__title {
  color: #4C4C4C;
}

.soins-intro__body {
  color: #4C4C4C;
}

.soins-intro__text {
  color: #4C4C4C;
}

@media (max-width: 1024px) {
  .soins-intro__header,
.soins-intro__body {
    text-align: start;
  }

  .soins-intro__title,
.soins-intro__text,
.soins-intro__list {
    color: #FFFFFF;
  }
}
.activites-intro__container {
  position: relative;
  display: flex;
  border-radius: 15px;
  overflow: hidden;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 50px;
}
.activites-intro__container .activites-intro__image-mobile {
  display: none;
}
@media (max-width: 1024px) {
  .activites-intro__container {
    gap: 35px;
    flex-direction: column;
    align-items: stretch;
  }
  .activites-intro__container .activites-intro__image-desktop {
    display: none;
  }
  .activites-intro__container .activites-intro__image-mobile {
    position: absolute;
    inset: 0;
    display: block;
    z-index: 0;
    overflow: hidden;
  }
  .activites-intro__container .activites-intro__image-mobile::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(2px);
    z-index: 11;
  }
  .activites-intro__container .activites-intro__image-mobile img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }
}
@media (max-width: 768px) {
  .activites-intro__container {
    gap: 25px;
  }
}

.activites-intro__col--content {
  position: relative;
  z-index: 12;
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: 0;
}
@media (max-width: 1024px) {
  .activites-intro__col--content {
    inline-size: 100%;
    background-color: transparent;
    border-radius: 0;
    padding: 70px;
  }
}
@media (max-width: 768px) {
  .activites-intro__col--content {
    padding: 50px;
  }
}

.activites-intro__col--media {
  flex-grow: 0;
  flex-shrink: 0;
  flex-basis: auto;
}

.activites-intro__figure {
  display: block;
  overflow: hidden;
  border-radius: 15px;
}

.activites-intro__image {
  display: block;
  object-fit: cover;
  object-position: center;
  height: 450px;
  width: 450px;
}
@media (max-width: 1024px) {
  .activites-intro__image {
    height: 400px;
    width: 400px;
  }
}
@media (max-width: 768px) {
  .activites-intro__image {
    height: 400px;
    width: 400px;
  }
}

.activites-intro__header {
  text-align: start;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .activites-intro__header {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .activites-intro__header {
    margin-bottom: 8px;
  }
}

.activites-intro__title {
  font-size: 3rem;
  color: #4C4C4C;
}
@media (max-width: 1024px) {
  .activites-intro__title {
    font-size: 2.8rem;
  }
}
@media (max-width: 768px) {
  .activites-intro__title {
    font-size: 2.6rem;
  }
}

.activites-intro__body {
  color: #4C4C4C;
}

.activites-intro__text {
  color: #4C4C4C;
}

@media (max-width: 1024px) {
  .activites-intro__header,
.activites-intro__body {
    text-align: start;
  }

  .activites-intro__title,
.activites-intro__text {
    color: #FFFFFF;
  }
}
.activites {
  color: #4C4C4C;
}

.activites-section__intro {
  color: #4C4C4C;
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .activites-section__intro {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .activites-section__intro {
    margin-bottom: 30px;
  }
}

.activites-section__desc {
  max-inline-size: 90ch;
  margin-inline: auto;
  color: #4C4C4C;
  opacity: 0.85;
}

.activites-section--past .activite-card {
  border-radius: 50px 50px 0 0;
}

.activites-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  justify-items: center;
  gap: 40px;
}
@media (max-width: 1024px) {
  .activites-grid {
    gap: 30px;
  }
}
@media (max-width: 768px) {
  .activites-grid {
    gap: 20px;
    display: block;
  }
}

.activite-card {
  display: block;
  position: relative;
  background-color: #FFFFFF;
  flex-basis: 450px;
  height: auto;
  min-height: 0;
  margin-bottom: 75px;
}
@media (max-width: 1024px) {
  .activite-card {
    flex-basis: 400px;
    margin-bottom: 65px;
  }
}
@media (max-width: 768px) {
  .activite-card {
    flex-basis: 350px;
    margin-bottom: 55px;
    max-width: 300px;
    margin-inline: auto;
  }
}

.activite-card__header {
  position: relative;
  display: block;
  width: 100%;
  background-color: #FFFFFF;
  border: none;
  text-align: left;
  cursor: pointer;
}
.activite-card__header:focus-visible {
  outline: 2px solid #A9CBB7;
  outline-offset: 2px;
}

.activite-card__date-badge {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 12;
  transform: translateY(-45%) translateX(15%);
  display: inline-block;
  background-color: #fffdff;
  color: #FFFFFF;
  border-radius: 2rem;
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.05em;
  padding: 5px 20px;
  font-size: 1.2rem;
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
}
@media (max-width: 1024px) {
  .activite-card__date-badge {
    padding: 3.75px 15px;
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .activite-card__date-badge {
    padding: 2.5px 10px;
    font-size: 0.95rem;
  }
}

.activite-card__media {
  position: relative;
  display: block;
  aspect-ratio: 3/2;
  overflow: hidden;
}

.activite-card__image {
  width: 100%;
  height: 100%;
  border-radius: 50px;
  object-fit: cover;
  display: block;
}

.activite-card__curved-separator {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 60%;
  height: 90%;
  pointer-events: none;
}

.activite-card__chevron {
  position: absolute;
  bottom: 15px;
  left: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #FFFFFF;
  background: rgba(76, 76, 76, 0.4);
  border-radius: 50%;
  transition: transform 0.2s ease;
  padding: 15px;
}
@media (max-width: 1024px) {
  .activite-card__chevron {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .activite-card__chevron {
    padding: 10px;
  }
}

.activite-card__title-pill {
  position: absolute;
  left: 50%;
  bottom: 0;
  text-align: center;
  transform: translate(-50%, 50%);
  z-index: 12;
  pointer-events: none;
  display: inline-block;
  background-color: #FFFFFF;
  color: #4C4C4C;
  border-radius: 2rem;
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.05em;
  padding: 5px 20px;
  font-size: 1.2rem;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 1024px) {
  .activite-card__title-pill {
    padding: 3.75px 15px;
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .activite-card__title-pill {
    padding: 2.5px 10px;
    font-size: 0.95rem;
  }
}

.activite-card__content,
.activite-card .accordion__content {
  overflow: hidden;
  height: 0;
  transition: height 0.25s ease;
  border-radius: 0 0 50px 50px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.activite-card .accordion__content .activite-card__meta {
  padding: 50px 30px 0 30px;
}
@media (max-width: 1024px) {
  .activite-card .accordion__content .activite-card__meta {
    padding: 50px 20px 0 20px;
  }
}
@media (max-width: 768px) {
  .activite-card .accordion__content .activite-card__meta {
    padding: 50px 20px 0 20px;
  }
}

.activite-card__content .activite-card__desc,
.activite-card .accordion__content .activite-card__desc {
  border-radius: 0 0 50px 50px;
  padding: 30px;
}
@media (max-width: 1024px) {
  .activite-card__content .activite-card__desc,
.activite-card .accordion__content .activite-card__desc {
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .activite-card__content .activite-card__desc,
.activite-card .accordion__content .activite-card__desc {
    padding: 20px;
  }
}

.activite-card__meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #4C4C4C;
}

.activite-card__time {
  letter-spacing: 0.02em;
  display: flex;
  align-items: center;
}

.activite-card__desc {
  color: #4C4C4C;
  line-height: 1.6;
}

.activite-card.is-open .activite-card__chevron,
.activite-card.is-open .accordion__chevron {
  transform: rotate(180deg);
}

.accordion__chevron {
  transition: transform 0.2s ease;
}

.accordion__content {
  transition: height 0.25s ease;
  overflow: hidden;
}

.evenements {
  color: #4C4C4C;
}

.evenements__intro {
  color: #4C4C4C;
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .evenements__intro {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .evenements__intro {
    margin-bottom: 30px;
  }
}

.evenements__desc {
  max-inline-size: 90ch;
  margin-inline: auto;
  color: #4C4C4C;
  opacity: 0.85;
}

.evenements-board {
  border: 1px solid rgba(196, 196, 196, 0.42);
  border-radius: 12px;
  background-color: #FFFFFF;
  overflow: hidden;
}
@media (max-width: 768px) {
  .evenements-board {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

.evenements-row {
  display: grid;
  grid-template-columns: 1.2fr 2fr 1fr;
  align-items: center;
}
@media (max-width: 768px) {
  .evenements-row {
    min-width: 560px;
  }
}

.evenements-row:not(.evenements-row--head) {
  border-top: 1px solid rgba(196, 196, 196, 0.42);
  background-color: #FFFFFF;
}

.evenements-row:not(.evenements-row--head):hover {
  background-color: #FAFAF9;
}

.evenements-row--head {
  background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
  color: #FFFFFF;
}

.evenements-row--head .evenements-cell {
  font-weight: 700;
}

.evenements-cell {
  padding: 0.75rem 1rem;
  font-weight: 400;
}

.evenements-cell--title {
  font-weight: 600;
}

.instances-intro__container {
  position: relative;
  display: flex;
  border-radius: 15px;
  overflow: hidden;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 50px;
}
.instances-intro__container .instances-intro__image-mobile {
  display: none;
}
@media (max-width: 1024px) {
  .instances-intro__container {
    gap: 35px;
    flex-direction: column;
    align-items: stretch;
  }
  .instances-intro__container .instances-intro__image-desktop {
    display: none;
  }
  .instances-intro__container .instances-intro__image-mobile {
    position: absolute;
    inset: 0;
    display: block;
    z-index: 0;
    overflow: hidden;
  }
  .instances-intro__container .instances-intro__image-mobile::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(2px);
    z-index: 11;
  }
  .instances-intro__container .instances-intro__image-mobile img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }
}
@media (max-width: 768px) {
  .instances-intro__container {
    gap: 25px;
  }
}

.instances-intro__col--content {
  position: relative;
  z-index: 12;
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: 0;
}
@media (max-width: 1024px) {
  .instances-intro__col--content {
    inline-size: 100%;
    background-color: transparent;
    border-radius: 0;
    padding: 70px;
  }
}
@media (max-width: 768px) {
  .instances-intro__col--content {
    padding: 50px;
  }
}

.instances-intro__col--media {
  flex-grow: 0;
  flex-shrink: 0;
  flex-basis: auto;
}

.instances-intro__figure {
  display: block;
  overflow: hidden;
  border-radius: 15px;
}

.instances-intro__image {
  display: block;
  object-fit: cover;
  object-position: center;
  height: 450px;
  width: 450px;
}
@media (max-width: 1024px) {
  .instances-intro__image {
    height: 400px;
    width: 400px;
  }
}
@media (max-width: 768px) {
  .instances-intro__image {
    height: 400px;
    width: 400px;
  }
}

.instances-intro__header {
  text-align: start;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .instances-intro__header {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .instances-intro__header {
    margin-bottom: 8px;
  }
}

.instances-intro__title {
  color: #4C4C4C;
}

.instances-intro__body {
  color: #4C4C4C;
}

.instances-intro__text {
  color: #4C4C4C;
}

@media (max-width: 1024px) {
  .instances-intro__header,
.instances-intro__body {
    text-align: start;
  }

  .instances-intro__title,
.instances-intro__text {
    color: #FFFFFF;
  }
}
.instances {
  color: #4C4C4C;
}

.instances__list_intro {
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .instances__list_intro {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .instances__list_intro {
    margin-bottom: 30px;
  }
}

.instances__text {
  opacity: 0.85;
}

.instances__list {
  display: flex;
  flex-direction: column;
  gap: 50px;
}
@media (max-width: 1024px) {
  .instances__list {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .instances__list {
    gap: 25px;
  }
}

.instances-item {
  background-color: #FFFFFF;
  color: #4C4C4C;
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 0.8em 1.6em rgba(0, 0, 0, 0.06);
}

.instances-item__header {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  grid-template-columns: auto 1fr auto;
  cursor: pointer;
  border: 0;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.02) 100%);
  text-align: left;
  padding: 25px;
}
@media (max-width: 1024px) {
  .instances-item__header {
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .instances-item__header {
    padding: 15px;
  }
}

.instances-item__icon {
  height: 40px;
  width: 40px;
  object-fit: contain;
}
@media (max-width: 1024px) {
  .instances-item__icon {
    height: 35px;
    width: 35px;
  }
}
@media (max-width: 768px) {
  .instances-item__icon {
    height: 30px;
    width: 30px;
  }
}

.instances-item__title {
  margin: 0;
  color: #4C4C4C;
  font-weight: 600;
  font-size: 2rem;
}
@media (max-width: 1024px) {
  .instances-item__title {
    font-size: 1.5rem;
  }
}
@media (max-width: 768px) {
  .instances-item__title {
    font-size: 1rem;
  }
}

.instances-item__content {
  height: 0;
  overflow: hidden;
  transition: height 0.35s ease;
  opacity: 0;
}

.instances-item__desc {
  margin: 0 auto;
  padding-top: 0;
}

.instances-item__chevron {
  font-size: 1.5rem;
  line-height: 1;
  color: #4C4C4C;
  transition: transform 0.2s ease;
}

.instances-item .accordion__toggle[aria-expanded=true] .instances-item__chevron,
.instances-item.is-open .instances-item__chevron {
  transform: rotate(180deg);
}

.instances-item.is-open .instances-item__content {
  opacity: 1;
}

.tarifs-hero {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  inline-size: 100%;
  border-radius: 0 0 50px 50px;
  overflow: hidden;
  block-size: 80dvh;
  min-block-size: 300px;
  color: #FFFFFF;
}

.tarifs-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.tarifs-hero__img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.tarifs-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background-color: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(1.5px);
}

.tarifs-hero__inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  padding: 100px;
}
@media (max-width: 1024px) {
  .tarifs-hero__inner {
    gap: 30px;
    padding: 70px;
  }
}
@media (max-width: 768px) {
  .tarifs-hero__inner {
    gap: 20px;
    padding: 50px;
  }
}

.tarifs-hero__title {
  font-size: 3rem;
  font-weight: 800;
  color: #FFFFFF;
}
@media (max-width: 1024px) {
  .tarifs-hero__title {
    font-size: 2.8rem;
  }
}
@media (max-width: 768px) {
  .tarifs-hero__title {
    font-size: 2.6rem;
  }
}

.tarifs-hero__text {
  font-size: 1.2rem;
  color: #FFFFFF;
  max-inline-size: 70ch;
  margin-inline: auto;
}
@media (max-width: 1024px) {
  .tarifs-hero__text {
    font-size: 1rem;
    max-inline-size: 60ch;
  }
}
@media (max-width: 768px) {
  .tarifs-hero__text {
    font-size: 0.95rem;
    max-inline-size: 55ch;
  }
}

.tarifs__intro {
  color: #4C4C4C;
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .tarifs__intro {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .tarifs__intro {
    margin-bottom: 30px;
  }
}

.tarifs__text {
  opacity: 0.85;
  max-inline-size: 72ch;
  margin-inline: auto;
}

.tarifs__previews {
  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 1fr));
  gap: 28px;
}
@media (max-width: 900px) {
  .tarifs__previews {
    grid-template-columns: 1fr;
  }
}

.tarifs-card {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 22px;
  padding: 22px 22px 22px 18px;
  border-radius: 16px;
  background-color: #FFFFFF;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
  color: #4C4C4C;
  text-decoration: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.tarifs-card:hover {
  transform: translateY(-2px);
  box-shadow: rgba(0, 0, 0, 0.12) 0 12px 18px -3px, rgba(0, 0, 0, 0.06) 0 6px 10px -2px;
}
@media (max-width: 768px) {
  .tarifs-card {
    grid-template-columns: auto 1fr;
    grid-template-areas: "icon title" "icon desc" "cta  cta";
    row-gap: 10px;
  }
}

.tarifs-card__icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background-image: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  flex-shrink: 0;
}
.tarifs-card__icon .material-symbols-outlined {
  font-size: 28px;
  color: #FFFFFF;
}
@media (max-width: 768px) {
  .tarifs-card__icon {
    grid-area: icon;
  }
}

.tarifs-card__body {
  min-width: 0;
}
@media (max-width: 768px) {
  .tarifs-card__body {
    grid-area: title/title/desc/desc;
  }
}

.tarifs-card__title {
  margin: 0 0 6px 0;
  line-height: 1.2;
  color: #4C4C4C;
}

.tarifs-card__desc {
  margin: 0;
  opacity: 0.85;
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tarifs-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
  padding: 10px 14px;
  border-radius: 999px;
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  color: #FFFFFF;
  font-weight: 700;
  white-space: nowrap;
  transition: background 0.3s ease, color 0.3s ease-in-out;
}
.tarifs-card__cta .material-symbols-outlined {
  transition: transform 0.3s ease-in-out, color 0.3s ease-in-out;
}
@media (max-width: 768px) {
  .tarifs-card__cta {
    grid-area: cta;
    justify-self: start;
  }
}

.tarifs-card:hover .tarifs-card__cta {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.tarifs-card:hover .tarifs-card__cta .material-symbols-outlined {
  transform: translateX(5px);
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.tarifs-section {
  padding-bottom: 0;
}

.tarifs-section__intro {
  text-align: center;
  color: #4C4C4C;
  opacity: 0.85;
  max-inline-size: 70ch;
  margin-inline: auto;
  margin-top: 40px;
}
@media (max-width: 1024px) {
  .tarifs-section__intro {
    margin-top: 35px;
  }
}
@media (max-width: 768px) {
  .tarifs-section__intro {
    margin-top: 25px;
  }
}

.aides-intro__container {
  position: relative;
  display: flex;
  border-radius: 15px;
  overflow: hidden;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 50px;
}
.aides-intro__container .aides-intro__image-mobile {
  display: none;
}
@media (max-width: 1024px) {
  .aides-intro__container {
    gap: 35px;
    flex-direction: column;
    align-items: stretch;
  }
  .aides-intro__container .aides-intro__image-desktop {
    display: none;
  }
  .aides-intro__container .aides-intro__image-mobile {
    position: absolute;
    inset: 0;
    display: block;
    z-index: 0;
    overflow: hidden;
  }
  .aides-intro__container .aides-intro__image-mobile::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(2px);
    z-index: 11;
  }
  .aides-intro__container .aides-intro__image-mobile img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }
}
@media (max-width: 768px) {
  .aides-intro__container {
    gap: 25px;
  }
}

.aides-intro__col--content {
  position: relative;
  z-index: 12;
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: 0;
}
@media (max-width: 1024px) {
  .aides-intro__col--content {
    inline-size: 100%;
    background-color: transparent;
    border-radius: 0;
    padding: 70px;
  }
}
@media (max-width: 768px) {
  .aides-intro__col--content {
    padding: 50px;
  }
}

.aides-intro__col--media {
  flex-grow: 0;
  flex-shrink: 0;
  flex-basis: auto;
}

.aides-intro__figure {
  display: block;
  overflow: hidden;
  border-radius: 15px;
}

.aides-intro__image {
  display: block;
  object-fit: cover;
  object-position: center;
  height: 450px;
  width: 450px;
}
@media (max-width: 1024px) {
  .aides-intro__image {
    height: 400px;
    width: 400px;
  }
}
@media (max-width: 768px) {
  .aides-intro__image {
    height: 400px;
    width: 400px;
  }
}

.aides-intro__header {
  text-align: start;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .aides-intro__header {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .aides-intro__header {
    margin-bottom: 8px;
  }
}

.aides-intro__title {
  font-size: 3rem;
  color: #4C4C4C;
}
@media (max-width: 1024px) {
  .aides-intro__title {
    font-size: 2.8rem;
  }
}
@media (max-width: 768px) {
  .aides-intro__title {
    font-size: 2.6rem;
  }
}

.aides-intro__body {
  color: #4C4C4C;
}

.aides-intro__text {
  color: #4C4C4C;
}

@media (max-width: 1024px) {
  .aides-intro__header,
.aides-intro__body {
    text-align: start;
  }

  .aides-intro__title,
.aides-intro__text {
    color: #FFFFFF;
  }
}
.aides {
  color: #4C4C4C;
}

.aides__list_intro {
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .aides__list_intro {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .aides__list_intro {
    margin-bottom: 30px;
  }
}

.aides__text {
  opacity: 0.85;
}

.aides__list {
  display: flex;
  flex-direction: column;
  gap: 50px;
}
@media (max-width: 1024px) {
  .aides__list {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .aides__list {
    gap: 25px;
  }
}

.aides-item {
  background-color: #FFFFFF;
  color: #4C4C4C;
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 0.8em 1.6em rgba(0, 0, 0, 0.06);
}

.aides-item__header {
  width: 100%;
  grid-template-columns: auto 1fr auto;
  display: flex;
  justify-content: space-between;
  cursor: pointer;
  border: 0;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.02) 100%);
  text-align: left;
  padding: 25px;
}
@media (max-width: 1024px) {
  .aides-item__header {
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .aides-item__header {
    padding: 15px;
  }
}

.aides-item__icon {
  height: 40px;
  width: 40px;
  object-fit: contain;
}
@media (max-width: 1024px) {
  .aides-item__icon {
    height: 35px;
    width: 35px;
  }
}
@media (max-width: 768px) {
  .aides-item__icon {
    height: 30px;
    width: 30px;
  }
}

.aides-item__title {
  margin: 0;
  color: #4C4C4C;
  font-weight: 600;
  font-size: 2rem;
}
@media (max-width: 1024px) {
  .aides-item__title {
    font-size: 1.5rem;
  }
}
@media (max-width: 768px) {
  .aides-item__title {
    font-size: 1rem;
  }
}

.aides-item__content {
  height: 0;
  overflow: hidden;
  transition: height 0.35s ease;
  opacity: 0;
}

.aides-item__desc {
  margin: 0 auto;
  padding: 25px;
}
@media (max-width: 1024px) {
  .aides-item__desc {
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .aides-item__desc {
    padding: 15px;
  }
}

.aides-item__chevron {
  font-size: 1.5rem;
  line-height: 1;
  color: #4C4C4C;
  transition: transform 0.2s ease;
}

.aides-item .accordion__toggle[aria-expanded=true] .aides-item__chevron,
.aides-item.is-open .aides-item__chevron {
  transform: rotate(180deg);
}

.aides-item.is-open .aides-item__content {
  opacity: 1;
}

.procedures-intro__container {
  position: relative;
  display: flex;
  border-radius: 15px;
  overflow: hidden;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 50px;
}
.procedures-intro__container .procedures-intro__image-mobile {
  display: none;
}
@media (max-width: 1024px) {
  .procedures-intro__container {
    gap: 35px;
    flex-direction: column;
    align-items: stretch;
  }
  .procedures-intro__container .procedures-intro__image-desktop {
    display: none;
  }
  .procedures-intro__container .procedures-intro__image-mobile {
    position: absolute;
    inset: 0;
    display: block;
    z-index: 0;
    overflow: hidden;
  }
  .procedures-intro__container .procedures-intro__image-mobile::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(2px);
    z-index: 11;
  }
  .procedures-intro__container .procedures-intro__image-mobile img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }
}
@media (max-width: 768px) {
  .procedures-intro__container {
    gap: 25px;
  }
}

.procedures-intro__col--content {
  position: relative;
  z-index: 12;
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: 0;
}
@media (max-width: 1024px) {
  .procedures-intro__col--content {
    inline-size: 100%;
    background-color: transparent;
    border-radius: 0;
    padding: 70px;
  }
}
@media (max-width: 768px) {
  .procedures-intro__col--content {
    padding: 50px;
  }
}

.procedures-intro__col--media {
  flex-grow: 0;
  flex-shrink: 0;
  flex-basis: auto;
}

.procedures-intro--reversed .procedures-intro__container {
  flex-direction: row-reverse;
}

.procedures-intro__figure {
  display: block;
  overflow: hidden;
  border-radius: 15px;
}

.procedures-intro__image {
  display: block;
  object-fit: cover;
  object-position: center;
  height: 450px;
  width: 450px;
}
@media (max-width: 1024px) {
  .procedures-intro__image {
    height: 400px;
    width: 400px;
  }
}
@media (max-width: 768px) {
  .procedures-intro__image {
    height: 400px;
    width: 400px;
  }
}

.procedures-intro__header {
  text-align: start;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .procedures-intro__header {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .procedures-intro__header {
    margin-bottom: 8px;
  }
}

.procedures-intro__title {
  font-size: 3rem;
  color: #4C4C4C;
}
@media (max-width: 1024px) {
  .procedures-intro__title {
    font-size: 2.8rem;
  }
}
@media (max-width: 768px) {
  .procedures-intro__title {
    font-size: 2.6rem;
  }
}

.procedures-intro__body,
.procedures-intro__text {
  color: #4C4C4C;
}

@media (max-width: 1024px) {
  .procedures-intro__header,
.procedures-intro__body {
    text-align: start;
  }

  .procedures-intro__title,
.procedures-intro__text {
    color: #FFFFFF;
  }
}
.procedures__list_intro {
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .procedures__list_intro {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .procedures__list_intro {
    margin-bottom: 30px;
  }
}

.procedures__title {
  color: #4C4C4C;
  font-size: 2.25rem;
}
@media (max-width: 1024px) {
  .procedures__title {
    font-size: 1.75rem;
  }
}
@media (max-width: 768px) {
  .procedures__title {
    font-size: 1.25rem;
  }
}

.procedures__text {
  opacity: 0.85;
}

.procedures__container {
  margin-bottom: 100px;
}
@media (max-width: 1024px) {
  .procedures__container {
    margin-bottom: 75px;
  }
}
@media (max-width: 768px) {
  .procedures__container {
    margin-bottom: 50px;
  }
}

.procedures__list {
  position: relative;
  isolation: isolate;
  list-style: none;
  padding: 0 0 0 92px;
  margin: 0 auto;
  max-width: 920px;
}
.procedures__list::before {
  content: "";
  position: absolute;
  left: 40px;
  top: 28px;
  bottom: 28px;
  width: 2px;
  background: rgba(169, 203, 183, 0.22);
  border-radius: 2px;
  z-index: 0;
}
.procedures__list::after {
  content: "";
  position: absolute;
  left: 40px;
  top: 28px;
  bottom: 28px;
  width: 2px;
  background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
  transform-origin: top center;
  transform: scaleY(var(--timeline-progress, 0));
  border-radius: 2px;
  pointer-events: none;
  z-index: 0;
}
@media (max-width: 1024px) {
  .procedures__list {
    padding-left: 80px;
  }
  .procedures__list::before, .procedures__list::after {
    left: 34px;
  }
}
@media (max-width: 768px) {
  .procedures__list {
    padding-left: 68px;
  }
  .procedures__list::before, .procedures__list::after {
    left: 28px;
  }
}

.procedures__item {
  position: relative;
  z-index: 1;
  margin-bottom: 50px;
  transition: opacity 0.45s ease, transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.procedures__item:last-child {
  margin-bottom: 0;
}
.procedures__item.is-future {
  opacity: 0.38;
  transform: translateY(14px);
}
.procedures__item.is-active {
  opacity: 1;
  transform: translateY(0);
}
.procedures__item.is-active .procedure-card {
  box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px, 0 0 0 3px rgba(169, 203, 183, 0.22);
}
.procedures__item.is-active .procedure-card::before {
  background: rgba(169, 203, 183, 0.85);
}
.procedures__item.is-active .procedure-card__step {
  background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
  box-shadow: rgba(169, 203, 183, 0.2) 0px 0px 0px 4px, rgba(0, 0, 0, 0.12) 0px 5px 8px -2px;
  transform: scale(1.12);
}
.procedures__item.is-past {
  opacity: 0.58;
  transform: translateY(0);
}
.procedures__item.is-past .procedure-card__step {
  background: rgba(169, 203, 183, 0.62);
  box-shadow: none;
}
@media (max-width: 768px) {
  .procedures__item {
    margin-bottom: 40px;
  }
}

.procedure-card__step.is-pinging {
  animation: step-ping 1.8s ease-out forwards;
}

@keyframes step-ping {
  0% {
    box-shadow: rgba(169, 203, 183, 0.2) 0px 0px 0px 4px, rgba(0, 0, 0, 0.12) 0px 5px 8px -2px, 0 0 0 0px rgba(169, 203, 183, 0.55);
  }
  55% {
    box-shadow: rgba(169, 203, 183, 0.2) 0px 0px 0px 4px, rgba(0, 0, 0, 0.12) 0px 5px 8px -2px, 0 0 0 18px rgba(169, 203, 183, 0);
  }
  100% {
    box-shadow: rgba(169, 203, 183, 0.2) 0px 0px 0px 4px, rgba(0, 0, 0, 0.12) 0px 5px 8px -2px;
  }
}
.procedures .procedure-card {
  position: relative;
  background: #FFFFFF;
  border-radius: 15px;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
  border-left: none;
  padding: 40px 50px;
  color: #4C4C4C;
  transition: box-shadow 0.2s ease, border-left-color 0.2s ease;
}
.procedures .procedure-card::before {
  content: "";
  position: absolute;
  left: -24px;
  top: 45px;
  width: 24px;
  height: 2px;
  background: rgba(169, 203, 183, 0.4);
  transition: background 0.2s ease;
}
@media (max-width: 1024px) {
  .procedures .procedure-card {
    padding: 35px 40px;
  }
  .procedures .procedure-card::before {
    left: -20px;
    top: 37px;
    width: 20px;
  }
}
@media (max-width: 768px) {
  .procedures .procedure-card {
    padding: 25px 35px;
  }
  .procedures .procedure-card::before {
    left: -16px;
    top: 31px;
    width: 16px;
  }
}

.procedures .procedure-card__step {
  position: absolute;
  left: -80px;
  top: 18px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  color: #FFFFFF;
  font-weight: 700;
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  transition: box-shadow 0.2s ease, transform 0.2s ease, background 0.2s ease;
  z-index: 2;
}
@media (max-width: 1024px) {
  .procedures .procedure-card__step {
    left: -68px;
    top: 14px;
    width: 48px;
    height: 48px;
  }
}
@media (max-width: 768px) {
  .procedures .procedure-card__step {
    left: -56px;
    top: 12px;
    width: 40px;
    height: 40px;
    font-size: 0.95rem;
  }
}

.procedures .procedure-card__header {
  display: block;
  margin-bottom: 25px;
}

.procedures .procedure-card__title {
  color: #4C4C4C;
  font-weight: 700;
  margin: 0;
  line-height: 1.25;
}

.procedures .procedure-card__body {
  color: #4C4C4C;
  display: flex;
  flex-direction: column;
}

.procedures .procedure-card__content {
  margin-bottom: 25px;
  opacity: 0.88;
  line-height: 1.7;
}
.procedures .procedure-card__content.ql-editor {
  padding: 0;
}

.procedures .procedure-card__attachments {
  border-top: 1px solid rgba(169, 203, 183, 0.25);
  padding-top: 25px;
  margin-top: 20px;
  width: 100%;
}

.procedures .procedure-card__attachments-title {
  font-size: 0.8rem;
  color: #4C4C4C;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  opacity: 0.55;
  margin-bottom: 20px;
}
@media (max-width: 1024px) {
  .procedures .procedure-card__attachments-title {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .procedures .procedure-card__attachments-title {
    margin-bottom: 8px;
  }
}

.procedures .procedure-card__attachments-list {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 8px;
}
@media (max-width: 1024px) {
  .procedures .procedure-card__attachments-list {
    gap: 6px;
  }
}

.procedures .procedure-card__attachments-item {
  display: flex;
}

.procedures .procedure-card__attachments-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  background: rgba(169, 203, 183, 0.1);
  border: 1px solid rgba(169, 203, 183, 0.3);
  border-radius: 8px;
  color: #4C4C4C;
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 600;
  transition: background 0.15s ease-in-out, border-color 0.15s ease-in-out, color 0.15s ease-in-out;
}
.procedures .procedure-card__attachments-link .material-symbols-outlined {
  font-size: 1.05rem;
}
.procedures .procedure-card__attachments-link:hover, .procedures .procedure-card__attachments-link:focus {
  background: #A9CBB7;
  border-color: #A9CBB7;
  color: #FFFFFF;
}
@media (max-width: 1024px) {
  .procedures .procedure-card__attachments-link {
    font-size: 0.8rem;
    padding: 6px 10px;
  }
}
@media (max-width: 768px) {
  .procedures .procedure-card__attachments-link {
    font-size: 0.8rem;
    padding: 6px 8px;
  }
}

.procedures .procedure-card__attachments-link-content {
  display: flex;
  align-items: center;
  gap: 6px;
}

.procedures .procedure-card__attachments-label {
  margin-inline-end: 6px;
}

.procedures .procedure-card__attachments-meta {
  opacity: 0.65;
}

.procedures-progress {
  position: sticky;
  top: 84px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #FFFFFF;
  border: 1px solid rgba(169, 203, 183, 0.4);
  border-radius: 50px;
  padding: 7px 16px 7px 12px;
  font-size: 0.95rem;
  font-weight: 600;
  color: #4C4C4C;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
  z-index: 10;
  margin-bottom: 50px;
  white-space: nowrap;
  user-select: none;
  pointer-events: none;
}
.procedures-progress .material-symbols-outlined {
  font-size: 1.1rem;
  color: #A9CBB7;
}
.procedures-progress__current {
  color: #7EBF8D;
  font-weight: 700;
  font-size: 1.05rem;
  min-width: 1.5ch;
  text-align: center;
}
.procedures-progress__sep, .procedures-progress__total {
  opacity: 0.55;
}

.livrets-flex {
  display: flex;
  flex-wrap: wrap;
  gap: 35px;
  margin-top: 40px;
}
@media (max-width: 1024px) {
  .livrets-flex {
    gap: 25px;
    margin-top: 35px;
  }
}
@media (max-width: 768px) {
  .livrets-flex {
    flex-direction: column;
    gap: 20px;
    margin-top: 25px;
  }
}

.livret-card {
  display: flex;
  align-items: stretch;
  flex: 0 1 calc(50% - 35px / 2);
  min-width: 260px;
  background: #FFFFFF;
  border: 1px solid rgba(170, 200, 206, 0.25);
  border-radius: 10px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
  overflow: hidden;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}
@media (max-width: 768px) {
  .livret-card {
    flex: 1 1 100%;
  }
}
.livret-card:hover {
  box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  transform: translateY(-2px);
}

.livret-card__icon {
  flex-shrink: 0;
  width: 58px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(90deg, #7EBF8D, #A9CBB7);
  color: #FFFFFF;
}
.livret-card__icon .material-symbols-outlined {
  font-size: 1.6rem;
}
@media (max-width: 1024px) {
  .livret-card__icon {
    width: 50px;
  }
}
@media (max-width: 768px) {
  .livret-card__icon {
    width: 46px;
  }
}

.livret-card__info {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 3px;
  padding: 15px 10px;
  min-width: 0;
}

.livret-card__titre {
  font-weight: 600;
  font-size: 0.95rem;
  color: #4C4C4C;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 768px) {
  .livret-card__titre {
    font-size: 0.8rem;
  }
}

.livret-card__badge {
  font-size: 0.8rem;
  font-weight: 700;
  color: #7EBF8D;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.livret-card__actions {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 15px;
  border-left: 1px solid rgba(170, 200, 206, 0.25);
}

.livret-card__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  text-decoration: none;
  color: #4C4C4C;
  transition: background 0.15s ease-in-out, color 0.15s ease-in-out;
}
.livret-card__btn .material-symbols-outlined {
  font-size: 1.25rem;
}
.livret-card__btn--view:hover {
  background: rgba(169, 203, 183, 0.18);
  color: #7EBF8D;
}
.livret-card__btn--download:hover {
  background: rgba(126, 191, 141, 0.12);
  color: #7EBF8D;
}

.procedures__intro {
  color: #4C4C4C;
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .procedures__intro {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .procedures__intro {
    margin-bottom: 30px;
  }
}

.procedures__workflow {
  margin: 0 auto 40px;
}

.procedures__step {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 24px;
}
@media (max-width: 768px) {
  .procedures__step {
    grid-template-columns: 50px 1fr;
    gap: 18px;
  }
}

.procedures__step-indicator {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 8px;
}

.procedures__step-dot {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #FFFFFF;
  border: 3px solid #A9CBB7;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  z-index: 12;
  position: relative;
  flex-shrink: 0;
  animation: dotPulseVertical 12s ease-in-out infinite;
}

.procedures__step:nth-child(1) .procedures__step-dot {
  animation-delay: 0s;
}

.procedures__step:nth-child(2) .procedures__step-dot {
  animation-delay: 3s;
}

.procedures__step:nth-child(3) .procedures__step-dot {
  animation-delay: 6s;
}

.procedures__step:nth-child(4) .procedures__step-dot {
  animation-delay: 9s;
}

@keyframes dotPulseVertical {
  0%, 6% {
    background: #FFFFFF;
    border-color: #A9CBB7;
    transform: scale(1);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  }
  8% {
    background: #FFFFFF;
    border-color: #A9CBB7;
    transform: scale(1.05);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  }
  10%, 14% {
    background: #7EBF8D;
    border-color: #7EBF8D;
    transform: scale(1.15);
    box-shadow: rgba(126, 191, 141, 0.4) 0px 0px 0px 8px, rgba(0, 0, 0, 0.15) 0px 6px 12px -2px;
  }
  16% {
    background: #7EBF8D;
    border-color: #7EBF8D;
    transform: scale(1.05);
    box-shadow: rgba(126, 191, 141, 0.2) 0px 0px 0px 4px, rgba(0, 0, 0, 0.12) 0px 5px 10px -2px;
  }
  18%, 100% {
    background: #FFFFFF;
    border-color: #A9CBB7;
    transform: scale(1);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  }
}
.procedures__step-line {
  width: 3px;
  flex: 1;
  background: rgba(169, 203, 183, 0.3);
  margin-top: 8px;
  position: relative;
  overflow: hidden;
}
.procedures__step-line::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 0%;
  background: #A9CBB7;
  animation: lineProgress 12s ease-in-out infinite;
}

.procedures__step:nth-child(1) .procedures__step-line::before {
  animation-delay: 0s;
}

.procedures__step:nth-child(2) .procedures__step-line::before {
  animation-delay: 3s;
}

.procedures__step:nth-child(3) .procedures__step-line::before {
  animation-delay: 6s;
}

@keyframes lineProgress {
  0%, 10% {
    height: 0%;
  }
  24%, 91.66% {
    height: 100%;
  }
  91.67%, 100% {
    height: 0%;
  }
}
.procedures__step--last .procedures__step-line {
  display: none;
}

.procedures__step-content {
  padding: 8px 0 40px 0;
}
@media (max-width: 768px) {
  .procedures__step-content {
    padding: 4px 0 32px 0;
  }
}

.procedures__step-title {
  margin: 0 0 8px 0;
  color: #4C4C4C;
}

.procedures__step-desc {
  margin: 0;
  opacity: 0.85;
  color: #4C4C4C;
}

.procedures__cta-wrapper {
  display: flex;
  justify-content: center;
  margin-top: 50px;
}
@media (max-width: 1024px) {
  .procedures__cta-wrapper {
    margin-top: 45px;
  }
}
@media (max-width: 768px) {
  .procedures__cta-wrapper {
    margin-top: 40px;
  }
}

.procedures__cta {
  border-radius: 50px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  color: #FFFFFF;
  background-image: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  text-decoration: none;
  gap: 15px;
  padding: 15px;
  transition: background 0.3s ease, color 0.3s ease-in-out;
}
@media (max-width: 1024px) {
  .procedures__cta {
    gap: 12.5px;
    padding: 12px;
  }
}
@media (max-width: 768px) {
  .procedures__cta {
    gap: 10px;
    padding: 10px;
  }
}
.procedures__cta span {
  transition: transform 0.3s ease-in-out;
}
.procedures__cta .material-symbols-outlined {
  transition: transform 0.3s ease-in-out, color 0.3s ease-in-out;
}
.procedures__cta:hover {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}
.procedures__cta:hover .material-symbols-outlined {
  transform: translateX(5px);
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

@media (prefers-reduced-motion: reduce) {
  .procedures__step-dot,
.procedures__step-line::before {
    animation: none;
  }

  .procedures__item,
.procedures__item.is-future,
.procedures__item.is-active,
.procedures__item.is-past {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .procedures__list::after {
    display: none;
  }

  .procedures .procedure-card__step {
    transition: none;
  }

  .procedure-card__step.is-pinging {
    animation: none;
  }
}
.doc-accueil__intro {
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .doc-accueil__intro {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .doc-accueil__intro {
    margin-bottom: 30px;
  }
}

.doc-accueil__title {
  color: #4C4C4C;
}

.doc-accueil__text {
  opacity: 0.85;
  max-inline-size: 70ch;
  margin-inline: auto;
}

.doc-accueil__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 1fr));
  gap: 28px;
}
@media (max-width: 900px) {
  .doc-accueil__grid {
    grid-template-columns: 1fr;
  }
}

.doc-accueil__card {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: 1fr auto;
  grid-template-areas: "icon body" "icon cta";
  align-items: start;
  gap: 35px 50px;
  padding: 50px 40px;
  border-radius: 15px;
  background-color: #FFFFFF;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
  text-decoration: none;
  color: #4C4C4C;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.doc-accueil__card:hover {
  transform: translateY(-2px);
  box-shadow: rgba(0, 0, 0, 0.12) 0 12px 18px -3px, rgba(0, 0, 0, 0.06) 0 6px 10px -2px;
}
@media (max-width: 1024px) {
  .doc-accueil__card {
    padding: 40px 35px;
    gap: 25px 40px;
  }
}
@media (max-width: 768px) {
  .doc-accueil__card {
    padding: 35px 25px;
    gap: 20px 35px;
  }
}

.doc-accueil__card-icon {
  grid-area: icon;
  align-self: start;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background-image: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  flex-shrink: 0;
}
.doc-accueil__card-icon .material-symbols-outlined {
  font-size: 28px;
  color: #FFFFFF;
}
@media (max-width: 768px) {
  .doc-accueil__card-icon {
    width: 44px;
    height: 44px;
  }
  .doc-accueil__card-icon .material-symbols-outlined {
    font-size: 22px;
  }
}

.doc-accueil__card-body {
  grid-area: body;
  min-width: 0;
}

.doc-accueil__card-title {
  font-size: 2rem;
  font-weight: 700;
  color: #4C4C4C;
  margin: 0 0 10px;
}
@media (max-width: 1024px) {
  .doc-accueil__card-title {
    font-size: 1.5rem;
  }
}
@media (max-width: 768px) {
  .doc-accueil__card-title {
    font-size: 1rem;
  }
}

.doc-accueil__card-desc {
  margin: 0;
  opacity: 0.8;
}

.doc-accueil__card-highlight {
  color: #7EBF8D;
  font-weight: 700;
}

.doc-accueil__card-cta {
  grid-area: cta;
  justify-self: end;
  border-radius: 50px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  color: #FFFFFF;
  background-image: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  text-decoration: none;
  gap: 15px;
  padding: 15px;
  margin-top: 10px;
  transition: background 0.3s ease, color 0.3s ease-in-out;
}
@media (max-width: 1024px) {
  .doc-accueil__card-cta {
    gap: 12.5px;
    padding: 12px;
  }
}
@media (max-width: 768px) {
  .doc-accueil__card-cta {
    gap: 10px;
    padding: 10px;
  }
}
.doc-accueil__card-cta span {
  transition: transform 0.3s ease-in-out;
}
.doc-accueil__card-cta .material-symbols-outlined {
  transition: transform 0.3s ease-in-out, color 0.3s ease-in-out;
}
.doc-accueil__card:hover .doc-accueil__card-cta {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}
.doc-accueil__card:hover .doc-accueil__card-cta .material-symbols-outlined {
  transform: translateX(5px);
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.recrutement-hero {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  inline-size: 100%;
  border-radius: 0 0 50px 50px;
  overflow: hidden;
  block-size: 80dvh;
  min-block-size: 300px;
  color: #FFFFFF;
}

.recrutement-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.recrutement-hero__img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.recrutement-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background-color: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(1.5px);
}

.recrutement-hero__inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  padding: 100px;
}
@media (max-width: 1024px) {
  .recrutement-hero__inner {
    gap: 30px;
    padding: 70px;
  }
}
@media (max-width: 768px) {
  .recrutement-hero__inner {
    gap: 20px;
    padding: 50px;
  }
}

.recrutement-hero__title {
  font-size: 3rem;
  font-weight: 800;
  color: #FFFFFF;
}
@media (max-width: 1024px) {
  .recrutement-hero__title {
    font-size: 2.8rem;
  }
}
@media (max-width: 768px) {
  .recrutement-hero__title {
    font-size: 2.6rem;
  }
}

.recrutement-hero__text {
  font-size: 1.2rem;
  color: #FFFFFF;
  max-inline-size: 70ch;
  margin-inline: auto;
}
@media (max-width: 1024px) {
  .recrutement-hero__text {
    font-size: 1rem;
    max-inline-size: 60ch;
  }
}
@media (max-width: 768px) {
  .recrutement-hero__text {
    font-size: 0.95rem;
    max-inline-size: 55ch;
  }
}

.recrutement {
  --stick-offset: 0px;
  color: #4C4C4C;
}

.recrutement__container {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  align-items: start;
  gap: 50px;
}
@media (max-width: 1024px) {
  .recrutement__container {
    gap: 35px;
    grid-template-columns: 1fr;
  }
}
@media (max-width: 768px) {
  .recrutement__container {
    gap: 25px;
  }
}

.recrutement__sidebar {
  position: sticky;
  top: var(--stick-offset);
  align-self: start;
  max-block-size: calc(100vh - var(--stick-offset));
  overflow: visible;
  overscroll-behavior: contain;
  min-block-size: 0;
  display: flex;
  flex-direction: column;
  gap: 50px;
  padding: 40px;
}
@media (max-width: 1024px) {
  .recrutement__sidebar {
    gap: 35px;
    padding: 30px;
    position: static;
    max-block-size: none;
    overflow: visible;
    overscroll-behavior: auto;
  }
}
@media (max-width: 768px) {
  .recrutement__sidebar {
    gap: 25px;
    padding: 20px;
  }
}

.recrutement__list-wrapper {
  overflow: auto;
  flex: 1;
  mask-image: linear-gradient(to bottom, black 0%, black calc(100% - 64px), rgba(0, 0, 0, 0) 100%);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}

.recrutement__sidebar .search-container {
  position: sticky;
  top: 0;
  z-index: 5;
  justify-content: center;
}

.recrutement__sidebar .search-input {
  flex-basis: 600px;
  padding: 8px;
}
@media (max-width: 1024px) {
  .recrutement__sidebar .search-input {
    padding: 7px;
    flex-basis: 550px;
  }
}
@media (max-width: 768px) {
  .recrutement__sidebar .search-input {
    padding: 6px;
    flex-basis: 500px;
  }
}

.recrutement__detail {
  position: sticky;
  top: 0;
  align-self: start;
  padding-bottom: 50px;
}
@media (max-width: 1024px) {
  .recrutement__detail {
    padding-bottom: 40px;
    position: static;
    max-block-size: none;
    overflow: visible;
    overscroll-behavior: auto;
  }
}
@media (max-width: 768px) {
  .recrutement__detail {
    padding-bottom: 30px;
  }
}

.recrutement__detail-inner {
  background-color: #FFFFFF;
  border-radius: 15px;
  min-block-size: 100dvh;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.recrutement__search {
  background-color: #FFFFFF;
  border-radius: 15px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 25px;
}
@media (max-width: 1024px) {
  .recrutement__search {
    gap: 8px;
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .recrutement__search {
    gap: 6px;
    padding: 15px;
  }
}

.recrutement__search-label {
  display: inline-flex;
  align-items: center;
  color: #4C4C4C;
}

.recrutement__search-input {
  inline-size: 100%;
  background-color: #FFFFFF;
  border: 1px solid #FAFAF9;
  border-radius: 12px;
  font-size: 1.2rem;
  padding: 15px;
}
@media (max-width: 1024px) {
  .recrutement__search-input {
    padding: 12.5px;
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .recrutement__search-input {
    padding: 10px;
    font-size: 0.95rem;
  }
}
.recrutement__search-input:focus {
  outline: none;
  border-color: #A9CBB7;
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.02);
}

.recrutement__filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
@media (max-width: 1024px) {
  .recrutement__filters {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .recrutement__filters {
    gap: 6px;
  }
}

.recrutement__filter {
  display: inline-flex;
  align-items: center;
  color: #4C4C4C;
}

.recrutement__select {
  background-color: #FFFFFF;
  border: 1px solid #FAFAF9;
  border-radius: 10px;
  font-size: 1.2rem;
  padding: 15px;
}
@media (max-width: 1024px) {
  .recrutement__select {
    padding: 12.5px;
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .recrutement__select {
    padding: 10px;
    font-size: 0.95rem;
  }
}

.recrutement__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 50px;
}
@media (max-width: 1024px) {
  .recrutement__list {
    gap: 35px;
  }
}
@media (max-width: 768px) {
  .recrutement__list {
    gap: 25px;
  }
}

.recrutement__item {
  display: block;
}

.job-card {
  inline-size: 100%;
  text-align: start;
  background-color: #FFFFFF;
  color: #4C4C4C;
  border: 1px solid transparent;
  border-radius: 15px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 25px;
}
@media (max-width: 1024px) {
  .job-card {
    padding: 20px;
    gap: 10px;
  }
}
@media (max-width: 768px) {
  .job-card {
    padding: 15px;
    gap: 8px;
  }
}
.job-card:focus {
  outline: none;
  border-color: #A9CBB7;
}
.job-card.is-active {
  border-color: #A9CBB7;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.06);
  background-color: #FFFFFF;
}

.job-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 16px;
}
@media (max-width: 1024px) {
  .job-card__header {
    gap: 8px;
    margin-bottom: 12px;
  }
}
@media (max-width: 768px) {
  .job-card__header {
    gap: 6px;
    margin-bottom: 8px;
  }
}

.job-card__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 15px;
  border: 1px solid #A9CBB7;
  color: #A9CBB7;
  font-size: 0.8rem;
  font-weight: 600;
  padding: 8px;
}
@media (max-width: 1024px) {
  .job-card__badge {
    font-size: 0.7rem;
    padding: 7px;
  }
}
@media (max-width: 768px) {
  .job-card__badge {
    font-size: 0.6rem;
    padding: 6px;
  }
}

.job-card__title {
  margin: 0;
  font-weight: 700;
  outline: none;
  color: #4C4C4C;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1 1 auto;
  font-size: 2rem;
}
@media (max-width: 1024px) {
  .job-card__title {
    font-size: 1.5rem;
  }
}
@media (max-width: 768px) {
  .job-card__title {
    font-size: 1rem;
  }
}

.job-card__meta {
  display: inline-flex;
  align-items: center;
  color: #4C4C4C;
  opacity: 0.9;
}

.job-card__salary {
  font-size: 1.2rem;
  font-weight: 600;
}
@media (max-width: 1024px) {
  .job-card__salary {
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .job-card__salary {
    font-size: 0.95rem;
  }
}

.job-card__excerpt {
  margin-bottom: 15px;
  font-size: 1.2rem;
}
.job-card__excerpt .quill-content {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  hyphens: auto;
  overflow-wrap: break-word;
  word-break: break-word;
}
@media (max-width: 1024px) {
  .job-card__excerpt {
    margin-bottom: 12.5px;
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .job-card__excerpt {
    margin-bottom: 10px;
    font-size: 0.95rem;
  }
}

.job-card__meta,
.job-card__excerpt {
  display: block;
  min-inline-size: 0;
}

.job-card__label-description {
  display: block;
}

.job-card__label-description .quill-content {
  overflow: hidden;
  text-overflow: ellipsis;
}

.job-card__footer {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .job-card__footer {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .job-card__footer {
    margin-bottom: 8px;
  }
}

.job-card__apply {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  background-color: #A9CBB7;
  color: #FFFFFF;
  border: 1px solid #A9CBB7;
  border-radius: 999px;
  font-weight: 700;
  font-size: 1.2rem;
  gap: 15px;
  padding: 15px;
}
@media (max-width: 1024px) {
  .job-card__apply {
    font-size: 1rem;
    gap: 12.5px;
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .job-card__apply {
    font-size: 0.95rem;
    gap: 10px;
    padding: 10px;
  }
}
.job-card__apply:hover, .job-card__apply:focus {
  opacity: 0.92;
}

.job-detail__apply-banner {
  display: none;
  padding: 25px 25px 0 25px;
}
@media (max-width: 1024px) {
  .job-detail__apply-banner {
    position: sticky;
    bottom: 0;
    width: 100%;
    background-color: #FFFFFF;
    border-top: 2px solid #A9CBB7;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px 20px 0 20px;
  }
}
@media (max-width: 768px) {
  .job-detail__apply-banner {
    padding: 15px 15px 0 15px;
  }
}

.job-detail__apply {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: #A9CBB7;
  border: 1px solid #A9CBB7;
  border-radius: 999px;
  font-weight: 700;
  font-size: 1.2rem;
  gap: 15px;
  padding: 15px;
}
@media (max-width: 1024px) {
  .job-detail__apply {
    font-size: 1rem;
    gap: 12.5px;
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .job-detail__apply {
    font-size: 0.95rem;
    gap: 10px;
    padding: 10px;
  }
}
.job-detail__apply:hover, .job-detail__apply:focus {
  opacity: 0.92;
}

.job-detail__header {
  margin-bottom: 16px;
}
@media (max-width: 1024px) {
  .job-detail__header {
    margin-bottom: 12px;
  }
}
@media (max-width: 768px) {
  .job-detail__header {
    margin-bottom: 8px;
  }
}

.job-detail__title {
  margin: 0;
  outline: none;
  color: #4C4C4C;
  font-weight: 700;
  overflow-wrap: normal;
  word-break: normal;
  -webkit-hyphens: auto;
  -ms-hyphens: auto;
  hyphens: auto;
}

.job-detail__infos {
  display: flex;
  flex-direction: column;
}

.job-detail__row {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
@media (max-width: 1024px) {
  .job-detail__row {
    gap: 8px;
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .job-detail__row {
    gap: 6px;
    margin-bottom: 8px;
  }
}

.job-detail__row--block {
  align-items: start;
}

.job-detail__column {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.job-detail__column--block {
  align-items: start;
}

.job-detail__label {
  font-size: 1.2rem;
  font-weight: 600;
  color: #4C4C4C;
  text-transform: none;
  white-space: nowrap;
}
@media (max-width: 1024px) {
  .job-detail__label {
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .job-detail__label {
    font-size: 0.95rem;
  }
}

.job-detail__content {
  hyphens: auto;
  overflow-wrap: break-word;
  word-break: break-word;
}

.job-detail__value {
  font-size: 1.2rem;
  color: #4C4C4C;
}
@media (max-width: 1024px) {
  .job-detail__value {
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .job-detail__value {
    font-size: 0.95rem;
  }
}

.job-detail__chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 15px;
  border: 1px solid #FAFAF9;
  background: transparent;
  color: #4C4C4C;
  font-weight: 600;
  padding: 8px;
}
@media (max-width: 1024px) {
  .job-detail__chip {
    padding: 7px;
  }
}
@media (max-width: 768px) {
  .job-detail__chip {
    padding: 6px;
  }
}

.job-detail__chip--contrat {
  border-color: #A9CBB7;
  color: #A9CBB7;
}

.job-detail__body {
  margin-bottom: 40px;
}
@media (max-width: 1024px) {
  .job-detail__body {
    margin-bottom: 35px;
  }
}
@media (max-width: 768px) {
  .job-detail__body {
    margin-bottom: 30px;
  }
}

.job-detail__body .job-detail__content > *:last-child {
  margin-bottom: 0;
}

.job-detail__body .job-detail__content ul,
.job-detail__body .job-detail__content ol {
  padding-inline-start: 1.25em;
}

.recrutement__intro {
  color: #4C4C4C;
  text-align: center;
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  .recrutement__intro {
    margin-bottom: 40px;
  }
}
@media (max-width: 768px) {
  .recrutement__intro {
    margin-bottom: 30px;
  }
}

.recrutement__text {
  opacity: 0.85;
  max-inline-size: 72ch;
  margin-inline: auto;
}

.recrutement__workflow {
  margin: 0 auto 40px;
}

.recrutement__step {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 24px;
}
@media (max-width: 768px) {
  .recrutement__step {
    grid-template-columns: 50px 1fr;
    gap: 18px;
  }
}

.recrutement__step-indicator {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 8px;
}

.recrutement__step-number {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-weight: 700;
  color: #FFFFFF;
  background-image: linear-gradient(135deg, #F7E1D7, #A9CBB7);
  box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  z-index: 12;
  position: relative;
  flex-shrink: 0;
  animation: numberPulseVertical 9s ease-in-out infinite;
}
@media (max-width: 768px) {
  .recrutement__step-number {
    width: 32px;
    height: 32px;
    font-size: 0.9rem;
  }
}

.recrutement__step:nth-child(1) .recrutement__step-number {
  animation-delay: 0s;
}

.recrutement__step:nth-child(2) .recrutement__step-number {
  animation-delay: 3s;
}

.recrutement__step:nth-child(3) .recrutement__step-number {
  animation-delay: 6s;
}

@keyframes numberPulseVertical {
  0%, 8% {
    transform: scale(1);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  }
  11% {
    transform: scale(1.05);
    box-shadow: rgba(169, 203, 183, 0.2) 0px 0px 0px 4px, rgba(0, 0, 0, 0.12) 0px 5px 8px -2px;
  }
  13%, 18% {
    transform: scale(1.15);
    box-shadow: rgba(169, 203, 183, 0.4) 0px 0px 0px 8px, rgba(0, 0, 0, 0.15) 0px 6px 12px -2px;
  }
  20% {
    transform: scale(1.05);
    box-shadow: rgba(169, 203, 183, 0.2) 0px 0px 0px 4px, rgba(0, 0, 0, 0.12) 0px 5px 8px -2px;
  }
  22%, 100% {
    transform: scale(1);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  }
}
.recrutement__step-line {
  width: 3px;
  flex: 1;
  background: rgba(169, 203, 183, 0.3);
  margin-top: 8px;
  position: relative;
  overflow: hidden;
}
.recrutement__step-line::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 0%;
  background: #A9CBB7;
  animation: lineProgressRecrutement 9s ease-in-out infinite;
}

.recrutement__step:nth-child(2) .recrutement__step-line::before {
  animation-name: lineProgressStep2;
  animation-delay: 0s;
}

@keyframes lineProgressRecrutement {
  0%, 13% {
    height: 0%;
  }
  32%, 88.88% {
    height: 100%;
  }
  88.89%, 100% {
    height: 0%;
  }
}
@keyframes lineProgressStep2 {
  0%, 46.33% {
    height: 0%;
  }
  65.33%, 88.88% {
    height: 100%;
  }
  88.89%, 100% {
    height: 0%;
  }
}
.recrutement__step--last .recrutement__step-line {
  display: none;
}

.recrutement__step-content {
  padding: 8px 0 40px 0;
}
@media (max-width: 768px) {
  .recrutement__step-content {
    padding: 4px 0 32px 0;
  }
}

.recrutement__step-title {
  margin: 0 0 8px 0;
  color: #4C4C4C;
}

.recrutement__step-desc {
  margin: 0;
  opacity: 0.85;
  color: #4C4C4C;
}

.recrutement__cta-wrapper {
  display: flex;
  justify-content: center;
  margin-top: 50px;
}
@media (max-width: 1024px) {
  .recrutement__cta-wrapper {
    margin-top: 45px;
  }
}
@media (max-width: 768px) {
  .recrutement__cta-wrapper {
    margin-top: 40px;
  }
}

.recrutement__cta {
  border-radius: 50px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  color: #FFFFFF;
  background-image: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  text-decoration: none;
  gap: 15px;
  padding: 15px;
  transition: background 0.3s ease, color 0.3s ease-in-out;
}
@media (max-width: 1024px) {
  .recrutement__cta {
    gap: 12.5px;
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .recrutement__cta {
    gap: 10px;
    padding: 10px;
  }
}
.recrutement__cta span {
  transition: transform 0.3s ease-in-out;
}
.recrutement__cta .material-symbols-outlined {
  transition: transform 0.3s ease-in-out, color 0.3s ease-in-out;
}
.recrutement__cta:hover {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}
.recrutement__cta:hover .material-symbols-outlined {
  transform: translateX(5px);
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

@media (prefers-reduced-motion: reduce) {
  .recrutement__step-number,
.recrutement__step-line::before {
    animation: none;
  }
}
.candidature-container__title {
  text-align: center;
  color: #4C4C4C;
}

.candidature-container .candidature-form {
  grid-column: 1/2;
  width: 100%;
}
@media (max-width: 1024px) {
  .candidature-container .candidature-form {
    width: unset;
    margin-bottom: 50px;
  }
}

.candidature-container .candidature-form #id_message {
  max-width: 100%;
  min-width: 100%;
  min-height: 100px;
  max-height: 250px;
  overflow: auto;
  border-radius: 15px;
  border: solid 1px #A9CBB7;
  color: #A9CBB7;
  padding: 15px;
}
@media (max-width: 1024px) {
  .candidature-container .candidature-form #id_message {
    padding: 12.5px;
  }
}
@media (max-width: 768px) {
  .candidature-container .candidature-form #id_message {
    padding: 10px;
  }
}
.candidature-container .candidature-form #id_message:focus {
  outline: none;
}

.candidature-actions .submit-button {
  background-image: linear-gradient(90deg, #A9CBB7, #7EBF8D);
  color: #FFFFFF;
  gap: 15px;
}
@media (max-width: 1024px) {
  .candidature-actions .submit-button {
    gap: 12.5px;
  }
}
@media (max-width: 768px) {
  .candidature-actions .submit-button {
    gap: 10px;
  }
}
.candidature-actions .submit-button:hover {
  opacity: 0.9;
}

.candidature-grid-container {
  overflow-x: auto;
  width: 100%;
}

.candidature-grid-container .candidature-grid {
  min-width: 1024px;
  border-radius: 8px;
}

.candidature-grid-container .candidature-grid .grid-header {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-radius: 15px 15px 0 0;
  background-image: linear-gradient(90deg, #7EBF8D, #A9CBB7);
  color: #FFFFFF;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 30px;
}
@media (max-width: 1024px) {
  .candidature-grid-container .candidature-grid .grid-header {
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .candidature-grid-container .candidature-grid .grid-header {
    padding: 30px;
  }
}

.candidature-grid-container .candidature-grid .grid-header .grid-cell {
  margin: unset;
  text-align: center;
}

.candidature-grid-container .candidature-grid .grid-row {
  display: grid;
  align-items: center;
  grid-template-columns: repeat(5, 1fr);
  border-bottom: 1px solid #A9CBB7;
  transition: background-color 0.2s ease;
}
.candidature-grid-container .candidature-grid .grid-row:last-child {
  border-radius: 0 0 15px 15px;
  border-bottom: none;
}
.candidature-grid-container .candidature-grid .grid-row:hover {
  background-color: #f5f5f5;
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell {
  text-align: center;
  padding: 30px;
}
@media (max-width: 1024px) {
  .candidature-grid-container .candidature-grid .grid-row .grid-cell {
    padding: 20px;
  }
}
@media (max-width: 768px) {
  .candidature-grid-container .candidature-grid .grid-row .grid-cell {
    padding: 30px;
  }
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
@media (max-width: 1024px) {
  .candidature-grid-container .candidature-grid .grid-row .grid-cell-actions {
    gap: 8px;
  }
}
@media (max-width: 768px) {
  .candidature-grid-container .candidature-grid .grid-row .grid-cell-actions {
    gap: 6px;
  }
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50px;
  font-weight: 700;
  border: none;
  background: unset;
  cursor: pointer;
  padding: 8px;
  transition: all 0.2s ease;
  font-size: 0.8rem;
}
@media (max-width: 1024px) {
  .candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button {
    font-size: 0.7rem;
    padding: 7px;
  }
}
@media (max-width: 768px) {
  .candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button {
    font-size: 0.6rem;
    padding: 6px;
  }
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button.view {
  color: #7EBF8D;
}
.candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button.view:hover {
  opacity: 0.9;
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button.delete {
  color: #D16464;
}
.candidature-grid-container .candidature-grid .grid-row .grid-cell-actions .action-button.delete:hover {
  opacity: 0.9;
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut {
  display: flex;
  justify-content: center;
  align-items: center;
}
.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut p {
  font-size: 0.8rem;
}
@media (max-width: 1024px) {
  .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut p {
    font-size: 0.7rem;
  }
}
@media (max-width: 768px) {
  .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut p {
    font-size: 0.6rem;
  }
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-nouveau,
.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-lu,
.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-traite {
  border-radius: 50px;
  font-weight: 700;
  color: #FFFFFF;
  padding: 8px;
}
@media (max-width: 1024px) {
  .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-nouveau,
.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-lu,
.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-traite {
    padding: 7px;
  }
}
@media (max-width: 768px) {
  .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-nouveau,
.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-lu,
.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-traite {
    padding: 6px;
  }
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-nouveau {
  background-image: linear-gradient(135deg, #f6d365, #fda085);
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-lu {
  background-image: linear-gradient(135deg, #a1c4fd, #c2e9fb);
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-traite {
  background-image: linear-gradient(135deg, #d4fc79, #96e6a1);
}

.candidature-grid-container .candidature-grid .grid-row .grid-cell:last-child {
  text-align: right;
}

@media (max-width: 1024px) {
  .candidature-grid-container .candidature-grid .candidature-grid-container {
    overflow-x: scroll;
  }
}
.error404 {
  min-height: 70vh;
  display: grid;
  place-items: center;
  padding: 2rem 1rem;
}

.error404__card {
  width: min(720px, 92vw);
  padding: 1.75rem;
  border: 1px solid #e6e8eb;
  border-radius: 14px;
  background: #FFFFFF;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.05);
  text-align: center;
}

.error404__title {
  margin: 0 0 0.5rem;
  font-size: clamp(22px, 3.2vw, 30px);
  font-weight: 700;
}

.error404__desc {
  margin: 0 auto 1rem;
  max-width: 60ch;
  color: #4C4C4C;
  line-height: 1.6;
}

.error404__desc code {
  background: #f6f7f8;
  border: 1px dashed #e1e3e6;
  border-radius: 6px;
  padding: 0 0.4rem;
  font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: 0.95em;
  color: #333;
}

.error404__actions {
  display: flex;
  gap: 0.6rem;
  justify-content: center;
  flex-wrap: wrap;
  margin: 1rem 0 0.25rem;
}

.error404__btn {
  appearance: none;
  border: 1px solid #dcdfe4;
  background: #FFFFFF;
  color: #1f2328;
  padding: 0.7rem 1rem;
  border-radius: 10px;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.05s ease;
}
.error404__btn:hover {
  background: #f6f7f8;
  border-color: #cfd3d9;
}
.error404__btn:active {
  transform: translateY(1px);
}

.error404__btn--primary {
  background: #1f6feb;
  border-color: #1f6feb;
  color: #FFFFFF;
}
.error404__btn--primary:hover {
  background: #195ec7;
  border-color: #195ec7;
}

.error404__muted {
  margin-top: 0.5rem;
  color: #727b87;
  font-size: 0.95rem;
}

@media (max-width: 480px) {
  .error404__card {
    padding: 1.25rem;
  }

  .error404__actions {
    gap: 0.5rem;
  }
}
.consent-root {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

#consent-trigger {
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid #ddd;
  background: #FFFFFF;
  color: #111;
  cursor: pointer;
  font-size: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.consent-panel {
  width: 320px;
  max-width: 86vw;
  border-radius: 12px;
  padding: 16px;
  background: #111;
  color: #FFFFFF;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25);
  display: none;
}

.consent-panel.open {
  display: block;
}

#consent-trigger:hover + .consent-panel {
  display: block;
}

.consent-panel h3 {
  margin: 0 0 8px;
  font-size: 16px;
}

.consent-panel p {
  margin: 0 0 12px;
  line-height: 1.45;
  font-size: 14px;
}

.consent-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: space-between;
}

.consent-link {
  color: #A9CBB7;
  text-decoration: underline;
  font-size: 14px;
}

.consent-buttons {
  display: flex;
  gap: 8px;
}

.btn {
  padding: 8px 12px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 14px;
}

.btn-outline {
  background: transparent;
  color: #FFFFFF;
  border: 1px solid #555;
}

.btn-primary {
  background: #A9CBB7;
  color: #111;
  border: none;
}

.form-consent-banner {
  color: #e69a00;
  font-size: 14px;
  line-height: 1.4;
  margin: 6px 0 10px;
}

.form-consent-banner .form-consent-link {
  background: none;
  border: none;
  color: #e69a00;
  text-decoration: underline;
  cursor: pointer;
  font-size: 14px;
  padding: 0;
}
.form-consent-banner .form-consent-link:hover {
  text-decoration: none;
}

.consent-panel-wrapper {
  position: relative;
  padding: 16px;
}

.consent-close {
  position: absolute;
  top: 8px;
  right: 10px;
  border: none;
  background: transparent;
  font-size: 20px;
  color: #FFFFFF;
  cursor: pointer;
  line-height: 1;
}
.consent-close:hover {
  color: #A9CBB7;
}

.content-policies {
  --section-gap: 1.25rem;
  --para-gap: 0.75rem;
  --title-gap: 1.25rem;
  --breadcrumb-gap: 1rem;
  --h2-bottom: 0.75rem;
  --h3-top: 0.75rem;
  --h3-bottom: 0.5rem;
  --indent-1: 1rem;
  --guide-color: rgba(0, 0, 0, 0.08);
}

@media (min-width: 768px) {
  .content-policies {
    --section-gap: 1.75rem;
    --para-gap: 1rem;
    --title-gap: 1.75rem;
    --breadcrumb-gap: 1.25rem;
    --h2-bottom: 1rem;
    --h3-top: 1rem;
    --h3-bottom: 0.625rem;
    --indent-1: 1.25rem;
  }
}
@media (min-width: 1024px) {
  .content-policies {
    --section-gap: 2.25rem;
    --para-gap: 1.125rem;
    --title-gap: 2rem;
    --breadcrumb-gap: 1.5rem;
    --h2-bottom: 1.125rem;
    --h3-top: 1.125rem;
    --h3-bottom: 0.75rem;
    --indent-1: 1.5rem;
  }
}
.content-policies .container__links {
  margin-bottom: var(--breadcrumb-gap);
}

.content-policies .privacy__title {
  margin: 0 0 var(--title-gap);
}

.content-policies .privacy__section:not(:last-of-type) {
  margin-bottom: var(--section-gap);
}

.content-policies .privacy__subtitle {
  margin: 0 0 var(--h2-bottom);
}

.content-policies .privacy__section p {
  margin: 0;
}

.content-policies .privacy__section p + p {
  margin-top: var(--para-gap);
}

.content-policies .privacy__heading {
  margin: var(--h3-top) 0 var(--h3-bottom);
  padding-left: var(--indent-1);
  border-left: 2px solid var(--guide-color);
}

.content-policies .privacy__heading + p {
  padding-left: calc(var(--indent-1) + 0.25rem);
}

.content-policies .privacy__heading + p + p {
  padding-left: calc(var(--indent-1) + 0.25rem);
  margin-top: var(--para-gap);
}

.content-policies .privacy__intro p + p {
  margin-top: calc(var(--para-gap) * 0.75);
}

.content-policies a {
  text-decoration: underline;
  text-underline-offset: 2px;
}

.faq-intro {
  padding: 100px 5% 50px;
}
@media (max-width: 1024px) {
  .faq-intro {
    padding: 70px 5% 40px;
  }
}
@media (max-width: 768px) {
  .faq-intro {
    padding: 50px 5% 35px;
  }
}

.faq-intro__cols {
  display: flex;
  gap: 50px;
  align-items: flex-start;
}
@media (max-width: 1024px) {
  .faq-intro__cols {
    flex-direction: column;
    gap: 35px;
  }
}

.faq-intro__col--text {
  flex: 1;
}

.faq-intro__col--themes {
  flex: 0 0 auto;
}

.faq-intro__title {
  font-size: 3.7rem;
  color: #4C4C4C;
  margin-bottom: 25px;
}
@media (max-width: 1024px) {
  .faq-intro__title {
    font-size: 3rem;
  }
}
@media (max-width: 768px) {
  .faq-intro__title {
    font-size: 2.2rem;
  }
}

.faq-intro__subtitle {
  font-size: 1.2rem;
  color: #4C4C4C;
  opacity: 0.7;
  margin: 0;
  max-width: 52ch;
}
@media (max-width: 1024px) {
  .faq-intro__subtitle {
    font-size: 1rem;
  }
}

.faq-themes {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.faq-themes__item {
  display: flex;
}

.faq-themes__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 1rem;
  font-weight: 600;
  color: #7EBF8D;
  text-decoration: none;
  transition: color 0.15s ease-in-out, gap 0.15s ease-in-out;
}
.faq-themes__link .material-symbols-outlined {
  font-size: 1.1rem;
  transition: transform 0.15s ease-in-out;
}
.faq-themes__link:hover {
  color: #4C4C4C;
}
.faq-themes__link:hover .material-symbols-outlined {
  transform: translateX(3px);
}

.faq-divider {
  border: none;
  border-top: 1px solid rgba(169, 203, 183, 0.25);
  margin: 0 5%;
}

.faq-section {
  padding: 50px 5%;
  scroll-margin-top: 50px;
}
@media (max-width: 1024px) {
  .faq-section {
    padding: 40px 5%;
  }
}
@media (max-width: 768px) {
  .faq-section {
    padding: 35px 5%;
  }
}

.faq-section__title {
  font-size: 2.5rem;
  color: #4C4C4C;
  margin-bottom: 25px;
  padding-bottom: 10px;
  border-bottom: 2px solid rgba(169, 203, 183, 0.35);
}
@media (max-width: 1024px) {
  .faq-section__title {
    font-size: 2rem;
  }
}
@media (max-width: 768px) {
  .faq-section__title {
    font-size: 1.5rem;
  }
}

.faq-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.faq-item {
  background: #FFFFFF;
  border-radius: 15px;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px, rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  overflow: hidden;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1), transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.faq-item.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.faq-item.is-open .faq-item__chevron {
  transform: rotate(180deg);
}

.faq-item__trigger {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 25px 35px;
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: background 0.15s ease-in-out;
}
.faq-item__trigger:hover {
  background: rgba(169, 203, 183, 0.05);
}
@media (max-width: 1024px) {
  .faq-item__trigger {
    padding: 20px 25px;
  }
}
@media (max-width: 768px) {
  .faq-item__trigger {
    padding: 10px 20px;
    gap: 10px;
  }
}

.faq-item__question-text {
  flex: 1;
  font-size: 1.2rem;
  font-weight: 600;
  color: #4C4C4C;
  line-height: 1.4;
}
@media (max-width: 1024px) {
  .faq-item__question-text {
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  .faq-item__question-text {
    font-size: 0.95rem;
  }
}

.faq-item__chevron {
  flex-shrink: 0;
  font-size: 1.3rem;
  color: #A9CBB7;
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}
@media (max-width: 768px) {
  .faq-item__chevron {
    font-size: 1.1rem;
  }
}

.faq-item__panel {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.faq-item.is-open .faq-item__panel {
  grid-template-rows: 1fr;
}

.faq-item__panel-inner {
  overflow: hidden;
}

.faq-item__answer {
  padding: 0 35px 25px 35px;
  color: #4C4C4C;
  font-size: 0.95rem;
  line-height: 1.75;
  opacity: 0.88;
}
.faq-item__answer.ql-editor {
  padding: 0 35px 25px;
}
.faq-item__answer p {
  margin: 0 0 10px;
}
.faq-item__answer p:last-child {
  margin-bottom: 0;
}
.faq-item__answer ul, .faq-item__answer ol {
  margin: 0 0 10px;
  padding-left: 25px;
}
@media (max-width: 1024px) {
  .faq-item__answer {
    padding: 0 25px 20px 25px;
  }
}
@media (max-width: 768px) {
  .faq-item__answer {
    padding: 0 20px 10px 20px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .faq-item {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .faq-item__panel {
    transition: none;
  }

  .faq-item__chevron {
    transition: none;
  }
}
@media (min-width: 1025px) {
  .apropos-intro__col--media,
.activites-intro__col--media,
.aides-intro__col--media,
.hebergement-intro__col--media,
.instances-intro__col--media,
.procedures-intro__col--media,
.soins-intro__col--media {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
  }
  .apropos-intro__col--media.is-visible,
.activites-intro__col--media.is-visible,
.aides-intro__col--media.is-visible,
.hebergement-intro__col--media.is-visible,
.instances-intro__col--media.is-visible,
.procedures-intro__col--media.is-visible,
.soins-intro__col--media.is-visible {
    opacity: 1;
    transform: translateY(0);
  }
}
.apropos-intro__col--content,
.activites-intro__col--content,
.aides-intro__col--content,
.hebergement-intro__col--content,
.instances-intro__col--content,
.procedures-intro__col--content,
.soins-intro__col--content {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.apropos-intro__col--content.is-visible,
.activites-intro__col--content.is-visible,
.aides-intro__col--content.is-visible,
.hebergement-intro__col--content.is-visible,
.instances-intro__col--content.is-visible,
.procedures-intro__col--content.is-visible,
.soins-intro__col--content.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.apropos-intro__stat {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.apropos-intro__stat.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.org__header, .org__figure {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.org__header.is-visible, .org__figure.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.equipe-card {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.equipe-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.values__header {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.values__header.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.value-card {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.value-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.activites-section__intro {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.activites-section__intro.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.activite-card {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.activite-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.aides__list_intro {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.aides__list_intro.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.aides-item {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.aides-item.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.espaces__header {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.espaces__header.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.espaces-card {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.espaces-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.galerie-hebergement__header {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.galerie-hebergement__header.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.galerie-card {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.galerie-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.instances__list_intro {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.instances__list_intro.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.instances-item {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.instances-item.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.procedures__title {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.procedures__title.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.recrutement-hero__inner {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.recrutement-hero__inner.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.tarifs-hero__inner {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.tarifs-hero__inner.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.prestations__header {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.prestations__header.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.prestation-item {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.prestation-item.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.doc-accueil__intro {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s cubic-bezier(0.4, 0, 0.2, 1), transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
}
.doc-accueil__intro.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.doc-accueil__card {
  opacity: 0;
  transition: opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1), transform 0.18s ease, box-shadow 0.18s ease;
}
.doc-accueil__card.is-visible {
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  .apropos-intro__col--media, .activites-intro__col--media,
.aides-intro__col--media, .hebergement-intro__col--media,
.instances-intro__col--media, .procedures-intro__col--media,
.soins-intro__col--media,
.apropos-intro__col--content, .activites-intro__col--content,
.aides-intro__col--content, .hebergement-intro__col--content,
.instances-intro__col--content, .procedures-intro__col--content,
.soins-intro__col--content,
.apropos-intro__stat, .org__header, .org__figure,
.equipe-card, .values__header, .value-card,
.activites-section__intro, .activite-card,
.aides__list_intro, .aides-item,
.espaces__header, .espaces-card,
.galerie-hebergement__header, .galerie-card,
.instances__list_intro, .instances-item,
.procedures__title,
.recrutement-hero__inner,
.tarifs-hero__inner,
.prestations__header, .prestation-item,
.doc-accueil__intro, .doc-accueil__card {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
@keyframes dm-pulse {
  0%, 100% {
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1), 0 0 0 0 rgba(169, 203, 183, 0.45);
  }
  60% {
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1), 0 0 0 10px rgba(169, 203, 183, 0);
  }
}
.darkmode-toggle {
  position: fixed;
  bottom: 24px;
  left: 24px;
  z-index: 110;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  background: linear-gradient(90deg, #7EBF8D, #A9CBB7);
  color: #FFFFFF;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: dm-pulse 2.8s ease-in-out infinite;
  transition: transform 0.2s ease;
}
.darkmode-toggle .material-symbols-outlined {
  font-size: 1.4rem;
  transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
}
.darkmode-toggle:hover {
  transform: scale(1.1);
  animation-play-state: paused;
}
.darkmode-toggle:active {
  transform: scale(0.93);
}

.darkmode-toggle--spinning .material-symbols-outlined {
  transform: rotate(360deg);
}

.darkmode-ripple {
  position: fixed;
  top: var(--ry);
  left: var(--rx);
  width: 220vmax;
  height: 220vmax;
  border-radius: 50%;
  transform: translate(-50%, -50%) scale(0);
  z-index: 109;
  pointer-events: none;
  transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}
.darkmode-ripple--expand {
  transform: translate(-50%, -50%) scale(1);
}

html[data-theme=dark] body {
  background-color: #0e0e16;
  color: #ffffff;
}
html[data-theme=dark] h1, html[data-theme=dark] h2, html[data-theme=dark] h3, html[data-theme=dark] h4, html[data-theme=dark] h5, html[data-theme=dark] h6 {
  color: #ffffff;
}
html[data-theme=dark] p {
  color: #cfcfff;
}
html[data-theme=dark] a {
  color: #ffffff;
}
html[data-theme=dark] hr {
  border-color: #2a2a44;
}
html[data-theme=dark] .pagination__link {
  color: #A9CBB7;
}
html[data-theme=dark] .job-detail__apply {
  color: #A9CBB7;
  -webkit-text-fill-color: #A9CBB7;
}
html[data-theme=dark] ul li, html[data-theme=dark] ol li {
  color: #cfcfff;
}
html[data-theme=dark] section {
  background-color: transparent;
}
html[data-theme=dark] button {
  color: #FFFFFF;
}
html[data-theme=dark] .container_button button,
html[data-theme=dark] .container_button a {
  color: #FFFFFF;
}
html[data-theme=dark] .dashboard_form .container_button .cancel_button {
  background-color: #272742;
  color: #FFFFFF;
}
html[data-theme=dark] .btn-primary {
  color: #FFFFFF;
}
html[data-theme=dark] .logout-card__btn--secondary {
  background: #272742;
  color: #ffffff;
}
html[data-theme=dark] .logout-card__title,
html[data-theme=dark] .logout-card__subtitle {
  color: #ffffff;
}
html[data-theme=dark] .logout-card__text {
  color: #cfcfff;
}
html[data-theme=dark] .messages_container .message p,
html[data-theme=dark] .messages_container .message {
  color: #ffffff;
}
html[data-theme=dark] .container_navbar_public {
  background-color: rgba(31, 31, 53, 0.94);
  border-bottom: 1px solid #2a2a44;
  color: #ffffff;
}
html[data-theme=dark] .navbar_public__toggle {
  color: #ffffff;
}
html[data-theme=dark] .navbar_public__toggle span {
  color: #ffffff;
}
html[data-theme=dark] .navbar_public__links_desktop a,
html[data-theme=dark] .navbar_public__links_desktop .submenu-toggle {
  color: #ffffff;
}
html[data-theme=dark] .navbar_public__links_desktop.navbar__links__single-page a {
  text-shadow: none;
}
html[data-theme=dark] .navbar_public__links_desktop.navbar__links__single-page a:hover {
  text-shadow: none;
  color: #FFFFFF;
}
html[data-theme=dark] .navbar_public .submenu-toggle {
  color: #ffffff;
  text-shadow: none;
}
html[data-theme=dark] .navbar_public .submenu-toggle:hover, html[data-theme=dark] .navbar_public .submenu-toggle:focus {
  color: #FFFFFF;
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  text-shadow: none;
  -webkit-text-fill-color: #FFFFFF;
}
html[data-theme=dark] .navbar_public .navbar_public__links_desktop .submenu-links {
  background-color: #1f1f35;
  border: none;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
}
html[data-theme=dark] .navbar_public .navbar_public__links_desktop .submenu-links a {
  color: #ffffff;
}
html[data-theme=dark] .navbar_public .navbar_public__links_desktop .submenu-links a:hover, html[data-theme=dark] .navbar_public .navbar_public__links_desktop .submenu-links a:focus {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
html[data-theme=dark] .navbar_public__links_general_side_nav {
  background-color: #1f1f35;
  border-left: 1px solid #2a2a44;
  box-shadow: -8px 0 24px rgba(0, 0, 0, 0.5);
}
html[data-theme=dark] .navbar_public__links_general_side_nav .navbar_public__links a {
  color: #ffffff;
}
html[data-theme=dark] .navbar_public__links_general_side_nav .navbar_public__links a:hover, html[data-theme=dark] .navbar_public__links_general_side_nav .navbar_public__links a:focus {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  color: #FFFFFF;
  -webkit-text-fill-color: #FFFFFF;
  background-clip: initial;
  -webkit-background-clip: initial;
}
html[data-theme=dark] .navbar_public__links_general_side_nav .menu-item .submenu-toggle {
  color: #ffffff;
  text-shadow: none;
}
html[data-theme=dark] .navbar_public__links_general_side_nav .menu-item .submenu-toggle:hover, html[data-theme=dark] .navbar_public__links_general_side_nav .menu-item .submenu-toggle:focus {
  color: #FFFFFF;
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  text-shadow: none;
  -webkit-text-fill-color: #FFFFFF;
}
html[data-theme=dark] .navbar_public__links_general_side_nav .submenu-links {
  background-color: #1f1f35;
  border: none;
}
html[data-theme=dark] .navbar_public__links_general_side_nav .submenu-links a {
  color: #ffffff;
}
html[data-theme=dark] .navbar_public__links_general_side_nav .submenu-links a:hover, html[data-theme=dark] .navbar_public__links_general_side_nav .submenu-links a:focus {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
html[data-theme=dark] .navbar_public__links_general_side_nav .navbar__links__contact a {
  background: linear-gradient(135deg, #4C4C4C, #A9CBB7);
  color: #FFFFFF;
}
html[data-theme=dark] .navbar_public__links_general_side_nav .navbar__links__contact a:hover, html[data-theme=dark] .navbar_public__links_general_side_nav .navbar__links__contact a:focus {
  background: rgba(169, 203, 183, 0.15);
  color: #A9CBB7;
}
html[data-theme=dark] .navbar_public .navbar__links__contact a,
html[data-theme=dark] .navbar_public__links_general_side_nav .navbar__links__contact a {
  background: rgba(169, 203, 183, 0.12);
  color: #ffffff;
  border: none;
  -webkit-text-fill-color: #ffffff;
}
html[data-theme=dark] .navbar_public .navbar__links__contact a:hover, html[data-theme=dark] .navbar_public .navbar__links__contact a:focus,
html[data-theme=dark] .navbar_public__links_general_side_nav .navbar__links__contact a:hover,
html[data-theme=dark] .navbar_public__links_general_side_nav .navbar__links__contact a:focus {
  background: rgba(169, 203, 183, 0.22);
  color: #FFFFFF;
  border: none;
  -webkit-text-fill-color: #FFFFFF;
}
html[data-theme=dark] .user_container {
  background-color: #1f1f35;
  border-bottom: 1px solid #2a2a44;
}
html[data-theme=dark] .user_container p, html[data-theme=dark] .user_container a {
  color: #ffffff;
}
html[data-theme=dark] .main-container-dashboard {
  background-color: #0e0e16;
}
html[data-theme=dark] .navbar_dashboard {
  background-color: #1f1f35;
  border-right: 1px solid #2a2a44;
}
html[data-theme=dark] .navbar_dashboard__trigger {
  background-color: #272742;
  color: #ffffff;
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.5);
}
html[data-theme=dark] .navbar_dashboard__links a {
  color: #cfcfff;
}
html[data-theme=dark] .navbar_dashboard__links a:hover, html[data-theme=dark] .navbar_dashboard__links a.active {
  color: #ffffff;
}
html[data-theme=dark] .navbar_dashboard__label {
  color: #cfcfff;
}
html[data-theme=dark] .navbar_dashboard__form-logout button {
  background: linear-gradient(135deg, #E57373, #F28B82);
  border: 1px solid #2a2a44;
  color: #FFFFFF;
  -webkit-text-fill-color: #FFFFFF;
}
html[data-theme=dark] .navbar_dashboard__form-logout button:hover {
  background: #2a2a44;
  border-color: #E57373;
  color: #E57373;
  -webkit-text-fill-color: #E57373;
}
html[data-theme=dark] .content,
html[data-theme=dark] .content_dashboard {
  background-color: #0e0e16;
}
html[data-theme=dark] .card {
  background: linear-gradient(145deg, #191929 0%, #1e1e33 100%);
  border: 1px solid #222238;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.28);
}
html[data-theme=dark] .card p, html[data-theme=dark] .card span, html[data-theme=dark] .card .card__stat-label {
  color: #cfcfff;
}
html[data-theme=dark] .card h1, html[data-theme=dark] .card h2, html[data-theme=dark] .card h3, html[data-theme=dark] .card h4 {
  color: #ffffff;
}
html[data-theme=dark] .card .card__stat-value {
  color: #A9CBB7;
}
html[data-theme=dark] .form-page-separator::before, html[data-theme=dark] .form-page-separator::after {
  background: #2a2a44;
}
html[data-theme=dark] .form-page-separator__label {
  background: #1f1f35;
  border-color: #2a2a44;
  color: #cfcfff;
}
html[data-theme=dark] .article_suggest_card {
  background: #2a2a44;
  border-color: transparent;
  color: #ffffff;
}
html[data-theme=dark] .article_suggest_card:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
}
html[data-theme=dark] .article_suggest_card__image::after {
  background: linear-gradient(to right, rgba(42, 42, 68, 0) 0%, rgba(42, 42, 68, 0.8) 70%, #2a2a44 100%);
}
@media (max-width: 640px) {
  html[data-theme=dark] .article_suggest_card__image::after {
    background: linear-gradient(to bottom, rgba(42, 42, 68, 0) 0%, rgba(42, 42, 68, 0.6) 60%, #2a2a44 100%);
  }
}
html[data-theme=dark] .articles__card__content {
  background-color: #2a2a44;
}
html[data-theme=dark] .articles__card__content__text h3,
html[data-theme=dark] .articles__card__content__text p {
  color: #ffffff;
}
html[data-theme=dark] .articles_suggestions {
  color: #ffffff;
}
html[data-theme=dark] .articles_suggestions__title {
  color: #ffffff;
}
html[data-theme=dark] .accueil__hero-banner__texte {
  color: #FAFAF9;
}
html[data-theme=dark] .accueil__hero-banner__titre {
  color: #FFFFFF;
}
html[data-theme=dark] .accueil__presentation {
  background-color: #0e0e16;
}
html[data-theme=dark] .accueil__presentation__titre {
  color: #ffffff;
}
html[data-theme=dark] .accueil__presentation__description {
  color: #cfcfff;
}
html[data-theme=dark] .accueil .accueil-services {
  background-color: #0e0e16;
  color: #ffffff;
}
html[data-theme=dark] .accueil .accueil-services__item {
  background-color: #2a2a44;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.35);
  color: #ffffff;
}
html[data-theme=dark] .accueil .accueil-services__item h3, html[data-theme=dark] .accueil .accueil-services__item p, html[data-theme=dark] .accueil .accueil-services__item span {
  color: #ffffff;
}
html[data-theme=dark] .doc-accueil__title {
  color: #ffffff;
}
html[data-theme=dark] .doc-accueil__text {
  color: #cfcfff;
}
html[data-theme=dark] .doc-accueil__card {
  background-color: #2a2a44;
  border: 1px solid #2a2a44;
  color: #ffffff;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
}
html[data-theme=dark] .doc-accueil__card:hover {
  border-color: rgba(169, 203, 183, 0.3);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}
html[data-theme=dark] .doc-accueil__card-title {
  color: #ffffff;
}
html[data-theme=dark] .doc-accueil__card-desc {
  color: #cfcfff;
}
html[data-theme=dark] .articles_recents {
  color: #ffffff;
}
html[data-theme=dark] .articles-recents__intro {
  color: #ffffff;
}
html[data-theme=dark] .articles_recents__title {
  color: #ffffff;
}
html[data-theme=dark] .articles_recents__card__content__date {
  color: #cfcfff;
}
html[data-theme=dark] .site-sections__card {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.45);
  opacity: 0.9;
}
html[data-theme=dark] .site-sections__card:hover {
  opacity: 1;
}
html[data-theme=dark] table {
  background-color: #2a2a44;
}
html[data-theme=dark] thead tr {
  background-color: #1f1f35;
}
html[data-theme=dark] thead th {
  color: #ffffff;
  border-color: #2a2a44;
  background-color: #1f1f35;
}
html[data-theme=dark] tbody td {
  color: #cfcfff;
  border-color: #222238;
}
html[data-theme=dark] tbody tr:nth-child(odd) td {
  background-color: rgba(39, 39, 66, 0.4);
}
html[data-theme=dark] tbody tr:hover td {
  background-color: rgba(169, 203, 183, 0.05);
  color: #ffffff;
}
html[data-theme=dark] input, html[data-theme=dark] textarea {
  background-color: #13131f;
  border-color: #2a2a44;
  color: #A9CBB7;
}
html[data-theme=dark] input::placeholder, html[data-theme=dark] textarea::placeholder {
  color: #55556a;
}
html[data-theme=dark] input:focus, html[data-theme=dark] textarea:focus {
  border-color: rgba(169, 203, 183, 0.5);
}
html[data-theme=dark] select {
  background-color: #13131f;
  border-color: #2a2a44;
  color: #ffffff;
}
html[data-theme=dark] label {
  color: #A9CBB7;
}
html[data-theme=dark] .container_user_personal_information_grid .text_information_container p {
  border-color: #2a2a44;
  color: #cfcfff;
  background-color: #2a2a44;
}
html[data-theme=dark] .switch-label .switch-slider {
  background-color: #272742;
}
html[data-theme=dark] .content-cell {
  background: linear-gradient(90deg, rgba(169, 203, 183, 0.3), rgba(126, 191, 141, 0.38)), #FFFFFF;
  color: #4C4C4C;
}
html[data-theme=dark] .content-cell p, html[data-theme=dark] .content-cell span {
  color: #4C4C4C;
}
html[data-theme=dark] .dropzone-container,
html[data-theme=dark] .dropzone-container--article {
  background-color: #13131f;
  border-color: #2a2a44;
}
html[data-theme=dark] .dropzone-container.dragover,
html[data-theme=dark] .dropzone-container--article.dragover {
  background-color: rgba(169, 203, 183, 0.08);
  border-color: #A9CBB7;
}
html[data-theme=dark] .dropzone-label {
  color: #ffffff;
}
html[data-theme=dark] .file-chip {
  background: #1f1f35;
  border-color: #2a2a44;
  color: #ffffff;
}
html[data-theme=dark] .file-chip:hover {
  border-color: #A9CBB7;
  background: #272742;
}
html[data-theme=dark] .file-chip__icon {
  color: #cfcfff;
}
html[data-theme=dark] .file-chip__name {
  color: #ffffff;
}
html[data-theme=dark] .quill-wrapper {
  border: none;
  background-color: #2a2a44;
  border-radius: 15px;
}
html[data-theme=dark] .quill-wrapper .ql-container,
html[data-theme=dark] .quill-wrapper .ql-editor {
  background-color: #2a2a44;
  color: #ffffff;
}
html[data-theme=dark] .quill-content {
  color: #ffffff;
}
html[data-theme=dark] .prestation-item__body {
  color: #ffffff;
  opacity: 1;
}
html[data-theme=dark] .modale_container .button-link,
html[data-theme=dark] .modale_container .cancel_button,
html[data-theme=dark] .modale_container .btn--rouge,
html[data-theme=dark] .modale_container .dashboard_form .container_button .cancel_button,
html[data-theme=dark] .modale_container .dashboard_form .container_button .btn--rouge {
  background-color: #2a2a44;
  color: #FFFFFF;
  -webkit-text-fill-color: #FFFFFF;
}
html[data-theme=dark] .modale_container .button-link:hover,
html[data-theme=dark] .modale_container .cancel_button:hover,
html[data-theme=dark] .modale_container .btn--rouge:hover,
html[data-theme=dark] .modale_container .dashboard_form .container_button .cancel_button:hover,
html[data-theme=dark] .modale_container .dashboard_form .container_button .btn--rouge:hover {
  background-color: #272742;
  color: #FFFFFF;
  -webkit-text-fill-color: #FFFFFF;
}
html[data-theme=dark] .modale_container .btn--danger {
  background-color: #D16464;
  color: #FFFFFF;
  -webkit-text-fill-color: #FFFFFF;
}
html[data-theme=dark] .articles__card__action_links a,
html[data-theme=dark] .categories .category--card__action_links a {
  background-color: rgba(39, 39, 66, 0.88);
  backdrop-filter: blur(6px);
}
html[data-theme=dark] .articles__card__action_links a span,
html[data-theme=dark] .categories .category--card__action_links a span {
  color: #ffffff;
}
html[data-theme=dark] .articles__card__action_links a:hover,
html[data-theme=dark] .categories .category--card__action_links a:hover {
  background-color: #272742;
}
html[data-theme=dark] .dashboard-inner-form .cell-actions button,
html[data-theme=dark] .section-dynamique .cell-actions button {
  background-color: #FFFFFF;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
}
html[data-theme=dark] .dashboard-inner-form .cell-actions button span,
html[data-theme=dark] .section-dynamique .cell-actions button span {
  color: #000000;
}
html[data-theme=dark] .dashboard-inner-form .cell-actions button:hover,
html[data-theme=dark] .section-dynamique .cell-actions button:hover {
  background-color: #f1f1f1;
}
html[data-theme=dark] .dashboard_form .container_button a {
  background-color: #D16464;
  color: #FFFFFF;
  -webkit-text-fill-color: #FFFFFF;
}
html[data-theme=dark] .icon__user_pp {
  outline: 2px solid rgba(169, 203, 183, 0.35);
  outline-offset: 2px;
}
html[data-theme=dark] *::-webkit-scrollbar-track {
  background: #0e0e16;
}
html[data-theme=dark] *::-webkit-scrollbar-thumb {
  background: #1f1f35;
}
html[data-theme=dark] *:hover::-webkit-scrollbar-thumb {
  background: #272742;
}
html[data-theme=dark] * {
  scrollbar-color: #1f1f35 #0e0e16;
}
html[data-theme=dark] .search-input {
  background-color: #1f1f35;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
}
html[data-theme=dark] .search-input__form__field {
  background-color: transparent;
  color: #ffffff;
}
html[data-theme=dark] .search-input__form__field::placeholder {
  color: #55556a;
}
html[data-theme=dark] .search-input__filter,
html[data-theme=dark] .search-input__submit {
  color: #cfcfff;
}
html[data-theme=dark] .search-filters {
  background-color: #272742;
  border-top: 1px solid #2a2a44;
}
html[data-theme=dark] .filter-item label {
  color: #cfcfff;
}
html[data-theme=dark] .filter-item select {
  background-color: #13131f;
  color: #ffffff;
  border-color: #2a2a44;
}
html[data-theme=dark] .search-input-blog {
  background-color: rgba(31, 31, 53, 0.95);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
}
html[data-theme=dark] .search-input-blog input {
  background: transparent;
  color: #ffffff;
}
html[data-theme=dark] .search-input-blog input::placeholder {
  color: #55556a;
}
html[data-theme=dark] .blog-intro .search-input-blog__filter,
html[data-theme=dark] .blog-intro .search-input-blog__submit {
  color: #cfcfff;
}
html[data-theme=dark] .modale_container {
  background-color: rgba(0, 0, 0, 0.75);
}
html[data-theme=dark] .modale_container__window {
  background-color: #2a2a44;
  border: 1px solid #2a2a44;
  color: #ffffff;
}
html[data-theme=dark] .modale_container__window h1, html[data-theme=dark] .modale_container__window h2, html[data-theme=dark] .modale_container__window h3, html[data-theme=dark] .modale_container__window h4, html[data-theme=dark] .modale_container__window p {
  color: #ffffff;
}
html[data-theme=dark] .modale_container__window label {
  color: #A9CBB7;
}
html[data-theme=dark] .modale_container__window_cross {
  color: #cfcfff;
}
html[data-theme=dark] .breadcrumb__link {
  color: #cfcfff;
}
html[data-theme=dark] .breadcrumb__item {
  color: #cfcfff;
}
html[data-theme=dark] .breadcrumb__separator {
  color: #55556a;
}
html[data-theme=dark] .quick-links__item {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
  opacity: 0.88;
}
html[data-theme=dark] .quick-links__item:hover {
  opacity: 1;
}
html[data-theme=dark] .transition-footer {
  background: #0e0e16;
}
html[data-theme=dark] .site-footer {
  background: #0e0e16;
  color: #ffffff;
}
html[data-theme=dark] .site-footer a {
  color: #ffffff;
}
html[data-theme=dark] .site-footer ul li {
  color: #ffffff;
}
html[data-theme=dark] .site-footer p {
  color: #ffffff;
}
html[data-theme=dark] .site-footer__title {
  color: #ffffff;
}
html[data-theme=dark] .site-footer__hotline {
  color: #ffffff;
}
html[data-theme=dark] .site-footer__copyright {
  color: #cfcfff;
}
html[data-theme=dark] .site-footer__link {
  color: #ffffff;
}
html[data-theme=dark] .site-footer__link::after {
  background-color: #A9CBB7;
}
html[data-theme=dark] .site-footer__address p,
html[data-theme=dark] .site-footer__address address,
html[data-theme=dark] .site-footer__address {
  color: #ffffff;
}
html[data-theme=dark] .site-footer__icon {
  background-color: #1f1f35;
}
html[data-theme=dark] .site-footer__icon:hover {
  background-color: #272742;
}
html[data-theme=dark] .contact-cta {
  background: #0e0e16;
}
html[data-theme=dark] .contact-cta__title {
  color: #ffffff;
}
html[data-theme=dark] .contact-cta__text {
  color: #cfcfff;
}
html[data-theme=dark] .contact-cta__faq {
  color: #cfcfff;
}
html[data-theme=dark] .contact-cta__faq a {
  color: #A9CBB7;
  text-decoration-color: #A9CBB7;
}
html[data-theme=dark] .contact-cta__faq a:hover {
  color: #ffffff;
}
html[data-theme=dark] .contact-cta__button {
  background: rgba(169, 203, 183, 0.12);
  color: #ffffff;
}
html[data-theme=dark] .contact-cta__button:hover {
  background: rgba(169, 203, 183, 0.22);
  color: #FFFFFF;
}
html[data-theme=dark] .contact_form-container-titre {
  color: #ffffff;
}
html[data-theme=dark] .contact_form-container .contact-map_container .contact-container {
  color: #ffffff;
}
html[data-theme=dark] .contact_form-container .contact-map_container .contact-container p {
  color: #ffffff;
}
html[data-theme=dark] .message-grid-container .message-grid .grid-header,
html[data-theme=dark] .candidature-grid-container .candidature-grid .grid-header {
  background-image: none;
  background-color: #1f1f35;
  color: #ffffff;
}
html[data-theme=dark] .message-grid-container .message-grid .grid-row,
html[data-theme=dark] .candidature-grid-container .candidature-grid .grid-row {
  border-bottom-color: #2a2a44;
  background-color: transparent;
}
html[data-theme=dark] .message-grid-container .message-grid .grid-row:nth-child(even),
html[data-theme=dark] .candidature-grid-container .candidature-grid .grid-row:nth-child(even) {
  background-color: rgba(39, 39, 66, 0.35);
}
html[data-theme=dark] .message-grid-container .message-grid .grid-row:hover,
html[data-theme=dark] .candidature-grid-container .candidature-grid .grid-row:hover {
  background-color: rgba(169, 203, 183, 0.07);
}
html[data-theme=dark] .message-grid-container .message-grid .grid-row .grid-cell,
html[data-theme=dark] .message-grid-container .message-grid .grid-row .grid-cell p,
html[data-theme=dark] .candidature-grid-container .candidature-grid .grid-row .grid-cell,
html[data-theme=dark] .candidature-grid-container .candidature-grid .grid-row .grid-cell p {
  color: #cfcfff;
}
html[data-theme=dark] .tarifs__intro {
  color: #ffffff;
}
html[data-theme=dark] .tarifs__text {
  color: #cfcfff;
}
html[data-theme=dark] .tarifs-section__intro {
  color: #cfcfff;
}
html[data-theme=dark] .tarifs-card {
  background-color: #2a2a44;
  border: 1px solid #2a2a44;
  color: #ffffff;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
}
html[data-theme=dark] .tarifs-card:hover {
  border-color: rgba(169, 203, 183, 0.3);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}
html[data-theme=dark] .tarifs-card__title {
  color: #ffffff;
}
html[data-theme=dark] .tarifs-card__desc {
  color: #cfcfff;
}
html[data-theme=dark] .tarifs-card:hover .tarifs-card__cta {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
html[data-theme=dark] .apropos-intro {
  background-color: #0e0e16;
}
html[data-theme=dark] .apropos-intro__title {
  color: #ffffff;
}
html[data-theme=dark] .apropos-intro__richtext {
  color: #cfcfff;
}
html[data-theme=dark] .apropos-intro__stat {
  background-color: #2a2a44;
  border: 1px solid #2a2a44;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.25);
}
html[data-theme=dark] .apropos-intro__stat-label {
  color: #cfcfff;
  opacity: 1;
}
html[data-theme=dark] .apropos-intro__stat-value {
  color: #A9CBB7;
}
html[data-theme=dark] .values__title {
  color: #ffffff;
}
html[data-theme=dark] .values__intro {
  color: #cfcfff;
}
html[data-theme=dark] .value-card {
  background-color: #1f1f35;
  border-color: #2a2a44;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
}
html[data-theme=dark] .value-card__text {
  color: #cfcfff;
}
html[data-theme=dark] .value-card__title {
  color: #A9CBB7;
}
html[data-theme=dark] .org {
  background-color: #0e0e16;
}
html[data-theme=dark] .org__title {
  color: #ffffff;
}
html[data-theme=dark] .org__intro {
  color: #cfcfff;
}
html[data-theme=dark] .org__caption {
  color: #cfcfff;
}
html[data-theme=dark] .equipes .equipe-card {
  background-color: #2a2a44;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}
html[data-theme=dark] .equipe-card__members {
  scrollbar-color: #A9CBB7 #2a2a44;
}
html[data-theme=dark] .equipe-card__member {
  background-color: rgba(169, 203, 183, 0.08);
  color: #ffffff;
}
html[data-theme=dark] .blog-intro {
  background-image: none;
  background-color: #0e0e16;
}
html[data-theme=dark] .blog-intro__title {
  color: #ffffff;
}
html[data-theme=dark] .blog-intro__description {
  color: #cfcfff;
}
html[data-theme=dark] .blog-intro .search-input-blog {
  background-color: #1f1f35;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
}
html[data-theme=dark] .blog-intro .search-input-blog__filter {
  color: #cfcfff;
}
html[data-theme=dark] .blog-intro .search-input-blog__form__field {
  color: #ffffff;
}
html[data-theme=dark] .blog-intro .search-input-blog__form__field::placeholder {
  color: #55556a;
}
html[data-theme=dark] .blog-intro .search-input-blog .search-filters {
  background-color: #272742;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
}
html[data-theme=dark] .blog-intro .search-input-blog .search-filters label {
  color: #cfcfff;
}
html[data-theme=dark] .blog-intro .search-input-blog .search-filters select, html[data-theme=dark] .blog-intro .search-input-blog .search-filters #filter-category {
  background-color: #13131f;
  color: #ffffff;
  border-color: #2a2a44;
}
html[data-theme=dark] .blog-intro .search-input-blog .search-filters input[type=checkbox] {
  accent-color: #A9CBB7;
}
html[data-theme=dark] .hebergement-intro__title {
  color: #ffffff;
}
html[data-theme=dark] .hebergement-intro__body {
  color: #cfcfff;
}
html[data-theme=dark] .hebergement-intro__text {
  color: #cfcfff;
}
html[data-theme=dark] .espaces__header {
  color: #ffffff;
}
html[data-theme=dark] .espaces__text {
  color: #cfcfff;
}
html[data-theme=dark] .espaces-card__content {
  background-color: #2a2a44;
  border-left: 1px solid #2a2a44;
}
html[data-theme=dark] .espaces-card__title {
  color: #ffffff;
}
html[data-theme=dark] .espaces-card__description {
  color: #cfcfff;
}
html[data-theme=dark] .espaces-card__bottom h4 {
  color: #ffffff;
}
html[data-theme=dark] .espaces-card__bottom p {
  color: #cfcfff;
}
html[data-theme=dark] .recrutement {
  color: #ffffff;
}
html[data-theme=dark] .recrutement__intro {
  color: #ffffff;
}
html[data-theme=dark] .recrutement__text {
  color: #cfcfff;
}
html[data-theme=dark] .recrutement__step-title {
  color: #ffffff;
}
html[data-theme=dark] .recrutement__step-desc {
  color: #cfcfff;
}
html[data-theme=dark] .recrutement__search {
  background-color: #0e0e16;
}
html[data-theme=dark] .recrutement__search-label {
  color: #ffffff;
}
html[data-theme=dark] .recrutement__filter {
  color: #ffffff;
}
html[data-theme=dark] .recrutement__search-input {
  background-color: #0e0e16;
  border-color: #2a2a44;
  color: #ffffff;
}
html[data-theme=dark] .recrutement__search-input::placeholder {
  color: #55556a;
}
html[data-theme=dark] .recrutement__search-input:focus {
  border-color: rgba(169, 203, 183, 0.5);
}
html[data-theme=dark] .recrutement__select {
  background-color: #0e0e16;
  border-color: #2a2a44;
  color: #ffffff;
}
html[data-theme=dark] .job-card {
  background-color: #0e0e16;
  color: #ffffff;
  border-color: transparent;
}
html[data-theme=dark] .job-card.is-active {
  background-color: #0e0e16;
  border-color: #A9CBB7;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.3);
}
html[data-theme=dark] .job-card:focus {
  border-color: #A9CBB7;
}
html[data-theme=dark] .job-card__title {
  color: #ffffff;
}
html[data-theme=dark] .job-card__meta {
  color: #cfcfff;
}
html[data-theme=dark] .recrutement__detail-inner {
  background-color: #0e0e16;
}
html[data-theme=dark] .job-detail__apply-banner {
  background-color: #0e0e16;
  border-top-color: #2a2a44;
}
html[data-theme=dark] .job-detail__title {
  color: #ffffff;
}
html[data-theme=dark] .job-detail__label {
  color: #ffffff;
}
html[data-theme=dark] .job-detail__value {
  color: #cfcfff;
}
html[data-theme=dark] .job-detail__chip {
  border-color: #2a2a44;
  color: #cfcfff;
}
html[data-theme=dark] .job-detail__chip--contrat {
  border-color: #A9CBB7;
  color: #A9CBB7;
}
html[data-theme=dark] .recrutement__cta {
  color: #FFFFFF;
  -webkit-text-fill-color: #FFFFFF;
}
html[data-theme=dark] .recrutement__cta:hover {
  -webkit-text-fill-color: transparent;
}
html[data-theme=dark] .recrutement__cta:hover .material-symbols-outlined {
  -webkit-text-fill-color: transparent;
}
html[data-theme=dark] .procedures__title {
  color: #ffffff;
}
html[data-theme=dark] .procedures-intro__title {
  color: #ffffff;
}
html[data-theme=dark] .procedures-intro__body,
html[data-theme=dark] .procedures-intro__text {
  color: #cfcfff;
}
html[data-theme=dark] .procedures__intro {
  color: #ffffff;
}
html[data-theme=dark] .procedures__step-dot {
  background: #0e0e16;
}
html[data-theme=dark] .procedures .procedure-card {
  background: #2a2a44;
  color: #ffffff;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
}
html[data-theme=dark] .procedures .procedure-card__title {
  color: #ffffff;
}
html[data-theme=dark] .procedures .procedure-card__body {
  color: #cfcfff;
}
html[data-theme=dark] .procedures .procedure-card__content {
  color: #cfcfff;
}
html[data-theme=dark] .procedures .procedure-card__attachments-title {
  color: #cfcfff;
}
html[data-theme=dark] .procedures .procedure-card__attachments-link {
  background: rgba(169, 203, 183, 0.07);
  border-color: rgba(169, 203, 183, 0.2);
  color: #ffffff;
}
html[data-theme=dark] .procedures .procedure-card__attachments-link:hover, html[data-theme=dark] .procedures .procedure-card__attachments-link:focus {
  background: #A9CBB7;
  border-color: #A9CBB7;
  color: #FFFFFF;
}
html[data-theme=dark] .procedures-progress {
  background: #0e0e16;
  border-color: rgba(169, 203, 183, 0.3);
  color: #ffffff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}
html[data-theme=dark] .procedures-progress__current {
  color: #7EBF8D;
}
html[data-theme=dark] .procedures-progress__sep, html[data-theme=dark] .procedures-progress__total {
  color: #cfcfff;
  opacity: 1;
}
html[data-theme=dark] .aides {
  color: #ffffff;
}
html[data-theme=dark] .aides-intro__title {
  color: #ffffff;
}
html[data-theme=dark] .aides-intro__body,
html[data-theme=dark] .aides-intro__text {
  color: #cfcfff;
}
html[data-theme=dark] .aides-item {
  background-color: #2a2a44;
  color: #ffffff;
  box-shadow: none;
}
html[data-theme=dark] .aides-item__header {
  background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.02) 100%);
}
html[data-theme=dark] .aides-item__title {
  color: #ffffff;
}
html[data-theme=dark] .aides-item__chevron {
  color: #cfcfff;
}
html[data-theme=dark] .aides-item__desc,
html[data-theme=dark] .aides-item__content {
  color: #cfcfff;
}
html[data-theme=dark] .instances {
  color: #ffffff;
}
html[data-theme=dark] .instances-intro__title {
  color: #ffffff;
}
html[data-theme=dark] .instances-intro__body,
html[data-theme=dark] .instances-intro__text {
  color: #cfcfff;
}
html[data-theme=dark] .instances-item {
  background-color: #1f1f35;
  color: #ffffff;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
}
html[data-theme=dark] .instances-item__header {
  background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.02) 100%);
}
html[data-theme=dark] .instances-item__title {
  color: #ffffff;
}
html[data-theme=dark] .instances-item__chevron {
  color: #cfcfff;
}
html[data-theme=dark] .instances-item__desc,
html[data-theme=dark] .instances-item__content {
  color: #cfcfff;
}
html[data-theme=dark] .livret-card {
  background: #0e0e16;
  border-color: #2a2a44;
  box-shadow: none;
}
html[data-theme=dark] .livret-card:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}
html[data-theme=dark] .livret-card__titre {
  color: #ffffff;
}
html[data-theme=dark] .livret-card__badge {
  color: #7EBF8D;
}
html[data-theme=dark] .livret-card__actions {
  border-left-color: #2a2a44;
}
html[data-theme=dark] .livret-card__btn {
  color: #cfcfff;
}
html[data-theme=dark] .livret-card__btn--view:hover {
  background: rgba(169, 203, 183, 0.12);
  color: #A9CBB7;
}
html[data-theme=dark] .livret-card__btn--download:hover {
  background: rgba(126, 191, 141, 0.1);
  color: #7EBF8D;
}
html[data-theme=dark] #facebook-form .container_button .submit-button {
  background: linear-gradient(90deg, #A9CBB7, #7EBF8D);
  color: #FFFFFF;
}
html[data-theme=dark] .faq-intro__title {
  color: #ffffff;
}
html[data-theme=dark] .faq-intro__subtitle {
  color: #cfcfff;
}
html[data-theme=dark] .faq-themes__link {
  color: #7EBF8D;
}
html[data-theme=dark] .faq-themes__link:hover {
  color: #ffffff;
}
html[data-theme=dark] .faq-divider {
  border-top-color: rgba(169, 203, 183, 0.15);
}
html[data-theme=dark] .faq-section__title {
  color: #ffffff;
  border-bottom-color: rgba(169, 203, 183, 0.2);
}
html[data-theme=dark] .faq-item {
  background: #2a2a44;
  box-shadow: none;
}
html[data-theme=dark] .faq-item__trigger:hover {
  background: rgba(169, 203, 183, 0.06);
}
html[data-theme=dark] .faq-item__question-text {
  color: #ffffff;
}
html[data-theme=dark] .faq-item__answer {
  color: #cfcfff;
}
html[data-theme=dark] .faq-item__answer p {
  color: #cfcfff;
}
html[data-theme=dark] .activite-card,
html[data-theme=dark] .activite-card__header {
  background-color: #4C4C4C;
}
html[data-theme=dark] .activite-card.is-open,
html[data-theme=dark] .activite-card.is-open .activite-card__header {
  background-color: #2a2a44;
}
html[data-theme=dark] .activite-card__content,
html[data-theme=dark] .activite-card .accordion__content {
  background-color: #2a2a44;
}
html[data-theme=dark] .activite-card--past,
html[data-theme=dark] .activite-card--past .activite-card__header {
  background-color: transparent;
}
html[data-theme=dark] .activite-card--past.is-open {
  background: linear-gradient(180deg, #4c4c4c 0%, #2a2a44 100%);
  border-radius: 50px;
}
html[data-theme=dark] .activite-card--past.is-open .activite-card__header {
  background: transparent;
}
html[data-theme=dark] .activite-card--past .activite-card__content,
html[data-theme=dark] .activite-card--past .accordion__content {
  background: transparent;
}
html[data-theme=dark] .activite-card__title-pill {
  background-color: #1f1f35;
  color: #ffffff;
}
html[data-theme=dark] .activite-card__meta {
  color: #cfcfff;
}
html[data-theme=dark] .activite-card__desc {
  color: #cfcfff;
}
html[data-theme=dark] .galerie-card__title-pill {
  background-color: #FFFFFF;
  color: #4C4C4C;
  -webkit-text-fill-color: #4C4C4C;
}
html[data-theme=dark] .services-carousel__arrow {
  background-color: #1f1f35;
  color: #ffffff;
  box-shadow: 0 0.6em 1.4em rgba(0, 0, 0, 0.4);
}
html[data-theme=dark] .consent-panel {
  background-color: #2a2a44;
  border: 1px solid #2a2a44;
}
html[data-theme=dark] .consent-panel h3 {
  color: #ffffff;
}
html[data-theme=dark] .consent-panel p {
  color: #cfcfff;
}
html[data-theme=dark] .consent-panel .consent-link {
  color: #A9CBB7;
}
html[data-theme=dark] #consent-trigger {
  background-color: #272742;
  color: #ffffff;
  border: 1px solid #2a2a44;
}
html[data-theme=dark] .darkmode-toggle {
  background: linear-gradient(90deg, #F7E1D7, #A9CBB7);
}
html[data-theme=dark] .leaflet-popup-content,
html[data-theme=dark] .leaflet-popup-content p,
html[data-theme=dark] .leaflet-popup-content a,
html[data-theme=dark] .leaflet-popup-content span {
  color: #4C4C4C;
  -webkit-text-fill-color: #4C4C4C;
}
html[data-theme=dark] .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-nouveau,
html[data-theme=dark] .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-lu,
html[data-theme=dark] .message-grid-container .message-grid .grid-row .grid-cell-statut .statut-traite,
html[data-theme=dark] .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-nouveau,
html[data-theme=dark] .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-lu,
html[data-theme=dark] .candidature-grid-container .candidature-grid .grid-row .grid-cell-statut .statut-traite {
  color: #FFFFFF;
  -webkit-text-fill-color: #FFFFFF;
}
html[data-theme=dark] .evenements-board {
  background-color: #2a2a44;
  border-color: #2a2a44;
}
html[data-theme=dark] .evenements-row:not(.evenements-row--head) {
  background-color: #2a2a44;
  border-top-color: #222238;
}
html[data-theme=dark] .evenements-row:not(.evenements-row--head):hover {
  background-color: rgba(169, 203, 183, 0.06);
}
html[data-theme=dark] .evenements-cell {
  color: #cfcfff;
}
html[data-theme=dark] .evenements-cell--title {
  color: #ffffff;
}
