/* 
Theme Name: Hello Elementor Child
Theme URI: https://github.com/elementor/hello-theme-child/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 2.0.0
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/* ======================================================
   1. VARIABLES GLOBALES
   ====================================================== */
:root {
  /* Couleurs */
  --color-primary: #b30838;
  --color-secondary: #7d91a0;
  --color-text: #616161;
  --color-accent: #ff4558;
  --color-gris-clair: #f5f5f5;
  --color-gris-medium: #e1e1e1;
  --color-rouge-opacite: #b308381a;
  --color-gris-fonce: #14212b;
  --color-blanc: #ffffff;
  --color-noir: #000000;

  /* Espacements fixes */
  --space-l: 2rem; /* 32 px */
  --space-xl: 3rem; /* 48 px */
  --space-2xl: 4rem; /* 64 px */
  --space-top-2xl: 4rem; /* 64 px */
  --space-3xl: 5rem; /* 80 px */
  --space-7xl: 7rem; /* 112 px */

  /* Espacements fluides */
  --space-fluid-s: clamp(0.75rem, 2vw, 1.25rem);
  --space-fluid-m: clamp(1.25rem, 4vw, 2rem);
}

/* ======================================================
   2. BASE
   ====================================================== */
body {
  overflow-x: hidden !important;
  background: var(--color-gris-clair);
}

.elementor-widget-text-editor p {
  margin-top: 0 !important;
}

/* ======================================================
   3. TYPOGRAPHIE
   ====================================================== */

/* Familles de polices */
body,
h4,
h5,
h6,
p,
a,
strong,
b {
  font-family: "Nunito", sans-serif;
}

h2,
h2 a,
h2 strong,
h3,
h3 strong,
.elementor-heading-title,
.wpgb-facet-13 h4,
.wpgb-facet-7 {
  font-family: "Exo 2", sans-serif;
  color: var(--color-noir);
}

/* Taille et interligne corps de texte */
.page p,
li,
td,
th,
.single p:not(.single.single-references p, .wpgb-card-wrapper p),
.single.single-references p {
  line-height: 1.6;
  font-size: clamp(1rem, 1.1vw, 1.125rem);
}

/* Titres h1 */
h1,
h1.elementor-heading-title {
  margin-top: 0;
  margin-bottom: var(--space-xl);
  text-wrap: balance;
  font-family: "Exo 2", sans-serif;
  color: var(--color-noir);
}

h1 b,
h1 strong {
  color: var(--color-primary);
  font-family: "Exo 2", sans-serif;
}

.dark h1 b,
.dark h1 strong {
  color: var(--color-accent);
}

/* Titres h2 */
h2,
h2.elementor-heading-title {
  margin-top: 0;
  margin-bottom: var(--space-l);
  text-wrap: balance;
  line-height: 1.2;
}

/* Titres h3 */
h3,
h3.elementor-icon-box-title,
h3.elementor-heading-title,
h3 .wpgb-block-2 {
  padding: 0;
  margin-bottom: var(--space-s);
  text-wrap: balance;
}

.wp-grid-builder .wpgb-card h3 a {
  font-family: "Exo 2", sans-serif;
}

/* Gras dans le corps */
p strong :not(.bg-fonce),
p b {
  color: var(--color-gris-fonce);
}

/* ======================================================
   4. UTILITAIRES
   ====================================================== */

/* Espacements verticaux (padding-block) */
.section--pad-l {
  padding-block: var(--space-l);
}

.elementor-element.pad-xs {
  padding-block: var(--space-xs);
}
.elementor-element.pad-s {
  padding-block: var(--space-s);
}
.elementor-element.pad-l {
  padding-block: var(--space-l);
}
.elementor-element.pad-xl {
  padding-block: var(--space-xl);
}
.elementor-element.pad-2xl {
  padding-block: var(--space-2xl);
}
.elementor-element.pad-3xl {
  padding-block: var(--space-3xl);
}
.elementor-element.pad-5xl {
  padding-block: var(--space-5xl);
}
.elementor-element.pad-7xl {
  padding-block: var(--space-7xl);
}

.elementor-element.pad-top-2xl {
  padding-block: var(--space-2xl) 0;
}
.elementor-element.pad-top-7xl {
  padding-block: var(--space-7xl) 0;
}

.elementor-element.pad-fluid {
  padding-block: var(--space-fluid-m);
}

/* Espacements horizontaux (gouttières) */
.section--padx-l {
  padding-inline: var(--space-l);
}

.elementor-element.gut-xs {
  padding-inline: var(--space-xs);
}
.elementor-element.gut-s {
  padding-inline: var(--space-s);
}
.elementor-element.gut-l {
  padding-inline: var(--space-l);
}
.elementor-element.gut-xl {
  padding-inline: var(--space-xl);
}
.elementor-element.gut-5xl {
  padding-block: var(--space-5xl);
}
.elementor-element.gut-7xl {
  padding-inline: var(--space-7xl);
}

/* Marges */
.marge-80 {
  margin-top: -80px;
}

/* Divers */
.rad-xs {
  border-radius: var(--space-2xs);
}

.border {
  border: 2px solid var(--color-gris-medium);
  padding: 10px;
}

.ombre-forte {
  box-shadow:
    0 0px 135px rgba(0, 0, 0, 0.24),
    0 15px 65px rgba(0, 0, 0, 0.24);
}

/* ======================================================
   5. LAYOUT — GRILLES
   ====================================================== */

/* Mobile first — 1 colonne */
.grid,
.grille-container-card,
.grille-container-cardx3,
.grille-container-cardx4 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: stretch !important;
}

.single-references .grid--3 {
  grid-template-columns: 1fr;
  gap: 0px;
}

/* Tablette — 2 colonnes */
@media (min-width: 768px) {
  .grid,
  .grille-container-card,
  .grille-container-cardx3,
  .grille-container-cardx4,
  .grille-container-cardx5 {
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
  }

  .single-references .grid--3 {
    grid-template-columns: repeat(2, 1fr);
    gap: 0px;
  }
}

/* Desktop — colonnes multiples */
@media (min-width: 1024px) {
  .grid--2 {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }

  .grid--3 {
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }

  .grid--4 {
    grid-template-columns: repeat(4, 1fr);
    gap: 28px;
  }

  .grid--5 {
    grid-template-columns: repeat(5, 1fr);
    gap: 28px;
  }

  .single-references .grid--3 {
    grid-template-columns: repeat(3, 1fr);
    gap: 0px;
  }
}

/* Conteneur boxé Elementor */
.e-con-boxed {
  padding-inline: 20px;
}

@media (min-width: 768px) {
  .e-con-boxed {
    padding-inline: 32px;
  }
}

@media (min-width: 1024px) {
  .e-con-boxed {
    padding-inline: 40px;
  }

  .elementor-element.pad-7xl > .e-con-inner {
    gap: var(--space-7xl);
  }

  .single-references .elementor-element.pad-3xl > .e-con-inner {
    gap: var(--space-3xl);
  }
}

/* ======================================================
   6. ALIGNEMENT & MISE EN PAGE
   ====================================================== */

/* Centrage */
#content .center > .elementor-element,
#content .center .elementor-heading-title,
#content .center h2,
#content .center h3,
#content .center h4,
#content .center h5,
#content .center h6,
#content .center p,
#content .center a,
#content .center.surtitre,
#content .center .surtitre,
#content .cta-centre-content {
  justify-content: center;
  align-self: center;
  text-align: center;
}

/* Colonnes texte desktop */
@media (min-width: 1024px) {
  .text-col-2 {
    padding-top: var(--space-2xl);
  }

  .max-80 {
    max-width: 80% !important;
    margin: 0 auto;
    text-align: center;
  }
}

