@charset "UTF-8";
/*
|--------------------------------------------------------------------------
| File Structure
|--------------------------------------------------------------------------
|
| 0 - Helpers
| 1 - Utils
| 2 - Variables
| 3 - Base
| 4 - Vendors
| 5 - Components
| 6 - Layouts
| 7 - Templates
|
*/
/*
|--------------------------------------------------------------------------
| 0 - Helpers
|--------------------------------------------------------------------------
|
|
|
*/
/*
|--------------------------------------------------------------------------
| 1 - Utils
|--------------------------------------------------------------------------
|
|
|
*/
/*
|--------------------------------------------------------------------------
| 2 - Variables
|--------------------------------------------------------------------------
|
|
|
*/
/*
|--------------------------------------------------------------------------
| 3 - Base
|--------------------------------------------------------------------------
|
|
|
*/
/*
|--------------------------------------------------------------------------
| 4 - Vendors
|--------------------------------------------------------------------------
|
|
|
*/
.breadcrumb {
  font-size: var(--breadcrumb-font-size);
  color: var(--breadcrumb-color);
  font-weight: var(--breadcrumb-font-weight);
  line-height: var(--breadcrumb-line-height);
  margin-bottom: var(--breadcrumb__margin-bottom);
  font-family: "Poppins", sans-serif;
  margin-top: 20px;
}

.breadcrumb li {
  font-size: 1rem;
  display: inline-block;
}

.breadcrumb li a {
  color: #FFB800;
  text-decoration: none;
}

.breadcrumb li a:hover {
  color: #FFF;
}

.breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

.breadcrumb__separator {
  margin: var(--breadcrumb-separator__margin);
}

.breadcrumb__current {
  color: #FFF;
  font-weight: var(--breadcrumb-font-weight--current);
}

.container-fluid {
  width: 100%;
  background-color: transparent;
  display: flex;
  justify-content: center;
  align-items: center;
}

.container-fluid ol {
  width: 1440px;
  padding: 0px 114px;
  max-width: 0 auto;
}
@media (max-width: 1200px) {
  .container-fluid ol {
    padding: 0px 50px;
  }
}
@media (max-width: 1100px) {
  .container-fluid ol {
    padding: 0px 30px;
  }
}
@media (max-width: 768px) {
  .container-fluid ol {
    padding: 0px 15px;
  }
}

/* stylelint-disable no-duplicate-selectors */
/*
|--------------------------------------------------------------------------
| Global
|--------------------------------------------------------------------------
|
| Global styles for the breadcrumb.
|
*/
:root {
  --breadcrumb-color: var(--primary-color, #FFB800);
  --breadcrumb-font-size: 0.8125rem;
  --breadcrumb-font-weight: 400;
  --breadcrumb-line-height: 1;
  --breadcrumb-separator__margin: 0.3125rem;
  --breadcrumb__margin-bottom: 1.25rem;
  --breadcrumb__margin-top: 1.25rem;
}

/*
|--------------------------------------------------------------------------
| Current
|--------------------------------------------------------------------------
|
| Styles for the current item.
|
*/
:root {
  --breadcrumb-color--current: var(--breadcrumb-color);
  --breadcrumb-font-weight--current: 500;
}

/*
|--------------------------------------------------------------------------
| 5 - Components
|--------------------------------------------------------------------------
|
|
|
*/
.contact-container {
  display: flex;
  flex-direction: column;
  gap: 40px;
  margin: 40px 0;
  width: 100%;
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
  font-family: "Poppins", sans-serif;
}

.contact-header {
  width: 100%;
  text-align: center;
  margin-bottom: 40px;
}

.contact-title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 4rem;
  line-height: 1.125;
  text-align: center;
  vertical-align: middle;
  color: white;
  max-width: 700px;
  margin: 0 auto;
}

span.contact-header__tag2.tag-float {
  height: 25px;
  display: flex;
  background: #323232;
  width: 96px;
  color: #fff;
}

span.contact-header__tag1.tag-float {
  height: 25px;
  display: flex;
  background: #fa7b7b;
  width: 92px;
}

.contact-description {
  padding-top: 40px;
}

.contact-info a {
  color: #282828;
  text-decoration: none;
}

.contact-info a:hover {
  color: #ffb800;
}

.contact-info {
  z-index: 99;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 14px;
  background: #0e0e0e;
  border: 1px solid #2d2d2d;
  border-radius: 20px;
  padding: 25px;
}
@media (max-width: 1024px) {
  .contact-info {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 768px) {
  .contact-info {
    gap: 20px;
    padding: 20px;
  }
}
@media (max-width: 425px) {
  .contact-info {
    grid-template-columns: repeat(1, 1fr) !important;
    gap: 0;
  }
}

.contact-info__item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}
@media (max-width: 900px) {
  .contact-info__item {
    gap: 0;
  }
}

.contact-info__icon-label-row {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 16px;
}
@media (max-width: 768px) {
  .contact-info__icon-label-row {
    gap: 0;
  }
}

.contact-info__icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.contact-info__icon img {
  width: 48px;
  height: 48px;
}
@media (max-width: 900px) {
  .contact-info__icon img {
    width: 38px;
    height: 38px;
  }
}

.contact-info__label {
  font-family: "Inter", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 1.5rem;
  line-height: 2.4375rem;
  letter-spacing: 0;
  color: #fff;
}
@media (max-width: 900px) {
  .contact-info__label {
    font-size: 1.1rem;
  }
}
@media (max-width: 768px) {
  .contact-info__label {
    font-size: 1rem;
  }
}

.contact-info__text-container a {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.25rem;
  line-height: 1.9375rem;
  letter-spacing: 0;
  color: rgba(255, 255, 255, 0.8);
}
@media (max-width: 900px) {
  .contact-info__text-container a {
    font-size: 1rem !important;
  }
}
@media (max-width: 768px) {
  .contact-info__text-container a {
    font-size: 0.9rem !important;
  }
}

.contact-info__text-container p {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.25rem;
  letter-spacing: 0;
  color: rgba(255, 255, 255, 0.8);
}
@media (max-width: 768px) {
  .contact-info__text-container p {
    font-size: 0.9rem !important;
  }
}

.contact-info__text-container {
  margin-top: 2px;
}

.contact-info__text-container a:hover {
  color: #ffb800;
}

.contact-form {
  width: 100%;
  border-radius: 12px;
  padding: 48px 0px 32px 0px;
  color: #fff;
  box-sizing: border-box;
}

.contact-map-link {
  width: 100%;
  display: flex;
  justify-content: center;
  margin-top: 20px;
}

.contact-map-link__button {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 32px;
  background: #ffb800;
  color: #222;
  text-decoration: none;
  border-radius: 8px;
  font-weight: 600;
  font-size: 1rem;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(255, 184, 0, 0.3);
}

.contact-map-link__button:hover {
  background: #e6a600;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(255, 184, 0, 0.4);
  color: #222;
}

.contact-map-link__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

@media (max-width: 1024px) {
  .contact-map-container-contact-info {
    display: flex;
    flex-direction: column;
  }
}

/* Champs de formulaire (input + textarea) */
.contact-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
}
@media (max-width: 768px) {
  .contact-form-grid {
    display: flex;
    flex-direction: column;
    gap: 30px;
  }
}

.form-group {
  display: flex;
  flex-direction: column;
}

.form-full {
  grid-column: span 2;
}

.form-input,
.form-textarea,
select {
  background: transparent;
  border: none;
  border-bottom: 1px solid #8b8b8b !important;
  color: #8b8b8b;
  font-size: 16px;
  padding: 8px 0;
  font-family: "Poppins", sans-serif;
  width: 100%;
}

.form-input::placeholder,
.form-textarea::placeholder {
  color: #fff !important;
}

.form-textarea {
  min-height: 100px;
  resize: none;
}

.form-submit {
  grid-column: span 2;
}

.submit-button {
  background-color: #f3b100;
  border: none;
  color: #000;
  font-weight: 600;
  font-size: 18px;
  padding: 12px 30px;
  border-radius: 8px;
  cursor: pointer;
  font-family: "Poppins", sans-serif;
  transition: background-color 0.4s ease-in-out, transform 0.3s ease-in-out;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
}
@media (max-width: 768px) {
  .submit-button {
    width: 100%;
  }
}

.submit-button:hover {
  transform: translateY(-3px);
  background-color: #f6c232;
}

textarea.wpcf7-form-control.wpcf7-textarea.form-textarea {
  width: 100%;
  height: 20px;
}

.form-input,
.form-textarea {
  background: transparent;
  border: none;
  border-bottom: 1px solid #8b8b8b;
  color: white;
  font-size: 18px;
  padding: 8px 0;
  font-family: "Poppins", sans-serif;
  transition: border-color 0.3s, color 0.3s;
  width: 100%;
}

.form-input:focus,
.form-textarea:focus {
  outline: none;
  border-bottom: 1px solid #faf2dc !important;
  color: #faf2dc;
}

/* Placeholder blanc par défaut */
.form-input::placeholder,
.form-textarea::placeholder {
  color: white;
  opacity: 0.7;
}

label {
  display: block;
  color: #555;
  cursor: text;
  transition: color 0.3s ease, font-weight 0.3s ease, transform 0.3s ease;
}

.form-group:focus-within label {
  color: #fae8ba;
  transform: translateY(-3px);
}

.form-input:focus,
.form-textarea:focus {
  outline: none;
  border-bottom-color: #fae8ba;
  transition: border-color 0.3s ease;
}

.map-container {
  width: 640px;
  height: 600px;
  border-radius: 20px;
  overflow: hidden;
}
@media (max-width: 1024px) {
  .map-container {
    width: 100%;
    height: 400px;
  }
}

iframe {
  width: 100%;
  height: 100%;
  border: none;
}

input.wpcf7-form-control.wpcf7-submit.has-spinner.submit-button {
  width: 15%;
}

/* Message d'erreur global */
.wpcf7-not-valid-tip {
  display: block !important;
  /* bloc complet, nouvelle ligne */
  margin-top: 6px !important;
  /* espace au-dessus */
  color: #d93025;
  font-size: 0.85rem;
  font-weight: 500;
  position: static !important;
  max-width: 100%;
}

.wpcf7-not-valid {
  display: block;
}

.wpcf7-validation-errors {
  background-color: #fdecea;
  border: 1px solid #d93025;
  padding: 15px;
  margin-bottom: 20px;
  border-radius: 4px;
  font-weight: 600;
  font-size: 1rem;
}

.wpcf7-mail-sent-ok {
  color: #0f9d58;
  background-color: #e6f4ea;
  border: 1px solid #0f9d58;
  padding: 15px;
  margin-bottom: 20px;
  border-radius: 4px;
  font-weight: 600;
  font-size: 1rem;
}

.wpcf7 form.sent .wpcf7-response-output {
  border: none;
  padding: 0;
  border-color: #46b450;
  color: #46b450 !important;
  margin-right: 0;
  margin-left: 0;
}

.wpcf7-acceptance.wpcf7-not-valid {
  outline: 2px solid #d93025;
  background-color: #fff0f0;
}

.wpcf7-not-valid,
.wpcf7-validation-errors {
  animation: shake 0.3s ease-in-out;
}

@keyframes shake {
  0%, 100% {
    transform: translateX(0);
  }
  25% {
    transform: translateX(-4px);
  }
  75% {
    transform: translateX(4px);
  }
}
.screen-reader-response {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
  padding: 0;
  margin: 0;
}

.subscribe span.wpcf7-not-valid-tip {
  display: none !important;
}

.newsletter .wpcf7-form.invalid {
  display: flex;
  justify-content: center;
  flex-direction: column;
}

.wpcf7-response-output {
  margin-top: 10px;
  color: #d93025;
}

.footer-social a img {
  transition: transform 0.7s ease-in-out;
  will-change: transform;
}

.footer-social a:hover img {
  transform: scale(0.9);
}

input:focus {
  background-color: transparent;
  outline: none;
  box-shadow: none;
}

.newsletter input[type=email]:-webkit-autofill {
  -webkit-box-shadow: none !important;
  -webkit-text-fill-color: #3d3d3d !important;
  transition: background-color 5000s ease-in-out 0s;
}

input[type=email]:-webkit-autofill,
input[type=text]:-webkit-autofill,
input[type=tel]:-webkit-autofill {
  -webkit-box-shadow: none !important;
  -webkit-text-fill-color: #fff !important;
  transition: background-color 5000s ease-in-out 0s;
}

span.submit-icon {
  position: relative;
  top: 5px;
}

input::placeholder,
textarea::placeholder,
select::placeholder {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 16px !important;
  line-height: 1;
  letter-spacing: 0;
  vertical-align: middle;
  color: #5f5f5f;
}

input::-webkit-input-placeholder,
textarea::-webkit-input-placeholder,
select::-webkit-input-placeholder {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 26px;
  line-height: 1;
  letter-spacing: 0;
  vertical-align: middle;
  color: #999;
}

input:-moz-placeholder,
textarea:-moz-placeholder,
select:-moz-placeholder {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 26px;
  line-height: 1;
  letter-spacing: 0;
  vertical-align: middle;
  color: #999;
}

input::-moz-placeholder,
textarea::-moz-placeholder,
select::-moz-placeholder {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 26px;
  line-height: 1;
  letter-spacing: 0;
  vertical-align: middle;
  color: #999;
}

input:-ms-input-placeholder,
textarea:-ms-input-placeholder,
select:-ms-input-placeholder {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 26px;
  line-height: 1;
  letter-spacing: 0;
  vertical-align: middle;
  color: #999;
}

small.required-note {
  font-size: 9px;
  opacity: 0.5;
  padding-top: 8px;
}

input[type=checkbox] {
  width: auto;
}

.wpcf7-form-control-wrap {
  position: relative;
  width: 100%;
  grid-column: span 2;
}

span.wpcf7-list-item-label {
  margin-left: 5px;
  font-size: 15px;
}
@media (max-width: 768px) {
  span.wpcf7-list-item-label {
    font-size: 13px;
  }
}

.wpcf7-list-item {
  display: inline-block;
  margin: 0 !important;
}

.form-group.form-flex {
  grid-column: span 2;
  display: flex !important;
  flex-direction: row-reverse !important;
}
@media (max-width: 1024px) {
  .form-group.form-flex {
    display: flex !important;
    flex-direction: column-reverse !important;
    gap: 20px;
  }
}

.champ-obli {
  color: #555 !important;
}
@media (max-width: 1000px) {
  .champ-obli {
    text-align: right !important;
    width: 100% !important;
    font-size: 13px !important;
    color: #555 !important;
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: left !important;
  }
}

.form-submit {
  display: flex;
  align-items: center;
}

.contact-form form:has(.wpcf7-not-valid) .submit-button,
.wpcf7 .wpcf7-submit:disabled {
  cursor: not-allowed;
}

.contact-form form:has(.wpcf7-not-valid) .submit-button:hover,
.wpcf7 .wpcf7-submit:disabled:hover {
  transform: translateY(0);
  background-color: #f3b100;
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  max-width: 1200px;
  margin: 40px auto;
  align-items: stretch;
}

.post-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 0;
  box-shadow: none;
  overflow: hidden;
  height: 100%;
  padding: 0 0 32px 0;
}

.post-card__image {
  border-radius: 5px;
  width: 100%;
  height: 30vh;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f7f7f7;
  position: relative;
}

.post-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
}

.post-card__body {
  font-family: "Poppins", sans-serif;
  text-align: left;
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 0px 24px;
}

.post-card__title {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.2;
}

.post-card__title a {
  color: #FFB800;
  text-decoration: none;
}

.post-card__excerpt {
  color: #222;
  font-size: 1.15rem;
  flex: 1;
}

.post-card__excerpt p {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
  margin: 0px !important;
  padding: 0px !important;
}

.post-card__readmore {
  display: flex;
  align-items: center;
  gap: 18px;
  color: #000000;
  font-size: 1.1rem;
  text-decoration: none;
  transition: color 0.2s;
  background: none;
  border: none;
  outline: none;
}

.post-card__readmore:hover {
  color: #FFB800;
}

.post-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #FFB800;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  margin-left: 8px;
}

.post-card__icon svg {
  display: block;
  margin: auto;
}

@media (max-width: 1200px) {
  .blog-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 800px) {
  .blog-grid {
    grid-template-columns: 1fr;
  }
  .post-card__body {
    padding: 24px 12px 0 12px;
  }
}
.realisations {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-bottom: 75px;
}

.realisation-card {
  border-radius: 8px;
  position: relative;
  background-size: cover;
  background-position: center;
  min-height: 60vh;
  overflow: hidden;
  transition: box-shadow 0.3s;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}
.realisation-card:hover .realisation-overlay, .realisation-card:focus-within .realisation-overlay {
  opacity: 1;
  pointer-events: auto;
}

.realisation-overlay {
  position: absolute;
  inset: 0;
  background: rgba(20, 20, 20, 0.85);
  display: flex;
  border-radius: 8px;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
}

.realisation-logo {
  width: 120px;
  height: 120px;
  object-fit: contain;
  margin-bottom: 18px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.realisation-tech {
  color: #fff;
  font-size: 22px;
  font-weight: 500;
  margin-bottom: 18px;
  text-align: center;
  font-family: "Poppins", sans-serif;
}

.realisation-link {
  font-family: "Poppins", sans-serif;
  background: #FFB800;
  color: #ffffff;
  padding: 14px 32px;
  border-radius: 5px;
  font-weight: 500;
  font-size: 18px;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
  margin-top: 8px;
}
.realisation-link:hover {
  background: #e5a600;
  color: #fff;
}

/* Responsive */
@media (max-width: 900px) {
  .realisations {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 600px) {
  .realisations {
    grid-template-columns: 1fr;
  }
}
.text-image--style_2 .text-image__text__title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 77px;
}

section.section.class1.class9.section--no-paddings.section--marginTop--md h2 {
  font-size: 3.5rem;
}

.class1.class9 .section-spacing {
  padding-top: 50px;
}

.text-image {
  display: flex;
}
@media (max-width: 1024px) {
  .text-image {
    flex-direction: column;
  }
}

.text-image__image {
  width: 376px;
  border-radius: 20px;
}
@media (max-width: 1024px) {
  .text-image__image {
    width: 100%;
    height: auto;
  }
}

.text-image__image img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 20px;
}
@media (max-width: 1024px) {
  .text-image__image img {
    margin-bottom: 10px;
  }
}

.text-image.section-spacing.text-image--left.text-image--style_1 {
  flex-direction: row;
  gap: 24px;
}
@media (max-width: 1024px) {
  .text-image.section-spacing.text-image--left.text-image--style_1 {
    flex-direction: column;
  }
}

.text-image--right {
  flex-direction: column;
}

.text-image__text {
  flex: 1;
  position: relative;
}

.class1 .text-image__text__title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 3rem;
  line-height: 1.08;
  letter-spacing: -1.2px;
  vertical-align: middle;
  color: #FFF;
}

.text-image__text__title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 77px;
  line-height: 1.08;
  letter-spacing: -1.2px;
  vertical-align: middle;
  color: #FFF;
}

.class4 .text-image.section-spacing.text-image--right.text-image--style_1 {
  flex-direction: row-reverse;
}
@media (max-width: 1024px) {
  .class4 .text-image.section-spacing.text-image--right.text-image--style_1 {
    flex-direction: column;
  }
}

@media (max-width: 1024px) {
  .class4 .text-image.section-spacing.text-image--right.text-image--style_1 .text-image__image {
    order: 1;
  }
}

.text-image__text__title h3 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 3.375rem;
  letter-spacing: -1.2px;
  vertical-align: middle;
  color: #fff;
}
@media (max-width: 768px) {
  .text-image__text__title h3 {
    font-size: 1.5rem;
  }
}

