/* =============================================================================
   1. VARIABLES CSS CUSTOM PROPERTIES
   ============================================================================= */

:root {

  /* --- Couleurs --- */
  --color-primary:        #EF3340;
  --color-primary-rgb:    239, 51, 64;
  --color-primary-dark:   #c9202d;   /* Rouge foncé (hover) */
  --color-secondary:      #074045;
  --color-secondary-rgb: 7, 64, 69;
  --color-secondary-light: #0a5e65;   /* Vert sombre (hover) */
  --color-secondary-flashy: #aedbde;
  --color-tertiary: #53979b;
  --color-tertiary-rgb: 83, 151, 155;

  --color-text:           #212529;
  --color-text-muted:     #6c757d;
  --color-text-light:     #adb5bd;

  /* --color-white:          #faffff; */
  --color-white:          #ffffff;
  --color-black:          #000000;
  --color-light:          #f8f9fa;
  --color-border:         #dee2e6;

  /* --- Typographie --- */
  /* Choisir l'une des deux : décommenter la ligne souhaitée */
  --font-title: "Anton", "Helvetica Neue", Arial, sans-serif;
  /* --font-primary: "Lexend Deca", "Helvetica Neue", Arial, sans-serif; */
  --font-primary: "Noto Sans", "Helvetica Neue", Arial, sans-serif;
  /* --font-primary: "Roboto", "Helvetica Neue", Arial, sans-serif; */


--font-size-xs: 1.15rem;
--font-size-s: 1.25rem;
--font-size-base: 1.35rem;
--font-size-lg: 1.5rem;


  --line-height-base: 1.6;

  --font-size-h1: 3.6rem;
  --font-size-h2: 2.25rem;
  --font-size-h3: 1.75rem;
  --font-size-h4: 1.5rem;
  --font-size-h5: 1.25rem;
  --font-size-h6: 1rem;

  --font-weight-regular: 400;
  --font-weight-medium:  500;
  --font-weight-bold:    700;

--letter-spacing-s: 0.01rem;
--letter-spacing-base: 0.02rem;

  /* --- Espacements --- */
  --spacing-xs: 0.5rem;
  --spacing-sm: 1rem;
  --spacing-md: 2rem;
  --spacing-lg: 4rem;
  --spacing-xl: 12rem;

  /* --- Bordures --- */
  --border-radius:    4px;
  --border-radius-lg: 8px;

  /* --- Transitions --- */
  --transition: 0.2s ease;

  /* --- Layout --- */
  --container-max-width: 1300px;
  --padding-page-x: 0 10rem;
  --navbar-height: 80px;

  /* --- Breakpoints (référence — ne pas utiliser dans @media, CSS custom props non supportées) ---
   * sm  : 599px  — mobiles
   * md  : 768px  — tablettes portrait
   * lg  : 1024px — tablettes paysage / petits laptops
   * xl  : 1280px — desktop
   * 2xl : 1536px — grands écrans
   * ---------------------------------------------------------------- */
}

    
/* =============================================================================
   2. CSS RESET
   ============================================================================= */

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
    font-size: 62.5%;
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-base);
  color: var(--color-secondary);
  background-color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: var(--font-weight-bold);
  line-height: 1.2;
  color: var(--color-text);
}

h1 { font-size: var(--font-size-h1); }
h2 { font-size: var(--font-size-h2); }
h3 { font-size: var(--font-size-h3); }
h4 { font-size: var(--font-size-h4); }
h5 { font-size: var(--font-size-h5); }
h6 { font-size: var(--font-size-h6); }

p {
  line-height: var(--line-height-base);
}

a {
  color: var(--color-secondary);
  text-decoration: none;
  transition: color var(--transition);
}

a:hover {
  color: var(--color-white);
}

ul, ol {
  list-style: none;
}

img,
svg,
video {
  display: block;
  max-width: 100%;
  height: auto;
}

button,
input,
select,
textarea {
  font: inherit;
  border: none;
  background: none;
}

button {
  cursor: pointer;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

* {
  -webkit-backface-visibility: hidden;
}

::-moz-selection { background-color: #EF3340; color: #fff; }
::selection      { background-color: #EF3340; color: #fff; }


/* =============================================================================
   UTILITAIRES ACCESSIBILITÉ
   ============================================================================= */

/* Classe générique pour contenu visible uniquement des lecteurs d'écran */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* =============================================================================
   3. CSS GLOBAL
   ============================================================================= */

.container {
    width: 100%;
    max-width: var(--container-max-width);
    margin-left: auto;
    margin-right: auto;
    padding: var(--padding-page-x);
}

.menu-item--cta a {
    display: inline-block;
    background-color: var(--color-secondary);
    color: var(--color-white);
    padding: 1.2rem 2.5rem;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 8px), calc(100% - 8px) 100%, 0 100%);
    transition: background-color var(--transition), color var(--transition), clip-path var(--transition);
    font-size: var(--font-size-s);
    font-weight: 500;
}

.menu-item--cta a:hover {
    background-color: var(--color-secondary-light);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%);
}

@media (max-width: 1536px) {

    .container {
        max-width: 1200px;
        padding: 0 5rem;
    }

}

@media (max-width: 1280px) {

    .container {
        max-width: 970px;
        padding: 0 3rem;
    }

}

@media (max-width: 1024px) {

    .container {
        max-width: 100%;
    }

    .menu-item--cta a {
        font-size: var(--font-size-xs);
    }

}


/* =============================================================================
   4. HEADER
   ============================================================================= */

.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background-color: var(--color-tertiary);
    overflow-x: clip;
}

.site-header::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background-color: var(--color-secondary);
    z-index: 11;
    pointer-events: none;
}

.site-header::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-left: 8px solid var(--color-secondary);
    z-index: 11;
}

.site-nav {
    position: relative;
    z-index: 10;
    display: flex;
	height: 80px;
}

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

.site-nav__logo {
    position: relative;
    width: 15rem;
}

.site-nav__logo img {
    width: 100%;
    height: auto;
    position: relative;
    z-index: 1;
}

.site-nav__logo-nn {
    width: 100%;
    height: auto;
    display: block;
    position: relative;
    z-index: 1;
}

.site-nav__logo-bg {
    fill: var(--color-primary);
}

.site-nav__logo-cut {
    fill: none;
    stroke: var(--color-secondary);
    stroke-miterlimit: 10;
}

.site-nav__logo-letters {
    fill: var(--color-white);
}

.site-header--inner .site-nav__logo,
.site-header--home  .site-nav__logo {
    align-self: stretch;
    display: flex;
    align-items: stretch;
}

.site-header--inner .site-nav__logo {
    width: 10rem;
}

.site-header--home .site-nav__logo {
    width: 16rem;
}

.site-header--inner .site-nav__logo a,
.site-header--home  .site-nav__logo a {
    display: flex;
    align-items: center;
    height: 100%;
}

.site-header--home .site-nav__logo a {
    width: 100%;
    background-color: var(--color-white);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 15px), calc(100% - 15px) 100%, 0 100%);
    justify-content: center;
    padding: 0 2.6rem 0 0;
    position: relative;
    z-index: 1;
}

.site-nav__logo-img {
    width: 100%;
    height: auto;
    display: block;
    position: relative;
    z-index: 1;
}

.site-nav__logo-border {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 2;
    overflow: visible;
}

.site-header--inner .site-nav__logo-nn {
    height: 100%;
    width: auto;
}

.site-header--inner .site-nav__logo::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: -100vw;
    right: 100%;
    background-color: var(--color-primary);
    z-index: 0;
}

.site-header--home .site-nav__logo::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: -100vw;
    right: 100%;
    background-color: var(--color-white);
    z-index: 0;
}

.site-nav__menu {
    display: block;
}

.site-nav__list {
    display: flex;
    align-items: center;
    gap: 4rem;
}

.site-nav__list .menu-item a {
    font-weight: 600;
    position: relative;
}

.site-nav__list .menu-item a:hover {
    color: var(--color-secondary);
}

.site-nav__list > .menu-item > a::after {
    content: '';
    position: absolute;
    bottom: -3px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 1px;
    background-image: repeating-linear-gradient(
        to right,
        currentColor 0px,
        currentColor 5px,
        transparent 4px,
        transparent 9px
    );
    transition: width 0.3s ease;
}

.site-nav__list > .menu-item > a:hover::after {
    width: 100%;
}

.site-nav__toggle {
    display: none;
    align-items: center;
    gap: 0.6rem;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0 0 0 1.4rem;
    color: var(--color-secondary);
    z-index: 1100;
}

.site-nav__toggle p {
    font-weight: 600;
    color: var(--color-secondary);
    transition: opacity 0.2s ease;
}

.site-nav__toggle[aria-expanded="true"] p {
    opacity: 0;
}

.hamburger-box {
    display: flex;
    flex-direction: column;
    gap: 4px;
    width: 2.2rem;
}

.hamburger-inner {
    display: block;
    height: 2px;
    width: 100%;
    background-color: var(--color-secondary);
    border-radius: 2px;
    transform-origin: center;
    transition: transform 0.3s ease, opacity 0.3s ease, width 0.3s ease;
}

/* Croix quand ouvert */
.site-nav__toggle[aria-expanded="true"] .hamburger-inner:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
}
.site-nav__toggle[aria-expanded="true"] .hamburger-inner:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
}
.site-nav__toggle[aria-expanded="true"] .hamburger-inner:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
}

.site-nav__list > .menu-item-has-children {
    position: relative;
}

.site-nav__list .sub-menu {
    display: none;
    position: fixed;
    top: 100px;
    left: 50%;
    transform: translateX(-50%);
    min-width: 24rem;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border: 1px solid var(--color-secondary);
    z-index: 8;
    list-style: none;
}

@keyframes dunner-sub-menu-in {
    from {
        opacity: 0;
        transform: translateX(-50%) translateY(-1.5rem);
    }
    to {
        opacity: 1;
        transform: translateX(-50%) translateY(0);
    }
}

.site-nav__list .sub-menu.is-visible {
    display: flex;
    animation: dunner-sub-menu-in 0.25s ease forwards;
}

.site-nav__list .sub-menu .menu-item {
    border-right: 1px solid var(--color-secondary);
    width: 20rem;
    height: 20rem;
}

.site-nav__list .sub-menu .menu-item:last-child {
    border-right: none;
}

.site-nav__list .sub-menu .menu-item a {
    display: flex;
    height: 100%;
    width: 100%;
    justify-content: center;
    align-items: center;
    transition: color var(--transition), background-color var(--transition);
    font-weight: 600;
    font-size: var(--font-size-s);
    text-transform: uppercase;
}

.site-nav__list .sub-menu .menu-item a:hover {
    color: var(--color-white);
    background-color: var(--color-secondary);
}

.site-nav__lang {
    position: relative;
}

.site-nav__lang-toggle {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.4rem 0;
    color: var(--color-secondary);
}

.site-nav__lang-icon {
    width: 1.6rem;
    height: 1.6rem;
    flex-shrink: 0;
}

.site-nav__lang-current {
    font-size: var(--font-size-s);
    font-weight: 600;
    letter-spacing: 0.05em;
}

.site-nav__lang-chevron {
    width: 1.5rem;
    height: 1.5rem;
    transition: transform 0.25s ease;
    position: relative;
    top: 0.5px;
}

.site-nav__lang.is-open .site-nav__lang-chevron {
    transform: rotate(180deg);
}

.site-nav__lang-list {
    position: absolute;
    top: calc(100% + 3.2rem);
    left: 0;
    list-style: none;
    margin: 0;
    background: transparent;
    min-width: 7rem;
    pointer-events: none;
    visibility: hidden;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border: 1px solid var(--color-secondary);
    z-index: 20;
}

.site-nav__lang.is-open .site-nav__lang-list {
    pointer-events: auto;
    visibility: visible;
}