/* Bloc titre + texte */
.bloc-titre-texte {
  gap: 0;
}

.bloc-titre .center {
  gap: 15px;
}

/* ======================================================
   7. COULEURS DE FOND
   ====================================================== */
.bg-gris {
  background-color: var(--color-gris-clair);
}
.bg-blanc {
  background-color: var(--color-blanc);
}
.bg-fonce {
  background-color: var(--color-gris-fonce);
}
.bg-rouge {
  background-color: var(--color-primary);
}

/* Texte sur fonds sombres */
.bg-fonce,
.bg-fonce p,
.bg-fonce li,
.bg-fonce h1,
.bg-fonce h2,
.bg-fonce h3,
.dark,
.dark p,
.dark li,
.dark h1,
.dark h2,
.dark h3,
.dark .elementor-heading-title {
  color: var(--color-blanc);
}

/* Dégradés */
.bg-gris-grad {
  background: linear-gradient(
    0deg,
    var(--color-gris-clair) 0%,
    var(--color-blanc) 71%
  );
}

.bg-gris-grad-hor {
  background: linear-gradient(
    90deg,
    var(--color-gris-clair) 80%,
    var(--color-blanc) 80%
  );
}

.bg-gris-grad-hor-reverse {
  background: linear-gradient(
    90deg,
    var(--color-blanc) 80%,
    var(--color-gris-clair) 80%
  );
}

.bg-fonce-grad-ver {
  background: linear-gradient(
    0deg,
    var(--color-gris-fonce) 80%,
    var(--color-blanc) 80%
  );
}

.bg-fonce-grad-ver-reverse {
  background: linear-gradient(
    0deg,
    var(--color-blanc) 80%,
    var(--color-gris-fonce) 80%
  );
}

@media (min-width: 1800px) {
  .bg-gris-grad-hor {
    background: linear-gradient(
      90deg,
      var(--color-gris-clair) 70%,
      var(--color-blanc) 70%
    );
  }

  .bg-gris-grad-hor-reverse {
    background: linear-gradient(
      90deg,
      var(--color-blanc) 70%,
      var(--color-gris-clair) 70%
    );
  }

  .bg-fonce-grad-ver {
    background: linear-gradient(
      0deg,
      var(--color-gris-fonce) 70%,
      var(--color-blanc) 70%
    );
  }

  .bg-fonce-grad-ver-reverse {
    background: linear-gradient(
      0deg,
      var(--color-blanc) 70%,
      var(--color-gris-fonce) 70%
    );
  }
}

@media (max-width: 1024px) {
  .bg-gris-grad-hor,
  .bg-gris-grad-hor-reverse {
    background: var(--color-gris-clair);
  }

  .bg-fonce-grad-ver,
  .bg-fonce-grad-ver-reverse {
    background: var(--color-gris-fonce);
  }
}

/* ======================================================
   8. SURTITRE
   ====================================================== */
.surtitre .elementor-heading-title,
.elementor-widget-text-editor del,
.type-merci h6,
.single-temoignage h6,
.single-evenement h6,
.elementor-slides .swiper-slide-inner .elementor-slide-heading {
  color: var(--color-primary);
  font-size: clamp(1rem, 1.1vw, 1.2rem);
  vertical-align: middle;
  text-decoration: none;
}

.elementor-slides .swiper-slide-inner .elementor-slide-heading {
  color: var(--color-blanc);
}

/* Trait avant surtitre */
del::before,
.surtitre::before,
.type-merci h6::before,
.single-temoignage h6::before,
.single-evenement h6::before,
.elementor-slide-heading::before {
  content: " ";
  width: 30px;
  height: 3px;
  background: var(--color-primary);
  display: inline-block;
  vertical-align: middle;
  margin-right: 15px;
}

/* Trait après surtitre centré */
.center del::after,
.center .surtitre .elementor-heading-title::after,
.center.surtitre .elementor-heading-title::after {
  content: " ";
  width: 30px;
  height: 3px;
  background: var(--color-primary);
  display: inline-block;
  vertical-align: middle;
  margin-left: 15px;
}

/* Surtitre post-info */
.surtitre.elementor-widget-post-info {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0;
}

.surtitre .elementor-post-info__terms-list-item {
  font-family: "Nunito", sans-serif;
  font-size: clamp(1.2rem, 1.1vw, 1.325rem);
  font-weight: 700;
}

.surtitre.elementor-widget .elementor-icon-list-items.elementor-inline-items {
  margin-inline: 5px;
}

/* ======================================================
   9. LISTES
   ====================================================== */
.elementor-location-single ul,
.elementor-location-single ol,
#content ul,
#content ol {
  padding-left: 30px;
}

.elementor-location-single
  ul:not(.wpgb-pagination, .elementor-post-info, .elementor-toc__list-wrapper)
  li,
#content
  ul:not(.wpgb-pagination, .elementor-post-info, elementor-toc__list-wrapper)
  li {
  list-style-type: none;
  text-indent: -15px;
}

.elementor-toc__body {
  padding: 0 20px;
}

.elementor-location-single li,
#content li {
  margin-bottom: 10px;
}

/* Puce SVG personnalisée */
.elementor-location-single
  ul
  li:not(.elementor-widget-post-info ul li, .elementor-toc__body ul li)::before,
#content ul:not(.wpgb-inline-list) li:not(li.e-n-menu-item)::before {
  content: url(https://tvhconsulting2026.kinsta.cloud/wp-content/uploads/2026/03/check-list.svg);
  padding-right: 10px;
  display: inline-block;
  vertical-align: middle;
}

/* Listes ordonnées */
#content ol li,
.article-container ol li,
.page ol li,
.single ol li {
  position: relative;
  padding-left: 10px;
}

ol li::marker {
  font-weight: 700;
  font-size: 20px;
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
  width: 20px;
  height: 20px;
  display: block !important;
  border-radius: 30px;
}

ol li:not(ol ul li)::before {
  content: "";
  width: 30px;
  height: 30px;
  border: 1px solid var(--color-primary);
  display: block;
  border-radius: 30px;
  position: absolute;
  top: 1px;
  left: -30px;
}

/* Post-info */
.elementor-widget-post-info ul li::before {
  display: none;
}

.elementor-widget-post-info ul li {
  text-indent: 0;
}

/* ======================================================
   10. BOUTONS & HYPERLIENS
   ====================================================== */
#content .elementor-widget-button {
  margin-top: unset;
}

/* Typographie commune */
.elementor-widget-button .elementor-button,
.wp-block-button .wp-element-button,
.elementor-element.elementor-button-info .elementor-button,
.elementor-element.elementor-button-warning .elementor-button,
#content .mauticform-button-wrapper .mauticform-button.btn-default,
#content .mauticform-pagebreak-wrapper .mauticform-pagebreak.btn-default,
.mauticform-button-wrapper .mauticform-button.btn-default,
.elementor-slides .swiper-slide-inner .elementor-slide-button {
  font-family: "Nunito", sans-serif;
  font-size: clamp(1rem, 1.1vw, 1.125rem);
  font-weight: 700;
  letter-spacing: 0px;
  color: var(--color-blanc);
}

/* Couleur de fond principale */
.elementor-widget-button .elementor-button,
.wp-block-button .wp-element-button,
.elementor-element.elementor-button-info .elementor-button,
#content .mauticform-button-wrapper .mauticform-button.btn-default,
#content .mauticform-pagebreak-wrapper .mauticform-pagebreak.btn-default,
.mauticform-button-wrapper .mauticform-button.btn-default,
.elementor-slides .swiper-slide-inner .elementor-slide-button {
  background-color: var(--color-primary);
}