.text-image__text__content p {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 2.125rem;
  letter-spacing: 0;
  vertical-align: middle;
  color: rgba(255, 255, 255, 0.8);
  margin-bottom: 7px;
}

.text-image__text__content {
  padding-top: 20px;
}
@media (max-width: 768px) {
  .text-image__text__content {
    padding-top: 10px;
  }
}

.class2 .parag-left {
  padding-left: 20%;
  padding-bottom: 30px;
}
@media (max-width: 1024px) {
  .class2 .parag-left {
    padding-left: 0;
  }
}

.class2 .text-image__text__link {
  display: none;
}

.text-image__text__content ul {
  list-style-type: disc;
  padding-left: 30px;
}

.text-image__text__content ul li {
  margin-bottom: 8px;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 1.7;
  letter-spacing: 0;
  vertical-align: middle;
  color: #fff;
}
@media (max-width: 768px) {
  .text-image__text__content ul li {
    font-size: 1.125rem !important;
    margin-bottom: 0;
  }
}

.text-image__text__link a {
  color: #271635;
  text-align: center;
  font-size: 1rem;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.48px;
  text-transform: uppercase;
  position: relative;
  padding: 17px 3.625rem 17px 2.75rem;
  overflow: hidden;
  transition: color 0.3s;
}

.text-image__text__link a:hover {
  color: #fff;
}

.text-image__tag-container.floatSmooth {
  position: absolute;
  display: flex;
  right: 20%;
  bottom: 41%;
}

.class2 .text-image__tag-container.floatSmooth {
  position: absolute;
  display: flex;
  bottom: auto;
}

.class1.class2 .text-image__tag.tag-float {
  background: #9DE0FD !important;
  width: 126px !important;
  height: 25px !important;
}

.class2 .text-image__tag.tag-float {
  height: 25px;
  background: #FF8C78;
  width: 101px;
}

span.text-image__tag.tag-float {
  background: #9DE0FD;
  width: 115px;
  height: 25px;
}

/* Style 2 */
.text-image--style_2 .text-image__top-row {
  display: flex;
  align-items: center;
  width: 100%;
  gap: 2rem;
  margin-bottom: 1.5rem;
  justify-content: space-between;
}
@media (max-width: 768px) {
  .text-image--style_2 .text-image__top-row {
    flex-direction: column;
  }
}

.text-image--style_2 .text-image__text__title {
  width: 800px;
}
@media (max-width: 768px) {
  .text-image--style_2 .text-image__text__title {
    width: 100%;
  }
}

.trusted-clients__tag {
  width: 113px;
  height: 25px;
  background-color: #F16A6A;
}

.trusted-clients__tag-container.floatSmooth {
  display: flex;
  align-items: center;
  justify-content: center;
}

.testimonial-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  width: 880px;
  height: 413px !important;
  background: #0D0D0D;
  border: 1px solid #202020;
  border-radius: 14px;
  gap: 30px;
  box-shadow: 0 0 20px rgba(32, 36, 36, 0.4);
  pointer-events: auto;
}
@media (max-width: 768px) {
  .testimonial-content {
    height: auto !important;
  }
}

.testimonial-author {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-left: 50px;
}
@media (max-width: 768px) {
  .testimonial-author {
    padding-left: 18px;
    padding-bottom: 20px;
  }
}

.testimonial-author img {
  width: 40px !important;
  height: 40px !important;
  object-fit: cover;
  border-radius: 50%;
  border: 2px solid #fff;
}

.author-role {
  color: #b3b3b3;
  font-size: 0.95rem;
}

.author-name {
  font-size: 1rem;
  font-weight: 600;
  color: #fff;
  text-align: left;
}

.author-info {
  display: flex;
  flex-direction: column;
}

.trusted-clients__title h2 {
  text-align: left;
  font-size: 4.125rem !important;
  font-weight: 700;
  margin-bottom: 2.5rem;
  color: #fff;
  letter-spacing: 0.01em;
  line-height: 1.2273;
}
@media (max-width: 768px) {
  .trusted-clients__title h2 {
    font-weight: 600;
    font-size: 1.75rem !important;
    line-height: 1.1667;
    letter-spacing: 0;
  }
}

.testimonial-container {
  display: flex;
  overflow: visible;
  gap: 20px;
  pointer-events: auto;
}

.testimonial-logo {
  width: 365px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 14px;
}
@media (max-width: 1024px) {
  .testimonial-logo {
    display: none;
  }
}

.testimonial-logo img {
  width: 80px;
  height: 416px !important;
  margin-bottom: 16px;
}

.testimonial-logo h2 {
  font-size: 2rem;
  margin: 0;
  font-family: "Cinzel", serif;
}

.subtitle {
  font-size: 0.9rem;
  color: #e0cda9;
  margin-top: 8px;
}

.trusted-clients .swiper-pagination.swiper-pagination-clickable.swiper-pagination-bullets.swiper-pagination-horizontal {
  top: 0 !important;
  margin-left: -115px;
  padding-top: 0px;
}
@media (max-width: 1300px) {
  .trusted-clients .swiper-pagination.swiper-pagination-clickable.swiper-pagination-bullets.swiper-pagination-horizontal {
    top: 0 !important;
    margin-left: 0px;
    padding-top: 0px;
    text-align: center;
  }
}
@media (max-width: 768px) {
  .trusted-clients .swiper-pagination.swiper-pagination-clickable.swiper-pagination-bullets.swiper-pagination-horizontal {
    margin-left: 20px;
    text-align: left;
  }
}

.testimonial-slider {
  margin-bottom: 16px;
}

.dot {
  display: inline-block;
  width: 32px;
  height: 6px;
  border-radius: 4px;
  background: #333;
  margin-right: 6px;
  opacity: 0.5;
}

.dot.active {
  background: #fff;
  opacity: 1;
}

p.testimonial-text {
  font-family: "Inter", sans-serif;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.3317;
  letter-spacing: 0;
  color: #fff;
  margin-top: 32px;
  text-align: left;
  padding: 0 50px;
}
@media (max-width: 768px) {
  p.testimonial-text {
    font-family: "Inter", sans-serif;
    font-weight: 500;
    font-size: 1rem;
    line-height: 1.2083;
    letter-spacing: 0;
    padding: 0 20px;
    margin-top: 62px;
  }
}

.trusted-clients {
  background: #181818;
  display: flex;
  justify-content: center;
  align-items: center;
  pointer-events: auto;
  touch-action: pan-y;
}

.trusted-clients .swiper-slide {
  border-radius: 14px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.15);
  overflow: visible;
  transition: transform 0.3s;
  pointer-events: auto;
  /* display: flex; */
  /* justify-content: center; */
  /* align-items: center; */
}

.trusted-clients .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 10px;
}

.trusted-clients .swiper-pagination {
  bottom: 0 !important;
}

.trusted-clients .swiper-pagination .swiper-pagination-bullet {
  background: #ffffff;
  opacity: 0.6;
  width: 15px;
  height: 8px;
  border-radius: 8px;
  margin: 0 4px;
  transition: all 0.3s;
}

.trusted-clients .swiper-pagination .swiper-pagination-bullet-active {
  background: #ffffff;
  opacity: 1;
  width: 48px;
}

@media screen and (max-width: 768px) {
  .swiper-slide {
    height: auto;
    width: auto;
  }
}
.logo-techno__tag {
  width: 150px;
  height: 25px;
  background-color: #B3FD9D;
}

.logo-techno__tag-container.floatSmooth {
  display: flex;
  align-items: center;
  justify-content: center;
}

.logotechnology__container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
@media (max-width: 768px) {
  .logotechnology__container {
    gap: 20px;
  }
}

/* Partie du bloc */
.logotechnology {
  border: 1px solid #202020;
  padding: 40px 30px;
  border-radius: 20px;
  display: flex;
  justify-content: center;
  cursor: pointer;
  background-color: rgb(13, 13, 13);
  transition: background-color 0.4s ease, transform 0.4s ease, border-color 0.4s ease;
}
@media (max-width: 768px) {
  .logotechnology {
    padding: 30px !important;
  }
}

.logotechnology:hover {
  background-color: #202020;
  border-color: transparent;
}

.logotechnology img {
  filter: grayscale(100%) contrast(0.9);
  transition: filter 0.5s ease;
}
@media (max-width: 768px) {
  .logotechnology img {
    width: 35px;
    filter: none;
  }
}

.logotechnology:hover img {
  filter: none;
}

.logotechnology__subtitle {
  width: 50%;
}
@media (max-width: 1024px) {
  .logotechnology__subtitle {
    width: 100%;
    order: 2;
  }
}

.logotechnology__subtitle p {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1.3317;
  letter-spacing: 0;
  color: #fff;
  text-align: left;
}
@media (max-width: 768px) {
  .logotechnology__subtitle p {
    font-family: "Inter", sans-serif;
    font-weight: 400;
    font-size: 1rem !important;
    line-height: 1.5;
    letter-spacing: 0;
  }
}

/* Mise en forme du texte <strong> dans le paragraphe */
.logotechnology__subtitle strong {
  font-weight: 600;
}

/* Bloc titre */
.logotechnology__title {
  width: 45%;
  text-align: left;
}
@media (max-width: 1024px) {
  .logotechnology__title {
    width: 100%;
  }
}

/* Titre principal */
.logotechnology__title h2 {
  color: #fff;
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 2.875rem;
  line-height: 1.05;
  letter-spacing: -0.07rem;
  margin: 0;
}
@media (max-width: 768px) {
  .logotechnology__title h2 {
    font-weight: 600;
    font-size: 1.75rem !important;
    line-height: 1.1667;
    letter-spacing: 0;
  }
}

.techno-slider {
  padding-top: 90px;
}
@media (max-width: 768px) {
  .techno-slider {
    padding-top: 30px;
  }
}

.section-mobil {
  display: none;
}
@media (max-width: 1100px) {
  .section-mobil {
    display: block;
  }
}

/* Wrapper image */
.project-partial__image-wrapper {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  height: 675px;
  transition: box-shadow 0.3s ease;
}
@media (max-width: 1200px) {
  .project-partial__image-wrapper {
    height: 598px !important;
  }
}
@media (max-width: 1024px) {
  .project-partial__image-wrapper {
    width: 100% !important;
    height: 598px !important;
  }
}
@media (max-width: 768px) {
  .project-partial__image-wrapper {
    width: 100%;
    height: 304px !important;
  }
}
@media (max-width: 400px) {
  .project-partial__image-wrapper {
    width: 100%;
    height: 304px !important;
  }
}

/* Image principale (2e enfant, sauf logo) */
.project-partial__image-wrapper img:nth-child(2),
.project-partial__image-wrapper img:not(.project-partial__logo) {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  filter: brightness(0.7);
  border-radius: 20px;
  transform: scale(1);
  opacity: 1;
  transition: transform 0.8s cubic-bezier(0.25, 0.1, 0.25, 1), filter 0.8s ease, opacity 0.8s ease;
}

/* Logo positionné */
.project-partial__logo {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
}

/* Logo centré, masqué par défaut */
.project-partial__image-wrapper img.project-partial__logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.8);
  opacity: 0.8;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

/* Hover sur wrapper image (logo) */
.project-partial__image-wrapper:hover img.project-partial__logo {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}
@media (max-width: 768px) {
  .project-partial__image-wrapper:hover img.project-partial__logo {
    width: 80%;
  }
}

/* Hover sur item - effets */
.project-partial__item:hover .project-partial__image-wrapper {
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.8);
}

.project-partial__item:hover .project-partial__image-wrapper img:nth-child(2),
.project-partial__item:hover .project-partial__image-wrapper img:not(.project-partial__logo) {
  transform: scale(1.05);
  filter: brightness(0.9);
}

/* Contenu du projet */
.project-partial__content h3 a {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 2.625rem;
  line-height: 1.9286;
  letter-spacing: -0.105rem;
  margin-bottom: 3.75rem;
  color: #fff;
  transition: color 0.3s ease;
}

/* Hover couleur titre projet */
.project-partial__item:hover .project-partial__content h3 {
  color: #f5b400;
}

.project-partial__view-all.link-arrow.ctaa {
  display: flex;
}
@media (max-width: 768px) {
  .project-partial__view-all.link-arrow.ctaa {
    justify-content: center;
  }
}

/* Bloc global */
.project-partial {
  color: #fff;
  font-family: "Poppins", sans-serif;
  background: transparent;
}
@media (max-width: 1024px) {
  .project-partial {
    padding-bottom: 20px !important;
  }
}
@media (max-width: 768px) {
  .project-partial {
    padding-bottom: 0 !important;
  }
}

/* Titre principal */
.project-partial__title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 4.125rem;
  line-height: 1.2273;
  letter-spacing: -0.165rem;
  text-align: center;
  margin-bottom: 5rem;
  max-width: 1050px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 1024px) {
  .project-partial__title h2 {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .project-partial__title h2 {
    margin-bottom: 0;
    max-width: 100% !important;
    font-family: "Poppins", sans-serif;
    font-weight: 600;
    font-size: 1.75rem !important;
    line-height: 1.1667;
    letter-spacing: 0;
  }
}

/* CTA */
.project-partial__cta {
  display: flex;
  justify-content: flex-end;
}

.project-partial__cta a {
  font-family: "Inter", sans-serif;
  font-weight: 700;
  font-size: 1.765rem;
  line-height: 1.416;
  letter-spacing: 0;
}
@media (max-width: 768px) {
  .project-partial__cta a {
    font-size: 1rem;
  }
}

/* Grille projets */
.project-partial__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
@media (max-width: 1100px) {
  .project-partial__list {
    display: none;
  }
}

/* Carte projet */
.project-partial__item {
  position: relative;
  overflow: hidden;
  min-height: 350px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
@media (max-width: 1100px) {
  .project-partial__item {
    align-items: center !important;
  }
}
@media (max-width: 1024px) {
  .project-partial__item {
    align-items: start !important;
  }
}

/* Contenu projet */
.project-partial__content {
  position: relative;
  z-index: 3;
  background: transparent;
  padding: 0.5rem 0;
  text-align: left;
}

/* Titre projet */
.project-partial__content h3 {
  margin: 0;
  font-size: 2.2rem;
  font-weight: 600;
  color: #fff;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
  transition: color 0.3s ease;
}
@media (max-width: 768px) {
  .project-partial__content h3 {
    font-weight: 500;
    font-size: 1.25rem;
    line-height: 26px;
    letter-spacing: -0.8px;
  }
}

/* Tags */
.project-partial__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  cursor: auto !important;
  padding-top: 10px;
}

span.project-partial__tag.left.tag-float {
  background: #ff8c78;
  width: 117px;
  height: 25px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #000;
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 0.75rem;
  line-height: 1;
  letter-spacing: 0;
  border-radius: 6px;
  text-decoration: none;
  flex-direction: row-reverse;
}

span.project-partial__tag.right.tag-float {
  width: 97px;
  height: 25px;
  background: white;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #000;
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 0.75rem;
  line-height: 1;
  letter-spacing: 0;
  border-radius: 6px;
  text-decoration: none;
}

/* Styles pour les liens dans les tags */
.project-partial__tag a {
  color: inherit;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-family: inherit;
  font-weight: inherit;
  font-size: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  margin: 0;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: inherit;
  transition: none;
}

span.project-partial__tag.left.tag-float a {
  flex-direction: row-reverse;
  gap: 2px;
}

.project-partial__tag a:hover {
  color: inherit;
  text-decoration: none;
  background: transparent;
  transform: none;
}

/* Style pour l'icône dans les tags */
.project-partial__tag-icon {
  margin-right: 8px;
  object-fit: contain;
}

.project-partial__tag-container-wrapper {
  display: flex;
  justify-content: space-between;
  padding-bottom: 15px;
}
@media (max-width: 768px) {
  .project-partial__tag-container-wrapper {
    padding-bottom: 30px;
  }
}

/* Tag individuel */
.tag {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 0.75rem;
  line-height: 2.0833;
  letter-spacing: 0;
  margin-bottom: 1.25rem;
  background: #262627;
  color: #fff;
  border-radius: 6px;
  padding: 0.3em 1em;
}
@media (max-width: 768px) {
  .tag {
    font-family: "Inter", sans-serif;
    font-weight: 600;
    font-size: 0.7rem;
    letter-spacing: 0;
    line-height: 1;
    margin-bottom: 2.25rem;
    font-size: 0.7rem;
  }
}

/* Responsive tablettes */
@media (max-width: 900px) {
  .project-partial__list {
    grid-template-columns: 1fr;
  }
  .project-partial__item {
    min-height: 250px;
  }
  .project-partial__title {
    font-size: 2rem;
  }
}
/* Swiper pagination */
.project-slider {
  height: fit-content;
}

@media (max-width: 768px) {
  .section-mobil .swiper-pagination.swiper-pagination-clickable.swiper-pagination-bullets.swiper-pagination-horizontal {
    bottom: 0 !important;
    top: auto !important;
  }
}
.project-slider .swiper {
  padding-bottom: 30px;
}

.project-slider .swiper-pagination {
  bottom: 0 !important;
}

.project-slider .swiper-pagination-bullet {
  background: #ffffff;
  opacity: 0.6;
  width: 15px;
  height: 8px;
  border-radius: 8px;
  margin: 0 4px;
  transition: all 0.3s;
}

.project-slider .swiper-pagination-bullet-active {
  background: #ffffff;
  opacity: 1;
  width: 48px;
}

.expertise-section__header {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 95px;
}

.expertise-section__header-left {
  width: 52%;
}
@media (max-width: 768px) {
  .expertise-section__header-left {
    width: 100%;
  }
}

.expertise-section__intro {
  margin-top: 6px;
}

.expertise-section__header-right {
  width: 50%;
}
@media (max-width: 768px) {
  .expertise-section__header-right {
    width: 100%;
  }
}

.expertise-section__tag {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #FF9A26;
  color: #222;
  font-weight: 500;
  border-radius: 6px;
  font-size: 0.875rem;
  font-family: "Roboto";
  width: 138px;
  height: 25px;
  gap: 8px;
  z-index: 2;
  margin-right: 123px;
}

.expertise-section__intro p {
  color: #DDD7D7;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.375rem;
  line-height: 1.7727;
  letter-spacing: 0;
  text-align: left;
}
@media (max-width: 768px) {
  .expertise-section__intro p {
    font-family: "Inter", sans-serif;
    font-weight: 400;
    font-size: 1rem;
    line-height: 1.5;
    letter-spacing: 0;
  }
}

.expertise-section__tag-container {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 17px;
}

.expertise-section__intro a {
  display: block !important;
  width: 50%;
}
@media (max-width: 1200px) {
  .expertise-section__intro a {
    padding-left: 0;
    display: flex;
    padding-top: 12px;
    padding-bottom: 18px;
    width: 100%;
  }
}

.expertise-section__title h2 {
  color: white;
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 2.875rem;
  line-height: 1.1304;
  letter-spacing: 0;
  text-align: left;
}
@media (max-width: 768px) {
  .expertise-section__title h2 {
    font-size: 1.75rem !important;
    line-height: 1.1667;
    letter-spacing: 0;
  }
}

.expertise-section__row {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin-top: 42px;
}

.expertise-section__card {
  background-color: #151515;
  border-radius: 16px;
  padding: 34px 40px;
  color: #fff;
  position: relative;
  flex: 1;
  height: 260px;
  display: flex;
  flex-direction: column;
  background-size: cover;
  background-position: center;
  overflow: hidden;
  border: 1px solid #2D2D2D;
}
@media (max-width: 768px) {
  .expertise-section__card {
    padding: 25px 20px;
  }
}

/* Logo card */
.expertise-section__card--logo {
  max-width: 391px;
  justify-content: center;
  align-items: center;
  display: flex;
  background-color: rgb(14, 14, 14);
}
@media (max-width: 768px) {
  .expertise-section__card--logo {
    display: none !important;
  }
}

.expertise-section__row.expertise-section__row--middle {
  margin-top: 22px;
}

.expertise-section__logo {
  max-width: 100%;
  height: auto;
}

/* Carte principale large */
.expertise-section__card--large {
  flex: 2;
}

/* Contenu des cartes */
.expertise-section__card-content h3 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 1.875rem;
  line-height: 1.3;
  letter-spacing: 0;
  text-align: left;
}
@media (max-width: 1024px) {
  .expertise-section__card-content h3 {
    font-size: 1.3rem;
  }
}