.site-nav__lang-item {
    opacity: 0;
    transform: translateY(-6px);
    transition:
        opacity 0.2s ease calc(var(--lang-i, 1) * 50ms),
        transform 0.2s ease calc(var(--lang-i, 1) * 50ms);
    border-bottom: 1px solid var(--color-secondary);
}

.site-nav__lang-item:last-child {
    border-bottom: none;
}

.site-nav__lang.is-open .site-nav__lang-item {
    opacity: 1;
    transform: translateY(0);
}

.site-nav__lang-item a {
    display: block;
    padding: 2rem;
    font-size: var(--font-size-s);
    font-weight: 600;
    color: var(--color-secondary);
    text-decoration: none;
    letter-spacing: 0.05em;
    transition: background var(--transition), color var(--transition);
    text-align: center;
}

.site-nav__lang-item a:hover {
    background: var(--color-secondary);
    color: var(--color-white);
}

.site-nav__actions {
    display: flex;
    align-items: center;
    gap: 2.5rem;
}

.site-nav__menu-wrapper {
    display: flex;
    gap: 4rem;
    align-items: center;
    height: 100%;
}

/* Overlay menu mobile
   Injecté par JS dans <body> — s'affiche derrière le panel nav
   ---------------------------------------------------------------- */
.nav-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(var(--color-tertiary-rgb), 0.45);
    z-index: 998;
    opacity: 0;
    transition: opacity 0.35s ease;
    cursor: pointer;
}

.nav-overlay.is-visible {
    display: block;
}

.nav-overlay.is-active {
    opacity: 1;
}


/* Liste légale mobile + copyright
   Masqués sur desktop, visibles dans le panneau nav mobile
   ---------------------------------------------------------------- */
.site-nav__list--legal,
.site-nav__copyright {
    display: none;
}


/* ── Responsive Header ─────────────────────────────────────────────────────── */

@media (max-width: 1024px) {

    .site-nav__list--legal {
        display: flex;
        flex-direction: column;
        border-top: 1px solid rgba(7, 64, 69, 0.2);
    }

    .site-nav__copyright {
        display: block;
        font-size: 1rem;
        font-weight: 600;
        letter-spacing: 0.1em;
        text-align: center;
    }

    .site-nav__toggle {
        display: flex;
    }

    .site-nav__menu-wrapper {
        gap: 0;
    }

    .site-nav__menu {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: min(311px, 100vw);
        height: 100dvh;
        background-color: var(--color-tertiary);
        border-right: 1px solid var(--color-secondary);
        z-index: 1000;
        overflow-y: auto;
        padding: calc(var(--navbar-height) + 3rem) var(--spacing-lg) var(--spacing-lg);
        transform: translateX(-100%);
        transition: transform 0.38s cubic-bezier(0.4, 0, 0.2, 1);
        display: flex;
        flex-direction: column;
        justify-content: space-between;
    }

    .site-nav__menu.is-open {
        transform: translateX(0);
    }

    .site-nav__list {
        flex-direction: column;
        gap: 0;
        align-items: stretch;
    }

    .site-nav__list .menu-item > a {
        display: block;
        padding: 1.4rem 0;
        border-bottom: 1px solid rgba(7, 64, 69, 0.2);
    }

    .site-nav__menu-inner .site-nav__list .menu-item .sub-menu a {
        border-bottom: none;
        text-transform: none;
    }

    .site-nav__menu-inner .site-nav__list .menu-item .sub-menu li:last-child a {
        padding-bottom: 2rem;
    }

    .site-nav__list > .menu-item:last-child > a {
        border-bottom: none;
    }

    .site-nav__list .sub-menu .menu-item a:hover {
        background-color: transparent;
        color: var(--color-secondary);
    }

    .site-nav__list > .menu-item > a::after {
        display: none;
    }

    /* Sous-menu mobile : inline en colonne, masqué par défaut */
    .site-nav__list .menu-item-has-children > a {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .site-nav__list .menu-item-has-children > a::before {
        content: '';
        display: block;
        width: 0.8rem;
        height: 0.8rem;
        border-right: 1.5px solid currentColor;
        border-bottom: 1.5px solid currentColor;
        transform: rotate(45deg);
        transition: transform 0.25s ease;
        flex-shrink: 0;
        order: 99;
        margin-left: auto;
    }

    .site-nav__list .menu-item-has-children.is-mobile-open > a::before {
        transform: rotate(-135deg);
    }

    .site-nav__list .sub-menu {
        position: static;
        transform: none;
        left: auto;
        min-width: auto;
        border: none;
        padding-left: var(--spacing-sm);
        top: auto;
        display: none;
        flex-direction: column;
    }

    .site-nav__list .menu-item-has-children.is-mobile-open > .sub-menu {
        display: flex;
    }

    .site-nav__list .sub-menu .menu-item {
        border-right: none;
        width: auto;
        height: auto;
    }

    .site-nav__list .sub-menu .menu-item a {
        justify-content: flex-start;
        padding: 0.8rem 0;
    }
}

@media (max-width: 768px) {

    .site-header--home .site-nav__logo,
    .site-header--inner .site-nav__logo {
        width: 9rem;
    }

    .site-nav__contact {
        display: none;
    }
}

@media (max-width: 599px) {

    .site-nav__lang-icon {
        display: none;
    }
}


/* =============================================================================
   5. PAGES LÉGALES
   ============================================================================= */

.legal {
    position: relative;
    overflow-x: clip;
    background-color: var(--color-tertiary);
}

.legal__lame {
    position: absolute;
    right: -15rem;
    top: 50%;
    transform: translateY(-50%);
    width: 50rem;
    display: grid;
    opacity: 0.3;
    pointer-events: none;
    user-select: none;
}

.legal__lame img:first-child {
    grid-area: 1 / 1;
    width: 100%;
    height: auto;
    display: block;
    transform-origin: center;
}

.legal__lame img:last-child {
    position: absolute;
    grid-area: 1 / 1;
    width: 100%;
    height: auto;
    display: block;
}

.legal-layout {
    position: relative;
    display: grid;
    grid-template-columns: 28rem 1fr;
    gap: 10rem;
    align-items: start;
}

.legal-sidebar {
    padding: 10rem 0;
    height: 100%;
}

.legal-nav {
    position: sticky;
    top: calc(80px + 5rem);
}

.legal-nav__title {
    font-family: var(--font-title);
    font-size: 1.8rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    color: var(--color-secondary);
    margin-bottom: 1.5rem;
}

.legal-nav__list {
    position: relative;
    padding-left: 28px;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.legal-nav__list::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 20px;
    border: 1px solid var(--color-secondary);
    background: repeating-linear-gradient(
        -45deg,
        transparent,
        transparent 3px,
        rgba(7, 64, 69, 0.4) 3px,
        rgba(7, 64, 69, 0.4) 4px
    );
    pointer-events: none;
}

.legal-nav__item a {
    display: block;
    padding: 0.6rem 0;
    color: var(--color-secondary);
    font-size: var(--font-size-s);
    font-weight: 600;
    border-left: 2px solid transparent;
    margin-left: 0;
    transition: color var(--transition);
    line-height: 1.4;
}

.legal-nav__item a:hover {
    color: var(--color-white);
}

.legal-nav__item--active > a {
    color: var(--color-white);
}

.legal-nav__subitem a {
    display: block;
    padding: 0.6rem 0 0.4rem 1rem;
    color: var(--color-secondary);
    font-size: var(--font-size-xs);
    font-weight: 600;
    transition: color var(--transition);
}

.legal-nav__subitem--active a,
.legal-nav__subitem a:hover {
    color: var(--color-white);
}

.legal-content {
    position: relative;
    padding-left: 5rem;
    border-left: 1px solid var(--color-secondary);
    padding-top: 8rem;
    padding-bottom: 8rem;
}

.legal-content::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 8px solid var(--color-secondary);
}

.legal-content::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 8px solid var(--color-secondary);
}

.legal-content__title-wrap {
    margin-bottom: 3rem;
    padding: 2rem;
    border: 1px solid var(--color-secondary);
    background: repeating-linear-gradient(
        -45deg,
        transparent,
        transparent 5px,
        rgba(7, 64, 69, 0.4) 5px,
        rgba(7, 64, 69, 0.4) 6px
    );
}

.legal-content__title {
    font-family: var(--font-title);
    font-size: 4.6rem;
    font-weight: 400;
    letter-spacing: 0.05rem;
    text-transform: uppercase;
    color: var(--color-secondary);
}

.legal-content__body {
    font-size: var(--font-size-base);
    line-height: 1.8;
}

.legal-content__body h2 {
    font-family: var(--font-title);
    text-transform: uppercase;
    font-size: var(--font-size-h3);
    font-weight: 400;
    color: var(--color-secondary);
    letter-spacing: 0.05rem;
    margin-top: 5rem;
    margin-bottom: 1.5rem;
    scroll-margin-top: calc(80px + 3rem);
    line-height: 1.4;
}

.legal-content__body h3 {
    font-size: var(--font-size-h4);
    margin-top: 3rem;
    margin-bottom: 1rem;
}

.legal-content__body p {
    margin-bottom: 1.5rem;
}

.legal-content__body ul,
.legal-content__body ol {
    list-style: square;
    padding-left: 2.5rem;
    margin-bottom: 1.5rem;
}

.legal-content__body ol {
    list-style: decimal;
}

.legal-content__body li {
    margin-bottom: 0.5rem;
}

.legal-content__body a {
    color: var(--color-primary);
    text-decoration: underline;
}

.legal-content__body strong {
    font-weight: var(--font-weight-bold);
    color: var(--color-secondary);
}

.legal-content__last-update {
    margin-top: 4rem;
    color: var(--color-secondary);
    font-size: var(--font-size-xs);
    font-weight: 500;
}

.legal-dim {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 1px;
    background: var(--color-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

.legal-dim::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 8px solid var(--color-secondary);
}

.legal-dim::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 8px solid var(--color-secondary);
}

.legal-dim--left  { left: 0; }
.legal-dim--right { right: 0; }

.legal-dim__label {
    position: relative;
    z-index: 1;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.22rem;
    text-transform: uppercase;
    color: var(--color-secondary);
    background-color: var(--color-tertiary);
}

.legal-dim--left .legal-dim__label {
    transform: rotate(180deg);
    left: -1rem;
}

.legal-dim--right .legal-dim__label {
    right: -1rem;
}

@media (max-width: 1024px) {

    .legal-dim--left,
    .legal-dim--right {
        display: none;
    }
}

/* ── Responsive Pages Légales ──────────────────────────────────────────────── */

@media (max-width: 1900px) {

    .legal__lame {
        left: -23rem;
        opacity: 0.2;
    }
}

@media (max-width: 1536px) {

    .legal-content__title {
        font-size: 4rem;
    }
}

@media (max-width: 1280px) {

    .legal-layout {
        gap: 3rem;
    }

    .legal-content__title {
        font-size: 3rem;
    }

    .legal-content {
        padding-left: 3rem;
    }

    .legal-content__body h2 {
        font-size: 1.6rem;
    }
}

@media (max-width: 1024px) {

    .legal-layout {
        grid-template-columns: 22rem 1fr;
        gap: 5rem;
    }

    .legal__lame {
        display: none;
    }

    .legal-content__title {
        font-size: 2.6rem;
    }

    .legal-content__body {
        font-size: var(--font-size-s);
    }
}