/* Hover principal */
.elementor-widget-button .elementor-button:hover,
.wp-block-button .wp-element-button:hover,
.elementor-element.elementor-button-info .elementor-button:hover,
#content .mauticform-button-wrapper .mauticform-button.btn-default:hover,
#content .mauticform-pagebreak-wrapper .mauticform-pagebreak.btn-default:hover {
  background-color: #b30838e0;
}

/* Variante sombre */
.elementor-element.elementor-button-success .elementor-button,
.elementor-element.elementor-button-warning .elementor-button {
  background-color: var(--color-gris-fonce);
}

.elementor-element.elementor-button-success .elementor-button:hover,
.elementor-element.elementor-button-warning .elementor-button:hover,
.elementor-slides .swiper-slide-inner .elementor-slide-button:hover {
  background-color: #14212be0;
}

.elementor-element.elementor-button-success .elementor-button-icon {
  background-color: var(--color-primary);
}

/* Variantes info & warning — border-radius et padding */
.elementor-element.elementor-button-info .elementor-button,
.elementor-element.elementor-button-warning .elementor-button {
  border-radius: 30px;
  padding: 20px 40px;
}

/* Formulaires Mautic */
#content .mauticform-button-wrapper .mauticform-button.btn-default,
#content .mauticform-pagebreak-wrapper .mauticform-pagebreak.btn-default {
  border-radius: 30px;
  padding: 15px 35px;
}

/* Bouton standard avec icône */
.elementor-widget-button .elementor-button,
.wp-block-button .wp-element-button {
  border-radius: 50px;
  padding: 8px 8px 8px 40px;
}

.elementor-button-icon {
  padding: 18px;
  background-color: var(--color-gris-fonce);
  border-radius: 30px;
  margin-left: 10px;
}

.elementor-button-icon .e-font-icon-svg {
  width: 10px;
  height: 10px;
}

.elementor-button-content-wrapper {
  align-items: center;
}

/* Variante danger (lien texte) */
.elementor-element.elementor-button-danger .elementor-button {
  background-color: transparent;
  color: var(--color-gris-fonce);
  padding: 0;
  border-radius: 0;
}

.elementor-element.elementor-button-danger .elementor-button-icon {
  padding: 0;
  background-color: transparent;
  border-radius: 0;
  margin: 0;
}

.elementor-element.elementor-button-danger
  .elementor-button-icon
  .e-font-icon-svg {
  width: 14px;
  height: 14px;
}

.elementor-button-danger .elementor-button {
  fill: var(--color-gris-fonce);
}

.elementor-button-danger .elementor-button-text {
  border-bottom: 2px solid transparent;
  padding-bottom: 2px;
}

.elementor-button-danger:hover .elementor-button-text {
  border-bottom: 2px solid var(--color-gris-fonce);
}

/* ======================================================
   11. FORMULAIRES
   ====================================================== */
.col-formulaire {
  padding: 32px;
  background: #fff;
  border: 1px solid var(--color-gris-clair);
  box-sizing: border-box;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.05);
}

#content .mauticform-selectbox,
#content .mauticform-input,
#content .mauticform-textarea {
  border-color: var(--color-gris-clair);
  background: #f8f8f8;
  color: var(--color-secondary);
  font-family: inherit;
}

#content .mauticform-label,
#content .mauticform-checkboxgrp-label {
  color: var(--color-noir);
  font-size: 0.8em;
}

input[type="date"],
input[type="email"],
input[type="number"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="text"],
input[type="url"],
select,
textarea {
  background-color: var(--color-gris-clair);
  border: 1px solid var(--color-gris-medium);
}

.mauticform-label,
label {
  font-weight: bold;
  font-size: 0.92em !important;
}

.elementor-widget-theme-post-content .mauticform-innerform {
  background: var(--color-blanc);
  padding: 20px;
}

.accordion-learmore .elementor-widget-text-editor {
  padding: 20px 0 20px 0;
}

/* ======================================================
   12. ICÔNES CONTACT
   ====================================================== */
ul .ic-tel::before,
ul .ic-fax::before,
ul .ic-mail::before {
  content: "";
  width: 19px;
  height: 19px;
  position: absolute;
  left: -30px;
  top: 4px;
}

ul .ic-tel::before {
  background: transparent url("/wp-content/uploads/2021/01/icon-tel.svg")
    no-repeat scroll 0 0 / contain;
}

ul .ic-fax::before {
  background: transparent url("/wp-content/uploads/2021/01/ic-fax.svg")
    no-repeat scroll 0 0 / contain;
}

ul .ic-mail::before {
  background: transparent url("/wp-content/uploads/2021/01/ic-mail.svg")
    no-repeat scroll 0 0 / contain;
}

.box-evenement .ic svg {
  width: 19px;
  height: 19px;
}

/* ======================================================
   13. TABLEAU
   ====================================================== */
.ert-title-row th,
table thead:first-child tr:first-child th {
  letter-spacing: 1.5px;
  text-transform: uppercase;
  text-align: center !important;
  font-size: 14px;
  text-wrap: balance;
}

/* ======================================================
   14. CHIFFRES CLÉS
   ====================================================== */
.elementor-counter .elementor-counter-number-wrapper {
  font-size: 40px;
  color: var(--color-primary);
}

.elementor-counter .elementor-counter-title {
  line-height: 1.25em;
  font-size: 16px;
  color: #14212b;
  font-weight: 600 !important;
  padding-top: 10px;
  padding-bottom: 20px;
}

/* ======================================================
   15. PARTAGE SOCIAL
   ====================================================== */
.ayudawp-share-buttons {
  margin: 0;
  padding: 20px;
  border-top: 0;
  border-bottom: 0;
}

.ayudawp-buttons-container {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.ayudawp-share-buttons .ayudawp-share-btn {
  width: 100%;
  color: var(--color-blanc);
  border-radius: 50px;
  background: var(--color-secondary);
}

/* ======================================================
   16. FAQ SCHÉMA
   ====================================================== */
.schema-faq-section {
  border-bottom: 1px solid #e1e1e1;
  overflow: hidden;
  transition: background-color 0.3s ease;
}

.schema-faq-section:hover {
  background-color: #fcfcfc;
}

.schema-faq-question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 10px;
  margin: 0;
  cursor: pointer;
  font-size: 18px;
  font-weight: 600;
  color: #1a1a1a;
  transition: color 0.3s ease;
}

.schema-faq-question:after {
  content: "+";
  font-size: 24px;
  font-weight: 300;
  transition: transform 0.4s ease;
  display: inline-block;
}

.schema-faq-section.active .schema-faq-question:after {
  transform: rotate(45deg);
  color: #0073aa;
}

.schema-faq-answer {
  max-height: 0;
  opacity: 0;
  margin: 0 !important;
  padding: 0 10px;
  overflow: hidden;
  transition:
    max-height 0.5s cubic-bezier(0, 1, 0, 1),
    opacity 0.3s ease;
}

.schema-faq-section.active .schema-faq-answer {
  max-height: 1000px;
  opacity: 1;
  padding-bottom: 25px;
  transition:
    max-height 0.5s ease-in-out,
    opacity 0.5s ease;
}

/* ======================================================
   17. SOMMAIRE BLOG (TOC)
   ====================================================== */
#elementor-toc__6add0ca .elementor-toc__list-item-text,
.elementor-toc__body .elementor-toc__list-item-text {
  font-weight: 700;
  text-transform: uppercase;
  color: var(--color-text);
  font-size: 13px;
  line-height: 1.3;
  text-decoration: none;
  display: inline-block;
}

#elementor-toc__6add0ca .elementor-toc__list-item-text.elementor-item-active,
.elementor-toc__body .elementor-toc__list-item-text.elementor-item-active{
  color: var(--color-primary);
}