.expertise-section__card-content p {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.125rem;
  line-height: 1.4444;
  letter-spacing: 0;
  text-align: left;
  color: rgba(255, 255, 255, 0.88);
  padding-top: 20px;
}
@media (max-width: 1024px) {
  .expertise-section__card-content p {
    font-size: 1rem;
  }
}

.expertise-section__card.expertise-section__card--main.expertise-section__card--large h3 {
  padding-top: 15px;
}

/* Numéros */
.expertise-section__card-number {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 3.5781rem;
  line-height: 0.4384;
  letter-spacing: 0;
  padding-top: 15px;
}
@media (max-width: 768px) {
  .expertise-section__card-number {
    font-size: 2.5781rem;
  }
}

.expertise-section__row--bottom {
  display: flex;
  gap: 24px;
  margin-top: 40px;
}

.expertise-section__facts-video {
  flex: 1 1 0%;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #fff;
  border-radius: 14px;
  padding: 32px 36px;
}

.expertise-section__facts-box {
  display: flex;
  justify-content: space-between;
}

.expertise-section__facts-value {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 5.7756rem;
  line-height: 1.1962;
  letter-spacing: -0.3456rem;
  text-align: left;
}

.expertise-section__facts-label {
  align-self: flex-start;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 0.80625rem;
  line-height: 1.1426;
  letter-spacing: 0.04rem;
  text-transform: uppercase;
}

.expertise-section__facts-box.text-imgfac .expertise-section__facts- {
  align-self: flex-start !important;
}

.expertise-section__facts-right {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.expertise-section__facts-desc {
  font-family: "Inter", sans-serif;
  font-weight: 500;
  font-size: 1rem;
  line-height: 1.2525;
  letter-spacing: -0.0369rem;
  text-align: left;
}

.expertise-section__facts-box {
  flex: 0 0 390px;
  min-width: 220px;
  background: #F5B400;
  color: #181818;
  border-radius: 20px;
  padding: 32px 36px;
  display: flex;
  flex-direction: column;
}
@media (max-width: 768px) {
  .expertise-section__facts-box {
    flex: 0 0 290px;
  }
}

.expertise-section__card-header {
  display: flex;
  justify-content: space-between;
}

.cards-expertise-slider {
  display: none;
}

@media (max-width: 768px) {
  .expertise-section__header {
    flex-direction: column;
    gap: 0px;
  }
  .expertise-section__cards {
    grid-template-columns: 1fr;
    grid-template-rows: none;
  }
  .expertise-section__facts-row {
    flex-direction: column;
    gap: 16px;
  }
  .cards-expertise-slider {
    display: block;
  }
  .expertise-section__row {
    flex-direction: column;
    gap: 16px;
    display: none;
  }
  .expertise-section__card--logo,
  .expertise-section__facts-box {
    max-width: unset;
    min-width: unset;
    width: 100%;
  }
  .expertise-section__facts-video {
    width: 100%;
    min-width: unset;
  }
}
/* Layout for this demo */
.wrap {
  position: relative;
  max-width: 1000px;
  width: 90%;
  margin: 100px auto;
}

/* The outer-div to move the elements */
.box-video {
  position: relative;
  width: 100%;
  margin: 0 auto 20px auto;
  cursor: pointer;
  overflow: hidden;
}

/* Set Cover aka Background-Image */
.box-video .bg-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  z-index: 2;
}

/* Add light shade to make play button visible*/
.bg-video::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.1);
  z-index: 3;
}

/* The Play-Button using CSS-Only */
.box-video .bt-play {
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -30px 0 0 -30px;
  display: inline-block;
  width: 60px;
  height: 60px;
  background: rgba(255, 255, 255, 0.1);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 50%;
  text-indent: -999em;
  cursor: pointer;
  z-index: 2;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}

/* The Play-Triangle */
.box-video .bt-play:after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  height: 0;
  width: 0;
  margin: -12px 0 0 -6px;
  border: solid transparent;
  border-left-color: #000;
  border-width: 12px 20px;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}

.box-video:hover .bt-play {
  transform: scale(1.1);
}

/* When Class added the Cover gets hidden... */
.box-video.open .bg-video {
  visibility: hidden;
  opacity: 0;
  -webkit-transition: all 0.6s 0.8s;
  transition: all 0.6s 0.8s;
}

/* and iframe shows up */
.box-video.open .video-container {
  opacity: 1;
  -webkit-transition: all 0.6s 0.8s;
  transition: all 0.6s 0.8s;
}

/* Giving the div ratio of 16:9 with padding */
.video-container {
  position: relative;
  width: 100%;
  height: 0;
  margin: 0;
  z-index: 1;
  padding-bottom: 56.27198%;
}

.video-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* Styles pour le popup vidéo */
.video-popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

.video-popup.active {
  opacity: 1;
  visibility: visible;
}

.video-popup__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.9);
  backdrop-filter: blur(5px);
}

.video-popup__content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  max-width: 800px;
  max-height: 90vh;
  background: #000;
  border-radius: 14px;
  overflow: hidden;
}

.video-popup__close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 40px;
  height: 40px;
  background: rgba(0, 0, 0, 0.7);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.3s ease;
}

.video-popup__close:hover {
  background: rgba(0, 0, 0, 0.9);
}

.video-popup__iframe-container {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%; /* Ratio 16:9 */
}

.video-popup__iframe-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* Responsive pour le popup */
@media (max-width: 768px) {
  .video-popup__content {
    width: 95%;
    max-height: 80vh;
  }
  .video-popup__close {
    top: 10px;
    right: 10px;
    width: 35px;
    height: 35px;
  }
}
.popup-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  display: none;
  z-index: 1000;
  justify-content: center;
  align-items: center;
}

.popup-content {
  position: relative;
  max-width: 90%;
  max-height: 90%;
}

.popup-close {
  position: absolute;
  top: -40px;
  right: 0;
  color: white;
  font-size: 30px;
  cursor: pointer;
  background: none;
  border: none;
  font-weight: bold;
}

.popup-close:hover {
  color: #ccc;
}

.youtube-iframe {
  width: 560px;
  height: 315px;
  border: none;
}

.bg-center-link {
  width: 803px !important;
  height: 442px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 100%;
  border-radius: 20px;
}
@media (max-width: 768px) {
  .bg-center-link {
    width: 100% !important;
    height: 294px;
  }
}

.popup-youtube {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  padding: 20px;
  cursor: pointer;
  overflow: visible;
  z-index: 0;
  transition: transform 0.7s ease-in-out;
  background: rgba(11, 11, 11, 0.2);
}
@media (max-width: 768px) {
  .popup-youtube {
    padding: 20px;
  }
}

.popup-youtube:hover {
  transform: translate(-50%, -50%) scale(1.1);
}

.popup-youtube img {
  width: 30px;
  height: 30px;
  filter: brightness(1);
  transition: filter 0.3s ease;
}
@media (max-width: 768px) {
  .popup-youtube img {
    width: 25px;
    height: 25px;
  }
}

.popup-content {
  position: relative;
  background: #000;
  border-radius: 10px;
  max-width: 90vw;
  width: 1400px;
  aspect-ratio: 16/9;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.6);
  margin: auto;
  overflow: hidden;
}

.youtube-iframe {
  width: 100%;
  height: 100%;
  border: none;
  border-radius: 10px;
  display: block;
}

.popup-close {
  position: absolute;
  top: 10px;
  right: 14px;
  font-size: 28px;
  color: #fff;
  background: transparent;
  border: none;
  cursor: pointer;
  z-index: 10;
  transition: transform 0.2s ease;
}

.popup-close:hover {
  transform: scale(1.2);
}

@media (max-width: 600px) {
  .youtube-iframe {
    width: 100%;
    height: 200px;
  }
}
.last-post__tag-container {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 17px;
  padding: 0 50px;
}

.last-post__tag {
  background: #9DE0FD;
  width: 115px;
  height: 25px;
}

.last-post {
  color: #fff;
}

.last-post .container {
  margin: 0 auto;
  padding: 0;
}

.last-post__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 40px;
}

@media (max-width: 1024px) {
  .last-post__header {
    flex-direction: column;
    align-items: start;
    margin-bottom: 0px;
    gap: 10px;
  }
}
.last-post__title h1 {
  font-family: "Poppins", sans-serif;
  font-size: 4.125rem;
  line-height: 1.1667;
  letter-spacing: -0.04em;
  color: #fff;
  font-weight: 600;
  max-width: 700px;
  text-align: left;
}

@media (max-width: 768px) {
  .last-post__title h1 {
    font-size: 3rem !important;
    line-height: 1.1667;
    letter-spacing: 0;
    max-width: 100%;
    text-align: left;
  }
}
.last-post__view-all {
  font-family: "Inter", sans-serif;
  font-weight: 700;
  font-size: 1.765rem;
  line-height: 2.5rem;
  text-align: right;
  vertical-align: middle;
}

@media (max-width: 768px) {
  .last-post__view-all {
    font-size: 1rem;
  }
}
.last-post__view-all:hover {
  opacity: 0.8;
}

.last-post__view-all svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
}

.last-post__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}

@media (max-width: 1200px) {
  .last-post__grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 1200px) {
  .last-post__grid {
    display: none;
  }
}
@media (max-width: 768px) {
  .last-post__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 767px) {
  .last-post__grid {
    grid-template-columns: 1fr;
  }
}
.last-post__item {
  overflow: hidden;
  transition: transform 0.3s ease;
}

@media (max-width: 768px) {
  .last-post__item {
    /* width: 360px !important; */
  }
}
.last-post__item:hover {
  transform: translateY(-5px);
}

/* image container */
.last-post__image {
  aspect-ratio: 16/9;
  border-radius: 20px;
  overflow: visible;
  position: relative;
}

.last-post__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 20px;
  transition: transform 0.3s ease, filter 0.3s ease;
  display: block;
}

.last-post__item:hover .last-post__image img {
  filter: brightness(0.7);
  transition: transform 0.8s cubic-bezier(0.25, 0.1, 0.25, 1), filter 0.8s ease, opacity 0.8s ease;
}

.last-post__content {
  padding: 24px 0;
  text-align: left;
}

.last-post__category-tag {
  display: flex;
  gap: 12px;
}

.last-post__categories {
  display: flex;
  gap: 8px;
  justify-content: space-between;
}
@media (max-width: 768px) {
  .last-post__categories {
    align-items: center;
  }
}

.last-post__category {
  color: #fff;
}

.last-post__date {
  display: block;
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.6);
  font-family: "Inter", sans-serif;
  font-weight: 400;
  line-height: 1.89;
  text-transform: capitalize;
}

h2.last-post__item-title {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 1.375rem;
  line-height: 1;
  margin: 0 0 12px;
  padding-top: 15px;
  color: #fff;
  transition: color 0.3s ease;
}

@media (max-width: 1024px) {
  h2.last-post__item-title {
    font-size: 1.2rem !important;
    line-height: 1;
    letter-spacing: 0;
  }
}
/* changement couleur du titre au hover du bloc entier */
.last-post__item:hover h2.last-post__item-title {
  color: #FFB800;
}

.last-post__item-title a {
  color: #fff;
  text-decoration: none;
  transition: color 0.3s ease;
}

.last-post__item-title a:hover {
  color: #FFB800;
}

.last-post__excerpt {
  font-size: 0.875rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.8);
  margin: 0;
}

.last-post-slider {
  display: none;
}

@media (max-width: 1200px) {
  .last-post-slider {
    display: block;
  }
}
.about-section__right .formobile {
  display: none !important;
}

@media (max-width: 1024px) {
  .about-section__right .formobile {
    display: block !important;
  }
}
.forweb {
  display: block !important;
}

@media (max-width: 992px) {
  .forweb {
    display: none !important;
  }
}
.about-section__tag_first {
  width: 148px;
  height: 25px;
  background: #B3FD9D;
}

.about-section__tag-container.floatSmooth {
  display: flex;
  align-content: center;
  justify-content: center;
}

.about-section {
  overflow: hidden;
}

.about-section .container--about {
  display: grid;
  grid-template-columns: 0.5fr 1.5fr;
  gap: 40px;
  align-items: flex-start;
}
@media (max-width: 1024px) {
  .about-section .container--about {
    display: flex !important;
    flex-direction: column;
    gap: 0;
  }
}

.about-section__image-wrapper img {
  width: 100%;
  display: block;
  border-radius: 20px;
}

.about-section__image-wrapper--top {
  margin-bottom: 100px;
  width: 299px;
  height: 426px;
}
@media (max-width: 1024px) {
  .about-section__image-wrapper--top {
    width: 100%;
    height: auto;
    margin-bottom: 20px;
  }
}

.about-section__image-wrapper.about-section__image-wrapper--bottom {
  width: 570px;
}
@media (max-width: 1024px) {
  .about-section__image-wrapper.about-section__image-wrapper--bottom {
    width: 100%;
    height: auto;
  }
}

.about-section__text {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 1.7;
  letter-spacing: 0;
  vertical-align: middle;
  color: rgba(255, 255, 255, 0.8);
}

.about-section__title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 3.5rem;
  line-height: 1.14;
  letter-spacing: 0;
  vertical-align: middle;
  color: white;
}

.about-section__title {
  margin-bottom: 60px;
}
@media (max-width: 768px) {
  .about-section__title {
    margin-bottom: 30px;
  }
}

.sub-title p {
  color: white;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 1.875rem;
  line-height: 1.37;
  letter-spacing: 0;
  vertical-align: middle;
}
@media (max-width: 768px) {
  .sub-title p {
    font-family: "Poppins", sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 1.375rem;
    line-height: 1.75rem;
    letter-spacing: 0;
    vertical-align: middle;
  }
}

.about-section__text.about-section__text--right {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 1.7;
  letter-spacing: 0;
  vertical-align: middle;
}

.about-section__text.about-section__text--right p span {
  font-family: "Inter", sans-serif;
  font-weight: 500;
  font-size: 1.25rem;
  line-height: 1.7;
  letter-spacing: 0;
  vertical-align: middle;
}

.about-section__text--right {
  margin-bottom: 67px;
}

.about-section__bottom-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 38px;
}
@media (max-width: 1370px) {
  .about-section__bottom-content {
    display: flex;
    flex-direction: column;
  }
}
@media (max-width: 768px) {
  .about-section__bottom-content {
    gap: 15px;
  }
}

.about-section__figures {
  display: flex;
  flex-direction: column;
  gap: 45px;
}
@media (max-width: 1370px) {
  .about-section__figures {
    flex-direction: row;
    justify-content: space-around;
  }
}

/* key-figure */
.key-figure__number {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-size: 6.06rem;
  line-height: 0.44;
  letter-spacing: 0;
  vertical-align: middle;
  color: #FFFFFF;
}

.key-figure__label {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 0.85rem;
  line-height: 1.96;
  letter-spacing: 0;
  vertical-align: middle;
  color: rgba(255, 255, 255, 0.8);
}

.key-figure {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (max-width: 768px) {
  .key-figure {
    align-items: center;
  }
}

/* Responsive styles */
@media (max-width: 992px) {
  .about-section .container--about {
    grid-template-columns: 1fr;
  }
  .about-section__bottom-content {
    grid-template-columns: 1fr;
  }
  .about-section__figures {
    padding-left: 0;
    margin-top: 30px;
    flex-direction: row;
    justify-content: space-around;
  }
}
@media (max-width: 768px) {
  .about-section__title {
    font-size: 2rem;
  }
  .key-figure__number {
    font-size: 6.25rem;
  }
  .key-figure__label {
    font-size: 0.9rem;
    text-align: center;
  }
  .about-section__figures {
    flex-direction: column;
    align-items: center;
    gap: 70px;
  }
}
.nos-valeurs-section {
  color: #fff;
}

.nos-valeurs-section__header {
  text-align: center;
  margin-bottom: 40px;
  max-width: 920px;
  margin: 0 auto;
}

.nos-valeurs-section__tag {
  display: inline-flex;
  align-items: center;
  font-size: 1rem;
  font-weight: 600;
  border-radius: 8px;
  padding: 7px 22px 7px 16px;
  margin-bottom: 18px;
  background: #222;
  color: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
  gap: 10px;
}

.about-tag1-container {
  display: flex;
  justify-content: flex-end !important;
}

.about-tag2-container {
  display: flex;
  justify-content: flex-start !important;
}

.nos-valeurs-section__tag-icon {
  width: 28px;
  height: 28px;
  object-fit: contain;
  margin-right: 8px;
  display: inline-block;
  vertical-align: middle;
}

.nos-valeurs-section__title {
  max-width: 652px;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .nos-valeurs-section__title {
    width: 100%;
    max-width: 100%;
  }
}

.nos-valeurs-section__title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 4rem;
  line-height: 1.125;
  letter-spacing: -0.02em;
  text-align: center;
  vertical-align: middle;
}
@media (max-width: 768px) {
  .nos-valeurs-section__title h2 {
    text-align: left;
  }
}

.about-tag1 {
  width: 115px;
  height: 25px;
  background-color: #ff9a26;
}

.about-tag2 {
  width: 99px;
  height: 25px;
  background-color: #ff9a26;
}

.nos-valeurs-section__grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 32px;
}
@media (max-width: 1024px) {
  .nos-valeurs-section__grid {
    display: none;
  }
}

.valeurs-slider {
  display: none;
}
@media (max-width: 1024px) {
  .valeurs-slider {
    display: block;
  }
}

.valeurs-slider {
  background-color: transparent;
  display: none;
}

.valeur-card {
  flex: 1 1 calc(33.33% - 32px);
  max-width: calc(33.33% - 32px);
}

.valeur-card,
.valeurs-card {
  background: linear-gradient(to bottom, rgba(0, 0, 17, 0.0666666667) 85%, rgba(245, 180, 0, 0.15) 131%, rgba(245, 180, 49, 0) 0%) top left no-repeat;
  border-radius: 20px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.18);
  padding: 32px 24px 28px 24px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-height: 340px;
  transition: transform 0.18s, box-shadow 0.18s;
  border: 1px solid rgb(45, 45, 45);
}
@media (max-width: 768px) {
  .valeur-card,
  .valeurs-card {
    padding-bottom: 0 !important;
  }
}

@media (max-width: 768px) {
  .valeur-card p,
  .valeurs-card p {
    font-size: 16px !important;
  }
}

@media (max-width: 1024px) {
  .valeurs-card {
    gap: 30px;
  }
}
@media (max-width: 768px) {
  .valeurs-card {
    gap: 5px;
  }
}

.valeurs-card__title h3 {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 2rem;
  line-height: 2.4375rem;
  letter-spacing: 0;
}
@media (max-width: 768px) {
  .valeurs-card__title h3 {
    font-size: 1.3rem;
    margin-bottom: 10px;
  }
}