@media (max-width: 768px) {

    .legal-layout {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .legal-sidebar {
        padding: 4rem 0 0;
    }

    .legal-nav {
        position: static;
    }

    .legal-nav__list {
        display: flex;
        flex-wrap: wrap;
        gap: 0.4rem;
        padding-left: 0;
    }

    .legal-nav__list::before {
        display: none;
    }

    .legal-nav__item a {
        padding: 0.5rem 1.2rem;
        border: 1px solid var(--color-secondary);
        font-size: var(--font-size-xs);
    }

    .legal-nav__item--active > a {
        background-color: var(--color-secondary);
        color: var(--color-white);
    }

    /* Sous-nav des ancres masqué sur mobile */
    .legal-nav__sublist {
        display: none;
    }

    .legal-content {
        padding-left: 0;
        border-left: none;
        padding-top: 4rem;
        padding-bottom: 6rem;
    }

    .legal-content::before,
    .legal-content::after {
        display: none;
    }

    .legal-content__title {
        font-size: 3.2rem;
    }

    .legal-dim {
        display: none;
    }
}


/* =============================================================================
   PRÉ-FOOTER CTA
   ============================================================================= */

.prefooter-cta {
    position: relative;
    background-color: var(--color-tertiary);
    border-top: 1px solid var(--color-secondary);
}

.prefooter-cta::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    transform: translateY(-50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
}

.prefooter-cta::after {
    content: '';
    position: absolute;
    right: 0;
    top: 0;
    transform: translateY(-50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-left: 8px solid var(--color-secondary);
}

.prefooter-cta__inner {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}

.prefooter-cta__illus {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60rem;
    min-width: 60rem;
}

.prefooter-cta__label {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.1rem;
    margin-bottom: 1.5rem;
}

.prefooter-cta__title {
    font-family: var(--font-title);
    font-size: 4.8rem;
    font-weight: 400;
    text-transform: uppercase;
    color: var(--color-white);
    letter-spacing: 0.05rem;
    margin-bottom: 2.4rem;
}

.prefooter-cta__desc {
    font-weight: 500;
    color: var(--color-white);
    margin-bottom: 3.6rem;
    max-width: 52rem;
}

.prefooter-cta__btn {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    background-color: var(--color-secondary);
    color: var(--color-white);
    padding: 1.4rem 3rem;
    font-size: var(--font-size-s);
    font-weight: 500;
    text-decoration: none;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%);
    transition: background-color var(--transition), clip-path var(--transition);
}

.prefooter-cta__btn svg {
    width: 1.8rem;
    height: 1.8rem;
    flex-shrink: 0;
    transition: transform var(--transition);
}

.prefooter-cta__btn:hover {
    background-color: var(--color-secondary-light);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 14px), calc(100% - 14px) 100%, 0 100%);
}

.prefooter-cta__btn:hover svg {
    transform: translateX(4px);
}

.prefooter-cta__dim {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 1px;
    background: var(--color-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

.prefooter-cta__dim::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 8px solid var(--color-secondary);
}

.prefooter-cta__dim::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 8px solid var(--color-secondary);
}

.prefooter-cta__dim-label {
    position: relative;
    z-index: 1;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    padding: 0.8rem 0;
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.22rem;
    text-transform: uppercase;
    color: var(--color-secondary););
    background-color: var(--color-tertiary);
}

.prefooter-cta__dim--left {
    left: 0;
}

.prefooter-cta__dim--left .prefooter-cta__dim-label {
    transform: rotate(180deg);
    left: -1rem
}

.prefooter-cta__dim--right {
    right: 0;
}

.prefooter-cta__dim--right .prefooter-cta__dim-label {
    right: -1rem
}

/* ── Responsive Pré-footer ─────────────────────────────────────────────────── */

@media (max-width: 1024px) {

    .prefooter-cta__illus {
        width: auto;
        min-width: auto;
        position: absolute;
        left: 2rem;
        height: 100%;
        overflow: hidden;
        max-width: 75%;
    }

    .prefooter-cta__title {
        font-size: 3.2rem;
        line-height: 1.2;
    }

    .prefooter-cta__dim.prefooter-cta__dim--left,
    .prefooter-cta__dim.prefooter-cta__dim--right,
    .site-footer__right {
        display: none;
    }

    .prefooter-cta__inner {
        justify-content: flex-end;
    }

    .prefooter-cta__content {
        padding: 10rem 0;
        width: 400px;
    }

    .prefooter-cta__label {
        letter-spacing: 0.05rem;
        margin-bottom: 1rem;
        font-size: 1.05rem;
    }

    .prefooter-cta__desc {
        font-size: var(--font-size-s);
        margin-bottom: 3rem;
    }

    .prefooter-cta__btn {
        font-size: var(--font-size-xs);
    }

    .prefooter-cta__btn svg {
        width: 1.5rem;
        height: 1.5rem;
        position: relative;
        top: 1px;
    }
}

@media (max-width: 768px) {

    .prefooter-cta__title {
        font-size: 3rem;
    }

    .prefooter-cta__desc {
        font-size: var(--font-size-s);
    }
}


/* =============================================================================
   6. FOOTER
   ============================================================================= */


.site-footer {
    position: relative;
    overflow: hidden;
    background-color: var(--color-secondary);
    color: var(--color-tertiary);
}

.site-footer__inner {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding-top: 10rem;
    padding-bottom: 10rem;
}

.site-footer__menus {
    display: flex;
    gap: 10rem;
}

.site-footer__nav-title,
.site-footer__address-name {
    margin-bottom: 1rem;
    font-size: var(--font-size-lg);
    font-weight: 700;
}

.site-footer__nav-list .menu-item {
    padding: 0.2rem 0;
}

.site-footer__nav-title,
.site-footer__nav-list .menu-item a {
    color: var(--color-tertiary);
}

.site-footer__nav-list .menu-item a:hover {
    color: var(--color-white);
}

.site-footer__copyright {
    position: relative;
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.22rem;
    text-align: center;
    height: 5rem;
    padding-top: 0.5rem;
}

.footer-dim {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 1px;
    /* background: rgba(250, 255, 255, 0.12); */
    background-color: var(--color-tertiary);
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

.footer-dim::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    /* border-bottom: 8px solid rgba(250, 255, 255, 0.25); */
    border-bottom: 8px solid var(--color-tertiary);
}

.footer-dim::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 8px solid var(--color-tertiary);
}

.footer-dim__label {
    position: relative;
    z-index: 1;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    padding: 0.8rem 0;
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.22rem;
    text-transform: uppercase;
    /* color: rgba(250, 255, 255, 0.3); */
    color: var(--color-tertiary);
    background-color: var(--color-secondary);
}

.footer-dim--left  { left: 0; }
.footer-dim--right { right: 0; }

.footer-dim--left .footer-dim__label  { 
    transform: rotate(180deg); 
    left: -1rem;
}

.footer-dim--right .footer-dim__label { 
    right: -1rem;
}

.footer-dim-top {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: var(--color-tertiary);
    pointer-events: none;
}

.footer-dim-top::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-tertiary);
}

.footer-dim-top::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-left: 8px solid var(--color-tertiary);
}

/* Lignes horizontales s'étendant des bords du container jusqu'aux bords du viewport */
.footer-dim-ext {
    position: absolute;
    top: 0;
    height: 1px;
    background: var(--color-tertiary);
    pointer-events: none;
}

.footer-dim-ext--left {
    right: 100%;
    width: calc((100vw - var(--container-max-width)) / 2);
}

.footer-dim-ext--right {
    left: 100%;
    width: calc((100vw - var(--container-max-width)) / 2);
}

@media (max-width: 1536px) {
    .footer-dim-ext--left {
        width: calc((100vw - 1200px) / 2);
    }

    .footer-dim-ext--right {
        width: calc((100vw - 1200px) / 2);
    }
}

@media (max-width: 1280px) {
    .footer-dim-ext--left {
        width: calc((100vw - 970px) / 2);
    }

    .footer-dim-ext--right {
        width: calc((100vw - 970px) / 2);
    }
}

/* Flèches des deux côtés */
.footer-dim-ext--left::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-tertiary);
}

.footer-dim-ext--left::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-left: 8px solid var(--color-tertiary);
}

.footer-dim-ext--right::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-tertiary);
}

.footer-dim-ext--right::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-left: 8px solid var(--color-tertiary);
}

@media (max-width: 1024px) {
    .footer-dim-ext { display: none; }
}

.site-footer__info {
    max-width: 40rem;
}

.site-footer__address {
    font-style: normal;
}

.site-footer__address a {
    color: var(--color-tertiary);
}

.site-footer__address a:hover {
    color: var(--color-white);
}

.site-footer__address-contact,
.site-footer__tagline {
    margin-top: 3rem;
}

.site-footer__social {
    margin-top: 3rem;
}

.site-footer__social-link {
    color: var(--color-tertiary);
    display: flex;
    align-items: center;
    gap: 0.8rem;
}

.site-footer__social-link:hover {
    color: var(--color-white);
}

.site-footer__social-link svg {
    width: 3rem;
    height: 3rem;
    fill: var(--color-tertiary);
    transition: fill var(--transition);
}

.site-footer__social-link:hover svg {
    fill: var(--color-white);
}

.site-footer__nn {
    position: absolute;
    bottom: 10rem;
    right: 10rem;
    width: 16rem;
    opacity: 0.5;
    pointer-events: none;
}

.site-footer__nn-svg {
    width: 100%;
    height: auto;
    overflow: visible;
}