#elementor-toc__6add0ca .elementor-toc__list-wrapper,
.elementor-toc__body .elementor-toc__list-wrapper {
  position: relative;
  padding-left: 35px;
  list-style: none;
}

#elementor-toc__6add0ca .elementor-toc__list-wrapper,
#elementor-toc__6add0ca .elementor-toc__list-item,
.elementor-toc__body .elementor-toc__list-wrapper,
.elementor-toc__body .elementor-toc__list-item {
  border-left: none;
}

/* Ligne verticale */
#elementor-toc__6add0ca .elementor-toc__list-wrapper::before,
.elementor-toc__body .elementor-toc__list-wrapper::before {
  content: "";
  position: absolute;
  left: 7px;
  top: 12px;
  bottom: 12px;
  width: 2px;
  background-color: var(--color-gris-medium);
  z-index: 1;
}

/* Items de liste */
#elementor-toc__6add0ca .elementor-toc__list-item,
.elementor-toc__body .elementor-toc__list-item {
  position: relative;
  margin-bottom: 25px;
  padding-left: 0;
}

#elementor-toc__6add0ca .elementor-toc__list-item::before,
.elementor-toc__body .elementor-toc__list-item::before {
  content: "";
  position: absolute;
  left: -34px;
  top: 4px;
  width: 14px;
  height: 14px;
  background-color: var(--color-blanc);
  border: 3px solid var(--color-primary);
  border-radius: 50%;
  z-index: 2;
}

/* ======================================================
   18. HEADER & MENU
   Note : styles de navigation détaillés dans menu.css
   ====================================================== */
.header-tvh {
  overflow: visible !important;
}

/* ======================================================
   19. SECTION INTRO
   ====================================================== */
.section-intro .content-section {
  padding-left: var(--space-7xl);
  margin-left: -7rem;
  width: calc(100% + var(--space-7xl));
}

/* ======================================================
   20. SECTION CTA
   ====================================================== */
.section-cta.bg-fonce,
.section-formulaire.bg-fonce {
  background:
    url(https://tvhconsulting2026.kinsta.cloud/wp-content/uploads/2026/03/ligne-deco.svg),
    url(https://tvhconsulting2026.kinsta.cloud/wp-content/uploads/2026/03/trait-rouge-droit-1.svg),
    linear-gradient(90deg, var(--color-gris-fonce) 80%, var(--color-blanc) 80%);
  background-repeat: no-repeat;
  background-size: 17%, 17%, cover;
  background-position:
    top left,
    bottom 30% right,
    center center;
}

.section-cta .img-cta {
  margin-left: -20%;
}

@media (min-width: 1025px) {
  .section-cta .elementor-widget-loop-grid {
    width: 70%;
    margin: 0;
    align-self: flex-start;
  }
}

@media (min-width: 1800px) {
  .section-cta.bg-fonce,
  .section-formulaire.bg-fonce {
    background:
      url(https://tvhconsulting2026.kinsta.cloud/wp-content/uploads/2026/03/ligne-deco.svg),
      url(https://tvhconsulting2026.kinsta.cloud/wp-content/uploads/2026/03/trait-rouge-droit-1.svg),
      linear-gradient(
        90deg,
        var(--color-gris-fonce) 70%,
        var(--color-blanc) 70%
      );
    background-repeat: no-repeat;
    background-size: 17%, 17%, cover;
    background-position:
      top left,
      bottom 30% right,
      center center;
  }
}

@media (max-width: 1024px) {
  .section-cta.bg-fonce,
  .section-formulaire.bg-fonce {
    background:
      url(https://tvhconsulting2026.kinsta.cloud/wp-content/uploads/2026/03/ligne-deco.svg),
      url(https://tvhconsulting2026.kinsta.cloud/wp-content/uploads/2026/03/trait-rouge-droit-1.svg),
      var(--color-gris-fonce);
    background-repeat: no-repeat;
    background-size: 17%, 17%, cover;
    background-position:
      top left,
      bottom 30% right,
      center center;
  }

  .section-cta .img-cta {
    margin-left: 0%;
  }

  .section-cta .img-cta img {
    margin-right: -60%;
  }

  .section-cta > .e-con-inner {
    gap: var(--space-xl);
  }
}

@media (max-width: 767px) {
  .section-cta .img-cta img {
    margin-right: 0;
    margin-top: -50%;
  }

  .section-cta > .e-con-inner {
    gap: var(--space-7xl);
  }

  .section-cta .col-img {
    margin-top: 20%;
  }

  #content .section-cta .elementor-widget-loop-grid .e-loop-item img {
    max-width: 100%;
  }
}

/* ======================================================
   21. CTA CENTRÉ
   ====================================================== */
.cta-centre-content {
  background-image:
    url(https://tvhconsulting2026.kinsta.cloud/wp-content/uploads/2026/03/ligne-deco-blanche.svg),
    url(https://tvhconsulting2026.kinsta.cloud/wp-content/uploads/2026/03/ligne-deco-blanche.svg);
  background-repeat: no-repeat;
  background-size: 15% 60%;
  background-position:
    top -25% left 0%,
    bottom -25% right 0%;
  max-width: 90%;
  margin-top: -13%;
  padding: var(--space-xl);
}

.elementor-element.e-con.e-parent:has(+ .section-cta-centre),
.elementor-element.e-con.e-parent:has(
    + .elementor-element .section-modele-cta
  ) {
  padding-bottom: 15%;
}

@media (max-width: 1024px) {
  .elementor-element.e-con.e-parent:has(+ .section-cta-centre),
  .elementor-element.e-con.e-parent:has(
      + .elementor-element .section-modele-cta
    ) {
    padding-bottom: 25%;
  }
}

@media (max-width: 767px) {
  .cta-centre-content {
    background-size: 15% 50%;
    background-position:
      top -30% left -2%,
      bottom -30% right -2%;
    margin-top: -25%;
  }

  .section-cta-centre.elementor-element.pad-2xl {
    padding-block: var(--space-m);
  }

  .elementor-element.e-con.e-parent:has(+ .section-cta-centre),
  .elementor-element.e-con.e-parent:has(
      + .elementor-element .section-modele-cta
    ) {
    padding-bottom: 40%;
  }
}

/* ======================================================
   22. SECTION VIDÉO
   ====================================================== */
.section-video .elementor-widget-video.vid-lightbox {
  overflow: visible;
}

.section-video
  .elementor-widget-video.vid-lightbox
  .elementor-custom-embed-image-overlay
  img {
  display: none;
}

.section-video
  .elementor-widget-video.vid-lightbox
  .elementor-wrapper.elementor-open-lightbox {
  max-width: 20%;
}

.dialog-lightbox-widget
  .dialog-lightbox-message
  .elementor-video-container
  .elementor-video-wrapper
  iframe {
  max-width: 50vw;
}

@media (min-width: 1025px) {
  .section-video-alt .elementor-widget-button {
    align-self: center;
  }
}

.single .elementor-widget-video {
  margin-bottom: 60px !important;
}

/* ======================================================
   23. TÉMOIGNAGES
   ====================================================== */
#content .section-citation .elementor-widget-testimonial {
  max-width: 70%;
  margin: 0 auto;
}

@media (max-width: 1024px) {
  #content .section-citation .elementor-widget-testimonial {
    max-width: 80%;
  }
}

.elementor-testimonial-wrapper .elementor-testimonial-content,
.elementor-widget-testimonial-carousel .elementor-testimonial__text {
  font-size: clamp(1.3rem, 1.5vw, 1.6rem);
  line-height: 1.2em;
  font-style: normal;
}

.elementor-testimonial-content::before {
  content: " ";
  background: transparent url("/wp-content/uploads/2021/01/guillemet.svg")
    scroll 0 0 no-repeat;
  width: 50px;
  height: 50px;
  position: absolute;
  left: -50px;
  top: -25px;
  display: block;
}

.elementor-testimonial-wrapper .elementor-testimonial-image img,
.elementor-testimonial__image img {
  background-color: var(--color-blanc);
  padding: 3px;
}

.elementor-widget-testimonial-carousel .elementor-testimonial__image img {
  height: 57px;
  width: 57px;
}

.elementor-testimonial__name {
  font-family: "Exo 2", sans-serif;
  font-weight: 500;
  margin-bottom: 3px;
  font-size: 18px;
}

#content .elementor-testimonial-job {
  font-size: 12px;
}

/* Citation encadrée */
#content .quote-encadre .elementor-testimonial-content {
  background: var(--color-blanc);
  box-shadow: 0px 10px 32px #d7d7d766;
  padding: 30px 30px 40px 70px;
  margin: 30px 0 35px 0;
}

#content .elementor-widget-text-editor blockquote,
.single .elementor-widget-text-editor blockquote {
  background: var(--color-blanc);
  box-shadow: 0px 10px 32px #d7d7d766;
  padding: 0px 30px 40px 70px;
  margin: 30px 0 35px 0;
}

#content blockquote p {
  margin-bottom: 0;
}

.quote-encadre.elementor-widget-testimonial .elementor-testimonial-wrapper {
  overflow: visible;
}

#content blockquote p,
#content .elementor-widget-text-editor blockquote,
#content .quote-encadre .elementor-testimonial-content {
  text-align: left;
  color: var(--color-gris-fonce);
  font-size: clamp(1.2rem, 1.1vw, 1.325rem);
  line-height: 1.5em;
}

.quote-encadre .elementor-testimonial-content::before,
.elementor-widget-blockquote blockquote p::before {
  content: " ";
  background: transparent url("/wp-content/uploads/2021/01/guillemet.svg")
    scroll 0 0 no-repeat;
  width: 50px;
  height: 50px;
  position: absolute;
  left: 10px;
  top: -5px;
  display: block;
}

.elementor-widget-text-editor blockquote::before {
  content: " ";
  background: transparent url("/wp-content/uploads/2021/01/guillemet.svg")
    scroll 0 0 no-repeat !important;
  width: 50px;
  height: 50px;
  position: relative;
  left: -60px !important;
  top: -35px !important;
  display: block;
}

.elementor-widget-text-editor cite {
  display: flex;
  flex-direction: row;
  gap: 10px;
  font-style: normal;
  align-items: center;
  margin-bottom: 30px;
}

#content .elementor-widget-text-editor cite img {
  border-radius: 60px;
}