.valeur-card__icon {
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.valeur-card__icon img {
  object-fit: contain;
  margin-right: 0;
  display: block;
}

.valeur-card__title h3 {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 2rem;
  line-height: 1.22;
  letter-spacing: 0;
  color: #ffffff;
}

.valeur-card__desc p {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.125rem;
  line-height: 1.6875rem;
  letter-spacing: 0;
  color: rgba(255, 255, 255, 0.8);
  margin-bottom: 0 !important;
  margin-top: 23px;
}

@media (max-width: 768px) {
  .nos-valeurs-section__title {
    font-size: 1.5rem;
    margin-bottom: 30px;
  }
  .nos-valeurs-section__grid {
    gap: 18px;
  }
  .nos-valeurs-section__tag {
    font-size: 0.95rem;
    padding: 6px 12px 6px 10px;
  }
  .nos-valeurs-section__tag-icon {
    width: 22px;
    height: 22px;
    margin-right: 6px;
  }
  .valeur-card {
    padding: 20px 12px 18px 12px;
    min-height: 140px;
  }
  .valeur-card__icon img {
    width: 26px;
    height: 26px;
  }
  .valeur-card__title {
    font-size: 1.05rem;
  }
  .valeur-card__desc {
    font-size: 0.95rem;
  }
}
/* Pagination */
.swiper-pagination {
  text-align: center;
  margin-top: 20px;
  user-select: none;
}

.nos-valeurs-section__grid {
  padding-top: 50px;
}

.valeurs-slider .swiper-pagination-bullet {
  background: #ffffff;
  opacity: 0.6;
  width: 15px;
  height: 8px;
  border-radius: 8px;
  margin: 0 4px;
  transition: all 0.3s;
}

.valeurs-slider .swiper-pagination-bullet-active {
  background: #ffffff;
  opacity: 1;
  width: 48px;
}

a.about-section__tag.tag-float.about-tag2 {
  display: flex !important;
  flex-direction: row-reverse !important;
}

.our-technologies-section__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 48px;
  flex-wrap: wrap;
}
@media (max-width: 768px) {
  .our-technologies-section__header {
    gap: 12px !important;
    margin-bottom: 12px;
  }
}

.our-technologies-section__title {
  width: 537px;
}
@media (max-width: 900px) {
  .our-technologies-section__title {
    width: 100%;
  }
}

.our-technologies-section__header-left {
  flex: 1 1 350px;
  min-width: 300px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
@media (max-width: 900px) {
  .our-technologies-section__header-left {
    flex: auto;
  }
}

.our-technologies-section__icon-tag {
  object-fit: contain;
  margin-bottom: 4px;
}

.our-technologies-section__badge {
  display: inline-block;
  background: #FF4D29;
  color: #fff;
  font-size: 0.85rem;
  font-weight: 500;
  border-radius: 6px;
  padding: 3px 14px;
  margin-bottom: 8px;
  margin-top: 0;
  letter-spacing: 0.02em;
  align-self: flex-start;
}

.our-technologies-section__title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 2.875rem;
  line-height: 1.049;
  letter-spacing: -1.13px;
  vertical-align: middle;
  color: white;
}

.our-technologies-section__title strong,
.our-technologies-section__title b {
  color: #FFD600;
  font-weight: 700;
}

.our-technologies-section__header-right {
  flex: 1 1 350px;
  min-width: 300px;
  display: flex;
  justify-content: flex-end;
}
@media (max-width: 900px) {
  .our-technologies-section__header-right {
    flex: auto;
  }
}

.our-technologies-section__intro p {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 1.3317;
  letter-spacing: 0;
  vertical-align: middle;
  max-width: 420px;
  word-break: break-word;
  color: rgba(255, 255, 255, 0.8);
}

.our-technologies-section__intro p {
  margin: 0 0 10px 0;
}

.our-technologies-section__cards {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.our-technologies-section__card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  background: transparent;
  border: 1px solid;
  border-image-source: linear-gradient(95.07deg, #2D2D2D 19.79%, #F5B400 49.47%, #2D2D2D 79.15%);
  border-image-slice: 1;
  border-image-repeat: round;
  border-radius: 20px !important;
  padding: 47px 47px;
  gap: 24px;
  box-shadow: none;
  transition: border-color 0.3s;
  overflow: hidden;
  height: 360px;
}
@media (max-width: 768px) {
  .our-technologies-section__card {
    height: 310px;
    gap: 0px;
  }
}

.our-technologies-section__card:hover {
  border-color: #FFD600;
}

.our-technologies-section__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  margin-right: 18px;
  gap: 28px;
}

span.our-technologies.tag-float {
  background: #FF8C78;
  width: 149px;
  height: 25px;
}

.our-technologies-section__card-content {
  flex: 1;
}

.our-technologies-section__card-title h3 {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 3rem;
  line-height: 1.04;
  letter-spacing: 0;
  color: #fff;
}
@media (max-width: 786px) {
  .our-technologies-section__card-title h3 {
    font-size: 1.25rem !important;
  }
}

.our-technologies-section__card-title strong,
.our-technologies-section__card-title b {
  color: #FFD600;
  font-weight: 700;
}

.our-technologies-section__card-desc p {
  color: #DDD7D7;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.75rem;
  line-height: 1.43;
  letter-spacing: 0;
}

.our-technologies-section__card-desc p {
  margin: 15px 0 10px 0;
}

/* Responsive */
@media (max-width: 900px) {
  .our-technologies-section__header {
    flex-direction: column;
    gap: 24px;
  }
  .our-technologies-section__cards {
    gap: 20px;
  }
  .our-technologies-section__card {
    flex-direction: column;
    align-items: flex-start;
    padding: 24px 16px;
  }
  .our-technologies-section__icon {
    margin-bottom: 12px;
    margin-right: 0;
  }
  .our-technologies-section__icon img {
    width: 50px;
  }
}
.section-spacing.cta {
  padding-top: 100px !important;
  text-align: center;
  padding-bottom: 36px;
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cta a p {
  color: #000000 !important;
  font-weight: 600 !important;
}

.cta a {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  background: #F5B400;
  padding: 18px 28px;
  border-radius: 6px;
  color: #000;
  font-weight: 600;
  font-size: 20px;
  overflow: hidden;
  transition: color 0.3s ease;
  cursor: pointer;
  text-decoration: none;
  width: 600px;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: badgePulse 3s ease-in-out infinite;
  transition: background-color 0.4s ease-in-out, transform 0.3s ease-in-out;
}
@media (max-width: 768px) {
  .cta a {
    width: 300px;
  }
}

.cta a:hover {
  transform: translateY(-3px);
  background-color: #F6C232;
}

/* La couche d'arrière-plan animée */
@keyframes gradientShift {
  0%, 100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}
@keyframes badgePulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
}
.cta a p {
  margin-bottom: 0 !important;
  font-weight: 600 !important;
}

.text-image-chiffre__title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 3.375rem;
  line-height: 1.296;
  letter-spacing: -1.13px;
  vertical-align: middle;
  color: #fff;
}

span.text-image-chiffre__tag {
  height: 25px;
  background: #E29DFD;
  width: 102px;
}

.class2 .text-image-chiffre__tag {
  height: 25px;
  background: #B3FD9D;
  width: 118px;
}

.class2 .text-image-stat__main-row.section-spacing {
  display: none;
}

.text-image-chiffre__tag-container.floatSmooth {
  display: flex;
  align-items: center;
  justify-content: center;
}

.text-image-chiffre__content {
  display: flex;
  gap: 40px;
  align-items: flex-start;
  margin-top: 30px;
}
@media (max-width: 1024px) {
  .text-image-chiffre__content {
    flex-direction: column;
    gap: 24px;
  }
}

@media (max-width: 900px) {
  .text-image-chiffre__content {
    flex-direction: column;
    gap: 24px;
  }
}
.text-image-chiffre__image {
  width: 611px;
}
@media (max-width: 1024px) {
  .text-image-chiffre__image {
    width: 100%;
  }
}

.text-image-chiffre__image img {
  width: 100%;
  display: block;
  border-radius: 20px;
}

.text-image-chiffre__description {
  flex: 1;
}

.text-image-chiffre__description ul {
  list-style-type: disc;
  padding-left: 30px;
}

.text-image-chiffre__description ul li {
  margin-bottom: 8px;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 2.125rem;
  letter-spacing: 0;
  vertical-align: middle;
  color: rgba(255, 255, 255, 0.8);
}

.text-image-chiffre__description strong {
  color: #fff !important;
}

.text-image-chiffre__stats {
  display: flex;
  gap: 60px;
  justify-content: flex-start;
  margin-top: 32px;
}

@media (max-width: 700px) {
  .text-image-chiffre__stats {
    flex-direction: column;
    gap: 24px;
  }
}
.text-image-chiffre__stat {
  text-align: center;
}

.text-image-chiffre__stat-number {
  font-size: 9.125rem;
  font-weight: 400;
  line-height: 1.2;
  font-family: "Poppins", sans-serif;
  padding-top: 27px;
  color: #fff;
}

.text-image-chiffre__stat-label p {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.375rem;
  line-height: 1.818;
  letter-spacing: 0;
  vertical-align: middle;
}

.class2 .flex-cl {
  display: flex;
  flex-direction: column-reverse;
}

.class2 .text-image-chiffre__image {
  width: 462px;
}
@media (max-width: 1024px) {
  .class2 .text-image-chiffre__image {
    width: 100%;
  }
}

.parcours-section {
  color: #fff;
  font-family: "Inter", Arial, sans-serif;
}

.parcours-section__container {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 112px;
}
@media (max-width: 1024px) {
  .parcours-section__container {
    flex-direction: column;
    gap: 0;
  }
}

.parcours-section__step-icon img {
  height: 50px !important;
  max-width: 50px !important;
  width: 50px !important;
}

.parcours-section__left {
  flex: 1 1 588px;
}
@media (max-width: 1024px) {
  .parcours-section__left {
    flex: auto;
  }
}

.parcours-section__title {
  position: relative;
}

.agence-web-maroc .parcours-section__tag-container1.floatSmooth {
  position: absolute;
  bottom: 11%;
  left: 80%;
}

.agence-web-maroc .parcours-section__tag-container2.floatSmooth {
  bottom: 23%;
  position: absolute;
  left: 32%;
}

.parcours-section__tag-container1.floatSmooth {
  position: absolute;
  bottom: 40%;
  right: 35px;
}

.class1.class3 .parcours-section__tag-container1.floatSmooth {
  position: absolute;
  bottom: 18%;
  right: 35px;
}

.class1.class3 .parcours-section__tag-container2.floatSmooth {
  position: absolute;
  bottom: 46%;
  left: 30%;
}

.class2 .parcours-section__tag-container2.floatSmooth {
  position: absolute;
  right: 63%;
  bottom: 14%;
}

.parcours-section__tag1 {
  width: 140px;
  height: 25px;
  background: #FFDE6A;
}

.class1.class3 .parcours-section__tag1 {
  width: 84px !important;
}

.class2 .parcours-section__tag1 {
  width: 103px;
  height: 25px;
  background: #FFDE6A;
}

.class2 span.parcours-section__tag2.tag-float {
  width: 84px;
  height: 25px;
  background: #FF976A;
}

span.parcours-section__tag2.tag-float {
  width: 124px;
  height: 25px;
  background: #FF976A;
}

.class2 .class3 .parcours-section__tag1.tag-float {
  width: 93px;
}

.expertises-1 a.text-image__tag3.tag-float,
a.text-image__tag3.tag-float {
  left: 35%;
  position: relative;
  padding-bottom: 25px;
}

.parcours-section__title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 3.375rem;
  line-height: 1.296;
  letter-spacing: -1.13px;
  vertical-align: middle;
  padding-bottom: 40px;
}
@media (max-width: 768px) {
  .parcours-section__title h2 {
    padding-bottom: 20px;
  }
}

.parcours-section__step-icon h3 {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.625;
  letter-spacing: 0;
}
@media (max-width: 768px) {
  .parcours-section__step-icon h3 {
    font-size: 1.4rem;
    line-height: 1.4;
  }
}

.parcours-section__highlight {
  color: #ffc12b;
  font-weight: 700;
}

.parcours-section__badges {
  display: flex;
  gap: 10px;
  margin-bottom: 18px;
}

.parcours-section__badge {
  display: inline-block;
  font-size: 0.85rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 6px;
}

.parcours-section__badge--yellow {
  background: #ffc12b;
  color: #222;
}

.parcours-section__badge--orange {
  background: #ff7e29;
  color: #fff;
}

.parcours-section__desc {
  font-size: 1.05rem;
  color: #ccc;
  margin-bottom: 24px;
  line-height: 1.5;
}

.parcours-section__link {
  display: inline-block;
  font-weight: 700;
  color: #ffc12b;
  text-decoration: none;
  font-size: 1.1rem;
  margin-top: 20px;
  transition: color 0.2s;
}

.parcours-section__link:hover {
  color: #fff;
}

.parcours-section__cta {
  display: inline-block;
  font-weight: 700;
  color: #ffc12b;
  text-decoration: none;
  font-size: 1.1rem;
  margin-top: 10px;
  transition: color 0.2s;
}

.parcours-section__cta:hover {
  color: #fff;
}

.parcours-section__cta-arrow {
  margin-left: 4px;
  font-size: 1.1em;
}

.parcours-section__right {
  flex: 1 1 588px;
}

.parcours-section__steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.parcours-section__step {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  font-size: 1rem;
  flex-direction: column;
}
@media (max-width: 1024px) {
  .parcours-section__step {
    gap: 10px;
  }
}

.parcours-section__step-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

.parcours-section__step strong {
  color: #fff;
}

.parcours-section__step span {
  display: block;
  color: #bbb;
  font-size: 0.98em;
  margin-top: 2px;
}

@media (max-width: 768px) {
  .parcours-section__container {
    flex-direction: column;
    gap: 20px;
  }
  .parcours-section__left,
  .parcours-section__right {
    min-width: 0;
  }
}
.faq {
  background: #0E0E0E;
  position: relative;
}

button:focus {
  outline: none !important;
  box-shadow: none !important;
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  padding: 0 1.5rem;
  margin-top: 0;
  transition: max-height 0.4s ease, padding 0.4s ease, margin-top 0.4s ease;
  border-radius: 0 0 8px 8px;
  color: rgba(255, 255, 255, 0.9);
  font-size: 1rem;
  line-height: 1.6;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.125rem;
  line-height: 1.555;
  letter-spacing: 0;
  vertical-align: middle;
}
@media (max-width: 768px) {
  .faq-answer {
    font-size: 1rem !important;
  }
}

.faq-question.active + .faq-answer {
  margin: 1.5rem 0;
  margin-top: -0.5rem;
}

.faq-item + .faq-item {
  margin-top: 1rem;
}

.faq-question {
  text-align: center;
  width: 100%;
  background: none;
  border: none;
  color: #fff;
  text-align: left;
  padding: 0.5rem 2rem;
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: background 0.2s;
}
@media (max-width: 1024px) {
  .faq-question {
    padding: 2rem 1rem;
  }
}
@media (max-width: 768px) {
  .faq-question {
    font-size: 1rem !important;
    line-height: 1.3;
  }
}

.faq-question h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 1.25rem !important;
  line-height: 3.6;
  letter-spacing: 0;
}
@media (max-width: 1024px) {
  .faq-question h2 {
    line-height: 1.4 !important;
  }
}

button.faq-question.active {
  color: #F5B400;
}

@media (max-width: 768px) {
  span.faq-toggle svg {
    width: 18px !important;
  }
}

.faq-item {
  border: 1px solid #202020;
  border-radius: 12px;
}

.faq-question.active,
.faq-question:hover {
  background: #0D0D0D;
}

.faq-toggle {
  font-size: 1.2rem;
  transition: transform 0.2s;
}

.faq-question.active .faq-toggle {
  transform: rotate(180deg);
}

.expertise-section {
  padding-top: 60px;
}

.expertise-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

.expertise-card {
  break-inside: avoid;
  margin-bottom: 20px;
  box-sizing: border-box;
  display: inline-block;
  width: 100%;
}
@media (max-width: 1024px) {
  .expertise-card {
    margin-bottom: 20px;
  }
}

.expertise-secondary-cards .expertise-card:nth-child(1) {
  height: 590px;
}
@media (max-width: 1024px) {
  .expertise-secondary-cards .expertise-card:nth-child(1) {
    margin-top: 0px;
    height: 100%;
  }
}

.expertise-card:nth-child(2) {
  height: 649px;
}
@media (max-width: 1024px) {
  .expertise-card:nth-child(2) {
    height: 100%;
  }
}

.expertise-card:nth-child(3) {
  margin-top: -60px;
  height: 620px;
}
@media (max-width: 1024px) {
  .expertise-card:nth-child(3) {
    margin-top: 0px;
    height: 100%;
  }
}

.expertise-card:nth-child(5) {
  margin-top: -250px;
}
@media (max-width: 1024px) {
  .expertise-card:nth-child(5) {
    margin-top: 0px;
  }
}

@media (max-width: 1024px) {
  .expertise-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.expertise-card {
  background: #131313;
  border-radius: 18px;
  padding: 36px 32px 0px 32px;
  color: #fff;
  box-shadow: 0 2px 24px rgba(0, 0, 0, 0.6666666667);
  position: relative;
  border: 1.5px solid #232323;
}
@media (max-width: 768px) {
  .expertise-card {
    padding: 36px 15px 0px 15px;
  }
}

.expertise-card .expertise-card-header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 18px;
}
@media (max-width: 1400px) {
  .expertise-card .expertise-card-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
  }
}

pre {
  display: block;
  font-family: monospace;
  white-space: pre;
}

.expertise-card-header h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 3.375rem;
  line-height: 1;
  letter-spacing: -1.13px;
  vertical-align: middle;
}

.expertise-card--secondary .expertise-card-header h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 1.75rem;
  line-height: 1.5;
  letter-spacing: 0;
  vertical-align: middle;
  width: 368px;
}
@media (max-width: 768px) {
  .expertise-card--secondary .expertise-card-header h2 {
    width: 100% !important;
  }
}

.expertise-description pre {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 1.25rem;
  line-height: 1.65;
  letter-spacing: -1.13px;
  vertical-align: middle;
  color: rgb(255, 255, 255);
}

.expertise-description p {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6875;
  letter-spacing: 0;
  vertical-align: middle;
}

.expertise-card .expertise-list li strong {
  color: #fff;
  font-weight: 700;
}

.expertise-card .expertise-list li p {
  margin: 0;
  color: #ccc;
  font-size: 1em;
}

.expertise-card .expertise-icons {
  margin-top: 22px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.expertise-card .expertise-icons img,
.expertise-card .expertise-icons svg {
  width: 36px;
  height: 36px;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.4));
  background: #222;
  border-radius: 8px;
  padding: 4px;
  transition: background 0.2s;
}

.expertise-card .expertise-icons img:hover,
.expertise-card .expertise-icons svg:hover {
  background: rgba(245, 180, 0, 0.1333333333);
}

.expertise-card .expertise-image {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-top: 20px;
}

.expertise-card--full-left .expertise-card-header .expertise-link {
  position: absolute;
  right: 40px;
  top: 44px;
  z-index: 1;
}
@media (max-width: 768px) {
  .expertise-card--full-left .expertise-card-header .expertise-link {
    position: relative;
    right: auto;
    left: auto;
    top: 0px !important;
  }
}

/* Colonne gauche - 20% */
.expertise-card .expertise-image p {
  flex: 0 0 20%;
  margin: 0;
  color: #fff;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6875;
}

/* Colonne centrale - 60% */
.expertise-card .expertise-image img {
  flex: 0 0 60%;
  height: auto;
}

.expertise-card--full {
  grid-column: 1/-1;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  gap: 40px;
  height: 604px;
}
@media (max-width: 1024px) {
  .expertise-card--full {
    height: 1040px;
    flex-direction: column;
  }
}