.site-footer__nn-a { fill: #236664; }
.site-footer__nn-b { fill: #1e605d; }
.site-footer__nn-d { fill: var(--color-tertiary); }
.site-footer__nn-e { fill: #377f7f; }
.site-footer__nn-f { fill: #236664; }
.site-footer__nn-g { fill: #327676; }

.site-footer__nn-float {
    animation: footer-nn-float 5s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
    .site-footer__nn-float { animation: none; }
}

@keyframes footer-nn-float {
    0%, 80% { transform: translateY(0); }
    50%       { transform: translateY(-10px); }
}

/* ── Responsive Footer ─────────────────────────────────────────────────────── */

@media (max-width: 1280px) {

    .site-footer__menus {
        gap: 6rem;
    }

}

@media (max-width: 1024px) {

    .site-footer__inner {
        padding-top: 6rem;
        padding-bottom: 4rem;
    }

    .site-footer__menus {
        display: none;
    }

    .site-footer__info {
        max-width: 100%;
    }

    .site-footer__nn {
        bottom: 4rem;
        right: 3rem;
        width: 16rem;
    }

    .footer-dim {
        display: none;
    }

    .site-footer__tagline {
        width: min(425px, 100%);
    }

    .site-footer__copyright {
        display: none;
    }
}

@media (max-width: 768px) {

    .site-footer__right {
        width: 100%;
    }

    .site-footer__menus {
        flex-wrap: wrap;
        gap: 3.5rem;
    }

    .site-footer__nn {
        display: none;
    }
}

@media (max-width: 599px) {

    .site-footer__inner {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }

    .site-footer__menus {
        flex-direction: column;
        gap: 3rem;
    }
}


/* =============================================================================
   7. PAGE CONTACT
   ============================================================================= */

.contact-hero {
    background-color: var(--color-tertiary);
}

.contact-hero__inner {
    display: flex;
    align-items: start;
    gap: 0 10rem;
    position: relative;
}

.contact-hero__intro {
    padding: 15rem 0 0 0;
    flex: 1;
    width: 50%;
}

.contact-hero__title {
    font-family: var(--font-title);
    font-size: 5.6rem;
    font-weight: 400;
    letter-spacing: 0.05rem;
    text-transform: uppercase;
    color: var(--color-secondary);
    line-height: 1.3;
    margin-bottom: 2rem;
}

.contact-hero__body {
    margin-bottom: 1rem;
    font-weight: 500;
}

.contact__icon-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 30px;
    height: 30px;
    background-color: var(--color-secondary);
    box-shadow: 3px 3px 0 var(--color-secondary-flashy);
}

.contact__icon-wrapper svg {
    width: 16px;
    height: 16px;
    color: var(--color-white);
}

.contact-notice {
    padding: 1.2rem 1.6rem;
    border-radius: var(--border-radius);
    margin-bottom: var(--spacing-md);
    font-size: var(--font-size-s);
}

.contact-notice--success {
    background-color: #d1e7dd;
    color: #0a3622;
    border-left: 4px solid #198754;
}

.contact-notice--error {
    background-color: #f8d7da;
    color: #58151c;
    border-left: 4px solid var(--color-primary);
}

.contact-hero__form {
    flex: 1;
    width: 50%;
    padding: 12rem 0;
}

.contact-hero__form-wrapper {
    position: relative;
    border: 1px solid var(--color-secondary);
}

.contact-hero__form-title-wrap {
    border-bottom: 1px solid var(--color-secondary);
}

.contact-hero__form-title {
    font-family: var(--font-title);
    text-align: center;
    text-transform: uppercase;
    font-size: 2.4rem;
    font-weight: 600;
    color: var(--color-secondary);
    padding: 3rem 0;
    letter-spacing: 0.08rem;
}

.contact-form__supplement {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.contact-form__required-hint {
    position: absolute;
    bottom: -22px;
    right: 0;
    font-size: var(--font-size-xs);
    text-align: right;
}

.contact-form__row {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-bottom: 1px solid var(--color-secondary);
}

.contact-form__row::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    transform: translateX(-50%);
    width: 1px;
    height: 100%;
    background-color: var(--color-secondary);
}

.contact-form__field {
    position: relative;
    border-right: 1px solid var(--color-secondary);
}

.contact-form__row .contact-form__field:last-child {
    border-right: none;
}

.contact-form__field--full {
    grid-column: 1 / -1;
    border-bottom: 1px solid var(--color-secondary);
}

.contact-form__field--full.contact-form__field {
    border-right: none;
}

.contact-form__field input,
.contact-form__field textarea {
    display: block;
    width: 100%;
    padding: 2.6rem 1.2rem 0.8rem;
    border: none;
    font-family: var(--font-primary);
    font-size: var(--font-size-s);
    color: var(--color-secondary);
    background-color: var(--color-tertiary);
    transition: background-color var(--transition);
    outline: none;
}

.contact-form__field input:focus,
.contact-form__field textarea:focus {
    background-color: rgba(var(--color-secondary-rgb), 0.08);
}

.contact-form__field textarea {
    resize: none;
    min-height: 20rem;
}

.contact-form__field label {
    position: absolute;
    left: 1.2rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: var(--font-size-s);
    font-weight: var(--font-weight-medium);
    color: var(--color-secondary);
    pointer-events: none;
    transition: top 0.2s ease, transform 0.2s ease, font-size 0.2s ease, color 0.2s ease;
    z-index: 1;
}

.contact-form__field--full label {
    top: 1.6rem;
    transform: none;
}

.contact-form__field input:focus + label,
.contact-form__field input:not(:placeholder-shown) + label {
    top: 0.7rem;
    transform: translateY(0);
    font-size: 1.1rem;
    color: var(--color-secondary);
}

.contact-form__field textarea:focus + label,
.contact-form__field textarea:not(:placeholder-shown) + label {
    top: 0.6rem;
    font-size: 1.1rem;
    color: var(--color-secondary);
}

.contact-form__field label span {
    position: relative;
    top: -2px;
    right: -1px;
}

.contact-form__submit {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    background-color: var(--color-secondary);
    color: var(--color-white);
    border: none;
    padding: 2.2rem 2.5rem;
    font-family: var(--font-primary);
    font-size: var(--font-size-s);
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    transition: all var(--transition);
    width: 100%;
    justify-content: center;
}

.contact-form__submit svg {
    width: 1.6rem;
    height: 1.6rem;
    flex-shrink: 0;
    transition: transform var(--transition);
}

.contact-form__submit:hover {
    background-color: var(--color-secondary-light);
}

.contact-form__submit:hover svg {
    transform: translateX(4px) translateY(-4px);
}

.contact__info-row {
    display: flex;
    align-items: stretch;
    gap: 0.5rem;
}

.contact__info-row:last-child {
    border-bottom: none;
}

.contact__info-icon {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    width: 2rem;
}

.contact__info-icon svg {
    width: 1.6rem;
    height: 1.6rem;
}

.contact__info-cell {
    padding: 0.7rem 0;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    font-size: var(--font-size-s);
    font-style: normal;
}

.contact__info-cell a {
    display: inline-flex;
    align-items: center;
    color: var(--color-secondary);
    text-underline-offset: 2px;
    transition: color var(--transition);
}

.contact__info-cell a:hover {
    color: var(--color-primary);
}

.contact__external-icon {
    position: relative;
    top: -4px;
    right: -2px;
    width: 1rem;
    height: 1rem;
    flex-shrink: 0;
    transition: transform var(--transition);
}

.contact__info-cell a:hover .contact__external-icon {
    transform: translateX(2px) translateY(-2px);
}


/* =============================================================================
   PAGE SOLUTIONS
   ============================================================================= */

/* ── Hero parallax ─────────────────────────────────────────────────────────── */

.solutions-hero {
    position: relative;
    min-height: 35vh;
    display: flex;
    align-items: center;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    border-bottom: 1px solid var(--color-secondary);
}

.solutions-hero::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.solutions-hero::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%) rotate(180deg);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.solutions-hero__overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(var(--color-tertiary-rgb), 0.8);
/*     background-image:
        linear-gradient(rgba(var(--color-secondary-rgb),0.1) 1px, transparent 1px),
        linear-gradient(90deg, rgba(var(--color-secondary-rgb),0.1) 1px, transparent 1px),
        linear-gradient(rgba(var(--color-secondary-rgb),0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(var(--color-secondary-rgb),0.05) 1px, transparent 1px); */
    background-size:
        50px 50px,
        50px 50px,
        10px 10px,
        10px 10px;
}

.solutions-hero__inner {
    position: relative;
    z-index: 1;
    padding-top: var(--spacing-xl);
    padding-bottom: var(--spacing-xl);
}

.solutions-hero__title {
    font-family: var(--font-title);
    font-size: 7.6rem;
    font-weight: 400;
    color: var(--color-white);
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    line-height: 1.3;
    margin-bottom: 2.8rem;
    max-width: 70%;
}

.solutions-hero__desc {
    font-size: var(--font-size-lg);
    font-weight: 500;
    color: rgba(255, 255, 255, 0.82);
    line-height: var(--line-height-base);
    margin-bottom: 1.4rem;
    max-width: 64rem;
}

.solutions-hero__desc:last-of-type {
    margin-bottom: 0;
}

.solutions-hero__scroll {
    position: absolute;
    bottom: 2.8rem;
    left: 50%;
    transform: translateX(-50%);
    color: var(--color-white);
    animation: solutions-bounce 2.2s ease-in-out infinite;
}

.solutions-hero__scroll svg {
    width: 3.4rem;
    height: 3.4rem;
    display: block;
}

@keyframes solutions-bounce {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50%       { transform: translateX(-50%) translateY(9px); }
}

.solutions-section {
    position: relative;
    background-color: var(--color-tertiary);
    overflow-x: clip;
}

.solutions-lame {
    position: absolute;
    right: -15rem;
    top: 50%;
    transform: translateY(-50%) scaleX(-1);
    width: 50rem;
    display: grid;
    opacity: 0.2;
    pointer-events: none;
    user-select: none;
}

.solutions-lame img:first-child {
    grid-area: 1 / 1;
    width: 100%;
    height: auto;
    display: block;
    transform-origin: center;
}

.solutions-lame img:last-child {
    grid-area: 1 / 1;
    width: 100%;
    height: auto;
    display: block;
}

.solutions-lame--bottom-left {
    right: auto;
    left: calc((100vw - var(--container-max-width)) / 2 - 5rem);
    top: 70%;
    transform: translateX(-50%);
    z-index: 0;
}

.solutions-dim {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 1px;
    background: var(--color-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

.solutions-dim::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 8px solid var(--color-secondary);
}

.solutions-dim::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 8px solid var(--color-secondary);
}

.solutions-dim--left  { left: 0; }
.solutions-dim--right { right: 0; }

.solutions-dim__label {
    position: relative;
    z-index: 1;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.22rem;
    text-transform: uppercase;
    color: var(--color-secondary);
    background-color: var(--color-tertiary);
}

.solutions-dim--left .solutions-dim__label {
    transform: rotate(180deg);
    left: -1rem;
}

.solutions-dim--right .solutions-dim__label {
    right: -1rem;
}

.solutions-layout {
    position: relative;
    display: grid;
    grid-template-columns: 24rem 1fr;
    gap: 8rem;
    align-items: start;
    background-color: var(--color-tertiary);
}

.solutions-layout.container {
    padding-right: 0;
}

.solutions-sidebar {
    padding: 10rem 0;
    height: 100%;
}

.solutions-sidebar__nav {
    position: sticky;
    top: calc(var(--navbar-height) + 5rem);;
    display: flex;
    flex-direction: column;
}

.solutions-sidebar__nav-list {
    position: relative;
}

.solutions-sidebar__nav-list::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 20px;
    border: 1px solid var(--color-secondary);
/*     background: repeating-linear-gradient(
        -45deg,
        transparent,
        transparent 3px,
        rgba(7, 64, 69, 0.4) 3px,
        rgba(7, 64, 69, 0.4) 4px
    ); */
    pointer-events: none;
}

.solutions-nav__title {
    font-family: var(--font-title);
    font-size: 1.8rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    color: var(--color-secondary);
    margin-bottom: 1.5rem;
}

.solutions-sidebar__nav-link {
    position: relative;
    display: block;
    padding: 1rem 0 1rem 3rem;
    font-size: var(--font-size-s);
    font-weight: 600;
    color: var(--color-secondary);
    margin-left: -2px;
    transition: color var(--transition), border-color var(--transition);
    line-height: 1.4;
    text-transform: uppercase;
}

.solutions-sidebar__nav-link:hover {
    color: var(--color-white);
}

.solutions-sidebar__nav-link.is-active {
    color: var(--color-white);
}

.solutions-sidebar__nav-link.is-active::before {
    content: '';
    position: absolute;
    left: 9px;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
    height: 6px;
    background-color: var(--color-white);
}

.solutions-list {
    position: relative;
    border-left: 1px solid var(--color-secondary);
    padding-top: 8rem;
}

.solutions-list::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 8px solid var(--color-secondary);
}

.solutions-list::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 8px solid var(--color-secondary);
}

.solution-card {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    scroll-margin-top: calc(var(--navbar-height) + 3rem);
    margin-bottom: 10rem;
}

.solution-card--no-image .solution-card__media {
    display: none;
}

.solution-card__media {
    overflow: hidden;
    height: 40rem;
/*     border: 1px solid var(--color-secondary);
    background-color: var(--color-white);
    padding: 2rem; */
    margin: 0 10rem 2rem;
}

.solution-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.55s ease;
    border: 1px solid var(--color-secondary);
}

.solution-card__body {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2.8rem;
    padding: 0 10rem;
}

.solution-card__title-wrap {
    margin-bottom: 5rem;
    padding: 2rem 2rem 2rem 10rem;
    border-top: 1px solid var(--color-secondary);
    border-bottom: 1px solid var(--color-secondary);
    /* background: repeating-linear-gradient( -45deg, transparent, transparent 5px, rgba(7, 64, 69, 0.4) 5px, rgba(7, 64, 69, 0.4) 6px ); */
}

.solution-card__title {
    font-family: var(--font-title);
    font-size: 4rem;
    font-weight: 400;
    letter-spacing: 0.05rem;
    text-transform: uppercase;
    color: var(--color-secondary);
}

.solution-card__desc p {
    margin-bottom: 1.2rem;
    font-weight: 500;
}

.solution-card__desc p:last-child {
    margin-bottom: 0;
}

.solution-card__catalogs {
    display: flex;
    flex-wrap: wrap;
    gap: 1.2rem;
}