#content .elementor-widget-text-editor cite span {
  line-height: 1.5em;
}

#content .elementor-widget-text-editor cite strong {
  font-family: "Exo 2", sans-serif;
  font-weight: 500;
  margin-bottom: 3px;
  font-size: 18px;
}

#content .elementor-widget-text-editor cite {
  font-size: 12px;
}

.quote-encadre .elementor-testimonial-meta {
  display: flex;
  margin-bottom: 30px;
}

/* ======================================================
   24. HÉROS
   ====================================================== */
.hero-rond {
  overflow: hidden;
}

.hero-rond .col-img {
  position: relative;
  scale: 3.2;
  right: -35%;
  top: 200px;
}

.hero-rond .img-hero img {
  border-radius: 100%;
  width: 60%;
  position: relative;
  top: 0px;
  left: -60px;
}

.img-reseau {
  position: absolute;
  z-index: -1;
  top: -10%;
  left: -8%;
}

.hero-reseau-section {
  position: relative;
  overflow: hidden;
  background-image: url("https://tvhconsulting2026.kinsta.cloud/wp-content/uploads/2026/03/reseau-hero.svg");
  background-repeat: no-repeat;
  background-position: calc(100% + 200px) 40px;
  background-size: 1064px 930px;
}

@media (max-width: 1460px) {
  .hero-rond .col-texte {
    width: 50%;
  }
}

@media (max-width: 1024px) {
  #content .hero-rond .e-con-inner {
    flex-direction: column-reverse;
  }

  .hero-rond .col-texte {
    width: 100%;
  }

  #content .hero-rond .col-img {
    scale: 2;
    top: -100%;
    right: -90%;
  }

  #content .hero-rond .img-hero img {
    position: relative;
    top: 0px;
    left: -20%;
  }
}

@media (max-width: 767px) {
  #content .hero-rond .col-img {
    scale: 0.6;
    top: 3%;
    right: -43%;
  }
}
/* overlay heros single */
.references-template-default #content .elementor .dark.elementor-element:nth-of-type(1)::before, 
.post-template-default .dark.elementor-element.hero-article::before, 
.temoignage-template-default .temoignage .dark.elementor-element:nth-of-type(1)::before {
  background-color: var(--color-gris-fonce);
}
/* ======================================================
   25. ACCORDÉON IMAGE
   ====================================================== */
#content .section-ac-img .ac-tab {
  flex-grow: 1;
  width: 100%;
  transition: all 0.5s ease;
  cursor: pointer;
  min-height: 670px;
}

#content .section-ac-img .ac-tab:hover {
  flex-grow: 3;
  width: 200%;
}

#content .ac-number {
  margin-bottom: 50px;
}

.ac-number .elementor-heading-title {
  font-size: 120px;
  font-weight: 500;
}

.ac-icon {
  position: absolute;
  width: 110px;
  left: 45px;
  top: 70px;
}

.ac-icon .cls-1 {
  fill: var(--color-primary);
}

#content .section-ac-img .ac-tab:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(3, 22, 37, 0.85);
  transition: opacity 0.25s ease;
}

@media (max-width: 1024px) {
  #content .section-ac-img .ac-tab {
    min-height: auto;
  }
}

@media (min-width: 1025px) {
  #content .section-ac-img .ac-tab .ac-descr {
    visibility: hidden;
    transition: 0.3s;
  }

  #content .section-ac-img .ac-tab:hover .ac-descr {
    visibility: visible;
    transition: 0.3s;
  }

  #content .section-ac-img .ac-tab:hover:before {
    opacity: 0.8;
    transform: translate3d(0, 0, 0) translateY(0);
    transition: all 1s ease 0.25s;
  }
}

/* ======================================================
   26. TIMELINE (timetab)
   ====================================================== */
.timetab {
  padding-top: 190px;
}

.timetab-date {
  font-size: 13px;
  font-weight: 500;
  display: block;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
}

.timetab-label {
  position: absolute;
  display: block;
  transform: translateX(-15px) rotate(-45deg);
  top: -120px;
  left: 15px;
  width: 170px;
  line-height: 1.1;
  font-size: 12px;
  text-align: left;
  text-wrap: wrap;
}

#content .timetab .e-n-tab-title {
  background-color: transparent;
}

.timetab-date::before {
  content: "";
  width: 20px;
  height: 20px;
  background-color: var(--color-primary);
  border-radius: 50%;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 30px;
  z-index: 1;
}

#content .timetab .e-n-tab-title[aria-selected="true"] .timetab-date::before,
#content .timetab .e-n-tab-title:hover .timetab-date::before {
  border: 2px solid var(--color-blanc);
  bottom: 28px;
}

.timetab .e-n-tabs-content {
  margin-top: 20px;
}

.timetab .e-n-tabs-heading::before {
  content: "";
  top: 180px;
  position: absolute;
  left: 0;
  right: 0;
  height: 3px;
  background-color: var(--color-blanc);
}

.timetab-col-img img {
  border-radius: 5px;
}