.expertise-card--full .expertise-card--full-left {
  flex: 1 1 60%;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
@media (max-width: 1024px) {
  .expertise-card--full .expertise-card--full-left {
    flex: inherit;
  }
}

.expertise-card--full .expertise-card--full-left .expertise-card-header {
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 18px;
}
@media (max-width: 768px) {
  .expertise-card--full .expertise-card--full-left .expertise-card-header {
    flex-direction: column;
    gap: 20px;
    margin: 0;
  }
}

.expertise-card--full .expertise-title {
  font-size: 2.1rem;
  font-weight: 800;
  letter-spacing: -1px;
}

.expertise-card--full .expertise-title .highlight {
  color: #F5B400;
}

.expertise-card--full .expertise-link {
  color: #F5B400;
  font-weight: 700;
  text-decoration: none;
  font-size: 1.05rem;
  display: flex;
  align-items: center;
  gap: 3px;
  transition: color 0.2s;
}

.expertise-card--full .expertise-link:hover {
  color: #fff200;
}

.expertise-card--full .expertise-link span {
  font-size: 1.1em;
}

.expertise-card--full .expertise-description {
  margin-top: 24px;
}

.expertise-card--full .expertise-card--full-right {
  flex-direction: column;
  flex: 1 1 40%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.expertise-card--full .expertise-card--full-right .expertise-image {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

/* Colonne gauche - 20% */
.expertise-card--full .expertise-card--full-right .expertise-image p {
  flex: 0 0 20%;
  margin: 0;
  color: #fff;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6875;
}

/* Colonne centrale - 60% */
.expertise-card--full .expertise-card--full-right .expertise-image img {
  flex: 0 0 60%;
  height: auto;
}

@media (max-width: 900px) {
  .expertise-card--full {
    flex-direction: column;
    gap: 20px;
  }
  .expertise-card--full .expertise-card--full-right {
    margin-top: 24px;
  }
}
.cards-expertise-slider .pagination {
  position: relative !important;
}

.cards-expertise-slider .swiper-pagination {
  bottom: 0 !important;
}

.cards-expertise-slider.swiper-pagination-bullet {
  background: #ffffff;
  opacity: 0.6;
  width: 15px;
  height: 8px;
  border-radius: 8px;
  margin: 0 4px;
  transition: all 0.3s;
}

.cards-expertise-slider .swiper-pagination-bullet-active {
  background: #ffffff;
  opacity: 1;
  width: 48px;
}

span.tag-float.tag-float1 {
  background: #F5B400;
  height: 25px;
  width: 100px;
}

span.tag-float.tag-float2 {
  background: #F99898;
  height: 25px;
  width: 100px;
}

.expertise-card-badges1 {
  position: absolute;
  right: 11px;
  top: 41%;
}

.expertise-card-badges2 {
  position: absolute;
  bottom: 10%;
  right: 36%;
}

.expertise-card-badges {
  position: relative;
  display: flex;
  justify-content: space-between;
}

.expertise-card-badge-text.tag-float.tag-float {
  left: 0;
  position: absolute;
  bottom: -300px;
  display: flex;
  flex-direction: row-reverse;
  background: #94E48C;
  height: 25px;
  width: 110px;
}

.expertise-link p {
  margin: 0;
}

.expertise-section__card--main {
  position: relative;
  overflow: hidden;
  cursor: pointer;
}

.expertise-section__card.expertise-section__card--main.expertise-section__card--large::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("/app/uploads/2025/07/pexels-tranmautritam-326503-1-2.png");
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 0.5s ease;
  z-index: 0;
}
@media (max-width: 768px) {
  .expertise-section__card.expertise-section__card--main.expertise-section__card--large::before {
    opacity: 1 !important;
    z-index: 1;
  }
}

.expertise-section__row--middle .expertise-section__card-link:first-child .expertise-section__card::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("/app/uploads/2025/07/Conception.png");
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 0.5s ease;
  z-index: 0;
}
@media (max-width: 768px) {
  .expertise-section__row--middle .expertise-section__card-link:first-child .expertise-section__card::before {
    opacity: 1 !important;
    z-index: 1;
  }
}

.expertise-section__row--middle .expertise-section__card-link:nth-child(2) .expertise-section__card::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("/app/uploads/2025/07/Communication.png");
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 0.5s ease;
  z-index: 0;
}
@media (max-width: 768px) {
  .expertise-section__row--middle .expertise-section__card-link:nth-child(2) .expertise-section__card::before {
    opacity: 1 !important;
    z-index: 1;
  }
}

.expertise-section__card.expertise-section__card--main.expertise-section__card--large:hover::before {
  opacity: 1;
}

.expertise-section__card-link:first-child .expertise-section__card:hover::before {
  opacity: 1;
}

.expertise-section__card-link:nth-child(2) .expertise-section__card:hover::before {
  opacity: 1;
}

.expertise-section__card-content {
  position: relative;
  z-index: 1;
}

a.expertise-section__card-link {
  flex: 2;
}

/* Pagination */
.all-projects__pagination {
  display: flex;
  justify-content: center;
  margin-top: 3rem;
}
@media (max-width: 768px) {
  .all-projects__pagination {
    margin-top: 2rem;
  }
}

.pagination_realisation {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-family: "Inter", sans-serif;
}
@media (max-width: 768px) {
  .pagination_realisation {
    gap: 0.5rem;
  }
}

.pagination__prev,
.pagination__next {
  display: flex;
  align-items: center;
  padding: 0.75rem 0.5rem;
  background: #262627;
  color: #fff;
  text-decoration: none;
  border-radius: 6px;
  font-weight: 600;
  font-size: 1.5rem;
  transition: background-color 0.3s ease;
}
.pagination__prev:hover,
.pagination__next:hover {
  background: #F5B400;
  color: #000;
}
@media (max-width: 768px) {
  .pagination__prev,
  .pagination__next {
    padding: 0.5rem 1rem;
    font-size: 0.8rem;
  }
}

.pagination__numbers {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.pagination__link,
.pagination__current {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 6px;
  font-weight: 600;
  font-size: 0.875rem;
  text-decoration: none;
  transition: all 0.3s ease;
}
@media (max-width: 768px) {
  .pagination__link,
  .pagination__current {
    width: 2rem;
    height: 2rem;
    font-size: 0.8rem;
  }
}

.pagination__link {
  background: #262627;
  color: #fff;
}
.pagination__link:hover {
  background: #F5B400;
  color: #000;
}

.pagination__current {
  background: #F5B400;
  color: #000;
}

/* Responsive pagination */
@media (max-width: 480px) {
  .pagination {
    flex-direction: column;
    gap: 1rem;
  }
}
/* Wrapper image */
.all-projects__image-wrapper {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  height: 675px;
  transition: box-shadow 0.3s ease;
}
@media (max-width: 1200px) {
  .all-projects__image-wrapper {
    height: 598px !important;
  }
}
@media (max-width: 1024px) {
  .all-projects__image-wrapper {
    width: 100% !important;
    height: 598px !important;
  }
}
@media (max-width: 768px) {
  .all-projects__image-wrapper {
    width: 100%;
    height: 304px !important;
  }
}
@media (max-width: 400px) {
  .all-projects__image-wrapper {
    width: 100%;
    height: 304px !important;
  }
}

/* Image principale (2e enfant, sauf logo) */
.all-projects__image-wrapper img:nth-child(2),
.all-projects__image-wrapper img:not(.all-projects__logo) {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  filter: brightness(0.7);
  border-radius: 20px;
  transform: scale(1);
  opacity: 1;
  transition: transform 0.8s cubic-bezier(0.25, 0.1, 0.25, 1), filter 0.8s ease, opacity 0.8s ease;
}
@media (max-width: 768px) {
  .all-projects__image-wrapper img:nth-child(2),
  .all-projects__image-wrapper img:not(.all-projects__logo) {
    border-radius: 12px;
  }
}

/* Logo positionné */
.all-projects__logo {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
}

/* Logo centré, masqué par défaut */
.all-projects__image-wrapper img.all-projects__logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.8);
  opacity: 0.8;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

/* Hover sur wrapper image (logo) */
.all-projects__image-wrapper:hover img.all-projects__logo {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

/* Hover sur item - effets */
.all-projects__item:hover .all-projects__image-wrapper {
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.8);
}

.all-projects__item:hover .all-projects__image-wrapper img:nth-child(2),
.all-projects__item:hover .all-projects__image-wrapper img:not(.all-projects__logo) {
  transform: scale(1.05);
  filter: brightness(0.9);
}

/* Contenu du projet */
.all-projects__content h3 a {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 2.625rem;
  line-height: 1.9286;
  letter-spacing: -0.105rem;
  margin-bottom: 3.75rem;
  color: #fff;
  transition: color 0.3s ease;
}

/* Hover couleur titre projet */
.all-projects__item:hover .all-projects__content h3 {
  color: #F5B400;
}

/* Bloc global */
.all-projects {
  color: #fff;
  font-family: "Poppins", sans-serif;
  background: transparent;
  padding-bottom: 98px !important;
}
@media (max-width: 1024px) {
  .all-projects {
    padding-bottom: 20px !important;
  }
}
@media (max-width: 768px) {
  .all-projects {
    padding-bottom: 0 !important;
  }
}

/* Titre principal */
.all-projects__title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 4.125rem;
  line-height: 1.2273;
  letter-spacing: -0.165rem;
  text-align: center;
  margin-bottom: 5rem;
  max-width: 1050px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 1024px) {
  .all-projects__title h2 {
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .all-projects__title h2 {
    margin-bottom: 0;
    max-width: 100% !important;
    font-family: "Poppins", sans-serif;
    font-weight: 600;
    font-size: 1.75rem !important;
    line-height: 1.1667;
    letter-spacing: 0;
  }
}

/* CTA */
.all-projects__cta {
  display: flex;
  justify-content: flex-end;
}

.all-projects__cta a {
  font-family: "Inter", sans-serif;
  font-weight: 700;
  font-size: 1.765rem;
  line-height: 1.416;
  letter-spacing: 0;
}
@media (max-width: 768px) {
  .all-projects__cta a {
    font-size: 1rem;
  }
}

/* Grille projets */
.all-projects__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
/* Carte projet */
.all-projects__item {
  position: relative;
  overflow: hidden;
  min-height: 350px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
@media (max-width: 1100px) {
  .all-projects__item {
    align-items: center !important;
  }
}
@media (max-width: 1024px) {
  .all-projects__item {
    align-items: start !important;
  }
}

/* Contenu projet */
.all-projects__content {
  position: relative;
  z-index: 3;
  background: transparent;
  padding: 0.5rem 0;
  text-align: left;
}

/* Titre projet */
.all-projects__content h3 {
  margin: 0;
  font-size: 2.2rem;
  font-weight: 600;
  color: #fff;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
  transition: color 0.3s ease;
}
@media (max-width: 768px) {
  .all-projects__content h3 {
    font-weight: 500;
    font-size: 1.25rem;
    line-height: 26px;
    letter-spacing: -0.8px;
  }
}

/* Tags */
.all-projects__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  cursor: auto !important;
  padding-top: 10px;
}

span.all-projects__tag.left.tag-float {
  background: #FF8C78;
  width: 117px;
  height: 25px;
}

span.all-projects__tag.right.tag-float {
  width: 97px;
  height: 25px;
  background: white;
}

.all-projects__tag-container-wrapper {
  display: flex;
  justify-content: space-between;
  padding-bottom: 15px;
}
@media (max-width: 768px) {
  .all-projects__tag-container-wrapper {
    padding-bottom: 30px;
  }
}

/* Tag individuel */
.tag {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 0.75rem;
  line-height: 2.0833;
  letter-spacing: 0;
  margin-bottom: 1.25rem;
  background: #262627;
  color: #fff;
  border-radius: 6px;
  padding: 0.3em 1em;
}
@media (max-width: 768px) {
  .tag {
    font-family: "Inter", sans-serif;
    font-weight: 600;
    font-size: 0.7rem;
    letter-spacing: 0;
    line-height: 1;
    margin-bottom: 0rem;
    font-size: 0.7rem;
    padding: 0.5em 1em;
  }
}

/* Responsive tablettes */
@media (max-width: 900px) {
  .all-projects__list {
    grid-template-columns: 1fr;
  }
  .all-projects__item {
    min-height: 250px;
  }
  .all-projects__title {
    font-size: 2rem;
  }
}
/* Swiper pagination */
.project-slider {
  height: fit-content;
}

@media (max-width: 768px) {
  .section-mobil .swiper-pagination.swiper-pagination-clickable.swiper-pagination-bullets.swiper-pagination-horizontal {
    bottom: 0 !important;
    top: auto !important;
    display: none;
  }
}
.project-slider .swiper {
  padding-bottom: 30px;
}

.project-slider .swiper-pagination {
  bottom: 0 !important;
}

.project-slider .swiper-pagination-bullet {
  background: #ffffff;
  opacity: 0.6;
  width: 15px;
  height: 8px;
  border-radius: 8px;
  margin: 0 4px;
  transition: all 0.3s;
}

.project-slider .swiper-pagination-bullet-active {
  background: #ffffff;
  opacity: 1;
  width: 48px;
}

span.text-image-stat__tag.tag-float {
  background: #B3FD9D;
  width: 108px;
  height: 25px;
}

span.text-image-stat__tag3.tag-float {
  background: #464646;
  color: #fff;
  width: 108px;
  height: 25px;
}

.class2 .text-image-stat__tag3.tag-float {
  background: #FF8C78;
  color: #1C1A1A;
  width: 108px;
  height: 25px;
}

.text-image-stat__tag-container.floatSmooth {
  position: relative;
}

.expertises-2 a.parcours-section__tag1.tag-float {
  width: 84px;
}

.expertises-2 .parcours-section__tag-container1.floatSmooth {
  position: absolute;
  bottom: 18%;
  right: 35px;
}

.expertises-2 .parcours-section__tag-container2.floatSmooth {
  position: absolute;
  bottom: 44%;
  left: 31%;
}

.expertises-3 a.parcours-section__tag1.tag-float {
  width: 85px;
}

.expertises-4 a.parcours-section__tag1.tag-float {
  width: 85px;
}

.expertises-5 a.parcours-section__tag1.tag-float {
  width: 85px;
}

.expertises-6 a.parcours-section__tag1.tag-float {
  width: 85px;
}

.expertises-3 .parcours-section__tag-container1.floatSmooth {
  position: absolute;
  bottom: 7%;
  right: 35px;
}

.expertises-3 .parcours-section__tag-container2.floatSmooth {
  position: absolute;
  left: 30%;
  bottom: 42.7%;
}

.expertises-4 .parcours-section__tag-container1.floatSmooth {
  position: absolute;
  bottom: 7%;
  right: 35px;
}

.expertises-4 .parcours-section__tag-container2.floatSmooth {
  position: absolute;
  left: 30%;
  bottom: 26%;
}

.expertises-5 .parcours-section__tag-container1.floatSmooth {
  position: absolute;
  bottom: 7%;
  right: 35px;
}

.expertises-5 .parcours-section__tag-container2.floatSmooth {
  position: absolute;
  left: 30%;
  bottom: 37%;
}

.expertises-6 .parcours-section__tag-container1.floatSmooth {
  position: absolute;
  bottom: 7%;
  right: 35px;
}

.expertises-6 .parcours-section__tag-container2.floatSmooth {
  position: absolute;
  left: 31%;
  bottom: 27%;
}

a.text-image__tag4.tag-float {
  position: absolute;
  left: 49%;
  bottom: 12px;
}

.text-image-stat__main-row {
  display: flex;
  align-items: flex-start;
  gap: 2.5rem;
  position: relative;
}
@media (max-width: 900px) {
  .text-image-stat__main-row {
    flex-direction: column;
    gap: 1.5rem;
  }
}

.text-image-stat__image-col {
  flex: 0 0 365px;
}
@media (max-width: 900px) {
  .text-image-stat__image-col {
    flex: 1 1 100%;
    max-width: 100%;
  }
}

.text-image-stat__image {
  width: 100%;
  border-radius: 16px;
  display: block;
}

.text-image-stat__content-col {
  flex: 1 1 60%;
  color: #fff;
  font-size: 1.1rem;
  line-height: 1.7;
  display: flex;
  flex-direction: column;
}
@media (max-width: 900px) {
  .text-image-stat__content-col {
    flex: 1 1 100%;
    max-width: 100%;
  }
}

.text-image-stat__title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 3.375rem;
  line-height: 4.125rem;
  letter-spacing: -1.13px;
  vertical-align: middle;
  color: #fff;
}
@media (max-width: 768px) {
  .text-image-stat__title h2 {
    margin-bottom: 20px;
  }
}

.text-image-stat__desc {
  margin-bottom: 2.2rem;
}
@media (max-width: 768px) {
  .text-image-stat__desc {
    margin-bottom: 0rem;
  }
}

.text-image-stat__list {
  margin: 0 0 0 18px;
  padding: 0;
  list-style-type: disc;
  color: #fff;
  font-size: 1.1rem;
}
.text-image-stat__list li {
  margin-bottom: 0.5rem;
  font-weight: 500;
}

.text-image-stat__bottom-row {
  display: flex;
  align-items: flex-end;
  column-gap: 2.5rem;
  margin-top: 3.5rem;
  width: 100%;
}
@media (max-width: 900px) {
  .text-image-stat__bottom-row {
    flex-direction: column;
    gap: 1.5rem;
    align-items: stretch;
  }
}

.text-image-stat__main-row,
.text-image-stat__bottom-row {
  margin-left: auto;
  margin-right: auto;
}

.text-image-stat__bottom-content {
  flex: 1 1 60%;
}

.text-image-stat__bottom-title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 3.375rem;
  line-height: 1.222;
  letter-spacing: -1.13px;
  vertical-align: middle;
  color: #fff;
}
@media (max-width: 768px) {
  .text-image-stat__bottom-title h2 {
    margin-bottom: 20px;
  }
}

.text-image-stat__bottom-title h3 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 3.375rem;
  letter-spacing: -1.13px;
  vertical-align: middle;
  color: #fff;
  line-height: 1.3;
}
@media (max-width: 768px) {
  .text-image-stat__bottom-title h3 {
    font-size: 1.5rem;
  }
}

.text-image-stat__bottom-desc {
  font-size: 1.1rem;
  color: #fff;
  margin-bottom: 0;
}

.expertise-section__facts-box.text-imgfact {
  height: 330px !important;
}

.class2 .text-image-stat__bottom-row {
  flex-direction: row-reverse;
}
@media (max-width: 768px) {
  .class2 .text-image-stat__bottom-row {
    flex-direction: column;
  }
}

.class4 .text-image-stat__bottom-row {
  display: none;
}

.why-chenocom {
  color: #fff;
}

.why-chenocom__header {
  text-align: center;
  margin-bottom: 40px;
  position: relative;
}
@media (max-width: 768px) {
  .why-chenocom__header {
    margin-bottom: 20px;
  }
}

.why-chenocom__title h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 4rem;
  line-height: 1.125;
  letter-spacing: -1.28px;
  text-align: center;
  vertical-align: middle;
}
@media (max-width: 768px) {
  .why-chenocom__title h2 {
    text-align: left;
  }
}

.why-chenocom__title {
  max-width: 650px;
  margin: 0 auto;
}

.why-chenocom__highlight {
  color: #FFD600;
  font-weight: 700;
}

.class4 .text-image__tag-container.floatSmooth {
  position: relative;
  display: block;
  left: 30%;
  bottom: 39%;
}

a.all-jobs__item.all-jobs__item--bordered.all-jobs__item-link:hover {
  color: white !important;
}

.contact-header__tag-container-whychenoTop.floatSmooth {
  position: absolute;
  left: 15%;
}

.contact-header__tag-container-whychenoTop.floatSmooth .contact-header__tag.tag-float {
  background: #FF9A26;
  width: 99px;
  height: 25px;
  flex-direction: row-reverse;
}

.contact-header__tag-container-whychenobottom.floatSmooth {
  position: absolute;
  right: 20%;
}

.contact-header__tag-container-whychenobottom.floatSmooth .contact-header__tag.tag-float {
  background: #B3FD9D;
  width: 115px;
  height: 25px;
}