.solution-card__catalog {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
    padding: 1.2rem 2.5rem 1.3rem;
    font-size: var(--font-size-s);
    font-weight: var(--font-weight-medium);
    background-color: var(--color-secondary);
    text-decoration: none;
    transition: background-color var(--transition), color var(--transition), clip-path var(--transition);
    letter-spacing: var(--letter-spacing-s);
    cursor: pointer;
    color: var(--color-white);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 8px), calc(100% - 8px) 100%, 0 100%);
}

.solution-card__catalog svg {
    width: 1.6rem;
    height: 1.6rem;
    flex-shrink: 0;
}

.solution-card__catalog--standards,
.solution-card__catalog--airflex {
    color: var(--color-white);
}

.solution-card__catalog--standards:hover,
.solution-card__catalog--airflex:hover,
.solution-card__catalog:hover {
    background-color: var(--color-secondary-light);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%);
}

/* ── Responsive ─────────────────────────────────────────────────────────────── */

@media (max-width: 1024px) {
    .solutions-layout {
        grid-template-columns: 20rem 1fr;
        gap: 5rem;
    }
    .solution-card__body {
        padding: 4.5rem 4rem;
    }
    .solution-card__title {
        font-size: 3.2rem;
    }
}

@media (max-width: 768px) {
    .solutions-hero {
        min-height: 62vh;
        background-attachment: scroll;
    }

    .solutions-hero__title {
        font-size: 3.6rem;
    }

    .solutions-layout {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .solutions-sidebar {
        position: static;
        margin-bottom: 4rem;
    }

    .solutions-sidebar__nav {
        flex-direction: row;
        flex-wrap: nowrap;
        overflow-x: auto;
        border-left: none;
        border-bottom: 2px solid var(--color-border);
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .solutions-sidebar__nav::-webkit-scrollbar {
        display: none;
    }

    .solutions-sidebar__nav-link {
        border-left: none;
        border-bottom: 2px solid transparent;
        margin-left: 0;
        margin-bottom: -2px;
        white-space: nowrap;
        padding: 1.2rem 1.6rem;
    }

    .solutions-sidebar__nav-link.is-active {
        border-bottom-color: var(--color-primary);
    }

    .solution-card {
        grid-template-columns: 1fr;
        min-height: auto;
        box-shadow: none;
    }

    .solution-card__media {
        min-height: 26rem;
    }

    .solution-card__body {
        padding: 3.5rem var(--spacing-md);
    }
}

/* =============================================================================
   PAGE PARTENAIRES
   ============================================================================= */

.partners-hero {
    position: relative;
    min-height: 35vh;
    display: flex;
    align-items: center;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    border-bottom: 1px solid var(--color-secondary);
}

.partners-hero::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.partners-hero::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%) rotate(180deg);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.partners-hero__overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(var(--color-tertiary-rgb), 0.8);
}

.partners-hero__inner {
    position: relative;
    z-index: 1;
    padding-top: var(--spacing-xl);
    padding-bottom: var(--spacing-xl);
}

.partners-hero__title {
    font-family: var(--font-title);
    font-size: 7.6rem;
    font-weight: 400;
    color: var(--color-white);
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    line-height: 1.3;
    margin-bottom: 2.8rem;
    max-width: 70%;
}

.partners-hero__desc {
    font-size: var(--font-size-lg);
    font-weight: 500;
    color: rgba(255, 255, 255, 0.82);
    line-height: var(--line-height-base);
    margin-bottom: 0;
    max-width: 64rem;
}

.partners-hero__scroll {
    position: absolute;
    bottom: 2.8rem;
    left: 50%;
    transform: translateX(-50%);
    color: var(--color-white);
    animation: solutions-bounce 2.2s ease-in-out infinite;
}

.partners-hero__scroll svg {
    width: 3.4rem;
    height: 3.4rem;
    display: block;
}

/* ── Section principale ──────────────────────────────────────────────────── */

.partners-section {
    position: relative;
    background-color: var(--color-tertiary);
    overflow-x: clip;
}

.partners-layout {
    position: relative;
    display: grid;
    grid-template-columns: 24rem 1fr;
    gap: 8rem;
    align-items: start;
    background-color: var(--color-tertiary);
}

.partners-layout.container {
    padding-right: 0;
}

.partners-sidebar {
    padding: 10rem 0;
    height: 100%;
}

.partners-sidebar__nav {
    position: sticky;
    top: calc(var(--navbar-height) + 5rem);
    display: flex;
    flex-direction: column;
}

.partners-sidebar__nav-list {
    position: relative;
}

.partners-sidebar__nav-list::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 20px;
    border: 1px solid var(--color-secondary);
/*     background: repeating-linear-gradient(
        -45deg,
        transparent,
        transparent 3px,
        rgba(7, 64, 69, 0.4) 3px,
        rgba(7, 64, 69, 0.4) 4px
    ); */
    pointer-events: none;
}

.partners-nav__title {
    font-family: var(--font-title);
    font-size: 1.8rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    color: var(--color-secondary);
    margin-bottom: 1.5rem;
}

.partners-sidebar__nav-link {
    position: relative;
    display: block;
    padding: 1rem 0 1rem 3rem;
    font-size: var(--font-size-s);
    font-weight: 600;
    color: var(--color-secondary);
    margin-left: -2px;
    transition: color var(--transition), border-color var(--transition);
    line-height: 1.4;
    text-transform: uppercase;
}

.partners-sidebar__nav-link:hover {
    color: var(--color-white);
}

.partners-sidebar__nav-link.is-active {
    color: var(--color-white);
}

.partners-sidebar__nav-link.is-active::before {
    content: '';
    position: absolute;
    left: 9px;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
    height: 6px;
    background-color: var(--color-white);
}

/* ── Liste ───────────────────────────────────────────────────────────────── */

.partners-list {
    position: relative;
    border-left: 1px solid var(--color-secondary);
    padding-top: 8rem;
}

.partners-list::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 8px solid var(--color-secondary);
}

.partners-list::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateX(-50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 8px solid var(--color-secondary);
}

/* ── Card partenaire ─────────────────────────────────────────────────────── */

.partner-card {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    scroll-margin-top: calc(var(--navbar-height) + 3rem);
    margin-bottom: 10rem;
}

.partner-card--no-image .partner-card__media {
    display: none;
}

.partner-card__media {
    overflow: hidden;
    height: 40rem;
    margin: 0 10rem 2rem;
}

.partner-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.55s ease;
    border: 1px solid var(--color-secondary);
}

.partner-card__title-wrap {
    margin-bottom: 5rem;
    padding: 2rem 2rem 2rem 10rem;
    border-top: 1px solid var(--color-secondary);
    border-bottom: 1px solid var(--color-secondary);
/*     background: repeating-linear-gradient(
        -45deg,
        transparent, transparent 5px,
        rgba(7, 64, 69, 0.4) 5px, rgba(7, 64, 69, 0.4) 6px
    ); */
}

.partner-card__title {
    font-family: var(--font-title);
    font-size: 4rem;
    font-weight: 400;
    letter-spacing: 0.05rem;
    text-transform: uppercase;
    color: var(--color-secondary);
}

.partner-card__body {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2.8rem;
    padding: 0 10rem;
}

.partner-card__meta {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.partner-card__location,
.partner-card__website {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    font-size: var(--font-size-s);
    font-weight: var(--font-weight-medium);
    color: var(--color-secondary);
    letter-spacing: var(--letter-spacing-s);
    text-transform: uppercase;
}

.partner-card__website {
    text-decoration: none;
    transition: color var(--transition);
}

.partner-card__website:hover {
    color: var(--color-white);
}

.partner-card__location svg,
.partner-card__website svg {
    width: 1.4rem;
    height: 1.4rem;
    flex-shrink: 0;
}

.partner-card__desc p {
    margin-bottom: 1.2rem;
}

.partner-card__desc p:last-child {
    margin-bottom: 0;
}

.partner-card__catalog-wrap {
    display: flex;
}

.partner-card__catalog {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
    padding: 1.2rem 2.5rem;
    font-size: var(--font-size-s);
    font-weight: var(--font-weight-medium);
    background-color: var(--color-secondary);
    text-decoration: none;
    transition: background-color var(--transition), color var(--transition), clip-path var(--transition);
    letter-spacing: var(--letter-spacing-s);
    cursor: pointer;
    color: var(--color-white);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 8px), calc(100% - 8px) 100%, 0 100%);
}

.partner-card__catalog svg {
    width: 1.6rem;
    height: 1.6rem;
    flex-shrink: 0;
}

.partner-card__catalog:hover {
    background-color: var(--color-secondary-light);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%);
}


/* =============================================================================
   PAGE DISTRIBUTION
   ============================================================================= */

/* ── Hero ──────────────────────────────────────────────────────────────────── */

.dist-hero {
    position: relative;
    min-height: 35vh;
    display: flex;
    align-items: center;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    border-bottom: 1px solid var(--color-secondary);
}

.dist-hero::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.dist-hero::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%) rotate(180deg);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.dist-hero__overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(var(--color-tertiary-rgb), 0.8);
}

.dist-hero__inner {
    position: relative;
    z-index: 1;
    padding-top: var(--spacing-xl);
    padding-bottom: var(--spacing-xl);
}

.dist-hero__title {
    font-family: var(--font-title);
    font-size: 7.6rem;
    font-weight: 400;
    color: var(--color-white);
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    line-height: 1.3;
    margin-bottom: 2.8rem;
    max-width: 70%;
}

.dist-hero__desc {
    font-size: var(--font-size-lg);
    font-weight: 500;
    color: var(--color-white);
    line-height: var(--line-height-base);
    margin-bottom: 0;
    max-width: 64rem;
}

.dist-hero__scroll {
    position: absolute;
    bottom: 2.8rem;
    left: 50%;
    transform: translateX(-50%);
    color: var(--color-white);
    animation: solutions-bounce 2.2s ease-in-out infinite;
}

.dist-hero__scroll svg {
    width: 3.4rem;
    height: 3.4rem;
    display: block;
}

.dist-map-section {
    position: relative;
    background-color: var(--color-tertiary);
    overflow-x: clip;
    border-bottom: 1px solid var(--color-secondary);
}

.dist-map-section::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.dist-map-section::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-left: 8px solid var(--color-secondary);
    z-index: 1;
}

.dist-map-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 4rem;
    flex-wrap: wrap;
    border-bottom: 1px solid var(--color-secondary);
}

.dist-map-header__inner {
    display: flex;
    justify-content: space-between;
    width: 100%;
}

.dist-filter {
    display: flex;
    min-width: 330px;
    width: calc(30% + 1px);
    justify-content: space-between;
    align-content: center;
    align-items: center;
    padding-left: 5rem;
}

.dist-filter__select-wrap {
    position: relative;
}

.dist-filter__select {
    width: 100%;
    min-widht: 180px;
    padding: 2rem 4rem 2rem 1.6rem;
    font-size: var(--font-size-xs);
    color: var(--color-white);
    border-left: 1px solid var(--color-secondary);
    border-right: 1px solid var(--color-secondary);
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    transition: background-color var(--transition);
    letter-spacing: var(--letter-spacing-s);
    text-transform: uppercase;
    letter-spacing: 0.08rem;
    background-color: rgba(var(--color-secondary-rgb), 0.08);
}

.dist-filter__select:focus {
    color: var(--color-white);
}

.dist-filter__select option {
    background-color: var(--color-secondary);
    color: var(--color-white);
}

.dist-filter__chevron {
    position: absolute;
    right: 1.2rem;
    top: 50%;
    transform: translateY(-50%);
    width: 1.6rem;
    height: 1.6rem;
    color: var(--color-white);
    pointer-events: none;
}

.dist-type-filter {
    display: flex;
    gap: 0;
}

.dist-type-btn {
    padding: 2rem 1.8rem;
    font-family: var(--font-primary);
    font-size: var(--font-size-xs);
    letter-spacing: 0.08rem;
    text-transform: uppercase;
    color: var(--color-secondary);
    border-left: 1px solid var(--color-secondary);
    cursor: pointer;
    transition: background-color var(--transition), color var(--transition);
}