#content .timetab-content > .e-con-inner {
  align-items: center;
  gap: var(--space-xl);
}

.timetab-content {
  margin-top: var(--space-l);
}

.timetab-content-date .elementor-heading-title {
  color: var(--color-blanc);
  font-weight: 600;
}

@media (max-width: 1366px) {
  .timetab {
    padding-top: 20px;
  }

  .timetab-label {
    top: 50px;
  }

  .timetab .e-n-tab-title {
    height: 200px !important;
  }
}

/* ======================================================
   27. STEP AUDIT
   ====================================================== */
#step-audit {
  margin: auto;
}

#step-audit [class*="step-"]:before {
  height: 130px;
  width: 130px;
  content: "- ";
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  margin-top: -20px;
}

#step-audit p {
  border-top: 2px dashed;
  border-color: var(--color-primary);
  margin: 0;
  padding: 30px;
  counter-increment: section;
  position: relative;
}

/* Icônes par variante */
#step-audit .step-1-test-intrusion:before {
  background-image: url(/wp-content/uploads/2023/03/test-intrusion-social-engineering.svg);
}

#step-audit .step-1-cadrage:before {
  background-image: url(/wp-content/uploads/2023/03/audit-organisationnel-cadrage.svg);
}

#step-audit .step-1:before {
  background-image: url(/wp-content/uploads/2021/02/ic-step-01-01.svg);
}

#step-audit .step-2-test-intrusion:before {
  background-image: url(/wp-content/uploads/2023/03/test-intrusion-physique.svg);
}

#step-audit .step-2-revue-documentaire:before {
  background-image: url(/wp-content/uploads/2023/03/audit-organisationnel-revue-documentaire.svg);
}

#step-audit .step-2:before {
  background-image: url(/wp-content/uploads/2021/02/ic-step-2-v2-01.svg);
}

#step-audit .step-4-rapport-audit:before {
  background-image: url(/wp-content/uploads/2023/03/audit-organisationnel-rapport.svg);
}

#step-audit .step-3-test-intrusion:before {
  background-image: url(/wp-content/uploads/2023/03/test-intrusion-logique.svg);
}

#step-audit .step-3-audit-site:before {
  background-image: url(/wp-content/uploads/2023/03/audit-organisationnel-audit-site.svg);
}

#step-audit .step-3:before,
#step-audit .step-3-deploiement:before,
#step-audit .step-4-deploiement:before,
#step-audit .step-5-deploiement:before {
  background-image: url(/wp-content/uploads/2021/02/ic-step-3-01.svg);
}

/* Surcharge audit CRM */
#step-audit .audit-crm .step-1::before {
  background-image: url(/wp-content/uploads/2025/02/ic-step-01-audit-crm-4.svg);
}

#step-audit .audit-crm .step-2::before {
  background-image: url(/wp-content/uploads/2025/02/ic-step-02-audit-crm-4.svg);
}

#step-audit .audit-crm .step-3-audit-site::before {
  background-image: url(/wp-content/uploads/2025/02/ic-step-03-audit-crm-4.svg);
}

#step-audit .audit-crm .step-4-rapport-audit::before {
  background-image: url(/wp-content/uploads/2025/02/ic-step-04-audit-crm-4.svg);
}

/* Surcharge déploiement CRM */
#step-audit .deploi-crm .step-1::before {
  background-image: url(/wp-content/uploads/2025/02/ic-step-01-deploiement-crm.svg);
}

#step-audit .deploi-crm .step-2::before {
  background-image: url(/wp-content/uploads/2025/02/ic-step-02-deploiement-crm.svg);
}

#step-audit .deploi-crm .step-3-deploiement::before {
  background-image: url(/wp-content/uploads/2025/02/ic-step-03-deploiement-crm.svg);
}

#step-audit .deploi-crm .step-4-deploiement::before {
  background-image: url(/wp-content/uploads/2025/02/ic-step-04-deploiement-crm.svg);
}

#step-audit .deploi-crm .step-5-deploiement::before {
  background-image: url(/wp-content/uploads/2025/02/ic-step-05-deploiement-crm.svg);
}

/* Padding bas étapes finales */
#step-audit .step-3,
#step-audit .step-3-test-intrusion,
#step-audit .step-4-rapport-audit,
.step-5-deploiement {
  padding-bottom: 150px !important;
}

/* Numérotation */
#step-audit p:nth-child(odd):before {
  content: counter(section);
  right: 100%;
  margin-right: -20px;
  position: absolute;
  color: var(--color-blanc);
  font-size: 110%;
  line-height: 20px;
  text-align: left;
}

#step-audit p:nth-child(even):before {
  content: counter(section);
  left: 100%;
  margin-left: -20px;
  position: absolute;
  text-align: center;
  color: var(--color-blanc);
  font-size: 110%;
  line-height: 20px;
}

/* Serpentin */
#step-audit p:nth-child(odd) {
  border-left: 2px dashed;
  border-top-left-radius: 30px;
  border-bottom-left-radius: 30px;
  margin-right: 30px;
  padding-right: 0;
  padding-left: 50px;
  text-align: left;
}

#step-audit p:nth-child(even) {
  border-right: 2px dashed;
  border-top-right-radius: 30px;
  border-bottom-right-radius: 30px;
  margin-left: 30px;
  padding-left: 20px;
  padding-right: 50px;
  text-align: right;
}

#step-audit p:first-child {
  border-top: 0;
  border-top-right-radius: 0;
  border-top-left-radius: 0;
}

#step-audit p:last-child {
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}

/* ======================================================
   28. MONTAGE PHOTOS ALTERNÉ
   ====================================================== */
.section-alternated > .e-con-inner {
  display: flex;
  align-items: stretch;
}

.section-alternated .col-media {
  position: relative;
  min-height: 280px;
  overflow: visible;
}

.section-alternated .img-back {
  position: absolute;
  inset: 0;
}

.section-alternated .img-back,
.section-alternated .img-back .elementor-widget-container,
.section-alternated .img-back img {
  width: 100%;
  height: 100%;
}

.section-alternated .img-back img {
  display: block;
  object-fit: cover;
}

.section-alternated .col-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  align-self: stretch;
}

.section-alternated .col-text > .elementor-element {
  flex: 0 0 auto !important;
  width: 100%;
  margin: 0 !important;
}