@media (max-width: 600px) {
  .why-chenocom__btn {
    position: static;
    display: block;
    margin: 20px auto 0 auto;
  }
}
.why-chenocom__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
  padding-top: 60px;
}
@media (max-width: 1024px) {
  .why-chenocom__grid {
    padding-top: 0;
  }
}

@media (max-width: 900px) {
  .why-chenocom__grid {
    grid-template-columns: 1fr;
  }
}
.why-chenocom__card {
  background: linear-gradient(to bottom, rgba(0, 0, 17, 0.0666666667) 85%, rgba(245, 180, 0, 0.15) 131%, rgba(245, 180, 49, 0) 0%) top left no-repeat;
  border-radius: 20px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.18);
  padding: 32px 24px 28px 24px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  transition: transform 0.18s, box-shadow 0.18s;
  border: 1px solid #2D2D2D;
  min-height: 220px;
  position: relative;
}

.why-chenocom__icon {
  margin-bottom: 18px;
}

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

.why-chenocom__card-title h3 {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 2rem;
  line-height: 1.21875;
  letter-spacing: 0;
}
@media (max-width: 768px) {
  .why-chenocom__card-title h3 {
    font-size: 1.3rem;
    margin-bottom: 10px;
  }
}

.why-chenocom__card-desc p {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.125rem;
  letter-spacing: 0;
  color: rgba(255, 255, 255, 0.8);
  margin-bottom: 0 !important;
  margin-top: 23px;
}
@media (max-width: 768px) {
  .why-chenocom__card-desc p {
    margin-top: 10px;
  }
}

.all-jobs__list {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
}
@media (max-width: 1024px) {
  .all-jobs__list {
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
}

.all-jobs__item {
  flex: 0 0 calc(50% - 1rem);
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background-color: rgb(21, 21, 21);
  color: white;
  border-radius: 1rem;
  padding: 1.5rem;
  background: rgb(21, 21, 21);
  border: 1px solid #2D2D2D;
  min-height: 320px;
  position: relative;
}

.job-details {
  color: rgba(255, 255, 255, 0.8);
}

.single-page .job-details {
  color: rgba(255, 255, 255, 0.8);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
@media (max-width: 768px) {
  .single-page .job-details {
    gap: 14px;
  }
}

.single-page .job-description h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 3.5rem;
  line-height: 1.2273;
  letter-spacing: 0;
  vertical-align: middle;
  color: #fff;
  padding-top: 25px;
}
@media (max-width: 768px) {
  .single-page .job-description h2 {
    padding-bottom: 15px;
  }
}

.single-page .job-details .job-detail-item {
  display: flex;
  gap: 15px;
}
@media (max-width: 1024px) {
  .single-page .job-details .job-detail-item {
    flex-direction: column;
    gap: 0px;
  }
}

.single-page .job-details .job-detail-item p {
  font-size: 1rem !important;
}

@media (max-width: 768px) {
  .all-jobs__item {
    flex: 0 0 100%;
  }
}
.all-jobs__content {
  display: flex;
  gap: 20px;
  flex-direction: column;
}

.all-jobs__top-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  font-size: 1rem;
  margin-bottom: 0.5rem;
  color: #e0e0e0;
}

.all-jobs__contract-type {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 1.95;
  letter-spacing: 0;
}
@media (max-width: 768px) {
  .all-jobs__contract-type {
    font-size: 15px;
  }
}

@media (max-width: 768px) {
  .all-jobs__location {
    font-size: 15px;
  }
}

.all-jobs__date {
  font-size: 0.98rem;
  color: #e0e0e0;
}

.all-jobs__title {
  font-size: 1.35rem;
  font-weight: 700;
  color: #ffc72c;
  margin: 0.5rem 0;
  line-height: 1.2;
}

.all-jobs__title a {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 2rem;
  line-height: 1.21875;
  letter-spacing: 0;
  transition: color 0.2s;
  color: #F5B400;
}

.all-jobs__title a:hover {
  color: #fff;
}

.all-jobs__location .text-regular,
.all-jobs__description .text-regular {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 1.95;
  letter-spacing: 0;
}

.all-jobs__action {
  margin-top: auto;
}

.all-jobs__link {
  display: inline-flex;
  align-items: center;
  color: #ffc72c;
  font-weight: 600;
  text-decoration: none;
  font-size: 1rem;
  transition: color 0.2s;
}

.all-jobs__link span {
  margin-left: 0.3em;
  font-size: 1.1em;
}

.all-jobs__link:hover {
  color: #fff;
}

/* Pagination styles */
.all-jobs__pagination {
  margin-top: 2.5rem;
  text-align: center;
}

.pagination_jobs {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
}

.pagination__numbers {
  display: flex;
  gap: 0.5rem;
}

.pagination__current {
  color: #ffc72c;
  font-weight: bold;
}

.pagination__link {
  color: #fff;
  text-decoration: none;
  padding: 0 0.5em;
  transition: color 0.2s;
}

.pagination__link:hover {
  color: #ffc72c;
}

/* All-jobs hero section */
.all-jobs-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: 18px;
  padding: 2.5rem 2rem;
  margin-bottom: 2.5rem;
  gap: 2.5rem;
}
@media (max-width: 1024px) {
  .all-jobs-hero {
    margin: 0;
    padding: 0;
    gap: 0;
  }
}

.all-jobs-hero__content {
  flex: 1 1 0;
  min-width: 0;
}

.all-jobs-hero__title {
  font-size: 3rem;
  font-weight: 800;
  color: #fff;
  line-height: 1.05;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.7rem 1rem;
}

.all-jobs-hero__title .badge {
  margin-left: 0.5rem;
  font-size: 1rem;
  font-weight: 600;
  border-radius: 8px;
  padding: 0.2em 0.8em;
  display: inline-block;
  vertical-align: middle;
}

.all-jobs-hero__title .badge--blue {
  background: #b3e6ff;
  color: #222;
}

.all-jobs-hero__title .badge--green {
  background: #b6f7c2;
  color: #222;
}

.all-jobs-hero__image {
  flex: 0 0 320px;
  max-width: 340px;
}
@media (max-width: 1024px) {
  .all-jobs-hero__image {
    flex: auto;
    max-width: 100%;
    padding-bottom: 30px;
  }
}

.all-jobs-hero__image img {
  width: 100%;
  border-radius: 12px;
  object-fit: cover;
  display: block;
}

@media (max-width: 1024px) {
  .all-jobs-hero {
    flex-direction: column;
    align-items: flex-start;
  }
  .all-jobs-hero__image {
    width: 100%;
    max-width: 100%;
    margin-top: 1.5rem;
  }
}
.recru_tag a {
  display: flex;
  height: 25px;
  width: 114px;
  background: #9DE0FD;
}

.contact-header__tag-container.floatSmooth {
  display: flex;
  justify-content: center;
}

.test_tag a {
  background: #B3FD9D;
  width: 77px;
  height: 25px;
}

.all-posts {
  color: #fff;
  padding: 80px 0;
}

@media (max-width: 768px) {
  .all-posts {
    padding-bottom: 0 !important;
    padding-top: 40px;
  }
}
.all-posts .container {
  margin: 0 auto;
  padding: 0;
}

.all-posts__filter {
  margin-bottom: 40px;
  text-align: center;
}

@media (max-width: 768px) {
  .all-posts__filter {
    display: none;
  }
}
.filter-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 15px;
  max-width: 800px;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .filter-container {
    gap: 10px;
  }
}
.filter-btn {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1rem;
  line-height: 1;
  letter-spacing: -0.03em;
  background: #262627;
  color: #fff;
  padding: 0px 20px !important;
  height: 32px;
  border-radius: 100px;
  cursor: pointer;
  transition: all 0.6s ease;
  text-decoration: none;
  border: none;
}

.filter-btn {
  color: #fff;
  background: #262627;
  transition: all 0.3s ease;
}

.filter-btn:hover,
.filter-btn.filter-btn--active,
.filter-btn.filter-btn--active:hover {
  background: #FFB800;
  color: #fff;
}

@media (max-width: 768px) {
  .filter-btn {
    padding: 8px 16px;
    font-size: 0.8rem;
  }
}
.all-posts__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-bottom: 40px;
}

@media (max-width: 1200px) {
  .all-posts__list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .all-posts__list {
    grid-template-columns: 1fr;
    display: block;
  }
}
.all-posts__item-link {
  text-decoration: none;
  color: inherit;
  display: block;
  transition: transform 0.3s;
}

.all-posts__item-link:hover {
  text-decoration: none;
  color: inherit;
}

.all-posts__item {
  overflow: hidden;
  transition: transform 0.3s;
  border-radius: 20px;
  padding: 20px;
}

@media (max-width: 768px) {
  .all-posts__item {
    padding: 30px 0 !important;
  }
}
.all-posts__item-link:hover .all-posts__item {
  transform: translateY(-5px);
}

.all-posts__image {
  aspect-ratio: 16/9;
  overflow: hidden;
  margin-bottom: 20px;
}

.all-posts__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 15px;
}

@media (max-width: 768px) {
  .all-posts__image img {
    border-radius: 8px;
  }
}
.all-posts__content {
  text-align: left;
}

.all-posts__categories {
  display: flex;
  justify-content: space-between;
  margin-bottom: 15px;
}

.all-posts__category-tag {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.all-posts__category {
  color: #fff;
  background: #262627;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 500;
}

@media (max-width: 768px) {
  .all-posts__category {
    border-radius: 3.46px;
  }
}
.all-posts__date {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.6);
  text-transform: capitalize;
}

h2.all-posts__item-title {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 1.25rem;
  line-height: 1.3;
  margin: 0 0 12px;
  transition: color 0.3s ease;
  color: #fff;
}

@media (max-width: 1024px) {
  h2.all-posts__item-title {
    font-size: 20px !important;
  }
}
.all-posts__item-title a {
  color: #fff;
  text-decoration: none;
}

.all-posts__item-title a:hover {
  color: #FFB800;
}

.all-posts__excerpt {
  font-size: 0.875rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.8);
  margin: 0;
}

/* Slider mobile */
.posts-slider {
  display: none;
}

@media (max-width: 768px) {
  .posts-slider {
    display: none;
  }
}
.posts-slider .swiper {
  padding: 0 20px;
}

.posts-slider .swiper-slide {
  width: 100%;
}

.posts-slider .all-posts__item {
  margin: 0 10px;
}

/* Pagination */
.all-posts__pagination {
  margin-top: 40px;
  display: flex;
  justify-content: center;
}

.pagination_realisation {
  display: flex;
  align-items: center;
  gap: 20px;
}

.pagination__prev,
.pagination__next {
  color: #fff;
  text-decoration: none;
  font-weight: 500;
  transition: all 0.3s ease;
  background: none;
}

.pagination__prev:hover,
.pagination__next:hover {
  background: none;
  border-color: navajowhite;
  color: #FFB800;
}

.pagination__numbers {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.pagination__link {
  color: #fff;
  text-decoration: none;
  padding: 8px 12px;
  border-radius: 6px;
  transition: all 0.3s ease;
}

.pagination__link:hover {
  background: rgba(255, 255, 255, 0.1);
}

.pagination__current {
  background: #FFB800;
  color: #000;
  padding: 8px 12px;
  border-radius: 6px;
  font-weight: 600;
}

.pagination__dots {
  color: rgba(255, 255, 255, 0.6);
  padding: 8px 4px;
  font-weight: 400;
}

@media (max-width: 768px) {
  .pagination__dots {
    padding: 8px 2px;
  }
}
.last-post__image img {
  transition: box-shadow 0.3s ease;
}

.last-post__image:hover img {
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.5);
}

.all-posts__item:hover .all-posts__item-title {
  color: #FFB800;
}