.dist-type-btn:last-child {
    border-right: 1px solid var(--color-secondary);
}

.dist-type-btn:hover {
    background-color: rgba(var(--color-secondary-rgb), 0.08);
}

.dist-type-btn.is-active {
    background-color: rgba(var(--color-secondary-rgb), 0.08);
    color: var(--color-white);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.dist-map {
    width: 100%;
    height: 100vh;
    position: relative;
    z-index: 0;
}

.dist-list-map-container {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.dist-map .leaflet-container {
    background-color: #aedbde; /* --color-secondary-flashy : fond visible avant chargement des tuiles */
}

.dist-map .leaflet-tile-pane {
    filter: grayscale(1) sepia(0.6) hue-rotate(130deg) saturate(0.8) brightness(1);
}

.dist-map-attribution {
    text-align: center;
    border-top: 1px solid var(--color-secondary);
    padding: 2rem 0;
    font-weight: 500;
    font-size: var(--font-size-xs);
}

.dist-map-wrap {
    width: 70%;
    position: sticky;
    top: var(--navbar-height);
    border-left: 1px solid var(--color-secondary);
}

.dist-map-attribution a {
    text-decoration: none;
    transition: color var(--transition);
}

.dist-map-attribution a:hover {
    color: var(--color-white);
}

.dist-popup {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    min-width: 18rem;
}

.dist-popup__name {
    display: block;
    font-family: var(--font-title);
    font-size: 1.5rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.04rem;
    color: var(--color-secondary);
}

.dist-popup__badge {
    display: inline-block;
    padding: 0.8rem 1rem;
    font-size: 0.95rem;
    font-weight: 600;
    letter-spacing: 0.06rem;
    text-transform: uppercase;
    color: var(--color-white);
    margin-bottom: 1rem;
}

.dist-popup__badge--distributor {
    background-color: var(--color-primary);
}

.dist-popup__badge--integrator {
    background-color: var(--color-tertiary);
}

.dist-popup__location {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1.15rem;
    color: var(--color-secondary);
}

.dist-popup__location svg {
    width: 1.3rem;
    height: 1.3rem;
    flex-shrink: 0;
    color: var(--color-secondary);
}

.dist-popup__link {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1.15rem;
    color: var(--color-secondary);
    text-decoration: none;
    transition: color var(--transition);
    word-break: break-all;
}

.dist-popup__link:hover {
    color: var(--color-primary);
}

.dist-popup__link svg {
    width: 1.3rem;
    height: 1.3rem;
    flex-shrink: 0;
}

.dist-marker {
    background: none !important;
    border: none !important;
}

.dist-marker svg {
    width: 28px;
    height: 38px;
    display: block;
    filter: drop-shadow(0 3px 6px rgba(0,0,0,0.35));
    transition: transform 0.15s ease;
}

.dist-list {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    width: 30%;
    min-width: 330px;
}

.dist-no-distributors {
    text-align: center;
    color: var(--color-secondary);
    font-size: var(--font-size-lg);
    padding: 6rem 0;
}

.dist-card {
    position: relative;
    border-bottom: 1px solid var(--color-secondary);
    padding: 5rem;
    transition: background-color var(--transition);
    display: flex;
    flex-direction: column;
    cursor: pointer;
}

.dist-card:last-child {
    border-bottom: none;
}

.dist-card::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.dist-card::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%) rotate(180deg);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.dist-card:last-child::before,
.dist-card:last-child::after {
    border: none;
}

.dist-card--active,
.dist-card:hover {
    background-color: rgba(var(--color-secondary-rgb), 0.08);
}

.dist-card[hidden] {
    display: none;
}

.dist-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.2rem;
}

.dist-card__name {
    font-family: var(--font-title);
    font-size: 3rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.04rem;
    color: var(--color-secondary);
    line-height: 1.25;
    margin: 0 0 1rem;
}

.dist-card__badge {
    position: absolute;
    right: 0;
    top: -41px;
    height: 41px;
    flex-shrink: 0;
    font-size: 1.05rem;
    font-weight: var(--font-weight-medium);
    letter-spacing: 0.06rem;
    text-transform: uppercase;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
}

.dist-card__badge-label {
    position: relative;
}

.dist-card__badge-label::before {
    position: relative;
    left: -1px;
    content: '';
    display: inline-block;
    width: 0.6em;
    height: 0.6em;
    border-radius: 50%;
    flex-shrink: 0;
}

.dist-card__badge--distributor .dist-card__badge-label::before {
    background-color: var(--color-primary);
}

.dist-card__badge--integrator .dist-card__badge-label::before {
    background-color: var(--color-secondary);
}

.dist-card__body {
    position: relative;
}

.dist-card__meta {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    border: 1px solid var(--color-secondary);
}

.dist-card__meta-item {
    display: flex;
    align-items: center;
    font-size: var(--font-size-s);
    border-bottom: 1px solid var(--color-secondary);
}

.dist-card__meta-item:last-child {
    border-bottom: none;
}

.dist-card__meta-item svg {
    width: 1.4rem;
    height: 1.4rem;
    flex-shrink: 0;
    color: var(--color-secondary);
    margin: 0 1.4rem;
}

.dist-card__meta-item span,
.dist-card__meta-item a {
    padding: 1rem 2rem;
    border-left: 1px solid var(--color-secondary);
}

.dist-card__meta-item a {
    color: var(--color-secondary);
    text-decoration: none;
    transition: color var(--transition);
    word-break: break-all;
}

.dist-card__meta-item a:hover {
    color: var(--color-primary);
}

.dist-card__map-btn {
    width: fit-content;
    color: var(--color-secondary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    margin-left: auto;
    margin-top: 1rem;
    font-size: 1.05rem;
    font-weight: 500;
}

.dist-card:hover .dist-card__map-btn {
   
}

.dist-card__map-btn span {
    text-decoration: underline;
    text-underline-offset: 2px;
}

.dist-card__map-btn svg {
    position: relative;
    top: 0.5px;
    width: 1.4rem;
    height: 1.4rem;
}

.dist-card:hover .dist-card__map-btn svg {
    animation: dist-arrow-bounce 0.9s ease-in-out infinite;
}

@keyframes dist-arrow-bounce {
    0%, 100% { transform: translateX(0); }
    50%       { transform: translateX(4px); }
}

#dunner-map .leaflet-popup-content-wrapper {
	border-radius: 0;
}

#dunner-map .leaflet-container a {
    color: var(--color-secondary);
}

#dunner-map .leaflet-popup-content {
    margin: 2rem;
    font-size: 1.15rem;
}

#dunner-map .leaflet-bar {
    border-radius: 0;
}

#dunner-map .leaflet-bar {
    border: 1px solid var(--color-secondary);
}

#dunner-map .leaflet-bar a {
    background-color: var(--color-white);
}

#dunner-map .leaflet-bar a:first-child {
	border-top-left-radius: 0;
	border-top-right-radius: 0;
}

#dunner-map .leaflet-bar a {
    color: var(--color-secondary);
    border-bottom: 1px solid var(--color-secondary);
}

#dunner-map .leaflet-bar a:last-child {
    border-bottom: none;
}

#dunner-map .leaflet-bar a:last-child {
	border-bottom-left-radius: 0;
	border-bottom-right-radius: 0;
}

#dunner-map .leaflet-control-zoom-in,
#dunner-map .leaflet-control-zoom-out {
    font-family: var(--font-primary);
    font-weight: 300;
}

#dunner-map .leaflet-bar a {
    line-height: 26px;
}

#dunner-map .leaflet-control-zoom-out.leaflet-disabled {
    color: var(--color-text-muted);
    cursor: not-allowed;
}

.dist-info {
    background-color: var(--color-tertiary);
}

.dist-info__container {
    position: relative;
    display: flex;
    justify-content: space-between;
}

.dist-info--integration {
    background-color: var(--color-light);
}

.dist-info__inner {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    flex: 1;
}

.dist-info__inner:first-of-type {
    position: relative;
    padding: 10rem 10rem 10rem 0;
    border-right: 1px solid var(--color-secondary);
}

.dist-info__inner:first-of-type::before {
    content: '';
    position: absolute;
    right: 0;
    transform: translateX(50%);
    top: 0;
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 8px solid var(--color-secondary);
}

.dist-info__inner:first-of-type::after {
    content: '';
    position: absolute;
    right: 0;
    transform: translateX(50%);
    bottom: 0;
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 8px solid var(--color-secondary);
}

.dist-info__inner:last-of-type {
    padding: 10rem 0 10rem 10rem;
}

.dist-info__media {
    overflow: hidden;
    border: 1px solid var(--color-secondary);
    box-shadow: 8px 8px 0 var(--color-secondary);
}

.dist-info__media img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.55s ease;
}

.dist-info__media:hover img {
    transform: scale(1.03);
}

.dist-info__title {
    font-family: var(--font-title);
    font-size: 3.5rem;
    font-weight: 400;
    letter-spacing: 0.05rem;
    text-transform: uppercase;
    color: var(--color-secondary);
    margin-bottom: 1.4rem;
}

.dist-info__desc {
    margin-bottom: 1.6rem;
    font-weight: 500;
}

.dist-info__desc:last-child {
    margin-bottom: 0;
}

/* =============================================================================
   PAGE PRÉSENTATION
   ============================================================================= */

.pres-hero {
    position: relative;
    min-height: 42vh;
    display: flex;
    align-items: center;
    background-size: cover;
    background-position: top center;
    background-attachment: fixed;
    border-bottom: 1px solid var(--color-secondary);
}

.pres-hero::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.pres-hero::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%) rotate(180deg);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.pres-hero__overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(var(--color-tertiary-rgb), 0.8);
}

.pres-hero__inner {
    position: relative;
    z-index: 1;
    text-align: center;
    padding-top: var(--spacing-xl);
    padding-bottom: calc(var(--spacing-xl) + 4rem);
}

.pres-hero__subtitle {
    text-align: center;
    font-size: var(--font-size-xs);
    text-transform: uppercase;
    color: var(--color-white);
    font-weight: 500;
    margin-bottom: 2rem;
}

.pres-hero__title {
    font-family: var(--font-title);
    font-size: 5.8rem;
    font-weight: 400;
    color: var(--color-white);
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    line-height: 1.3;
    margin: 0 auto;
    max-width: 84rem;
}

.pres-hero__scroll {
    position: absolute;
    bottom: 2.8rem;
    left: 50%;
    transform: translateX(-50%);
    color: var(--color-white);
    animation: solutions-bounce 2.2s ease-in-out infinite;
}

.pres-hero__scroll svg {
    width: 3.4rem;
    height: 3.4rem;
    display: block;
}

.pres-section {
    position: relative;
    background-color: var(--color-tertiary);
    border-bottom: 1px solid var(--color-secondary);
}

.pres-section::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.pres-section::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%) rotate(180deg);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.pres-section__inner {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    padding: 0;
}

.pres-section__inner::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 1px;
    background-color: var(--color-secondary);
    transform: translateX(-0.5px);
    pointer-events: none;
}

.pres-section--reverse .pres-section__inner {
    direction: rtl;
}

.pres-section--reverse .pres-section__content,
.pres-section--reverse .pres-section__media {
    direction: ltr;
}

.pres-section__content {
    padding: 0 10rem;
}

.pres-section__media-wrapper {
    display: flex;
    justify-content: center;
    padding: var(--spacing-xl) 10rem;
}

.pres-section__media-inner {
    overflow: hidden;
    border: 1px solid var(--color-secondary);
}

.pres-section__media-inner img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.55s ease;
}

.pres-section__media-inner:hover img {
    transform: scale(1.03);
}

.pres-section__title {
    font-family: var(--font-title);
    font-size: 3.5rem;
    font-weight: 400;
    letter-spacing: 0.05rem;
    text-transform: uppercase;
    color: var(--color-secondary);
    margin-bottom: 2rem;
    line-height: 1.3;
}