.section-alternated
  .col-text
  > .elementor-element
  > .elementor-widget-container {
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

.section-alternated .col-text > .elementor-widget-text-editor {
  flex: 0 0 auto !important;
}

.section-alternated .col-text > .elementor-widget-button {
  flex-grow: 0 !important;
  margin-top: 1.5rem !important;
  align-self: flex-start;
}

.section-alternated .col-text .elementor-widget-text-editor p {
  margin-top: 0;
}

.section-alternated .col-text .elementor-widget-text-editor p:last-child {
  margin-bottom: 0;
}

/* Badge / image avant */
.section-alternated .img-front {
  --badge-size: 140px;
  --badge-offset: 18%;
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translate(var(--badge-offset), var(--badge-offset));
  width: var(--badge-size);
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: var(--color-blanc);
  border-radius: 0;
  box-shadow:
    0 0 60px rgba(0, 0, 0, 0.16),
    0 14px 40px rgba(0, 0, 0, 0.18);
  overflow: hidden;
  z-index: 5;
}

.section-alternated .img-front .elementor-widget-container {
  width: 100%;
  height: 100%;
}

.section-alternated .img-front img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.section-alternated .img-front.is-photo {
  padding: 0;
}

.section-alternated .img-front.is-photo img {
  object-fit: cover;
}

@media (min-width: 768px) {
  .section-alternated .col-media {
    min-height: 420px;
  }

  .section-alternated .img-front {
    --badge-size: 180px;
    --badge-offset: 16%;
    padding: 18px;
  }
}

@media (min-width: 1025px) {
  .section-alternated .col-media {
    min-height: 520px;
  }

  .section-alternated .img-front {
    --badge-size: 220px;
    --badge-offset: 14%;
    padding: 20px;
  }
}

/* ======================================================
   29. TRIPLE LAYER — MOBILE FIRST
   ====================================================== */
.col-media.is-triple-layer {
  --front-size: 80%;
  --badge-size: 120px;
  --badge-padding: 12px;
  --mobile-overlap: -25%;
  --mobile-bottom-space: 60px;

  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: auto;
  padding-bottom: var(--mobile-bottom-space);
  overflow: visible;
}

.col-media.is-triple-layer .img-back {
  position: relative;
  width: 100%;
  height: auto;
  z-index: 1;
}

.col-media.is-triple-layer .img-back .elementor-widget-container,
.col-media.is-triple-layer .img-back img {
  width: 100%;
  height: auto;
}

.col-media.is-triple-layer .img-back img {
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.col-media.is-triple-layer .img-front.is-photo {
  position: relative;
  width: var(--front-size);
  margin-top: var(--mobile-overlap);
  z-index: 5;
}

.col-media.is-triple-layer .img-front.is-photo .elementor-widget-container,
.col-media.is-triple-layer .img-front.is-photo img {
  width: 100%;
  height: 100%;
}

.col-media.is-triple-layer .img-front.is-photo img {
  display: block;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.is-rounded {
  border-radius: 50%;
}

.col-media.is-triple-layer .img-badge.is-rounded,
.col-media .img-badge.is-rounded {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 50%);
  width: var(--badge-size);
  height: var(--badge-size);
  padding: var(--badge-padding);
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-blanc);
  border-radius: 50%;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  overflow: hidden;
}

.col-media.is-triple-layer .img-badge.is-rounded .elementor-widget-container,
.col-media.is-triple-layer .img-badge.is-rounded img {
  width: 100%;
  height: 100%;
}

.col-media.is-triple-layer .img-badge.is-rounded img {
  display: block;
  object-fit: contain;
}

.col-media.is-triple-layer .img-front.origin-top-left,
.col-media.is-triple-layer .img-front.origin-top-right,
.col-media.is-triple-layer .img-front.origin-bottom-right,
.col-media.is-triple-layer .img-front.origin-bottom-left {
  top: auto;
  right: auto;
  bottom: auto;
  left: auto;
  transform: none;
}

@media (min-width: 768px) {
  .col-media.is-triple-layer {
    --layer-min-height: 480px;
    --front-size: 60%;
    --badge-size: 180px;
    --badge-padding: 18px;
    --front-top: auto;
    --front-right: auto;
    --front-bottom: auto;
    --front-left: auto;
    --front-translate-x: 0;
    --front-translate-y: 0;

    display: block;
    min-height: var(--layer-min-height);
    padding-bottom: 0;
  }

  .col-media.is-triple-layer .img-back {
    position: absolute;
    inset: 0;
    height: 100%;
  }

  .col-media.is-triple-layer .img-back .elementor-widget-container,
  .col-media.is-triple-layer .img-back img {
    width: 100%;
    height: 100%;
  }

  .col-media.is-triple-layer .img-back img {
    aspect-ratio: auto;
    object-fit: cover;
  }

  .col-media.is-triple-layer .img-front.is-photo {
    position: absolute;
    width: var(--front-size);
    margin-top: 0;
    top: var(--front-top);
    right: var(--front-right);
    bottom: var(--front-bottom);
    left: var(--front-left);
    transform: translate(var(--front-translate-x), var(--front-translate-y));
  }

  .col-media.is-triple-layer .img-badge.is-rounded {
    top: 50%;
    bottom: auto;
    left: 50%;
    transform: translate(-50%, -50%);
  }

  /* Presets d'ancrage */
  .col-media.is-triple-layer .img-front.origin-top-left {
    --front-top: 50%;
    --front-left: 50%;
  }
  .col-media.is-triple-layer .img-front.origin-top-right {
    --front-top: 50%;
    --front-right: 50%;
  }
  .col-media.is-triple-layer .img-front.origin-bottom-right {
    --front-bottom: 50%;
    --front-right: 50%;
  }
  .col-media.is-triple-layer .img-front.origin-bottom-left {
    --front-bottom: 50%;
    --front-left: 50%;
  }
}

@media (min-width: 1025px) {
  .col-media.is-triple-layer {
    --layer-min-height: 560px;
    --front-size: 60%;
    --badge-size: 220px;
    --badge-padding: 20px;
  }
}

/* ======================================================
   30. MEDIA DEVICE HERO
   ====================================================== */
.media-device-hero {
  overflow: visible;
}

.media-device-hero > .e-con-inner {
  overflow: visible;
  align-items: center;
}

.media-device-hero .col-text {
  position: relative;
  z-index: 2;
}

.media-device-hero .col-media {
  position: relative;
  overflow: visible;
  z-index: 1;
  margin-top: 40px;
}

.media-device-hero .img-back {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 420px;
  margin: 0 auto;
}

.media-device-hero .img-back,
.media-device-hero .img-back .elementor-widget-container,
.media-device-hero .img-back img,
.media-device-hero .media-device,
.media-device-hero .media-device .elementor-widget-container,
.media-device-hero .media-device img {
  width: 100%;
  height: auto;
}

.media-device-hero .img-back img,
.media-device-hero .media-device img {
  display: block;
  object-fit: contain !important;
  object-position: center center;
}

.media-device-hero .img-badge {
  position: absolute;
  z-index: 5;
  width: 110px;
  height: 110px;
  padding: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-blanc);
  overflow: hidden;
  box-shadow:
    0 12px 32px rgba(0, 0, 0, 0.12),
    0 4px 12px rgba(0, 0, 0, 0.06);
  top: auto;
  right: auto;
  bottom: -20px;
  left: 50%;
  transform: translateX(-50%);
}

.media-device-hero .img-badge.is-rounded {
  border-radius: 50%;
}

.media-device-hero .img-badge .elementor-widget-container,
.media-device-hero .img-badge img {
  width: 100%;
  height: 100%;
}

.media-device-hero .img-badge img {
  display: block;
  object-fit: contain;
}

@media (min-width: 768px) {
  .media-device-hero .col-media {
    width: calc(50% + 10vw);
    max-width: none;
    margin-top: 0;
    margin-right: -10vw;
  }

  .media-device-hero .img-back {
    width: 120%;
    max-width: none;
    margin: 0;
  }

  .media-device-hero .img-badge {
    width: 170px;
    height: 170px;
    padding: 16px;
    bottom: 2%;
    left: 34%;
    transform: translate(-50%, 0);
  }
}

@media (min-width: 1025px) {
  .media-device-hero .col-media {
    width: calc(50% + 16vw);
    margin-right: -16vw;
  }

  .media-device-hero .img-back {
    width: 138%;
  }

  .media-device-hero .img-badge {
    width: 220px;
    height: 220px;
    padding: 20px;
    left: 31%;
    bottom: -4%;
    transform: translate(-50%, 0);
  }
}

/* ======================================================
   31. COMPOSITION CERCLES
   ====================================================== */

/* Wrapper */
.circle-composition {
  height: 420px;
  overflow: visible;
  position: relative;
  margin: 0 auto;
}

/* Reset widget image */
.circle-composition .elementor-widget-image {
  position: absolute;
}

.circle-composition .elementor-widget-container {
  margin: 0 !important;
  padding: 0 !important;
}