.to-top-btn {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 50px;
  height: 50px;
  background: #F5B400;
  border-radius: 50%;
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 1000;
  border: 1px solid white;
}
.to-top-btn:hover {
  background: #F6C232;
  transform: translateY(-2px);
}
.to-top-btn:active {
  transform: translateY(0);
}
.to-top-btn.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.to-top-btn svg {
  width: 20px;
  height: 20px;
  transition: transform 0.2s ease;
}
.to-top-btn:hover svg {
  transform: translateY(-2px);
}
@media (max-width: 1000px) {
  .to-top-btn {
    bottom: 75px;
    right: 20px;
    width: 45px;
    height: 45px;
  }
  .to-top-btn svg {
    width: 18px;
    height: 18px;
  }
}
@media (max-width: 480px) {
  .to-top-btn {
    right: 15px;
    width: 40px;
    height: 40px;
  }
  .to-top-btn svg {
    width: 16px;
    height: 16px;
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.to-top-btn.visible {
  animation: fadeInUp 0.3s ease-out;
}

/* ============================== */
/* Général 
/* ============================== */
.about-chiffre {
  color: #fff;
  font-family: "Poppins", sans-serif;
  background: transparent;
}

/* ============================== */
/* Conteneur principal 
/* ============================== */
.about-chiffre__row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 2rem;
  flex-wrap: wrap;
}

/* ============================== */
/* Titre principal */
/* ============================== */
.about-chiffre__title h2 {
  line-height: 1.1;
  font-size: 3.5rem;
  letter-spacing: 0;
  max-width: 920px;
  color: #fff;
  text-align: left;
  word-break: break-word;
}
@media (max-width: 768px) {
  .about-chiffre__title h2 {
    max-width: 100% !important;
    font-weight: 600;
    font-size: 1.75rem !important;
    line-height: 1.1667;
    letter-spacing: 0;
    margin-bottom: 26px;
  }
}

/* ============================== */
/* Tag & Conteneur Tag */
/* ============================== */
.about-chiffre__tag-container {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-bottom: 70px;
  margin-top: 11px;
  margin-right: 74px;
  max-width: 923px;
}

.about-chiffre__tag {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #b6ffb6;
  color: #222;
  font-weight: 500;
  border-radius: 6px;
  font-size: 0.875rem;
  font-family: "Roboto";
  width: 148px;
  height: 25px;
  gap: 8px;
  z-index: 2;
}

.about-chiffre__tag-icon {
  width: 11px;
  height: 10px;
  vertical-align: middle;
}

.about-chiffre__tag-badge {
  display: inline-block;
  color: #fff;
  font-size: 0.9em;
  font-weight: 700;
  border-radius: 50%;
  width: 22px;
  height: 22px;
  line-height: 22px;
  margin-left: 6px;
  margin-right: -8px;
  border: 2px solid #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

/* ============================== */
/* Ligne descriptive */
/* ============================== */
.about-chiffre__row--desc {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: end;
  gap: 2rem;
  flex-wrap: nowrap;
  margin-bottom: 50px;
}
@media (max-width: 768px) {
  .about-chiffre__row--desc {
    margin-bottom: 0px;
  }
}

.about-chiffre__row--desc p {
  margin: 0;
  font-size: 1.5rem;
  font-family: "Inter", sans-serif;
  line-height: 1.444;
  font-weight: 400;
}
@media (max-width: 768px) {
  .about-chiffre__row--desc p {
    font-weight: 600;
    font-size: 1rem !important;
    line-height: 1.5 !important;
    letter-spacing: 0 !important;
  }
}

/* ============================== */
/* Avantages et description */
/* ============================== */
.about-chiffre__advantage,
.about-chiffre__desc {
  margin: 0;
  color: #fff;
  text-align: left;
}

.about-chiffre__advantage {
  width: 40%;
  min-width: 180px;
  display: flex;
  align-items: center;
}

.about-chiffre__advantage-text {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}
@media (max-width: 1024px) {
  .about-chiffre__advantage-text {
    padding-top: 10px;
  }
}

.about-chiffre__advantage-text span {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.6;
  font-family: "Inter", sans-serif;
  color: #ffffff !important;
}

@media (max-width: 1024px) {
  .about-section__text.forweb p {
    display: none;
  }
}

.about-chiffre__advantage-text::before {
  content: "";
  display: inline-block;
  width: 14px;
  height: 19.91px;
  background-image: url("/app/uploads/2025/06/icon-fire-1.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  vertical-align: middle;
}

.about-chifre__emoji {
  font-size: 1.2em;
  margin-right: 8px;
}

.about-chiffre__desc {
  width: 55%;
  min-width: 200px;
  color: #bdbdbd;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.5;
}

/* ============================== */
/* Bloc Statistiques */
/* ============================== */
.about-chiffre__stats {
  display: flex;
  justify-content: space-between;
  gap: 3rem;
  flex-wrap: wrap;
}

.about-chiffre__stat {
  display: flex;
  flex-direction: column;
  min-width: 120px;
}

.about-chiffre__stat:nth-child(1) {
  align-items: center !important;
  width: 25% !important;
}
@media (max-width: 1024px) {
  .about-chiffre__stat:nth-child(1) {
    width: 100% !important;
  }
}

.about-chiffre__stat:nth-child(2) {
  align-items: center !important;
}

.about-chiffre__stat:nth-child(3) {
  align-items: end !important;
}

.about-chiffre__stat-number {
  font-size: 9.125rem;
  font-weight: 400;
  line-height: 1.2;
  font-family: "Poppins", sans-serif;
  padding-top: 27px;
  color: #fff;
}
@media (max-width: 768px) {
  .about-chiffre__stat-number {
    padding-top: 0 !important;
  }
}

.about-chiffre__stat-label {
  font-size: 1.1rem;
  color: #bdbdbd;
  font-weight: 400;
  letter-spacing: 0.01em;
  text-align: center;
  margin-top: -20px;
}

.about-chiffre__stat-label p {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.375rem;
  line-height: 1.818;
  letter-spacing: 0;
  vertical-align: middle;
}
@media (max-width: 768px) {
  .about-chiffre__stat-label p {
    font-size: 1rem;
    line-height: 1.957;
  }
}

/* ============================== */
/* Responsive : max-width 900px */
/* ============================== */
@media (max-width: 1024px) {
  .about-chiffre {
    padding: 2.5rem 0rem 1.5rem 0rem;
  }
  .about-chiffre__row {
    flex-direction: column;
    gap: 1.5rem;
  }
  .about-chiffre__stats {
    flex-direction: column;
    gap: 0rem;
    align-items: center;
  }
  .about-chiffre__row--desc {
    flex-direction: column;
    gap: 0rem;
  }
  .about-chiffre__advantage,
  .about-chiffre__desc {
    width: 100%;
    margin-bottom: 1rem;
  }
  .about-chiffre__tag {
    position: static;
    margin-top: 1rem;
  }
}
/* ============================== */
/* Responsive : max-width 768px */
/* ============================== */
@media (max-width: 768px) {
  .about-chiffre {
    padding: 1.5rem 0rem 1rem 0rem;
  }
  .about-chiffre__title {
    font-size: 1.3rem;
    max-width: 98vw;
  }
  .about-chiffre__desc {
    font-size: 0.98rem;
    max-width: 98vw;
  }
  .about-chiffre__stats {
    flex-direction: column;
    gap: 0rem;
    align-items: center;
  }
  .about-chiffre__stat {
    min-width: 0;
    width: 100%;
    text-align: center;
  }
  .about-chiffre__stat-number {
    font-size: 6.25rem;
  }
  .about-chiffre__advantage {
    font-size: 1rem;
    order: 2;
  }
  .about-chiffre__tag {
    margin-top: 1rem;
  }
  .about-chiffre__stat:nth-child(1) {
    align-items: center !important;
  }
  .about-chiffre__stat:nth-child(3) {
    align-items: center !important;
  }
}
.hero-home {
  position: relative;
  padding-top: 12.9rem !important;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.hero-home__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}

/* Chaque bloc tags (seo et design) avec taille minimale et centrage */
.hero-home__tags.hero-home__tags--top {
  flex: 1 1 150px;
  display: flex;
  justify-content: center;
  position: relative;
}
@media (max-width: 768px) {
  .hero-home__tags.hero-home__tags--top .hero-home__top {
    flex-direction: column;
    gap: 15px;
  }
  .hero-home__tags.hero-home__tags--top .hero-home__bottom {
    flex-direction: column;
    gap: 15px;
    display: none;
  }
}

/* L’image ne se réduit pas */
.hero-home__image {
  flex-shrink: 0;
  max-width: 100%;
  height: auto;
}

/* Tags en position absolue dans leur container */
.hero-tag {
  display: inline-flex;
  align-items: center;
  font-family: "Roboto", sans-serif !important;
  font-size: 14px;
  font-weight: 600;
  border-radius: 6px;
  padding: 4px 10px;
  position: absolute;
  z-index: 2;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  gap: 5px;
  letter-spacing: 0.01em;
  animation: floatY 2.2s ease-in-out infinite;
}

.hero-tag__icon {
  width: 16px;
  height: 16px;
  margin-right: 6px;
  display: inline-block;
  vertical-align: middle;
}

/* Positionnement tags top */
.hero-tag--seo {
  background: #FF9A26;
  color: #222;
}

.hero-tag--design {
  background: #ffe484;
  color: #222;
  right: 32%;
}

.hero-home__bottom {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-top: 7px;
  max-width: 700px;
  width: 100%;
}
@media (max-width: 1340px) {
  .hero-home__bottom {
    padding-top: 40px;
  }
}

.hero-home__tags.hero-home__tags--bottom {
  display: flex;
}

.hero-tag--devops {
  background: #ff7a59;
  color: #000;
  bottom: 0;
  left: 5px;
  position: absolute;
}

.hero-tag--dev {
  background: #e5e5e5;
  color: #222;
  bottom: 0;
  right: 0;
  position: absolute;
}

/* Titre et sous-titre centrés */
.hero-home__title,
.hero-home__subtitle {
  text-align: center;
  max-width: 1050px;
  margin: 20px auto 0;
}

.hero-home__title h2 {
  font-family: "Poppins", sans-serif;
  font-size: 6.25rem;
  font-weight: 500;
  line-height: 1.2;
  color: white;
  text-align: center;
}
@media (max-width: 1024px) {
  .hero-home__title h2 {
    font-size: 5rem;
  }
}

.hero-home__title h2 span {
  background: linear-gradient(90deg, rgb(255, 184, 0) 0%, rgb(255, 184, 0) 20%, rgb(255, 255, 255) 100%);
  background-clip: text;
  color: transparent;
  font-weight: 500;
}

.hero-home__title {
  margin-top: 28px;
}

.hero-home__subtitle p {
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.9);
  max-width: 880px;
  margin: 0 auto;
  font-size: 20px;
}
@media (max-width: 768px) {
  .hero-home__subtitle p {
    font-size: 1rem !important;
    max-width: 100% !important;
    line-height: 1.5 !important;
  }
}

.hero-home__subtitle p strong {
  color: #ffffff;
}

.hero-home__subtitle p a {
  color: #FFD400 !important;
  text-decoration: none;
  font-size: 20px;
  font-weight: 700;
  font-family: "Inter", sans-serif;
  align-items: center;
  gap: 6px;
}
@media (max-width: 1200px) {
  .hero-home__subtitle p a {
    display: block;
    padding: 0;
    font-size: 1rem !important;
  }
}

/* Animation */
/* Responsive : empilement */
@media (max-width: 768px) {
  .hero-home__tags--top,
  .hero-home__tags--bottom {
    position: static;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    height: auto;
    margin: 10px 0 0 0;
  }
  .hero-tag--seo,
  .hero-tag--design,
  .hero-tag--devops,
  .hero-tag--dev {
    display: none;
  }
}
.hero-home {
  position: relative;
  padding-top: 8rem !important;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
@media (max-width: 1024px) {
  .hero-home {
    padding-top: 4rem !important;
  }
}
@media (max-width: 768px) {
  .hero-home {
    padding-top: 2rem !important;
  }
}

.hero-home__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}

/* Chaque bloc tags (seo et design) avec taille minimale et centrage */
.hero-home__tags.hero-home__tags--top {
  flex: 1 1 150px;
  display: flex;
  justify-content: center;
  position: relative;
}
@media (max-width: 768px) {
  .hero-home__tags.hero-home__tags--top .hero-home__top {
    flex-direction: column;
    gap: 15px;
  }
  .hero-home__tags.hero-home__tags--top .hero-home__bottom {
    flex-direction: column;
    gap: 15px;
  }
}

/* L’image ne se réduit pas */
.hero-home__image {
  flex-shrink: 0;
  max-width: 100%;
  height: auto;
}

/* Tags en position absolue dans leur container */
.hero-tag {
  display: inline-flex;
  align-items: center;
  font-family: "Roboto", sans-serif !important;
  font-size: 14px;
  font-weight: 600;
  border-radius: 6px;
  padding: 4px 10px;
  position: absolute;
  z-index: 2;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  gap: 5px;
  letter-spacing: 0.01em;
  animation: floatY 2.2s ease-in-out infinite;
}

.hero-tag__icon {
  width: 16px;
  height: 16px;
  margin-right: 6px;
  display: inline-block;
  vertical-align: middle;
}

/* Positionnement tags top */
.hero-tag--seo {
  background: #FF9A26;
  color: #222;
}

.hero-tag--design {
  background: #ffe484;
  color: #222;
  right: 32%;
}

.hero-home__bottom {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-top: 7px;
  max-width: 700px;
  width: 100%;
}
@media (max-width: 1024px) {
  .hero-home__bottom {
    display: none;
  }
}

.hero-home__tags.hero-home__tags--bottom {
  display: flex;
}

.hero-tag--devops {
  background: #ff7a59;
  color: #000;
  bottom: 0;
  left: 5px;
  position: absolute;
}

.hero-tag--dev {
  background: #e5e5e5;
  color: #222;
  bottom: 0;
  right: 0;
  position: absolute;
}

/* Titre et sous-titre centrés */
.hero-home__title,
.hero-home__subtitle {
  text-align: center;
  max-width: 1050px;
  margin: 20px auto 0;
}

.hero-home__title {
  margin-top: 28px;
}

.hero-home__subtitle p {
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.9);
  max-width: 880px;
  margin: 0 auto;
  font-size: 20px;
}

.hero-home__subtitle p strong {
  color: #ffffff;
}

.hero-home__subtitle p a {
  color: #FFD400 !important;
  text-decoration: none;
  font-size: 20px;
  font-weight: 700;
  font-family: "Inter", sans-serif;
  align-items: center;
  gap: 6px;
}

/* Animation */
/* Responsive : empilement */
@media (max-width: 768px) {
  .hero-home__tags--top,
  .hero-home__tags--bottom {
    position: static;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    height: auto;
    margin: 10px 0 0 0;
  }
  .hero-tag--seo,
  .hero-tag--design,
  .hero-tag--devops,
  .hero-tag--dev {
    display: none;
  }
}
/* Conteneur principal */
.hero-slider {
  width: 100%;
  overflow: hidden;
  padding-top: 70px;
  box-sizing: border-box;
  position: relative;
  /* optionnel : fond sombre pour faire ressortir les slides */
  user-select: none;
  cursor: grab;
  /* Permettre le scroll vertical sur mobile */
}
.hero-slider:active {
  cursor: grabbing;
}
@media (max-width: 768px) {
  .hero-slider {
    touch-action: pan-y;
    -webkit-overflow-scrolling: touch;
  }
}

/* Wrapper des slides */
.slider-wrapper {
  display: flex;
  gap: 20px;
  transition: transform 4s ease-in-out;
  will-change: transform;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  padding-bottom: 30px;
}

/* Slide par défaut*/
.slide {
  flex: 0 0 25vw;
  max-width: 25vw;
  max-height: 600px;
  border-radius: 15px;
  overflow: hidden;
  cursor: pointer;
  opacity: 0.4;
  transform: scale(0.9);
  pointer-events: none;
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.2);
  transition: opacity 0.3s ease-out;
  /* Transitions optimisées */
  transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Slide active (centrée) */
.slide.active {
  flex: 0 0 50vw;
  max-width: 50vw;
  opacity: 1 !important;
  transform: scale(1);
  pointer-events: auto;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.4);
  z-index: 10;
}

/* Slide précédente */
.slide.prev {
  flex: 0 0 25vw;
  max-width: 25vw;
  opacity: 0.6;
  transform: scale(0.95) translateX(-10%);
  pointer-events: auto;
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.25);
  z-index: 5;
}

/* Slide suivante */
.slide.next {
  flex: 0 0 25vw;
  max-width: 25vw;
  opacity: 0.6;
  transform: scale(0.95) translateX(10%);
  pointer-events: auto;
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.25);
  z-index: 5;
}

/* Image dans la slide */
.slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 15px;
  transition: transform 0.8s ease-in-out, opacity 0.8s ease-in-out;
  pointer-events: none;
  /* Permettre le scroll vertical sur mobile */
}
@media (max-width: 768px) {
  .slide img {
    touch-action: pan-y;
  }
}

/* Zoom doux sur slide active */
.slide.active img {
  transform: scale(1.05);
  animation: float 4s ease-in-out infinite;
}

@keyframes float {
  0%, 100% {
    transform: scale(1.05) translateY(0);
  }
  50% {
    transform: scale(1.05) translateY(-5px);
  }
}
/* Pagination */
.pagination {
  text-align: center;
  margin-top: 15px;
  user-select: none;
}

.pagination span {
  display: inline-block;
  width: 15px;
  height: 8px;
  border-radius: 8px;
  background: #fff;
  opacity: 0.5;
  margin: 0 6px;
  cursor: pointer;
  transition: width 0.3s ease-in-out, opacity 0.3s ease-in-out, background-color 0.3s ease-in-out;
}

.pagination span.active {
  width: 48px;
  opacity: 1;
  background-color: ffffff;
}

/* ----------- Responsive ----------- */
@media (max-width: 1024px) {
  .slide {
    flex: 0 0 30vw;
    max-width: 30vw;
    min-height: 300px;
  }
  .slide.active {
    flex: 0 0 60vw;
    max-width: 60vw;
  }
  .slide.prev,
  .slide.next {
    flex: 0 0 30vw;
    max-width: 30vw;
  }
}
@media (max-width: 768px) {
  .hero-slider {
    padding: 20px 0;
  }
  .slider-wrapper {
    gap: 12px;
  }
  .slide,
  .slide.active,
  .slide.prev,
  .slide.next {
    flex: 0 0 98% !important;
    max-width: 98% !important;
    transform: scale(1) translateX(0) !important;
    opacity: 1 !important;
    pointer-events: auto;
    box-shadow: none !important;
    min-height: auto !important;
  }
  .slide img {
    object-fit: cover;
    height: auto;
  }
}
/* ============================== */
/* Conteneur général */
/* ============================== */
/* ============================== */
/* Texte au-dessus du slider */
/* ============================== */
.logo-slider-text {
  color: #CBCBCB;
  font-size: 16px;
  font-weight: 400;
  text-align: center;
  margin: 0 auto;
  font-family: "Inter", sans-serif;
}
@media (max-width: 768px) {
  .logo-slider-text {
    font-family: "Inter", sans-serif;
    font-weight: 500;
    font-size: 1rem;
    line-height: 1.5;
    letter-spacing: 0.00875rem;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

/* ============================== */
/* Bloc principal du slider */
/* ============================== */
.logo-slider {
  background: #181818;
  padding-top: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.logo-slider .swiper {
  padding-bottom: 40px;
}

.logo-slider .swiper-wrapper {
  display: flex;
  gap: 20px;
  /* espace entre les slides */
}

.logo-slider .swiper-slide {
  overflow: hidden;
  transition: transform 0.3s;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}

.logo-slider .swiper-slide img {
  height: 30px;
  object-fit: cover;
  border-radius: 10px;
  filter: grayscale(100%);
  transition: filter 0.3s ease, transform 0.3s ease;
}
@media (max-width: 768px) {
  .logo-slider .swiper-slide img {
    object-fit: fill;
    border-radius: 0%;
  }
}

.logo-slider .swiper-slide:hover img {
  filter: grayscale(0);
  transform: scale(1.05);
}

/* ============================== */
/* Pagination Swiper */
/* ============================== */
.logo-slider .swiper-pagination {
  bottom: 0 !important;
}

.logo-slider .swiper-pagination .swiper-pagination-bullet {
  background: #ffffff;
  opacity: 0.6;
  width: 15px;
  height: 8px;
  border-radius: 8px;
  margin: 0 4px;
  transition: all 0.3s;
}

.logo-slider .swiper-pagination .swiper-pagination-bullet-active {
  background: #ffffff;
  opacity: 1;
  width: 48px;
}

.marquee-wrapper {
  overflow: hidden;
  background: #0E0E0E;
  padding: 10px 0;
}

.marquee-inner {
  display: flex;
  width: fit-content;
  animation: scroll 60s linear infinite;
}

.marquee-track {
  display: flex;
}

.marquee-text {
  font-size: 8rem;
  white-space: nowrap;
  padding-right: 6rem;
  color: transparent;
  -webkit-text-stroke: 1px white;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-weight: 700;
  text-transform: uppercase;
}

@media (max-width: 768px) {
  .marquee-text {
    font-size: 5rem;
  }
}
@keyframes scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
.marquee-wrapper:hover .marquee-inner {
  animation-play-state: paused;
}

/*
|--------------------------------------------------------------------------
| 6 - Layouts
|--------------------------------------------------------------------------
|
|
|
*/
.header-logo {
  padding-top: 6.5px;
}

.parent-active {
  color: #FFB800 !important;
}

/* === Sous-menu Mobile === */
.sub-menu-mobil {
  max-height: 0;
  overflow: hidden;
  padding-top: 0;
  padding-bottom: 0;
  opacity: 0;
  transform: translateY(-10px);
  pointer-events: none;
  visibility: hidden;
  transition: padding 0.6s ease, opacity 0.6s ease, transform 0.6s ease;
}

.sub-menu-mobil.active {
  max-height: 500px;
  /* assez grand pour ton contenu */
  padding-top: 18px;
  padding-bottom: 24px;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
  visibility: visible;
  padding-left: 20px;
}

.sub-menu-mobil::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, #181818, gold, #181818);
  opacity: 0.3;
}

.sub-menu-mobil.active {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Flèche par défaut pointe vers le bas */
.mobile-submenu-toggle svg {
  transform: rotate(0deg) !important;
  transition: transform 0.3s ease;
}

/* Rotation flèche quand ouvert */
.mobile-submenu-toggle.active svg {
  transform: rotate(180deg) !important;
}

/* S'assurer que la flèche revient à sa position initiale quand pas active */
.mobile-submenu-toggle:not(.active) svg {
  transform: rotate(0deg) !important;
}

/* Styles pour le menu mobile */
.mobile-menu-nav {
  padding: 15px 15px 1px 15px;
  color: white;
  margin-bottom: 14rem;
}

.menu-item-header > a.active::before {
  content: "";
  display: block;
  background: rgba(255, 255, 255, 0.2);
}

.mobile-menu-nav .menu-item-wrapper {
  margin-bottom: 12px;
}

.mobile-menu-nav .menu-item-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 5px 0;
}

.mobile-menu-nav a {
  color: white;
  text-decoration: none;
  font-size: 16px;
  font-weight: 500;
}

.mobile-submenu-toggle {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  margin-left: 8px;
  display: flex;
  align-items: center;
  color: white;
}

.dropdown-arrow {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  margin-left: 8px;
}

/* === Style du header principal === */
header {
  position: sticky;
  top: 0;
  z-index: 999;
  transition: all 0.3s ease;
  background: #0E0E0E;
  border-bottom: 2px solid rgba(178, 178, 178, 0.0705882353);
}

.header-logo,
.header-menu,
.header-contact {
  transition: transform 0.3s ease, opacity 0.3s ease;
}

header.scrolled {
  background: rgba(36, 35, 35, 0.55) !important;
  backdrop-filter: blur(15px) !important;
  -webkit-backdrop-filter: blur(15px) !important;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

header.scrolled .header-logo,
header.scrolled .header-menu,
header.scrolled .header-contact {
  transform: translateY(-2px);
  opacity: 0.95;
}

.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 97px;
  z-index: 1000;
  left: 0;
}
@media (max-width: 1000px) {
  .header {
    height: 88px;
    margin-bottom: -8px !important;
  }
}

.container-header {
  padding-top: 43px !important;
  padding-bottom: 43px !important;
}

/* === Menu principal === */
.header-menu {
  width: 60%;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 25px;
}
@media (max-width: 1000px) {
  .header-menu {
    display: none;
  }
}

.header-contact {
  width: 20%;
  display: flex;
  justify-content: flex-end;
}
@media (max-width: 1000px) {
  .header-contact {
    display: none;
  }
}

/* === Liens du header === */
.header a,
nav.mobile-menu-nav a {
  font-size: 16px;
  line-height: 1;
  font-weight: 500;
  color: #fff;
  font-family: "Inter", sans-serif;
}

.header a.logo {
  font-size: 25px;
  font-weight: bold;
  padding: 0;
}

/* === Bouton contact === */
.header-contact-btn a {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  background: #F5B400;
  padding: 18px 28px;
  border-radius: 6px;
  color: #000;
  font-weight: 600;
  font-size: 20px;
  overflow: hidden;
  transition: color 0.3s ease;
  cursor: pointer;
  text-decoration: none;
  z-index: 99999;
  transition: background-color 0.4s ease-in-out, transform 0.3s ease-in-out;
}

.header-contact-btn a:hover {
  transform: translateY(-3px);
  background-color: #F6C232;
}

/* Le contenu texte + svg doit être au-dessus */
.header-contact-btn a > svg,
.header-contact-btn a {
  position: relative;
  z-index: 1;
}

/* Texte et SVG changent de couleur au hover */
.header-contact-btn a:hover {
  color: rgba(0, 0, 0, 0) !important;
  z-index: 9999999999;
}

.header-contact-btn a:hover svg path {
  fill: #000;
  /* change la couleur du SVG aussi */
}

/* === Hover et lien actif === */
.header a:hover,
.header a.active {
  color: #FFB800 !important;
}

/* === Wrapper des items du menu === */
.menu-item-wrapper {
  position: relative;
}
@media (max-width: 1000px) {
  .menu-item-wrapper a {
    display: flex;
    justify-content: space-between;
  }
}

/* === Sous-menu par défaut === */
.sub-menu {
  position: absolute;
  top: 250%;
  left: 0;
  background: #0E0E0E;
  padding: 20px;
  width: 270px !important;
  display: flex;
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
  visibility: hidden;
  transition: opacity 0.3s ease, transform 0.3s ease;
  z-index: 1000;
  border-radius: 4px;
  justify-content: center;
  flex-direction: column;
  gap: 20px;
  border: 0.6px solid #2D2D2D;
}

/* === Affichage au hover === */
.menu-item-wrapper:hover .sub-menu,
.menu-item-wrapper:focus-within .sub-menu {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
  visibility: visible;
}

.menu-item-wrapper::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  height: 50px;
  pointer-events: auto;
  z-index: 999;
}
@media (max-width: 1000px) {
  .menu-item-wrapper::after {
    display: none !important;
  }
}

/* === Spécifique au 2ᵉ menu : sous-menu en grille === */
.menu-item-wrapper:nth-of-type(2) .sub-menu {
  width: 640px;
  min-width: 600px;
  border: 0.6px solid #2D2D2D;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  top: 250%;
}
@media (max-width: 1100px) {
  .menu-item-wrapper:nth-of-type(2) .sub-menu {
    grid-template-columns: repeat(1, 1fr);
    min-width: auto;
  }
}

/* Cible le 2e sous-menu et applique les styles à ses liens */
.menu-item-wrapper:nth-of-type(2) .sub-menu a {
  color: #fff;
  text-decoration: none;
  font-size: 15px;
  font-weight: 500;
  transition: color 0.3s;
  text-align: left;
  position: relative;
  display: flex;
  align-items: center;
}

/* === Flèche qui tourne au hover === */
.menu-item-wrapper:hover .dropdown-arrow svg {
  transform: rotate(180deg);
}

.dropdown-arrow svg {
  transition: transform 0.3s ease;
  display: inline-block;
}

/* === Liens du sous-menu (communs) === */
.sub-menu a {
  color: #fff;
  text-decoration: none;
  font-size: 15px;
  font-weight: 500;
  transition: color 0.3s;
  position: relative;
  display: flex;
  align-items: center;
}

.sub-menu a:hover {
  color: #F5B400 !important;
}

/* === Icônes avant les liens === */
/* === Images spécifiques pour chaque lien du 2e sous-menu === */
/* === Burger menu (mobile, caché par défaut) === */
.header-burger {
  display: none;
}
@media (max-width: 1000px) {
  .header-burger {
    display: block;
  }
}

.burger {
  width: 55px;
  height: 55px;
  border-radius: 10px;
  color: #fff;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 5px;
  transition: all 0.5s ease;
  margin-top: -4px;
}

.burger-strip {
  transition: all 0.5s ease;
}

.strip div {
  height: 3px;
  border-radius: 2px;
  background: white;
  margin: 10px;
  transition: all 0.55s cubic-bezier(0.075, 0.82, 0.165, 1);
  width: 40px;
  transform: rotate(0deg);
}

.burger:hover .strip div {
  background: white;
}

/* BURGER 1 */
.burger-strip div:first-child {
  width: 16px;
}

.burger-strip div:last-child {
  width: 28px;
}

/* Burger menu actif (quand le menu mobile est ouvert) */
.burger.active .burger-strip div:first-child {
  transform: rotate(45deg) translateY(1px) translateX(5px) !important;
}

.burger.active .burger-strip div:nth-child(2) {
  transform: rotate(-45deg) !important;
}

.burger.active .burger-strip div:last-child {
  transform: rotate(45deg) translateY(-13px) translateX(2px) !important;
}

/* Burger menu non-actif (forme initiale) */
.burger:not(.active) .burger-strip div:first-child {
  transform: rotate(0deg) translateY(0) translateX(0) !important;
}

.burger:not(.active) .burger-strip div:nth-child(2) {
  transform: rotate(0deg) !important;
}

.burger:not(.active) .burger-strip div:last-child {
  transform: rotate(0deg) translateY(0) translateX(0) !important;
}

/* S'assurer que les transformations sont appliquées */
.burger .burger-strip div {
  transform-origin: center;
}

/* Hover seulement quand pas actif */
.burger:not(.active):hover .burger-strip div:first-child {
  transform: rotate(45deg) translateY(1px) translateX(5px);
}

.burger:not(.active):hover .burger-strip div:nth-child(2) {
  transform: rotate(-45deg);
}

.burger:not(.active):hover .burger-strip div:last-child {
  transform: rotate(45deg) translateY(-13px) translateX(2px);
}

#mobileMenu {
  position: fixed;
  top: 81px;
  right: 0;
  width: 100%;
  height: 100vh;
  background: rgba(36, 35, 35, 0.55);
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
  box-shadow: -6px 0 30px rgba(0, 0, 0, 0.2);
  clip-path: polygon(100% 0, 100% 0, 100% 100%, 100% 100%);
  opacity: 0;
  transition: clip-path 0.6s ease, opacity 0.4s ease;
  pointer-events: none;
  z-index: 10000;
  will-change: transform;
}