.pres-section__desc {
    margin-bottom: 1.6rem;
}

.pres-section__desc:last-child {
    margin-bottom: 0;
}

.pres-links {
    position: relative;
    background-color: var(--color-tertiary);
    overflow: hidden;
}

.pres-links__grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6rem;
    padding-top: var(--spacing-xl);
    padding-bottom: var(--spacing-xl);
}

.pres-link-card {
    display: flex;
    flex-direction: column;
    /* background: repeating-linear-gradient( -45deg, transparent, transparent 5px, rgba(7, 64, 69, 0.4) 5px, rgba(7, 64, 69, 0.4) 6px ); */
    background-color: var(--color-secondary);
    padding: 6rem;
    /* border: 1px solid var(--color-white); */
}

.pres-link-card__media {
    overflow: hidden;
    border: 1px solid var(--color-white);
    margin-bottom: 2rem;
}

.pres-link-card__media img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.55s ease;
}

.pres-link-card:hover .pres-link-card__media img {
    transform: scale(1.03);
}

.pres-link-card__content {
    display: flex;
    flex-direction: column;
    flex: 1;
}

.pres-link-card__title {
    font-family: var(--font-title);
    font-size: 4rem;
    font-weight: 400;
    letter-spacing: 0.08rem;
    text-transform: uppercase;
    color: var(--color-white);
    margin-bottom: 1rem;
}

.pres-link-card__desc {
    color: var(--color-white);
    font-weight: 500;
    text-transform: uppercase;
    line-height: var(--line-height-base);
    margin-bottom: 2.4rem;
    flex: 1;
}

.pres-link-card__btn {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    align-self: flex-start;
    background-color: var(--color-secondary);
    color: var(--color-white);
    padding: 1.4rem 3rem;
    font-size: var(--font-size-s);
    font-weight: 500;
    text-decoration: none;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%);
    transition: background-color var(--transition), clip-path var(--transition);
}

.pres-link-card__btn svg {
    width: 1.8rem;
    height: 1.8rem;
    flex-shrink: 0;
    transition: transform var(--transition);
}

.pres-link-card__btn:hover {
    background-color: var(--color-secondary-light);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 14px), calc(100% - 14px) 100%, 0 100%);
}

.pres-link-card__btn:hover svg {
    transform: translateX(4px);
}

.pres-link-card .pres-link-card__btn {
    background-color: var(--color-white);
    color: var(--color-secondary);
}

/* ─── Variante colonne unique (page Organisation) ── */
.pres-links__grid--single {
    grid-template-columns: 1fr;
    max-width: 64rem;
}

/* =============================================================================
   PAGE ORGANISATION
   ============================================================================= */

.orga-sections {
    background-color: var(--color-tertiary);
}

.orga-section {
    position: relative;
    border-bottom: 1px solid var(--color-secondary);
}

.orga-section::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.orga-section::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%) rotate(180deg);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.orga-section__inner {
    position: relative;
    padding-top: var(--spacing-xl);
    padding-bottom: var(--spacing-xl);
}

.orga-section__title {
    font-family: var(--font-title);
    font-size: 3.4rem;
    font-weight: 400;
    letter-spacing: 0.05rem;
    text-transform: uppercase;
    color: var(--color-secondary);
    margin-bottom: 4rem;
    line-height: 1.2;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--color-secondary);
    display: inline-block;
}

/* ── Grille de cartes ────────────────────────────────────────────────────── */

.orga-grid {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 3rem;
    padding: 0;
    margin: 0;
}

/* ── Carte membre ────────────────────────────────────────────────────────── */

.orga-card {
    display: flex;
    flex-direction: column;
}

.orga-card__photo {
    overflow: hidden;
    border: 1px solid var(--color-secondary);
    box-shadow: 6px 6px 0 var(--color-secondary);
    margin-bottom: 1.6rem;
    aspect-ratio: 3 / 4;
}

.orga-card__img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: top center;
    transition: transform 0.55s ease;
}

.orga-card__img--placeholder {
    background-color: var(--color-light);
}

.orga-card:hover .orga-card__img {
    transform: scale(1.03);
}

.orga-card__body {
    padding: 0 0.4rem;
}

.orga-card__name {
    font-family: var(--font-title);
    font-size: 1.8rem;
    font-weight: 400;
    letter-spacing: 0.03rem;
    text-transform: uppercase;
    color: var(--color-secondary);
    margin-bottom: 0.4rem;
    line-height: 1.2;
}

.orga-card__position {
    font-size: var(--font-size-s);
    font-weight: 500;
}

/* =============================================================================
   PAGE HISTORIQUE
   ============================================================================= */

.hist-content {
    position: relative;
    background-color: var(--color-tertiary);
    border-bottom: 1px solid var(--color-secondary);
}

.hist-content::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.hist-content::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%) rotate(180deg);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.hist-content__inner {
    position: relative;
    padding-left: 0;
    padding-right: 0;
}

.hist-timeline {
    position: relative;
}

.hist-timeline__item {
    display: flex;
    border-bottom: 1px solid var(--color-secondary);
    position: relative;
}

.hist-timeline__item:last-of-type {
    border-bottom: none;
}

.hist-timeline__date {
    display: flex;
    justify-content: center;
    align-items: center;
    border-right: 1px solid var(--color-secondary);
    width: 20rem;
    min-width: 20rem;
}

.hist-timeline__date span {
    font-family: var(--font-title);
    font-size: 5rem;
    font-weight: 400;
    letter-spacing: 0.08rem;
    line-height: 1;
    display: inline-block;
}

.hist-timeline__body {
    padding: 5rem 10rem 5rem 3.6rem;
}

.hist-timeline__body p {
    margin-bottom: 1.2rem;
    font-size: 1.6rem;
}

.hist-timeline__body p:last-child {
    margin-bottom: 0;
}


/* =============================================================================
   PAGE ACCUEIL
   ============================================================================= */

/* ── 1. Hero ─────────────────────────────────────────────────────────────── */

.home-hero {
    position: relative;
    min-height: calc(100svh - var(--navbar-height));
    display: flex;
    align-items: center;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    border-bottom: 1px solid var(--color-secondary);
}

.home-hero::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.home-hero::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%) rotate(180deg);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.home-hero__inner {
    position: relative;
    z-index: 1;
}

.home-hero__overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(var(--color-tertiary-rgb), 0.8);
    background-size: 50px 50px, 50px 50px, 10px 10px, 10px 10px;
}

.home-hero__eyebrow {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.1rem;
    margin-bottom: 1.5rem;
}

.home-hero__title {
    font-family: var(--font-title);
    font-size: 8.4rem;
    font-weight: 400;
    color: var(--color-white);
    text-transform: uppercase;
    letter-spacing: 0.04rem;
    line-height: 1.3;
    margin-bottom: 2.8rem;
}

.home-hero__desc {
    font-size: var(--font-size-lg);
    color: var(--color-white);
    line-height: var(--line-height-base);
    margin-bottom: 4rem;
    max-width: 54rem;
}

.home-hero__ctas {
    display: flex;
    align-items: center;
    gap: 2rem;
    flex-wrap: wrap;
}

.home-hero__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
    padding: 1.4rem 2.8rem;
    font-family: var(--font-primary);
    font-size: var(--font-size-s);
    font-weight: 600;
    text-decoration: none;
    transition: all var(--transition);
}

.home-hero__cta svg {
    width: 1.8rem;
    height: 1.8rem;
    flex-shrink: 0;
    transition: transform var(--transition);
}

.home-hero__cta:hover svg {
    transform: translateX(4px);
}

.home-hero__cta--primary {
    background-color: var(--color-secondary);
    color: var(--color-white);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%);
}

.home-hero__cta--primary:hover {
    background-color: var(--color-secondary-light);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 16px), calc(100% - 16px) 100%, 0 100%);
}

.home-hero__cta--ghost {
    background-color: transparent;
    color: var(--color-secondary);
    border: 1px solid var(--color-secondary);
}

.home-hero__cta--ghost:hover {
    background-color: rgba(var(--color-secondary-rgb), 0.1);
    color: var(--color-secondary);
}

.home-hero__scroll {
    position: absolute;
    bottom: 2.8rem;
    left: 50%;
    transform: translateX(-50%);
    color: var(--color-white);
    animation: solutions-bounce 2.2s ease-in-out infinite;
}

.home-hero__scroll svg {
    width: 3.4rem;
    height: 3.4rem;
    display: block;
}

.home-stats {
    background-color: var(--color-secondary);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.home-stats__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
}

.home-stats__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 4.4rem 2rem;
    text-align: center;
}

.home-stats__number {
    position: relative;
    font-family: var(--font-title);
    font-size: 7rem;
    font-weight: 400;
    color: var(--color-white);
    letter-spacing: 0.1rem;
    line-height: 1;
    margin-bottom: 0.8rem;
}

.home-stats__number-plus {
    font-size: 4.4rem;
    position: absolute;
    right: -19px;
    top: -6px;
}

.home-stats__number-perc {
    font-size: 2.4rem;
    position: absolute;
    top: 8px;
    right: -29px;
}

.home-stats__number-suffix {
    font-size: 2.4rem;
    position: absolute;
    top: 8px;
    right: -45px;
}

html[lang="en-GB"] .home-stats__number-suffix {
    right: -25px;
}

html[lang="de-DE"] .home-stats__number-suffix {
    right: -10px;
    top: initial;
    bottom: 3px;
}

html[lang="it-IT"] .home-stats__number-suffix,
html[lang="pt-BR"] .home-stats__number-suffix {
    right: -15px;
}

html[lang="es-ES"] .home-stats__number-suffix {
    right: -14px;
}

html[lang="zh-CN"] .home-stats__number-suffix {
    right: -28px;
}

.home-stats__number-prefix {
    font-size: 6rem;
    line-height: 0.7;
    position: absolute;
    top: 8px;
    left: -30px;
}

.home-stats__label {
    font-size: var(--font-size-xs);
    text-transform: uppercase;
    letter-spacing: 0.04rem;
    color: var(--color-white);
    font-weight: 500;
}

/* ── 3. Solutions aperçu ──────────────────────────────────────────── */

.home-solutions {
    position: relative;
    background-color: var(--color-tertiary);
    border-bottom: 1px solid var(--color-secondary);
}

.home-solutions::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.home-solutions::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%) rotate(180deg);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.home-solutions__inner {
    position: relative;
    z-index: 1;
    padding-top: var(--spacing-xl);
    padding-bottom: var(--spacing-xl);
}

.home-solutions__header {
    text-align: center;
    margin-bottom: 6rem;
    max-width: 72rem;
    margin-left: auto;
    margin-right: auto;
}

.home-solutions__title {
    font-family: var(--font-title);
    font-size: 4.8rem;
    font-weight: 400;
    color: var(--color-white);
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    line-height: 1.2;
    margin-bottom: 1.6rem;
}

.home-solutions__desc {
    font-weight: 500;
    color: var(--color-white);
    max-width: 50rem;
    margin-left: auto;
    margin-right: auto;
}

.home-solutions__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2.4rem;
    list-style: none;
    margin-bottom: 6rem;
}

.home-solutions__card {
    background-color: var(--color-secondary);
    border: 1px solid var(--color-secondary);
    overflow: hidden;
    transition: border-color var(--transition);
}

.home-solutions__card-link {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-decoration: none;
    height: 100%;
}

.home-solutions__card-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 20rem;
    background-color: var(--color-secondary);
    padding: 3rem;
    transition: background-color var(--transition);
}

.home-solutions__card-icon svg {
    width: 100%;
    height: 100%;
    max-width: 16rem;
    max-height: 14rem;
    transition: transform 0.5s ease;
}