.circle-composition::before {
  content: "";
  position: absolute;
  width: 80%;
  padding-top: 80%;
  border-radius: 50%;
  background: rgba(206, 167, 182, 0.18);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* Rond de fond */
.circle-composition .circle-bg {
  top: 50%;
  left: 50%;
  width: 420px;
  transform: translate(-50%, -50%);
  z-index: 1;
  opacity: 0.9;
  mix-blend-mode: darken;
}

/* Badge réutilisable */
.circle-composition .img-badge {
  z-index: 2;
  width: 200px;
  border-radius: 50%;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  overflow: hidden;
}

/* Alignement vertical */
.circle-composition .circle-top,
.circle-composition .circle-bottom {
  left: 35%;
  transform: translateX(-50%);
}

.circle-composition .circle-top {
  top: 0;
}
.circle-composition .circle-bottom {
  bottom: 0;
}

/* Cercle droit (milieu) */
.circle-composition .circle-middle {
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}

@media (min-width: 768px) {
  .circle-composition {
    max-width: 650px;
    min-height: 400px;
  }

  .circle-composition .circle-bg {
    width: 520px;
  }
  .circle-composition .img-badge {
    width: 200px;
  }

  .circle-composition .circle-top,
  .circle-composition .circle-bottom {
    left: 38%;
  }
}

@media (min-width: 1025px) {
  .circle-composition {
    max-width: 760px;
    min-height: 500px;
  }

  .circle-composition .circle-bg {
    width: 620px;
  }
  .circle-composition .img-badge {
    width: 200px;
  }

  .circle-composition .circle-top,
  .circle-composition .circle-bottom {
    left: 40%;
  }
}

/* Variante 4 logos */
.circle-composition--4 {
  position: relative;
  width: min(100%, 520px);
  margin-inline: auto;
  overflow: visible;
}

.circle-composition--4 > .e-con-inner {
  position: relative;
  width: 100%;
  min-height: 0;
  overflow: visible;
}

.circle-composition--4 > .e-con-inner::before {
  content: "";
  display: block;
  padding-top: 100%;
}

.circle-composition--4::before {
  content: "";
  position: absolute;
  z-index: 1;
  width: 68%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: rgba(206, 167, 182, 0.16);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.circle-composition--4 .img-badge {
  position: absolute;
  z-index: 3;
  width: 42%;
  top: auto;
  right: auto;
  bottom: auto;
  left: auto;
  transform: none;
}

.circle-composition--4 .img-badge {
  bottom: auto !important;
  right: auto !important;
}

/* Positions scalables 4 logos */
.circle-composition--4 .circle-top-left {
  top: 30%;
  left: 28%;
  transform: translate(-50%, -50%);
}
.circle-composition--4 .circle-top-right {
  top: 30%;
  left: 72%;
  transform: translate(-50%, -50%);
}
.circle-composition--4 .circle-bottom-left {
  top: 70%;
  left: 28%;
  transform: translate(-50%, -50%);
}
.circle-composition--4 .circle-bottom-right {
  top: 70%;
  left: 72%;
  transform: translate(-50%, -50%);
}

/* ======================================================
   32. CERCLE DÉCORATIF ALÉATOIRE
   ====================================================== */
body.has-random-circle {
  position: relative;
}

body.has-random-circle::before {
  content: "";
  position: absolute;
  z-index: 100;
  pointer-events: none;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  background: rgba(206, 167, 182, 0.18);
  mix-blend-mode: darken;
  left: var(--circle-left, auto);
  right: var(--circle-right, auto);
  top: var(--circle-top, auto);
  bottom: var(--circle-bottom, auto);
  transform: translate(var(--circle-shift-x, 0), var(--circle-shift-y, 0));
}

body.has-random-circle .elementor {
  position: relative;
  z-index: 1;
}

/* ======================================================
   33. LANDING PAGE
   ====================================================== */
#formulaire-lp {
  background: var(--color-blanc);
  margin-top: -30%;
  box-shadow: 0px 3px 10px #0000001a;
  padding: 40px 60px;
  border-radius: 5px;
}

#formulaire-lp-s-marge,
.formulaire-lp-s-marge {
  background: var(--color-blanc);
  box-shadow: 0px 3px 10px #0000001a;
  padding: 28px;
  border-radius: 5px;
}

/* ======================================================
   34. AUTHOR BOX
   ====================================================== */
.elementor-author-box__name {
  font-size: clamp(1.1rem, 1.2vw, 1.2rem);
  font-weight: 500;
  color: var(--color-primary);
}

/* ======================================================
   35. FOOTER
   ====================================================== */
#tvh-footer.elementor-element.pad-2xl {
  padding-bottom: 20px;
}

#tvh-footer .footer-main {
  margin-bottom: 50px;
}

.logos-footer .gallery,
.logos-groupe .gallery {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
}

.logos-groupe .gallery {
  flex-wrap: wrap;
  gap: 5px;
}

.logos-groupe .gallery-item {
  width: auto;
}

.logos-groupe img {
  max-height: 50px;
  width: auto;
  float: left;
}

.tvh-footer .logos-footer .gallery .gallery-icon img {
  width: 75%;
  float: left;
}

.tvh-footer .logos-footer .gallery .gallery-icon.portrait img {
  width: 60%;
}

.tvh-footer h3 {
  font-size: 1.1em;
  font-weight: 700;
  letter-spacing: 1px;
}

#tvh-footer.tvh-footer .elementor-widget-text-editor,
#tvh-footer.tvh-footer .elementor-widget-text-editor p,
#tvh-footer.tvh-footer .elementor-widget-text-editor ul li {
  color: var(--color-secondary);
  font-size: clamp(0.8rem, 1.1vw, 1rem);
  line-height: 1.6;
}

.tvh-footer .elementor-widget-social-icons .e-font-icon-svg {
  width: 25px;
}

#tvh-footer .footer-adresse ul {
  list-style-type: none;
  padding-left: 30px;
}

#tvh-footer .footer-adresse ul li {
  position: relative;
  margin-bottom: 5px;
}

#tvh-footer ul .ic-tel::before,
#tvh-footer ul .ic-fax::before,
#tvh-footer ul .ic-mail::before {
  width: 25px;
  margin-left: 0;
  margin-right: 1em;
}

#tvh-footer .col-footer .elementor-widget-nav-menu .elementor-item {
  color: var(--color-blanc);
  font-size: 16px;
  line-height: 24px;
  padding: 0px 0 15px 20px;
}

#tvh-footer .col-footer .elementor-widget-nav-menu .elementor-item:hover,
.liens-footer a:hover {
  color: #ffffff75;
}

#tvh-footer .col-footer .elementor-widget-nav-menu .menu-item::before {
  content: "";
  width: 15px;
  height: 15px;
  background-image: url(/wp-content/uploads/2026/04/fleche-footer.svg);
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  position: absolute;
  top: 5px;
}

.liens-footer a {
  color: var(--color-blanc);
  font-weight: 700;
}

.liens-footer p {
  margin-bottom: 2px;
}

#tvh-footer .footer-bottom .elementor-widget-text-editor,
#tvh-footer .footer-bottom p,
#tvh-footer .footer-bottom a,
#tvh-footer .footer-bottom li {
  font-size: 11px;
  color: var(--color-secondary);
  align-self: center;
}

.footer-bottom nav .elementor-item,
.footer-bottom nav .elementor-item:hover {
  padding: 0;
}

.footer-bottom nav ul {
  gap: 10px;
}

#tvh-footer .footer-bottom li::after {
  content: "|";
  font-size: 11px;
  padding-left: 10px;
  border: none;
}

#tvh-footer .footer-bottom li:last-child::after {
  content: "";
}

#tvh-footer .footer-bottom .elementor-nav-menu {
  justify-content: center;
}