#mobileMenu.open {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  opacity: 1;
  pointer-events: auto;
  z-index: 999;
}

.mobile-close-btn {
  position: absolute;
  top: 20px;
  right: 20px;
  background: none;
  border: none;
  cursor: pointer;
  color: white;
  padding: 10px;
  z-index: 10001;
}

.mobile-close-btn svg {
  width: 24px;
  height: 24px;
}

.menu-item-header {
  display: flex;
  justify-content: space-between;
}

.site-footer {
  color: #fff;
  font-family: "Poppins", sans-serif;
  padding-top: 40px;
  padding-bottom: 0;
  text-align: left;
  position: relative;
  background: #0E0E0E;
}

.footer-header {
  display: flex;
  justify-content: space-between;
  padding: 50px 0;
}

.footer-main {
  display: flex;
  justify-content: space-between;
  padding-top: 80px;
  padding-bottom: 50px;
  border-bottom: 1px solid #222;
}

.hr {
  max-width: 1200px;
  margin: 0 auto;
  opacity: 0.2;
}

.hr2 {
  max-width: 100%;
  margin: 0 auto;
  border: 1px solid rgba(255, 255, 255, 0.0392156863);
  opacity: 0.5;
}

.gradient-hr {
  border: none;
  height: 1px;
  background: linear-gradient(to right, #181818, gold, #181818);
}

.footer-col {
  flex: 1 1 0;
  min-width: 200px;
  margin-right: 30px;
}

.footer-col:last-child {
  margin-right: 0;
}

.footer-title {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 1.25rem;
  line-height: 1.5;
  letter-spacing: 0;
  margin-bottom: 18px;
  color: #F5B400;
}
@media (max-width: 768px) {
  .footer-title {
    margin-bottom: 8px;
  }
}

.footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-col ul li {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.3;
  letter-spacing: 0;
  margin-bottom: 20px;
  color: #fff;
}

.footer-col ul li a {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1;
  letter-spacing: 0;
  color: #fff;
  text-decoration: none;
  transition: color 0.2s;
}

.footer-col ul li a:hover {
  color: #FFB800;
}

.newsletter.wpcf7-form {
  display: flex;
  max-width: 320px;
  height: 50px;
  background-color: #2f3542;
  border-radius: 50px;
  overflow: hidden;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
}

.newsletter .wpcf7-form input[type=email] {
  flex: 1;
  border: none;
  padding: 0 20px;
  font-size: 16px;
  color: rgba(0, 0, 0, 0.6392156863);
  background-color: transparent;
  outline: none;
  margin: 0;
}

input::placeholder {
  color: #000 !important;
  opacity: 0.5 !important;
  font-size: 13px;
}

.wpcf7-form .btn-submit {
  background-color: #ffb800;
  border: none;
  width: 50px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.3s ease;
  border-radius: 50px;
  padding: 9px;
}

.wpcf7-form .btn-submit:hover {
  background-color: #ffe484;
}

.wpcf7-form .btn-submit svg {
  stroke: #fff;
  width: 20px;
  height: 20px;
}

.subscribe {
  width: 300px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: 54px;
  padding: 5px;
  overflow: hidden;
  background: white;
}
@media (max-width: 1200px) {
  .subscribe {
    width: 230px;
  }
}
@media (max-width: 1024px) {
  .subscribe {
    width: 300px;
  }
}

.footer-bottom {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: 18px 20px 10px 20px;
  font-size: 14px;
  color: #aaa;
}

.footer-links a {
  color: #aaa;
  text-decoration: none;
  margin: 0 5px;
  transition: color 0.2s;
}

.footer-links a:hover {
  color: #FFB800;
}

.footer-social {
  display: flex;
  align-items: center;
  gap: 20px;
}

@media (max-width: 1024px) {
  .footer-main {
    flex-direction: column;
    gap: 30px;
    padding: 20px;
    text-align: center;
    align-items: center;
  }
  .footer-col {
    margin-right: 0;
    min-width: unset;
  }
  .footer-bottom {
    flex-direction: column;
    gap: 10px;
    text-align: center;
  }
  .footer-header {
    flex-direction: column;
    padding: 20px 20px 60px 20px;
    align-items: center;
    gap: 15px;
  }
}
.footer-social a img {
  transition: filter 0.3s ease;
}

.footer-social a img:hover {
  filter: hue-rotate(180deg);
}

/* Conteneur du formulaire */
.form-newsletter-wrapper {
  position: relative;
  max-width: 600px;
  margin: 40px 0;
}

.form-newsletter-input {
  display: inline-block;
  width: 60%;
  padding: 18px 36px;
  margin: 8px 0;
  margin-top: 18px;
  border: none;
  box-sizing: border-box;
  height: 70px;
  border-radius: 20px;
  box-shadow: 0 20px 30px 0 rgba(0, 0, 0, 0.06);
  font-size: 16px;
  line-height: 3;
}

.form-newsletter-input::placeholder {
  font-size: 16px;
  line-height: 3;
}

.form-newsletter-button {
  margin-left: -160px;
  font-size: 16px;
  display: inline-block;
  font-weight: 600;
  padding: 16px 32px;
  border-radius: 20px;
  border: none;
  cursor: pointer;
  background-color: #ffe484;
  color: #fff;
  position: relative;
  z-index: 2;
}

/* Responsive */
@media (max-width: 600px) {
  .form-newsletter-input {
    width: 100%;
    margin-bottom: 12px;
  }
  .form-newsletter-button {
    margin-left: 0;
    width: 100%;
    text-align: center;
  }
  .form-newsletter-wrapper {
    display: flex;
    flex-direction: column;
  }
}
button.cky-btn.cky-btn-preferences,
button.cky-btn.cky-btn-reject,
button.cky-btn.cky-btn-accept,
button.cky-btn.cky-btn-reject,
button.cky-btn.cky-btn-accept,
button.cky-btn.cky-btn-customize {
  color: rgb(0, 0, 0) !important;
  border: 2px solid #F5B400 !important;
  border-radius: 6px;
}

button.cky-btn.cky-btn-accept,
button.cky-btn.cky-btn-accept {
  background-color: #F5B400 !important;
}

.cky-btn-accept::after,
button.cky-btn.cky-btn-preferences::after,
button.cky-btn.cky-btn-customize::after,
button.cky-btn.cky-btn-reject::after {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-left: 8px;
  vertical-align: middle;
  background-image: url("/app/uploads/2025/07/Vector-9.svg");
  background-size: contain;
  background-repeat: no-repeat;
}

/* RESET DE BASE */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: "Poppins", sans-serif;
  background-color: #0E0E0E;
  position: relative;
}

body.mobile-menu.open {
  overflow: hidden;
}

.mobile-menu {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

main {
  position: relative;
}

main::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  transform: translateX(-50%);
  height: 100vh;
  width: 3px;
  background-color: #ccc;
  pointer-events: none;
  box-shadow: 20vw 0 #ccc, 40vw 0 #ccc, 60vw 0 #ccc, 80vw 0 #ccc, 100vw 0 #ccc;
  opacity: 0.02;
}

a {
  text-decoration: none;
  color: rgba(255, 255, 255, 0.8);
}

a:hover {
  color: #F6C232;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

.container {
  max-width: 1440px;
  margin: 0 auto;
  padding-left: 114px !important;
  padding-right: 114px !important;
}
@media (max-width: 1200px) {
  .container {
    padding-left: 50px !important;
    padding-right: 50px !important;
  }
}
@media (max-width: 1100px) {
  .container {
    padding-left: 30px !important;
    padding-right: 30px !important;
  }
}
@media (max-width: 768px) {
  .container {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
}

.section-spacing {
  padding-top: 150px;
}
@media (max-width: 1024px) {
  .section-spacing {
    padding-top: 80px;
  }
}
@media (max-width: 768px) {
  .section-spacing {
    padding-top: 60px;
  }
}

h1 {
  font-family: "Poppins", sans-serif;
  font-size: 6.25rem;
  font-weight: 500;
  line-height: 1.2;
  color: white;
  text-align: center;
}
@media (max-width: 1024px) {
  h1 {
    font-size: 4.5rem !important;
  }
}
@media (max-width: 768px) {
  h1 {
    font-size: 2.875rem !important;
  }
}
@media (max-width: 500px) {
  h1 {
    font-size: 2rem !important;
  }
}

h1 span {
  background: linear-gradient(90deg, rgb(255, 184, 0) 0%, rgb(255, 184, 0) 20%, rgb(255, 255, 255) 100%);
  background-clip: text;
  color: transparent;
  font-weight: 500;
}

h2 {
  font-weight: 600;
  font-family: "Poppins", sans-serif;
}
@media (max-width: 1024px) {
  h2 {
    font-size: 3rem !important;
    line-height: 1.2 !important;
  }
}
@media (max-width: 768px) {
  h2 {
    font-size: 1.75rem !important;
    line-height: 1.1667 !important;
    letter-spacing: 0;
  }
}

h2 span {
  background: linear-gradient(90deg, rgb(255, 184, 0) 0%, rgb(255, 184, 0) 20%, rgb(255, 255, 255) 100%);
  background-clip: text;
  color: transparent;
  font-weight: 700;
}

p {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 1.7;
  letter-spacing: 0;
  vertical-align: middle;
  color: rgba(255, 255, 255, 0.8);
  margin-bottom: 20px;
}
@media (max-width: 900px) {
  p {
    font-size: 1.25rem !important;
  }
}
@media (max-width: 768px) {
  p {
    font-family: "Inter", sans-serif;
    font-weight: 400 !important;
    font-size: 1.125rem !important;
    line-height: 1.5 !important;
    letter-spacing: 0;
  }
}

p span {
  color: #fff;
  font-weight: 500;
}

ul {
  list-style-type: disc;
  padding-left: 30px;
  color: rgba(255, 255, 255, 0.8);
}

ul {
  color: rgba(255, 255, 255, 0.8);
}

ol {
  color: rgba(255, 255, 255, 0.8);
}

ul li {
  margin-bottom: 8px;
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 2.125rem;
  letter-spacing: 0;
  vertical-align: middle;
  color: rgba(255, 255, 255, 0.8);
}
@media (max-width: 768px) {
  ul li {
    font-size: 18px;
  }
}

.plan-du-site__links ul li a {
  position: relative;
  text-decoration: none;
  background-image: linear-gradient(currentColor, currentColor);
  background-repeat: no-repeat;
  background-size: 0% 2px;
  background-position: left bottom;
  transition: background-size 0.4s ease;
  font-size: 20px;
}

@media (hover: hover) {
  .plan-du-site__links ul li a:hover {
    background-size: 100% 2px;
  }
}
li.premier-niveau {
  margin-bottom: 12px !important;
}
@media (max-width: 768px) {
  li.premier-niveau {
    margin-bottom: 8px !important;
  }
}

input,
select,
textarea {
  width: 100%;
}

.link-arrow {
  position: relative;
  color: #FFD400;
  text-decoration: none;
  font-weight: 700;
  transition: color 0.3s ease;
}

@media (max-width: 1024px) {
  .link-arrow.link-arrow-block::after {
    right: 0 !important;
    top: 46% !important;
    left: 121px;
  }
}

.arrow-icon, .link-arrow.cta {
  transition: transform 0.8s ease;
  transform: translateY(0) rotate(0deg);
  transform-origin: center;
}

.link-arrow:hover .arrow-icon {
  transform: translateY(0) rotate(380deg);
}

.link-arrow.cta:hover::after {
  transform: translateY(0) rotate(380deg);
}

svg.arrow-icon {
  margin-left: 3px;
  margin-bottom: -1px;
}
@media (max-width: 768px) {
  svg.arrow-icon {
    width: 14px;
    height: 14px;
  }
}

@keyframes floatSmooth {
  0% {
    transform: translateX(0px) translateY(0px);
  }
  40% {
    transform: translateX(30px) translateY(5px);
  }
  70% {
    transform: translateX(-20px) translateY(-10px);
  }
  100% {
    transform: translateX(0px) translateY(0px);
  }
}
.floatSmooth {
  animation: floatSmooth 12s linear infinite alternate;
}
@media (max-width: 1024px) {
  .floatSmooth {
    display: none !important;
  }
}

.tag-float {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #222;
  font-weight: 500;
  border-radius: 6px;
  font-size: 0.875rem;
  font-family: "Roboto";
  gap: 8px;
  z-index: 2;
}

.floatSmooth a img,
.floatSmooth a svg {
  transition: transform 0.8s ease;
  display: inline-block;
}

.floatSmooth a:hover img {
  transform: rotate(360deg);
}

.floatSmooth a:hover svg {
  transform: rotate(360deg);
}

a.hero-tag.floatSmooth:hover {
  color: #222 !important;
}

.hero-tag.floatSmooth svg,
.hero-tag.floatSmooth img {
  transition: transform 0.8s ease;
  display: inline-block;
}

.hero-tag.floatSmooth:hover svg,
.hero-tag.floatSmooth:hover img {
  transform: rotate(360deg);
}

section.job-description h3 {
  padding-top: 20px;
  font-size: 24px;
}

section.section.class8.expertises-6.section--no-paddings.section--marginTop--md .section-spacing {
  padding-top: 80px;
}

/*
|--------------------------------------------------------------------------
| 7 - Templates
|--------------------------------------------------------------------------
|
|
|
*/
.single-page {
  padding-top: 70px;
}

.single-page__header {
  margin-bottom: 15px;
  text-align: left;
  font-family: "Poppins", sans-serif;
}

.single-page__title {
  color: #FFB800;
}

.single-page__featured-image {
  margin-bottom: 40px;
  border-radius: 20px;
  overflow: hidden;
}

.single-page__featured-image img {
  width: 100%;
  height: auto;
  display: block;
}

.single-page__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 40px;
  padding: 20px;
  font-family: "Poppins", sans-serif;
}

@media (max-width: 768px) {
  .single-page__meta {
    flex-direction: column;
    gap: 20px;
    display: none;
  }
}
.single-page__meta-info {
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
@media (max-width: 1300px) {
  .single-page__meta-info {
    flex-direction: column !important;
    align-items: flex-start !important;
  }
}

.single-page__meta-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.95rem;
}

.single-page__meta-label {
  font-weight: 600;
  color: #fff;
}

b {
  font-weight: 600 !important;
}

.single-page__meta-value {
  color: #fff !important;
}

.single-page__meta-value a {
  color: #FFB800;
  text-decoration: none;
  transition: color 0.2s;
}

.single-page__meta-value a:hover {
  color: #c49000;
}

.single-page__share {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  min-width: 200px;
}

@media (max-width: 768px) {
  .single-page__share {
    align-items: flex-start;
    min-width: auto;
  }
}
.single-page__share-label {
  font-family: "Inter", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1rem;
  line-height: 1.2054;
  letter-spacing: 0;
  vertical-align: middle;
  color: #fff;
}
@media (max-width: 1024px) {
  .single-page__share-label {
    font-size: 1rem;
  }
}

.single-page__share-buttons {
  display: flex;
  gap: 8px;
}

.single-page__share-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  color: white;
  text-decoration: none;
  transition: all 0.3s ease;
  border: none;
  cursor: pointer;
}

.single-page__share-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.single-page__content {
  font-size: 1.1rem;
  line-height: 1.6;
  color: #333;
}

.single-page__content h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.5rem;
  line-height: 1.2273;
  letter-spacing: 0;
  vertical-align: middle;
  color: #fff;
  padding-top: 25px;
}
@media (max-width: 768px) {
  .single-page__content h2 {
    padding-bottom: 15px;
  }
}

.single-page__content h3,
.single-page__content h4,
.single-page__content h5,
.single-page__content h6 {
  color: #FFB800;
}

.single-page__content img {
  max-width: 100%;
  height: auto;
  border-radius: 5px;
  margin: 1.5em 0;
  width: 100%;
}

.image-articles {
  width: 800px;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .image-articles {
    width: 100% !important;
  }
}

.single-page__content a {
  color: #FFD400;
  text-decoration: none;
  transition: color 0.2s;
}

@media (max-width: 768px) {
  .single-page {
    padding-top: 50px;
  }
  .single-page__title {
    font-size: 2.5rem;
  }
}
/*# sourceMappingURL=app.css.map */