/* Stroke des icônes SVG inline (classe injectée par le SVG) */
.dunner-icon .cls-1 {
    stroke: currentColor;
}

/* Dans les cards solutions : couleur primaire sur fond secondaire */
.home-solutions__card-icon .dunner-icon .cls-1 {
    stroke: var(--color-primary);
    fill: none;
    stroke-width: 1;
}

.home-solutions__card:hover .home-solutions__card-icon svg {
    transform: scale(1.05);
}

.home-solutions__card-body {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.8rem 2.4rem;
    gap: 1rem;
    background-color: var(--color-tertiary);
}

.home-solutions__card-title {
    font-family: var(--font-title);
    font-size: 2rem;
    font-weight: 400;
    color: var(--color-secondary);
    text-transform: uppercase;
    letter-spacing: 0.08rem;
    margin: 0;
}

.home-solutions__card-arrow {
    color: var(--color-secondary);
    flex-shrink: 0;
    transition: transform var(--transition);
}

.home-solutions__card-arrow svg {
    width: 2rem;
    height: 2rem;
    display: block;
}

.home-solutions__card:hover .home-solutions__card-arrow {
    transform: translateX(4px);
}

.home-solutions__footer {
    text-align: center;
}

.home-solutions__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
    padding: 1.4rem 2.8rem;
    background-color: var(--color-secondary);
    color: var(--color-white);
    font-family: var(--font-primary);
    font-size: var(--font-size-s);
    font-weight: 600;
    text-decoration: none;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%);
    transition: background-color var(--transition), clip-path var(--transition);
}

.home-solutions__cta svg {
    width: 1.8rem;
    height: 1.8rem;
    flex-shrink: 0;
    transition: transform var(--transition);
}

.home-solutions__cta:hover {
    background-color: var(--color-secondary-light);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 14px), calc(100% - 14px) 100%, 0 100%);
}

.home-solutions__cta:hover svg {
    transform: translateX(4px);
}

.home-editorial {
    position: relative;
    background-color: var(--color-tertiary);
    border-bottom: 1px solid var(--color-secondary);
}

.home-editorial::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.home-editorial::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%) rotate(180deg);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.home-editorial__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8rem;
    align-items: center;
    padding-top: var(--spacing-xl);
    padding-bottom: var(--spacing-xl);
}

.home-editorial__eyebrow {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.1rem;
    margin-bottom: 1.5rem;
}

.home-editorial__title {
    font-family: var(--font-title);
    font-size: 4.8rem;
    font-weight: 400;
    color: var(--color-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    line-height: 1.2;
    margin-bottom: 2.4rem;
}

.home-editorial__body {
    font-weight: 500;
    margin-bottom: 3.6rem;
}

.home-editorial__ctas {
    display: flex;
    align-items: center;
    gap: 2rem;
    flex-wrap: wrap;
}

.home-editorial__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
    padding: 1.4rem 2.8rem;
    background-color: var(--color-secondary);
    color: var(--color-white);
    font-family: var(--font-primary);
    font-size: var(--font-size-s);
    font-weight: 600;
    text-decoration: none;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%);
    transition: background-color var(--transition), clip-path var(--transition);
}

.home-editorial__cta svg {
    width: 1.8rem;
    height: 1.8rem;
    flex-shrink: 0;
    transition: transform var(--transition);
}

.home-editorial__cta:hover {
    background-color: var(--color-secondary-light);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 14px), calc(100% - 14px) 100%, 0 100%);
}

.home-editorial__cta.home-editorial__cta--ghost:hover {
    clip-path: initial;
}

.home-editorial__cta:hover svg {
    transform: translateX(4px);
}

.home-editorial__cta--ghost {
    background-color: transparent;
    color: var(--color-secondary);
    border: 1px solid var(--color-secondary);
    clip-path: none;
}

.home-editorial__cta--ghost:hover {
    background-color: var(--color-secondary);
    color: var(--color-white);
}

.home-editorial__media {
    display: flex;
    flex-direction: column;
}

.home-editorial__media img {
    border: 1px solid var(--color-secondary);
    width: 100%;
    height: auto;
    display: block;
    aspect-ratio: 3 / 2;
    object-fit: cover;
    transition: transform 0.55s ease;
}

.home-editorial:hover .home-editorial__media img {
    transform: scale(1.03);
}

.home-partners {
    position: relative;
    background-color: var(--color-tertiary);
    border-bottom: 1px solid var(--color-secondary);
}

.home-partners::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    transform: translateY(50%);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.home-partners::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%) rotate(180deg);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 8px solid var(--color-secondary);
    z-index: 1;
}

.home-partners__inner {
    position: relative;
    padding-top: var(--spacing-xl);
    padding-bottom: var(--spacing-xl);
}

.home-partners__header {
    text-align: center;
    margin-bottom: 5rem;
}

.home-partners__title {
    font-family: var(--font-title);
    font-size: 4rem;
    font-weight: 400;
    color: var(--color-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    margin-bottom: 1.2rem;
}

.home-partners__desc {
    font-weight: 500;
    color: var(--color-secondary);
    max-width: 50rem;
    margin: 0 auto;
}

.home-partners__name {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    list-style: none;
    border: 1px solid var(--color-secondary);
    border-bottom: none;
    margin-bottom: 5rem;
}

.home-partners__name li {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 3.2rem 4.4rem;
    border-right: 1px solid var(--color-secondary);
    border-bottom: 1px solid var(--color-secondary);
    transition: background-color var(--transition);
}

.home-partners__name li:nth-child(3n) {
    border-right: none;
}

.home-partners__name li p {
    font-family: var(--font-title);
    font-size: 2.4rem;
    font-weight: 400;
    color: var(--color-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    margin: 0;
}

.home-partners__footer {
    text-align: center;
}

.home-partners__cta {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    padding: 1.4rem 3rem;
    background-color: var(--color-secondary);
    color: var(--color-white);
    font-size: var(--font-size-s);
    font-weight: 500;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%);
    transition: background-color var(--transition), clip-path var(--transition), color var(--transition);
}

.home-partners__cta svg {
    width: 1.8rem;
    height: 1.8rem;
    flex-shrink: 0;
    transition: transform var(--transition);
}

.home-partners__cta:hover {
    background-color: var(--color-secondary-light);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 14px), calc(100% - 14px) 100%, 0 100%);
}

.home-partners__cta:hover svg {
    transform: translateX(4px);
}

.home-distrib {
    position: relative;
    min-height: 55vh;
    display: flex;
    align-items: center;
}

.home-distrib__overlay {
	position: absolute;
	inset: 0;
	background-color: rgba(var(--color-tertiary-rgb), 0.8);
}

.home-distrib__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
    padding-top: var(--spacing-xl);
    padding-bottom: var(--spacing-xl);
}

.home-distrib__content {}

.home-distrib__map {
    position: relative;
    align-self: stretch;
    min-height: 46rem;
}

.home-distrib__map canvas {
    position: absolute;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
    display: block;
}

.home-distrib__eyebrow {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.1rem;
    margin-bottom: 1.5rem;
}

.home-distrib__title {
    font-family: var(--font-title);
    font-size: 5.2rem;
    font-weight: 400;
    color: var(--color-white);
    text-transform: uppercase;
    letter-spacing: 0.04rem;
    line-height: 1.2;
    margin-bottom: 2.4rem;
}

.home-distrib__body {
    font-weight: 500;
    color: var(--color-white);
    margin-bottom: 3.6rem;
}

.home-distrib__cta {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    padding: 1.4rem 3rem;
    background-color: var(--color-secondary);
    color: var(--color-white);
    font-size: var(--font-size-s);
    font-weight: 500;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%);
    transition: background-color var(--transition), clip-path var(--transition), color var(--transition);
}

.home-distrib__cta svg {
    width: 1.8rem;
    height: 1.8rem;
    flex-shrink: 0;
    transition: transform var(--transition);
}

.home-distrib__cta:hover {
    background-color: var(--color-secondary-light);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 14px), calc(100% - 14px) 100%, 0 100%);
}

.home-distrib__cta:hover svg {
    transform: translateX(4px);
}

@media (max-width: 768px) {
    .home-partners__logos {
        grid-template-columns: repeat(2, 1fr);
    }
    .home-partners__logos li:nth-child(3n) {
        border-right: 1px solid rgba(255, 255, 255, 0.12);
    }
    .home-partners__logos li:nth-child(2n) {
        border-right: none;
    }
}

@media (max-width: 599px) {
    .home-partners__logos {
        grid-template-columns: 1fr;
    }
    .home-partners__logos li:nth-child(2n) {
        border-right: 1px solid rgba(255, 255, 255, 0.12);
    }
    .home-partners__logos li {
        border-right: none;
    }
}

/* ─── AOS — Animate On Scroll ─────────────────────────────────────────────── */

[data-aos] {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 0.65s ease, transform 0.65s ease;
}

[data-aos].aos-animate {
    opacity: 1;
    transform: translateY(0);
}

[data-aos][data-aos-delay="0"]   { transition-delay: 0s; }
[data-aos][data-aos-delay="75"]  { transition-delay: 0.075s; }
[data-aos][data-aos-delay="100"] { transition-delay: 0.10s; }
[data-aos][data-aos-delay="150"] { transition-delay: 0.15s; }
[data-aos][data-aos-delay="225"] { transition-delay: 0.225s; }
[data-aos][data-aos-delay="200"] { transition-delay: 0.20s; }
[data-aos][data-aos-delay="250"] { transition-delay: 0.25s; }
[data-aos][data-aos-delay="300"] { transition-delay: 0.30s; }
[data-aos][data-aos-delay="350"] { transition-delay: 0.35s; }
[data-aos][data-aos-delay="400"] { transition-delay: 0.40s; }
[data-aos][data-aos-delay="450"] { transition-delay: 0.45s; }
[data-aos][data-aos-delay="500"] { transition-delay: 0.50s; }
[data-aos][data-aos-delay="550"] { transition-delay: 0.55s; }
[data-aos][data-aos-delay="600"] { transition-delay: 0.60s; }
[data-aos][data-aos-delay="650"] { transition-delay: 0.65s; }
[data-aos][data-aos-delay="700"] { transition-delay: 0.70s; }

@media (max-width: 768px) {
    [data-aos] {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
}

/* ─── AOS — Sweep couleur titre (gauche → droite) ──────────────────────────── */

[data-aos-color] {
    --_cp-start: var(--color-white);
    --_cp-end:   rgba(255, 255, 255, 0.3);
    background:          linear-gradient(90deg, var(--_cp-start) 50%, var(--_cp-end) 50%);
    background-size:     200% 100%;
    background-position: 100% 0;
    -webkit-background-clip: text;
    background-clip:         text;
    color: transparent;
    transition: opacity 0.65s ease, transform 0.65s ease, background-position 3.1s ease;
}

[data-aos-color].aos-animate {
    background-position: 0% 0;
}

/* Titres sur fond clair : editorial & partners → dégradé sombre */
.home-editorial [data-aos-color],
.home-partners  [data-aos-color] {
    --_cp-start: var(--color-secondary);
    --_cp-end:   rgba(var(--color-secondary-rgb), 0.3);
}

/* Titres sur fond clair : solution-card, dist-info, partner-card, pres-section, orga-section, contact-hero & legal → dégradé sombre */
.solution-card  [data-aos-color],
.dist-info      [data-aos-color],
.partner-card   [data-aos-color],
.pres-section   [data-aos-color],
.orga-section   [data-aos-color],
.contact-hero   [data-aos-color],
.legal          [data-aos-color] {
    --_cp-start: var(--color-secondary);
    --_cp-end:   rgba(var(--color-secondary-rgb), 0.3);
}

/* Accessibilité — données motion */
@media (prefers-reduced-motion: reduce) {
    [data-aos],
    [data-aos-color] {
        opacity:             1 !important;
        transform:           none !important;
        transition:          none !important;
        background-position: 0% 0 !important;
    }
}
