/*
Theme Name: TKorporation-child
Theme URI: http://themebubble.com/
Template: TKorporation
Author: themebubble
Author URI: http://themeforest.net/user/theme_bubble
Description: A stunning visual experience for minimal loving creative. This template is a responsive and retina-ready WordPress theme with grid system layout. It is optimized for mobile touch and swipe.
Tags: two-columns,three-columns,left-sidebar,right-sidebar,custom-background,custom-header,custom-menu,editor-style,featured-images,flexible-header,full-width-template,post-formats,rtl-language-support,sticky-post,theme-options,translation-ready,accessibility-ready
Version: 2.4.1524988450
Updated: 2018-04-29 07:54:10

*/








img {
    user-select: none;
    -webkit-user-drag: none;
    pointer-events: auto;
  }


@font-face {
    src: url('fonts/Roslindale-DisplayCondensedExtraLight.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedExtraLight.woff') format("woff");
    font-family: 'Roslindale';
    font-style: normal;
    font-weight: 200;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedExtraLightItalic.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedExtraLightItalic.woff') format("woff");
    font-family: 'Roslindale';
    font-style: italic;
    font-weight: 200;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedLight.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedLight.woff') format("woff");
    font-family: 'Roslindale';
    font-style: normal;
    font-weight: 300;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedLightItalic.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedLightItalic.woff') format("woff");
    font-family: 'Roslindale';
    font-style: italic;
    font-weight: 300;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedRegular.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedRegular.woff') format("woff");
    font-family: 'Roslindale';
    font-style: normal;
    font-weight: normal;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedItalic.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedItalic.woff') format("woff");
    font-family: 'Roslindale';
    font-style: italic;
    font-weight: normal;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedMedium.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedMedium.woff') format("woff");
    font-family: 'Roslindale';
    font-style: normal;
    font-weight: 500;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedMediumItalic.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedMediumItalic.woff') format("woff");
    font-family: 'Roslindale';
    font-style: italic;
    font-weight: 500;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedSemiBold.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedSemiBold.woff') format("woff");
    font-family: 'Roslindale';
    font-style: normal;
    font-weight: 600;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedSemiBoldItalic.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedSemiBoldItalic.woff') format("woff");
    font-family: 'Roslindale';
    font-style: italic;
    font-weight: 600;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedBold.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedBold.woff') format("woff");
    font-family: 'Roslindale';
    font-style: normal;
    font-weight: normal;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedBoldItalic.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedBoldItalic.woff') format("woff");
    font-family: 'Roslindale';
    font-style: italic;
    font-weight: normal;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedBlack.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedBlack.woff') format("woff");
    font-family: 'Roslindale';
    font-style: normal;
    font-weight: 800;
  }
  
  @font-face {
    src: url('fonts/Roslindale-DisplayCondensedUltra.woff2') format("woff2"),
         url('fonts/Roslindale-DisplayCondensedUltra.woff') format("woff");
    font-family: 'Roslindale';
    font-style: normal;
    font-weight: normal;
  }

  
::selection{
  background: #B2A79B;
    color: white;
}
/* Reset CSS de base */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

:root {
  --color-cream: #f5f0e8;
  --color-brown: #4a3728;
  --color-brown-dark: #3a2a1c;
  --color-white: #ffffff;
  --font-display: 'Roslindale', sans-serif;
  --font-body: 'Inter', -apple-system, sans-serif;
}


body {
  font-family: var(--font-body);
  color: var(--color-white);
  overflow-x: hidden;
}


/* Supprime les styles par défaut des listes */
ul, ol {
  list-style: none;
}
.selMobile{
    display:none !important;
}
html{
  margin: 0 !important;}
/* Supprime les soulignements et hérite de la couleur */
a {
  text-decoration: none;
  color: inherit;
}
p, h1, h2, h3{
  word-wrap: break-word;
  overflow-wrap: break-word;
  /* hyphens: auto; */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

p{
  font-family: "Inter", sans-serif;
  font-weight: 300 !important;
  letter-spacing: .2px;
  font-size: 16px;
  line-height: 24px;
}
.greenCta{
  font-family: 'inter';
    padding: 15px 40px;
    background: #D6FF62;
    color: #1a1a1a;
    border: none;
    border-radius: 90px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
    text-transform: uppercase;
    letter-spacing: 0px;
    margin-top: 30px;
}
/* --- Regular --- */
@font-face {
  font-family: 'PPEditorialOld';
  src: url('fonts/ppeditorialold-regular.otf') format('opentype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

/* --- Italic --- */
@font-face {
  font-family: 'PPEditorialOld';
  src: url('fonts/ppeditorialold-italic.otf') format('opentype');
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}

/* --- Ultralight --- */
@font-face {
  font-family: 'PPEditorialOld';
  src: url('fonts/ppeditorialold-ultralight.otf') format('opentype');
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}

/* --- Ultralight Italic --- */
@font-face {
  font-family: 'PPEditorialOld';
  src: url('fonts/ppeditorialold-ultralightitalic.otf') format('opentype');
  font-weight: 200;
  font-style: italic;
  font-display: swap;
}

/* --- Ultrabold --- */
@font-face {
  font-family: 'PPEditorialOld';
  src: url('fonts/ppeditorialold-ultrabold.otf') format('opentype');
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

/* --- Ultrabold Italic --- */
@font-face {
  font-family: 'PPEditorialOld';
  src: url('fonts/ppeditorialold-ultrabolditalic.otf') format('opentype');
  font-weight: 800;
  font-style: italic;
  font-display: swap;
}




body {
    font-family: var(--font-display);

  padding: 60px;
  line-height: 1.6;
  color: #111;
}

h1 {
  font-weight: 800;
  font-size: 2.5rem;
  margin-bottom: 20px;
              font-family: var(--font-display);
}

h2 {
  font-weight: 300;
  margin-top: 50px;
  font-family: var(--font-display);
}










/* ---------- NAVBAR -----------*/
.navbar {
  position: absolute;
  top: 0;
  z-index: 561;
  display: flex;
  justify-content: space-between;
  width: 100%;
  align-items: center;
  padding: 0 30px;
  z-index: 100;
  transition: transform 0.4s ease-in-out;
}

.navbar_logo.hide img {
  opacity: 0;
}

.navbar-logo {
  max-width: 200px;
  margin: 22px auto;
  transition: opacity 0.35s ease;
  opacity: 1;
}

.navbar-logo.hide {
  opacity: 0;
}

.blasonC {
  position: relative;
  display: inline-block;
  width: 90px;
}
.page-template-page-daccueil  .nav img    {
    max-width: 230px;
}
.blasonC .blason {
  display: block;
  backdrop-filter: blur(5px);
border-top: 1px solid rgb(51, 51, 51); 
  /* padding: 30px 0px; */
  transition: transform 0.4s;
}
.blasonC .croix {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-53%, -57%) rotate(0deg);
  height: auto;
transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1);
  pointer-events: none;
}
.burgermenu{
  background: #d6ff62;
  width: 50px;
  height: 50px;
  border-radius: 110px;
}
.elemntsNav{
  width:30%;
}
.BlsonSite{
  display: flex;
  justify-content: center;
}
.burgerM{
  display: flex;
  justify-content: flex-end;
}







/* --- Effet mobile --- */
@media (max-width: 767px) {
  .navbar.hide {
    transform: translateY(-100%);
  }
}

/* --- Animation fluide au chargement pour les écrans larges --- */
@media (min-width: 768px) {
  .navbar {
    transform: translateY(-20px);
    opacity: 0;
    animation: navbarSlideIn 0.8s ease-out forwards;
  }
}

@keyframes navbarSlideIn {
  0% {
    transform: translateY(-20px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

/* ---------- HEADER PAGE INT -----------*/

.headerPageAnex {
  height: 700px;
  margin: 20px;
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding: 50px;
  position: relative;
  overflow: hidden;
  text-align: center;
  background-image: url(/wp-content/uploads/2026/01/image-Cattenom1.jpg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.page-template-cattenom-en-image .headerPageAnex{
  background-image: url(/wp-content/uploads/2026/02/a8d41b7c1.webp) !important;
}

.page-template-patrimoine .headerPageAnex{
    background-image: url(/wp-content/uploads/2026/02/a8d41b7c4.webp) !important;
}

.page-template-ligne-maginot .headerPageAnex{
  background-image: url(/wp-content/uploads/2026/02/a8d41b7c3.webp) !important;
}

.page-template-centrale-nucleaire .headerPageAnex{
    background-image: url(/wp-content/uploads/2026/02/a8d41b7c2.webp) !important;
}




.badgeCattenom {
  position: absolute;
  top: -55px;
  background: #b2a79b;
  font-size: 15px;
  font-family: 'Inter';
  padding: 10px 20px;
  line-height: 17px;
  text-align: center;
  display: flex;
  border-radius: 90px;
  font-weight: 400;
  left: 50%;
  transform: translateX(-50%);
}










/* voile global */
.headerPageAnex::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.35); /* opacité globale */
  z-index: 1;
}
.headerPageAnex::after {
  content: "";
  position: absolute;
  inset: 0;

  background: linear-gradient(
    to top,
    rgba(0,0,0,0.75) 0%,
    rgba(0,0,0,0.55) 25%,
    rgba(0,0,0,0.25) 50%,
    rgba(0,0,0,0.10) 70%,
    rgba(0,0,0,0.00) 100%
  );

  z-index: 2;
}






.headerPageAnex h1 {
  margin-bottom: 20px;
  z-index: 99;
  color: white !important;
  font-weight: 300;
  font-size: 70px;
  line-height: 70px;
  position: relative;
}
.headerPageAnex p {
  margin-bottom: 50px;
  z-index: 99;
  color: white !important;
  max-width: 590px;
}
.contenueAvenir{
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 100px 0;
}
.contenueAvenir p{
  margin-bottom: 20px;
  font-size: 21px;
  text-align: center;
}

.LogoPageInt {
  position: absolute;
  top: 20px;
  left: 20px;
  height: 260px;
  z-index: 156;
}





/* ---------- PAGE D'ACCUEIL -----------*/


.video-header::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgb(0 0 0 / 25%) 0%, rgba(0, 0, 0, 0.1) 40%, rgb(0 0 0 / 0%) 50%, rgba(0, 0, 0, 0.3) 90%, rgba(0, 0, 0, 0.8) 120%);
    z-index: 2;
    pointer-events: none;
}

        /* Container du header vidéo */
        .video-header {
            position: relative;
            width: 100%;
            height: 100vh;
            overflow: hidden;
            background-color: #000;
        }

        /* La vidéo en arrière-plan */
        .video-header video {
            position: absolute;
            top: 50%;
            left: 50%;
            min-width: 100%;
            min-height: 100%;
            width: auto;
            height: auto;
            transform: translate(-50%, -50%);
            object-fit: cover;
            pointer-events: none; /* Empêche l'interaction directe avec la vidéo */
        }

        /* Overlay transparent pour empêcher le clic droit sur la vidéo */
        .video-overlay {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            z-index: 1;
            background: transparent;
        }

        /* Contenu par-dessus la vidéo */
.video-content {
    position: relative;
    z-index: 2;
    display: flex
;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
    color: white;
    text-align: center;
    padding: 20px;
    background: rgb(0 0 0 / 20%);
}


.video-content h1 {
    font-size: 40px;
    font-weight: 300;
    font-style: italic;
    letter-spacing: 1px;
}

        .video-content p {
            font-size: clamp(1rem, 2vw, 1.5rem);
            max-width: 800px;
            text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.7);
        }

        /* Bouton CTA */
        .cta-button {
            margin-top: 2rem;
            padding: 15px 40px;
            font-size: 1.1rem;
            color: white;
            background: rgba(255, 255, 255, 0.2);
            border: 2px solid white;
            border-radius: 50px;
            cursor: pointer;
            transition: all 0.3s ease;
            text-decoration: none;
            display: inline-block;
            backdrop-filter: blur(10px);
        }

        .cta-button:hover {
            background: white;
            color: #000;
            transform: scale(1.05);
        }

        /* Section de contenu après la vidéo */
        .content-section {
            padding: 60px 20px;
            max-width: 1200px;
            margin: 0 auto;
        }

        .content-section h2 {
            font-size: 2.5rem;
            margin-bottom: 1rem;
            color: #333;
        }

        .content-section p {
            font-size: 1.1rem;
            line-height: 1.6;
            color: #666;
        }

        /* Media queries pour mobile */
        @media (max-width: 768px) {
            .video-header {
                height: 100vh;
                height: 100dvh; /* Utilise dvh pour éviter les problèmes avec la barre d'adresse mobile */
            }
        }



/* ---------- PAGE HISTOIRE -----------*/


/* animation */

.page-template-Histoire .header-content {
  position: absolute;
  bottom: auto;
  left: auto;
  z-index: 5;
  text-align: center;
  margin: 0 auto;
}
.logoCattHistoire {
  position: absolute !important;
  top: 50px;
  left: 50px;
  max-width: 220px;
}

.header-main,
.header-subtitle,
.header-description {
  opacity: 0;
  transform: translateY(30px);
}

/* FIN - animation */

.page-id-2 {
    background-color: #060606 !important;
}
.page-id-2 p
{
  color: #d6d6d6;
}
/* Header Section */
.header-section {
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  /* background: linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.7)), url('http://cattenom.org/wp-content/uploads/2025/11/imageTest.png') center/cover; */
  background: url('/wp-content/uploads/2025/11/headerCattenom-min.jpg') center/cover;
  position: relative;
}

.header-section {
  position: relative;
  overflow: hidden;
}

/* --- Voile noir global --- */
.header-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  z-index: 1;
  pointer-events: none;
}
/* --- Dégradés haut et bas --- */
.header-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom,
      rgba(0, 0, 0, 0.8) 0%,
      rgba(0, 0, 0, 0.3) 20%,
      rgba(0, 0, 0, 0) 50%,
      rgba(0, 0, 0, 0.3) 80%,
      rgba(0, 0, 0, 0.8) 100%
    );
  z-index: 2;
  pointer-events: none;
}

/* --- Contenu au-dessus du tout --- */
.header-section * {
  position: relative;
  z-index: 3;
}
.header-logo {
  position: absolute;
  top: 40px;
  left: 40px;
}

.header-logo h1 {
  font-size: 28px;
  font-weight: 300;
  letter-spacing: 2px;
  margin: 0;
}

.header-logo span {
  font-size: 14px;
  vertical-align: super;
}

.header-icon {
  position: absolute;
  top: 40px;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 60px;
}

.header-icon svg {
  width: 100%;
  height: 100%;
  fill: #D6FF62;
}

.header-cta {
  position: absolute;
  top: 40px;
  right: 40px;
}

.cta-button {
  padding: 12px 30px;
  background: #D6FF62;
  color: #1a1a1a;
  text-decoration: none;
  border-radius: 5px;
  font-weight: 600;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: all 0.3s;
}

.cta-button:hover {
  background: #b8e000;
  transform: translateY(-2px);
}

.header-content {
  text-align: left;
  padding: 0 40px;
}


.header-title {
  font-size: 75px;
  font-style: italic;
  font-weight: 300 !important;
  margin-bottom: 0px;
  color: white !important;
  font-family: var(--font-display);
  transform: translate(0px, 9px);
}
.header-main {
    font-size: 150px;
    font-weight: 300;
    letter-spacing: 0px;
    margin: 0;
    line-height: 100px;
    color: #b2a79b;
    margin-bottom: 50px !important;
}
.header-subtitle {
  font-size: 27px;
  font-weight: 300;
  margin-top: 30px;
  margin-bottom: 20px;
  line-height: 35px;
  color: white !important;
}
.header-description {
  color: white !important;
  max-width: 800px;
  margin: 0 auto;
}


/* Animations de bas en haut */
@keyframes slideUpFade {
  from {
      opacity: 0;
      transform: translateY(50px);
  }
  to {
      opacity: 1;
      transform: translateY(0);
  }
}

@keyframes scaleInFade {
  from {
      opacity: 0;
      transform: scale(0.8);
  }
  to {
      opacity: 1;
      transform: scale(1);
  }
}

/* Slider Section */
.slider-section {
  position: relative;
  margin-bottom: 80px;
}

.swiper {
  width: 100%;
  height: 100vh;
}

.swiper-slide {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 40px;
  padding-bottom: 220px;
  text-align: center;
}

.slide-content {
  max-width: 900px;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0 auto;
}

/* État initial - TOUS les éléments cachés par défaut */
.main-date,
.date-label,
.period-title,
.description,
.navigation-buttons,
.historical-image {
  opacity: 0;
}

/* Éléments animés sur le slide avec la classe slide-animated */
.swiper-slide.slide-animated .main-date,
.swiper-slide.slide-animated .date-label,
.swiper-slide.slide-animated .period-title,
.swiper-slide.slide-animated .description,
.swiper-slide.slide-animated .navigation-buttons,
.swiper-slide.slide-animated .historical-image {
  animation-fill-mode: forwards;
}

/* Animation du main-date */
.swiper-slide.slide-animated .main-date {
  animation: slideUpFade 0.8s ease-out 0.1s forwards;
}

/* Animation du date-label */
.swiper-slide.slide-animated .date-label {
  animation: slideUpFade 0.8s ease-out 0.3s forwards;
}

/* Animation du period-title */
.swiper-slide.slide-animated .period-title {
  animation: slideUpFade 0.8s ease-out 0.5s forwards;
}

/* Animation des descriptions */
.swiper-slide.slide-animated .description:nth-of-type(1) {
  animation: slideUpFade 0.8s ease-out 0.7s forwards;
}

.swiper-slide.slide-animated .description:nth-of-type(2) {
  animation: slideUpFade 0.8s ease-out 0.9s forwards;
}

.swiper-slide.slide-animated .description:nth-of-type(3) {
  animation: slideUpFade 0.8s ease-out 1.1s forwards;
}

/* Animation des boutons de navigation */
.swiper-slide.slide-animated .navigation-buttons {
  animation: slideUpFade 0.8s ease-out 1.3s forwards;
}

/* Animation de l'image - apparaît en dernier */
.swiper-slide.slide-animated .historical-image {
  animation: scaleInFade 0.8s ease-out 1.5s forwards;
}



/* Espace de fin pour laisser voir le dernier losange */
#timelineWrapper{
  display: flex;
  gap: 60px;            /* ton gap actuel */
  will-change: transform;
  touch-action: pan-x;
}
#timelineWrapper::after{
  content:"";
  flex: 0 0 min(25vw, 140px); /* espace proportionnel à l’écran */
}
@media (max-width: 768px){
  #timelineWrapper{ gap: 30px; }
  #timelineWrapper::after{ flex-basis: min(35vw, 180px); }
}



/* Classe à ajouter sur les éléments de menu qui doivent avoir une image */
.menu-item.has-image {
    position: relative;
  }
  
  .menu-item.has-image > a::after {
    content: '(Prochainement)';
    display: inline-block;
    margin-left: 10px;
    color: #e2c5a7;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    vertical-align: middle;
    font-size: 14px;
    font-family: 'Inter';
}

.slider-section {
    margin-bottom: 0;
}

.date-container {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 40px;
  gap: 20px;
}

.historical-image {
  width: 120px;
  height: 80px;
  object-fit: cover;
  border: 3px solid #fff;
  box-shadow: 0 4px 15px rgba(0,0,0,0.5);
}

/* .main-date {
  font-size: 250px;
  font-weight: bolder;
  color: #D6FF62;
  position: relative;
} */
.main-date {
  font-size: 250px;
  font-weight: 300;
  color: #b2a79b;
  position: relative;
  /*background: linear-gradient(to bottom, #D6FF62 0%, #d6ff62 68%, #2f3912 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;*/
}
/* Image avant */
.main-date::before {
  content: "";
  position: absolute;
  top: -40px;
  left: -180px;
  width: 250px;
  height: 158px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  pointer-events: none;
  z-index: 2;
  transform: rotate(354deg);
}

/* Image après */
.main-date::after {
  content: "";
  position: absolute;
  bottom: 7px;
  right: -217px;
  width: 250px;
  height: 158px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  pointer-events: none;
  z-index: -1;
  transform: rotate(8deg);
}


.antiquite .main-date::after{
    background-image: url();

}
.antiquite .main-date::before{
    background-image: url(/wp-content/uploads/2025/11/images-timeline-11.png);
    border: 5px solid white;
}
.moyenage .main-date::after{
    background-image: url(/wp-content/uploads/2025/11/images-timeline-9-min.png);
      border: 5px solid white;
}
.moyenage .main-date::before{
    background-image: url();
}
.traitepyrenees .main-date::after{
    background-image: url(/wp-content/uploads/2025/11/images-timeline-8-min.png);
      border: 5px solid white;
}
.traitepyrenees .main-date::before{
    background-image: url();
}
.guerrefranco .main-date::after{
    background-image: url(/wp-content/uploads/2025/11/images-timeline-4-min.png);
      border: 5px solid white;
}
.guerrefranco .main-date::before{
    background-image: url(/wp-content/uploads/2025/11/images-timeline-10-min.png);
      border: 5px solid white;
}
.premiereguerre .main-date::after{
    background-image: url(/wp-content/uploads/2025/11/images-timeline-6-min.png);
      border: 5px solid white;
}
.premiereguerre .main-date::before{
    background-image: url(/wp-content/uploads/2025/11/images-timeline-5-min.png);
      border: 5px solid white;
}
.entreguerre .main-date::after{
    background-image: url(/wp-content/uploads/2025/11/images-timeline-1-min.png);
      border: 5px solid white;
}
.entreguerre .main-date::before{
    background-image: url();
}
.secondguerre .main-date::after{
    background-image: url();
}
.secondguerre .main-date::before{
    background-image: url();
}
.cattenomnormandie .main-date::after{
    background-image: url(/wp-content/uploads/2025/11/images-timeline-3-min.png);
      border: 5px solid white;
}
.cattenomnormandie .main-date::before{
    background-image: url(/wp-content/uploads/2025/11/images-timeline-2-min.png);
      border: 5px solid white;
}
.centrale .main-date::after{
    background-image: url(/wp-content/uploads/2025/11/images-timeline-7-min.png);
      border: 5px solid white;
}
.centrale .main-date::before{
    background-image: url();
}
.cattenom .main-date::after{
    background-image: url(/wp-content/uploads/2025/11/images-timeline-12-min.png);
      border: 5px solid white;
}
.cattenom .main-date::before{
    background-image: url(/wp-content/uploads/2026/02/165gree165rg.jpg);
      border: 5px solid white;
}








.moyenage .main-date{
    font-size: 220px !important;
}




.swiper-slide {
  padding-top: 70px;
}
.date-suffix {
  font-size: 60px;
  vertical-align: super;
}

.date-label {
  font-size: 24px;
  color: #888;
  letter-spacing: 2px;
}
.period-title {
  color: white;
  font-size: 30px;
  margin-bottom: 20px;
  font-weight: 100;
  letter-spacing: 1px;
  line-height: 39px;
}
.description {
  font-size: 16px;
  line-height: 26px;
  color: #c9c9c9;
  margin-bottom: 20px;
  font-weight: 300;
}
.navigation-buttons {
  display: flex;
  gap: 20px;
  margin-top: 40px;
}
.prev-btn img {
  transform: translate(-8px, -1px);
}
.next-btn img{
  transform: translate(8px, -2px);
}
.nav-btn {
  font-family: 'inter';
  padding: 9px 40px;
  background: #c7b9aa;
  color: #1a1a1a;
  border: none;
  border-radius: 10px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s;
  text-transform: uppercase;
  letter-spacing: 0px;
  border-radius: 91px;
}

.nav-btn:hover {
  background: #b29883;
  transform: translateY(-2px);
}

.nav-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ================================
   Section Overview - Version Mobile
   ================================ */

/* Version mobile (cachée par défaut sur desktop) */
.section-overview-mobile {
    display: none;
    padding: 60px 20px;
    text-align: center;
    background-color: #f5f0e8;
}



.section-overview-mobile .overview-mobile-title em {
    font-style: italic;
}

.section-overview-mobile .overview-mobile-text {
    font-size: 1rem;
    line-height: 1.7;
    color: #5a5149;
    margin-bottom: 30px;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}
.sectMobileCoup p {
    max-width: 410px;
    margin: 25px 0;
}
.sectMobileCoup{
    display: flex;
    flex-direction: column;
    align-items: center;
}
.sectMobileCoup h2 {
    font-size: 40px !important;
    max-width: 420px;
}
/* ================================
   Media Query - 768px et moins
   ================================ */
@media screen and (max-width: 768px) {
    /* Cacher la version desktop */
    .section-overview {
        display: none !important;
    }
    
    /* Afficher la version mobile */
    .section-overview-mobile {
        display: block;
    }
    .headerPageAnex h1 {
      margin-bottom: 10px;
      font-size: 50px;
      line-height: 50px;
  }
  .headerPageAnex p {
    margin-bottom: 20px;
}
.headerPageAnex {
  height:500px;
  padding: 20px;
}
.LogoPageInt {
  height: 120px;
}
}

/* Timeline Navigation */
.timeline-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.9);
  border-top: 1px solid #333;
  padding: 30px 0;
  z-index: 100;
  transform: translateY(100%);
  transition: transform 0.4s ease;
  background: rgba(0, 0, 0, 0.6); /* légère transparence */
  backdrop-filter: blur(10px);     /* flou principal */
  -webkit-backdrop-filter: blur(10px); /* compatibilité Safari */
}

.timeline-nav.visible {
  transform: translateY(0);
}

.timeline-container {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 60px;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 40px;
  overflow: visible !important;
  position: relative;
}

.timeline-wrapper {
  display: flex;
  gap: 60px;
  transition: transform 0.6s ease;
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
}

.timeline-wrapper.dragging {
  transition: none;
  cursor: grabbing;
}

.timeline-wrapper.dragging .timeline-item {
  pointer-events: none;
}

.timeline-container * {
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
}

.timeline-container {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 60px;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 40px;
  overflow: hidden;
  position: relative;
  cursor: grab;
}

.timeline-container.grabbing {
  cursor: grabbing;
}

.timeline-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  cursor: pointer;
  transition: all 0.3s;
  position: relative;
  flex-shrink: 0;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
}

.timeline-date {
  font-size: 60px;
  font-weight: 300;
  margin-bottom: 10px;
  color: #5a5146;
  transition: all 0.3s;
}

.timeline-label {
  font-size: 17px;
  color: #ffffff80;
  white-space: nowrap;
  transition: all 0.3s;
}
.timeline-indicator {
    width: 15px;
    height: 15px;
    background: transparent;
    border: 2px solid transparent;
    transform: rotate(45deg);
    margin-top: 15px;
    transition: all 0.3s;
    position: absolute;
    top: -56px;
}

/* L’indicateur caché par défaut */
.timeline-indicator {
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: none;
}

/* Quand la barre a la classe .visible → indicateur visible */
.timeline-nav.visible .timeline-indicator {
  opacity: 1;
}

.timeline-item.active .timeline-date {
  color: #FFECD6;
  font-size: 60px;
}
.timeline-item.active .timeline-label {
  color: #fff;
}

.timeline-item.active .timeline-indicator {
  background: #FFECD6;
  border-color: #FFECD6;
}

.timeline-item:not(.active):hover .timeline-date {
  color: #999;
}

@media (max-width: 1250px) {
  .timeline-container {
      gap: 50px;
  }
  
  .timeline-wrapper {
      gap: 50px;
  }
}

@media (max-width: 1024px) {
  .timeline-container {
      gap: 40px;
  }
  
  .timeline-wrapper {
      gap: 40px;
  }
}

@media screen and (max-width:1024px) {
  .main-date {
    font-size: 150px;
}
.timeline-date {
  font-size: 30px;
}
.timeline-item.active .timeline-date {
  font-size: 30px;
}
.timeline-label {
  font-size: 15px;
}
.moyenage .main-date {
  font-size: 100px !important;
}
.main-date::before {
  top: -40px;
  left: -187px;
  width: 200px;
  height: 125px;
}
.main-date::after {
  bottom: 0px;
  right: -197px;
  width: 200px;
  height: 125px;
}
}

@media (max-width: 768px) {
  .header-logo {
      top: 20px;
      left: 20px;
  }
  .logoCattHistoire{
    display: none;
  }
  .blasonC {
    position: relative;
    display: inline-block;
    transform: scale(.7);
}
.section-projet{
    display:none !important;
}
.header {
    height: 720px !important;
    min-height: 360px !important;
}
.scroll-arrow{
    display:none;
}
.page-template-page-daccueil .nav img {
    max-width: 120px;
}
  .header-logo h1 {
      font-size: 20px;
  }
  
  .header-icon {
      top: 20px;
      width: 40px;
      height: 40px;
  }
  
  .header-cta {
      top: 20px;
      right: 20px;
  }
  
  .cta-button {
      padding: 10px 20px;
      font-size: 12px;
  }
  
  .header-main {
      font-size: 60px;
  }
  
  .header-title {
      font-size: 18px;
  }
  
  .header-subtitle {
      font-size: 18px;
  }
  
  .header-description {
      font-size: 14px;
  }
  
  .main-date {
      font-size: 80px;
  }
  
  .timeline-container {
      gap: 30px;
      padding: 0 20px;
  }
  
  .timeline-wrapper {
      gap: 30px;
  }
  
  .timeline-date {
      font-size: 32px;
  }
  
  .timeline-item.active .timeline-date {
      font-size: 38px;
  }
  .main-date::before {
    top: -40px;
    left: -128px;
    width: 130px;
    height: 81px;
}
.main-date::after {
  bottom: 0px;
  right: -197px;
  width: 130px;
  height: 81px;
}
.main-date::after {
  bottom: 0px;
  right: -129px;
  width: 130px;
  height: 81px;
}
.period-title {
  color: white;
  font-size: 25px;
  margin-bottom: 10px;
  font-weight: 300;
  letter-spacing: 0px;
  line-height: 34px;
  font-weight: 500;
}

.description {
  font-size: 14px;
  line-height: 23px;
  margin-bottom: 13px;
  font-weight: 300;
}
.moyenage .main-date {
  font-size: 60px !important;
}

.header-section {
  height: auto;
  padding: 240px 0 240px 0;
}
.navbar-logo {
  max-width: 140px;

}
.header-main {
  font-size: 80px !important;
  line-height: 53px;
}
.header-subtitle {
  font-size: 21px;
  font-weight: 500 !important;
  margin-top: 20px;
  margin-bottom: 10px;
  line-height: 28px;
}
.header-title {
  font-size: 35px;
  margin-bottom: 11px;
  font-weight: 300 !important;
}
}


@media screen and (max-width:500px) {

  .main-date::before {
    top: -60px;
    left: -118px;
    width: 130px;
    height: 81px;
}

.main-date::after {
  bottom: -20px;
  right: -122px;
  width: 130px;
  height: 81px;
}
.swiper-slide {
  padding-top: 70px !important;
  padding: 30px;
}
.nav-btn {
  width: 50%;
  padding: 10px;
  font-size: 14px;
}
.navigation-buttons {
  margin-top: 30px;
  width: 100%;
}

    .moyenage .main-date::after {
        bottom: 28px;
        right: -52px;
    }

 .slides04 .period-title{
  max-width: 260px !important;
}
 .slides05 .period-title{
  max-width: 290px !important;
}
 .slides07 .period-title{
  max-width: 290px !important;
}
 .slides08 .period-title{
  max-width: 290px !important;
}
}

@media screen and (max-width:450px) {
  .page-template-Histoire .header-content {
    position: relative;

    margin: inherit;
}
.page-template-Histoire .header-section {
  height: auto;
  padding: 90px 0px;
}
}


/* ----NEW CODE POUR PAGE -- */





/* Header Container */
.header {
    position: relative;
    width: 100%;
    height: 100vh;
    min-height: 700px;
    overflow: hidden;
    padding: 20px;
    background: var(--color-cream);
}

/* Conteneur intérieur avec la vidéo */
.header-inner {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: 20px;
}

/* Video Background */
.video-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}

.video-background video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Fallback image si pas de vidéo */
.video-background::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(
        135deg,
        rgba(74, 55, 40, 0.4) 0%,
        rgba(74, 55, 40, 0.2) 50%,
        rgba(74, 55, 40, 0.3) 100%
    );
    z-index: 1;
}

/* Overlay gradient pour lisibilité du texte */
.header-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0.1) 0%,
        rgba(0, 0, 0, 0.15) 50%,
        rgba(0, 0, 0, 0.3) 100%
    );
    z-index: 1;
}

/* Lignes décoratives verticales */
.decorative-lines {
    position: absolute;
    top: 0;
    right: 40px;
    height: 100%;
    display: flex;
    gap: 8px;
    z-index: 2;
    pointer-events: none;
}

.decorative-line {
    width: 1px;
    height: 100%;
    background: linear-gradient(
        to bottom,
        transparent 0%,
        rgba(196, 164, 132, 0.4) 20%,
        rgba(196, 164, 132, 0.6) 50%,
        rgba(196, 164, 132, 0.4) 80%,
        transparent 100%
    );
}

/* Navigation */
.nav {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    padding: 30px 40px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    z-index: 10;
}

/* Logo */
.logo {
    width: 140px;
    height: 140px;
    animation: fadeInDown 1s ease-out;
}

.logo svg {
    width: 100%;
    height: 100%;
}

/* Menu Button - Fixed */
.menu-btn {
  position: fixed;
  top: 50px;
  right: 70px;
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--color-cream);
  border: none;
  padding: 12px 20px;
  cursor: pointer;
  transition: all 0.3s ease;
  z-index: 900;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  border-radius: 99px;
}

.menu-btn:hover {
    background: var(--color-white);
    transform: translateY(-2px);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.menu-text {
    font-family: var(--font-body);
    font-size: 0.85rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    color: var(--color-brown);
    text-transform: uppercase;
}

.menu-icon {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 4px;
}

.menu-icon span {
    display: block;
    width: 18px;
    height: 2px;
    background: var(--color-brown);
    transition: all 0.3s ease;
}

.menu-btn:hover .menu-icon span:nth-child(1) {
    transform: translateX(3px);
}

.menu-btn:hover .menu-icon span:nth-child(3) {
    transform: translateX(-3px);
}

/* Main Content */
.header-content {
    position: absolute;
    bottom: 15%;
    left: 40px;
    z-index: 5;
}

/* Main Title */
.main-title {
    font-family: var(--font-display);
    font-size: clamp(3rem, 6vw, 5rem);
    font-weight: 300;
    line-height: 1.1;
    color: var(--color-white);
    margin-bottom: 30px;
    text-shadow: 0 2px 30px rgba(0, 0, 0, 0.3);
    animation: fadeInUp 1.2s ease-out 0.4s both;
}

.main-title em {
    font-style: italic;
}

/* Subtitle */
.subtitle {
    font-family: var(--font-body);
    font-size: 1.1rem;
    font-weight: 500;
    line-height: 1.6;
    color: var(--color-white);
    margin-bottom: 20px;
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.3);
    animation: fadeInUp 1.2s ease-out 0.6s both;
}

/* Description */
.description {
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 300;
    line-height: 1.8;
    color: rgba(255, 255, 255, 0.9);
    max-width: 600px;
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.3);
    animation: fadeInUp 1.2s ease-out 0.8s both;
}

/* Scroll Indicator */
.scroll-indicator {
    position: absolute;
    bottom: 40px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    z-index: 5;
    animation: fadeIn 1s ease-out 1.2s both;
}

.scroll-indicator span {
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.7);
}

.scroll-arrow {
    width: 24px;
    height: 40px;
    border: 2px solid rgba(255, 255, 255, 0.5);
    border-radius: 12px;
    position: relative;
}

.scroll-arrow::after {
    content: '';
    position: absolute;
    top: 8px;
    left: 50%;
    transform: translateX(-50%);
    width: 4px;
    height: 8px;
    background: rgba(255, 255, 255, 0.7);
    border-radius: 2px;
    animation: scrollBounce 2s ease-in-out infinite;
}

/* Animations */
@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(40px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes scrollBounce {
    0%, 100% {
        transform: translateX(-50%) translateY(0);
        opacity: 1;
    }
    50% {
        transform: translateX(-50%) translateY(12px);
        opacity: 0.3;
    }
}

/* Responsive */
@media (max-width: 1024px) {
    .header {
        padding: 15px;
    }

    .nav {
        padding: 25px 30px;
    }

    .logo {
        width: 110px;
        height: 110px;
    }

    .header-content {
        left: 30px;
        right: 30px;
        max-width: none;
    }

    .decorative-lines {
        right: 30px;
    }

    .menu-btn {
        right: 45px;
    }
}

@media (max-width: 768px) {
    .header {
        padding: 10px;
    }

    .nav {
        padding: 20px;
    }

    .logo {
        width: 90px;
        height: 90px;
    }

    .menu-btn {
        top: 20px;
        right: 30px;
        padding: 10px 16px;
    }

    .menu-text {
        font-size: 0.75rem;
    }

    .header-content {
        position: relative;
        bottom: 40px; !important;
        left: 0px !important;
        z-index: 5;
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        height: 100%;
    }
    .main-title {
        font-size: clamp(2.2rem, 8vw, 3.5rem);
    }

    .subtitle {
        font-size: 1rem;
    }

    .description {
        font-size: 0.9rem;
    }

    .decorative-lines {
        display: none;
    }
}

@media (max-width: 480px) {
    .header {
        padding: 8px;
        min-height: 600px;
    }
    .footer-nav a {
        font-size: 26px !important;
    }
    .marquee-text {
        font-family: var(--font-display);
        font-size: 69px !important;
    }
    .marquee-container {
        height: 90px !important;
    }
    .footer-cta-title {
        font-size: 33px !important;
        font-weight: 300 !important;
        line-height: 38px !important;
    }
    .marquee-track img {
        max-width: 73px !important;
        margin: 1px !important;
        transform: translate(2px, -4px) !important;
    }
    .logo {
        width: 75px;
        height: 75px;
    }
    .footer-cta {
        display: flex !important;
        align-items: center!important;
    }
    .menu-btn {
        top: 18px;
        right: 20px;
    }
    .footer-cta-description {
        margin-top: 40px !important;
    }
    .header-content {
        bottom: 40px;
    }
    .header-content {
        text-align: left;
        padding: 0 20px !important;
    }
    .scroll-indicator {
        display: none;
    }
    .header {
        height: 600px !important;
        min-height: 360px !important;
    }
    .marquee-section {
        padding: 0px !important;
        padding-top: 40px !important;
    }
    .headerPageAnex{
      padding:20px;
    }
    .footer {
        background-color: var(--brown-dark) important;
        color: var(--text-light) important;
        padding: 0 15px 30px 15px important;
        position: relative important;
    }
    
}



/* ================================
CONTACT
   ================================ */

/* ── Variables ─────────────────────────────── */

div.wpforms-container-full .wpforms-field-label, .wp-core-ui div.wpforms-container-full .wpforms-field-label {
  color: white !important;
  font-weight: 300 !important;
  font-family: 'Inter' !important;
}
div.wpforms-container-full button[type=submit]:not(:hover):not(:active){
  background-color: #b2a79b !important;
}

div.wpforms-container-full input[type=submit]:hover, div.wpforms-container-full input[type=submit]:active, div.wpforms-container-full button[type=submit]:hover, div.wpforms-container-full button[type=submit]:active, div.wpforms-container-full .wpforms-page-button:hover, div.wpforms-container-full .wpforms-page-button:active, .wp-core-ui div.wpforms-container-full input[type=submit]:hover, .wp-core-ui div.wpforms-container-full input[type=submit]:active, .wp-core-ui div.wpforms-container-full button[type=submit]:hover, .wp-core-ui div.wpforms-container-full button[type=submit]:active, .wp-core-ui div.wpforms-container-full .wpforms-page-button:hover, .wp-core-ui div.wpforms-container-full .wpforms-page-button:active {
  background-color: #b2a79b !important;
}
.page-template-Contact .logoCattHistoire {
  position: absolute !important;
  top: 50px;
  left: 50px;
  max-width: 140px;
  z-index: 145;
}

  /* ── Section wrapper ───────────────────────── */
  .ibs-contact-section {
    position: relative;
    overflow: hidden;
    padding: 100px 0;
    min-height: 100vh;
    color: #ffffff;
}
  
  /* ── Background ────────────────────────────── */
  .ibs-contact-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
  }
  
  /*  Image – remplacer l'URL par votre propre image  */
  .ibs-contact-bg__image {
    position: absolute;
    inset: 0;
    background:
      url('/wp-content/uploads/contact-bg.jpg') center / cover no-repeat;
    filter: brightness(.35) saturate(.7);
  }
  
  /* Overlay dégradé sombre */
  .ibs-contact-bg__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 5.45);
}
  
  /* Grille subtile style biotech */
  .ibs-contact-bg__grid {
    position: absolute;
    inset: 0;
    opacity: .2;
    background-image: url(/wp-content/uploads/2026/01/image-Cattenom1.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center -30px;
}
  
  /* ── Container ─────────────────────────────── */
  .ibs-contact-container {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 80px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 40px;
    align-items: start;
    margin-top: 230px;
}
  /* ── Colonne gauche — Infos ────────────────── */
  .ibs-contact-title {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 500;
    color: #f5f0e8;
    margin: 0 0 20px;
    letter-spacing: -.02em;
    line-height: 1.15;
  }
  
  .ibs-contact-desc {
    font-size: 15px;
    line-height: 1.7;
    color:#f5f0e8;
    margin: 0 0 48px;
    max-width: 340px;
  }
  
  .ibs-contact-block {
    margin-bottom: 32px;
  }
  
  .ibs-contact-label {
    display: block;
    font-size: 26px;
    font-weight: 300;
    letter-spacing: 0;
    color: #f5f0e8;
    margin-bottom: 8px;
    font-family: var(--font-display);
}
  
.ibs-contact-link {
  font-size: 17px;
  font-weight: 300;
  color: #f5f0e8;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color .3s, color .3s;
  font-family: 'Inter';
}
  .ibs-contact-link:hover {
    color: #f5f0e8;
    border-bottom-color: #f5f0e8;
  }
  
  /* ── Colonne droite — Formulaire ───────────── */
  .ibs-contact-form {
    padding-top: 8px;
  }
  
  /* ── Override WPForms pour matcher le design ── */
  
  /* Labels */
  .ibs-contact-form .wpforms-field-label {
    font-family: 'inter';
    font-size: 12px !important;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: uppercase !important;
    color: #f5f0e8;

}

input, textarea, select {
  margin-top: 17px;
}

.ibs-contact-form .wpforms-field-sublabel {
  display: none;
}
  /* Sous-labels (Prénom / Nom) */
  .ibs-contact-form .wpforms-field-sublabel {
    font-family: var(--font-display);
    font-size: 10px !important;
    font-weight: 600 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase !important;
    color: #f5f0e8;
    margin-bottom: 6px !important;
  }
  
  /* Champs texte & email */
  .ibs-contact-form .wpforms-field input[type="text"],
  .ibs-contact-form .wpforms-field input[type="email"],
  .ibs-contact-form .wpforms-field input[type="tel"],
  .ibs-contact-form .wpforms-field input[type="url"],
  .ibs-contact-form .wpforms-field input[type="number"],
  .ibs-contact-form .wpforms-field textarea,
  .ibs-contact-form .wpforms-field select {
    background: #f5f0e830;
    border: 1px solid #f5f0e88c;
    border-radius: var(--ibs-radius) !important;
    color: #f5f0e8;
    font-family: 'inter', sans-serif !important;
    font-size: 14px !important;
    padding: 14px 16px !important;
    transition: border-color .3s, box-shadow .3s !important;
    width: 100% !important;
    box-sizing: border-box !important;
    outline: none !important;
  }
  
  .wpforms-field {
    margin-bottom: 20px;
  }
  
  .ibs-contact-form .wpforms-field input:focus,
  .ibs-contact-form .wpforms-field textarea:focus,
  .ibs-contact-form .wpforms-field select:focus {
    border-color: var(--ibs-accent) !important;
    box-shadow: 0 0 0 3px var(--ibs-accent-soft) !important;
  }
  
  /* Placeholder */
  .ibs-contact-form .wpforms-field input::placeholder,
  .ibs-contact-form .wpforms-field textarea::placeholder {
    color: rgba(160, 185, 210, .4) !important;
  }
  
  /* Textarea */
  .ibs-contact-form .wpforms-field textarea {
    min-height: 130px !important;
    resize: vertical !important;
  }
  
  /* Select / dropdown */
  .ibs-contact-form .wpforms-field select {
    appearance: none !important;
    -webkit-appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1.5l5 5 5-5' stroke='%237a9ab5' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 16px center !important;
    padding-right: 44px !important;
  }
  
  /* Lignes de champs côte à côte */
  .ibs-contact-form .wpforms-field-row {
    display: flex !important;
    gap: 20px !important;
  }
  
  .ibs-contact-form .wpforms-field-row .wpforms-field-row-block {
    flex: 1 !important;
  }
  
  /* Bouton submit */
  .ibs-contact-form .wpforms-submit-container {
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 12px !important;
    margin-top: 12px !important;
  }

  .ibs-contact-form .wpforms-submit-container button, .ibs-contact-form .wpforms-submit-container .wpforms-submit {
    font-family: 'inter';
    font-size: 15px !important;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: uppercase !important;
    color: var(--ibs-white) !important;
    background: #B2A79B;
    border: 1px solid var(--ibs-border) !important;
    border-radius: 50px !important;
    padding: 14px 32px !important;
    cursor: pointer !important;
    transition: all .35s ease !important;
    position: relative !important;
    overflow: hidden !important;
}
  

  
  /* Icône flèche à côté du bouton (optionnelle) */
  .ibs-contact-form .wpforms-submit-container::after {
    content: '→';
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: #B2A79B !important;
    color: var(--ibs-dark);
    font-size: 18px;
    font-weight: 700;
    flex-shrink: 0;
    transition: transform .3s, box-shadow .3s;
  }
  
  .ibs-contact-form .wpforms-submit-container:hover::after {
    transform: translateX(4px);
  }
  
  /* Messages d'erreur */
  .ibs-contact-form .wpforms-error-container,
  .ibs-contact-form label.wpforms-error {
    color: #f87171 !important;
    font-size: 12px !important;
    font-family: 'DM Sans', sans-serif !important;
  }
  
  /* Message de confirmation */
  .ibs-contact-form .wpforms-confirmation-container-full {
    background: var(--ibs-accent-soft) !important;
    border: 1px solid rgba(184, 230, 72, .3) !important;
    border-radius: var(--ibs-radius) !important;
    color: var(--ibs-white) !important;
    padding: 24px !important;
  }
  
  /* Champs requis — astérisque */
  .ibs-contact-form .wpforms-required-label {
    color: var(--ibs-accent) !important;
    font-weight: 400 !important;
  }
  
  /* ── Responsive ────────────────────────────── */
  @media (max-width: 900px) {
    .ibs-contact-container {
      grid-template-columns: 1fr;
      gap: 48px;
      padding: 0 24px;
    }
  
    .ibs-contact-section {
      padding: 64px 0;
    }
  
    .ibs-contact-desc {
      max-width: 100%;
    }
  }
  
  @media (max-width: 600px) {
    .ibs-contact-section {
      padding: 48px 0;
    }
  
    .ibs-contact-container {
      padding: 0 18px;
      gap: 36px;
    }
  
    .ibs-contact-form .wpforms-field-row {
      flex-direction: column !important;
      gap: 0 !important;
    }
  }










/* ================================
   Menu Fullscreen
   ================================ */
.menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1000;
    pointer-events: none;
    overflow: hidden;
}

.menu-overlay.active {
    pointer-events: all;
}

/* Background qui slide */
.menu-background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #5c5349;
  transform: translateY(100%);
  transition: transform 0.6s cubic-bezier(0.76, 0, 0.24, 1);
}

.menu-overlay.active .menu-background {
    transform: translateY(0);
}

.menu-overlay.closing .menu-background {
    transform: translateY(100%);
    transition-delay: 0.3s;
}

/* Contenu du menu */
/* .page-template-page-daccueil .menu-content {
  opacity: 0;
}
.page-template-Histoire .menu-content {
  opacity: 0;
}
 */



.menu-content {
    position: relative;
    width: 100%;
    height: 100%;
    padding: 40px 60px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto 1fr auto;
    gap: 20px;
    opacity: 0;
    transition: opacity 0.3s ease;
    transition-delay: 0s;
}

.menu-overlay.active .menu-content {
    opacity: 1;
    transition-delay: 0.4s;
}

.menu-overlay.closing .menu-content {
    opacity: 0;
    transition-delay: 0s;
}

/* Header du menu */
.menu-header {
    grid-column: 1 / -1;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
.menu-header img {
  max-width: 150px;
}

.menu-logo {
    width: 100px;
    height: 100px;
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.5s ease;
    transition-delay: 0s;
}

.menu-overlay.active .menu-logo {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.5s;
}

.menu-overlay.closing .menu-logo {
    opacity: 0;
    transform: translateY(30px);
    transition-delay: 0s;
}

.menu-logo svg {
    width: 100%;
    height: 100%;
}

/* Bouton fermer */
.menu-close {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: #F5F0EB;
  border: none;
  cursor: pointer;
  position: relative;
  transition: all 0.3s ease;
  opacity: 0;
  transform: translateY(30px);
}
.menu-overlay.active .menu-close {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.5s;
}

.menu-overlay.closing .menu-close {
    opacity: 0;
    transform: translateY(30px);
    transition-delay: 0s;
}

.menu-close:hover {
    background: #e0b565;
    transform: scale(1.05);
}

.menu-overlay.active .menu-close:hover {
    transform: scale(1.05);
}

.menu-close span {
    position: absolute;
    width: 20px;
    height: 2px;
    background: #1e2a4a;
    top: 50%;
    left: 50%;
}

.menu-close span:first-child {
    transform: translate(-50%, -50%) rotate(45deg);
}

.menu-close span:last-child {
    transform: translate(-50%, -50%) rotate(-45deg);
}

/* Navigation */
.menu-nav {
  grid-column: 1;
  grid-row: 2;
  display: flex;
  align-items: flex-start;
  margin-top: 60px;
}

.menu-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.menu-item {
    margin-bottom: 19px;
    opacity: 0;
    transform: translateY(40px);
    transition: all 0.5s ease;
}

.menu-overlay.active .menu-item {
    opacity: 1;
    transform: translateY(0);
}

.menu-overlay.active .menu-item:nth-child(1) { transition-delay: 0.55s; }
.menu-overlay.active .menu-item:nth-child(2) { transition-delay: 0.6s; }
.menu-overlay.active .menu-item:nth-child(3) { transition-delay: 0.65s; }
.menu-overlay.active .menu-item:nth-child(4) { transition-delay: 0.7s; }
.menu-overlay.active .menu-item:nth-child(5) { transition-delay: 0.75s; }
.menu-overlay.active .menu-item:nth-child(6) { transition-delay: 0.8s; }
.menu-overlay.active .menu-item:nth-child(7) { transition-delay: 0.85s; }

.menu-overlay.closing .menu-item {
    opacity: 0;
    transform: translateY(40px);
    transition-delay: 0s;
}

.menu-dot {
  color: #B2A79B;
  margin-right: 15px;
  font-size: 47px;
}
.menu-item a {
    font-family: var(--font-display);
    font-size: 45px;
    
    font-weight: 300 !important;
    color: #f5f0e8;
    text-decoration: none;
    transition: all 0.3s ease;
    display: inline-block;
}

.menu-item a:hover {
  color: #bbb2a9;
  transform: translateX(10px);
}

/* Footer du menu */
.menu-footer {
    grid-column: 1;
    grid-row: 3;
    display: flex;
    align-items: flex-end;
    gap: 30px;
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.5s ease;
}

.menu-overlay.active .menu-footer {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.9s;
}

.menu-overlay.closing .menu-footer {
    opacity: 0;
    transform: translateY(30px);
    transition-delay: 0s;
}

.social-link {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(245, 240, 232, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #f5f0e8;
    transition: all 0.3s ease;
}

.social-link:hover {
    background: #d4a855;
    color: #1e2a4a;
}

.menu-legal {
    display: flex;
    align-items: center;
    gap: 25px;
}

.menu-legal a {
    font-family: var(--font-body);
    font-size: 0.8rem;
    color: #f5f0e8;
    text-decoration: none;
    transition: color 0.3s ease;
}

.menu-legal a:hover {
    color: #d4a855;
}

.menu-legal a span {
    font-size: 0.7rem;
    margin-left: 3px;
}

.copyright {
    font-family: var(--font-body);
    font-size: 0.8rem;
    color: rgba(245, 240, 232, 0.5);
}

/* Image décorative */
.menu-image {
    grid-column: 2;
    grid-row: 2 / 4;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    opacity: 0;
    transform: translateY(50px);
    transition: all 0.6s ease;
}

.menu-overlay.active .menu-image {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.7s;
}

.menu-overlay.closing .menu-image {
    opacity: 0;
    transform: translateY(50px);
    transition-delay: 0s;
}

.menu-image-wrapper {
    position: relative;
    width: 450px;
    height: 350px;
    border-radius: 15px;
    overflow: hidden;
}

.menu-image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.menu-image-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 20px;
    background: linear-gradient(to top, rgba(0,0,0,0.6), transparent);
}

.menu-image-text {
    font-family: var(--font-display);
    font-size: 1.5rem;
    color: #f5f0e8;
    white-space: nowrap;
    animation: marquee 10s linear infinite;
}

.menu-image-text em {
    font-style: italic;
    color: #d2b79c;
}

@keyframes marquee {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

.menu-image-btn {
    position: absolute;
    top: 20px;
    right: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    background: #f5f0e8;
    padding: 15px;
    border-radius: 50px;
    text-decoration: none;
    transition: all 0.3s ease;
}

.menu-image-btn span:first-child {
    font-size: 1.2rem;
    color: #1e2a4a;
}

.menu-image-btn span:last-child {
    font-family: var(--font-body);
    font-size: 0.6rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    color: #1e2a4a;
    writing-mode: vertical-rl;
    text-orientation: mixed;
}

.menu-image-btn:hover {
    background: #d4a855;
}

/* Responsive Menu */
@media (max-width: 1024px) {
    .menu-content {
        padding: 30px 40px;
        grid-template-columns: 1fr;
    }

    .menu-image {
        display: none;
    }

    .menu-nav {
        grid-column: 1;
    }

    .menu-footer {
        grid-column: 1;
        flex-wrap: wrap;
    }
}

@media (max-width: 768px) {
    .menu-content {
        padding: 25px 30px;
    }

    .menu-logo {
        width: 80px;
        height: 80px;
    }

    .menu-close {
        width: 45px;
        height: 45px;
    }

    .menu-item a {
        font-size: 2rem;
    }

    .menu-legal {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }
}

@media (max-width: 480px) {
    .menu-content {
        padding: 20px;
    }

    .menu-item a {
        font-size: 1.6rem;
    }

    .menu-footer {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* ================================
   Section: Cattenom en un coup d'œil
   ================================ */
   .section-overview {
    background: var(--color-cream);
    padding: 100px 0;
    position: relative;
}

.overview-container {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: end;
    gap: 60px;
    max-width: 100%;
    margin: 0 auto;
}
/* Partie gauche - Titre Cattenom */
.overview-left {
    text-align: right;
}

.overview-title-left {
    font-family: var(--font-display);
    font-size: 125px;
    font-weight: 300;
    color: var(--color-brown);
    margin: 0;
}

.overview-title-left em {
    font-style: italic;
}

/* Partie centrale - Image */
.overview-center {
    display: flex;
    justify-content: center;
    border-radius: 20px;
}

.overview-image-wrapper {
    width: 330px;
    height: 400px;
    overflow: hidden;
    border-radius: 20px;
}

.overview-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
}

.overview-image-wrapper:hover .overview-image {
    transform: scale(1.05);
}

/* Partie droite - Texte et bouton */
.overview-right {
    text-align: left;
    max-width: 280px;
    margin-bottom: 50px;
}

.overview-text {
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 300;
    line-height: 1.7;
    color: var(--color-brown);
    margin-bottom: 25px;
}

.btn-savoir-plus {
    display: inline-flex;
    align-items: center;
    gap: 0;
    text-decoration: none;
    transition: all 0.3s ease;
}

.btn-savoir-plus span:first-child {
  background: #B2A79B;
  color: white;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 300;
  letter-spacing: 0.1em;
  padding: 15px 30px;
  border-radius: 90px;
  transition: all 0.3s ease;
}


.btn-arrow {
  background: #B2A79B;
  color: var(--color-cream);
  padding: 14px;
  font-size: 65px !important;
  border-radius: 90px;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.btn-arrow svg {
    width: 16px;
    height: 16px;
    transition: transform 0.3s ease;
    transform: rotate(-45deg);
}

/* Hover: fusion en un seul bloc */
.btn-savoir-plus:hover span:first-child {
    background: var(--color-brown);
    color: var(--color-cream);
    border-radius: 50px 0 0 50px;
}

.btn-savoir-plus:hover .btn-arrow {
  background: var(--color-brown);
  border-radius: 0 90px 90px 0;
}

.btn-savoir-plus:hover .btn-arrow svg {
    transform: rotate(0deg);
}

/* Titre principal "en un coup d'œil" */
.overview-main-title {
    text-align: center;
    margin-top: 40px;
}

.overview-main-title h2 {
    font-family: var(--font-display);
    font-size: 125px;
    font-weight: 300;
    color: var(--color-brown);
    margin: 0;
}

/* Description */
.overview-description {
    text-align: center;
    max-width: 800px;
    margin: 40px auto 0;
}

.overview-description p {
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 300;
    line-height: 1.8;
    color: var(--color-brown);
}

.overview-description sup {
    font-size: 0.6em;
}

/* Responsive Section Overview */
@media (max-width: 1024px) {
    .section-overview {
        padding: 80px 30px 60px;
    }

    .overview-container {
        gap: 40px;
    }

    .overview-image-wrapper {
        width: 240px;
        height: 280px;
    }
}

@media (max-width: 768px) {
    .section-overview {
        padding: 60px 20px 50px;
    }

    .overview-container {
        grid-template-columns: 1fr;
        gap: 30px;
        text-align: center;
    }

    .overview-left {
        text-align: center;
        order: 2;
    }

    .overview-center {
        order: 1;
    }

    .overview-right {
        text-align: center;
        max-width: 100%;
        order: 3;
    }

    .overview-image-wrapper {
        width: 260px;
        height: 300px;
        margin: 0 auto;
    }

    .overview-title-left {
        font-size: 2.5rem;
    }

    .overview-main-title h2 {
        font-size: 2.2rem;
    }
}

@media (max-width: 480px) {
    .overview-image-wrapper {
        width: 220px;
        height: 260px;
    }


}

/* ================================
   Section: Tabs (À travers les siècles)
   ================================ */
.section-tabs {
    background: var(--color-cream);
    padding: 0 20px 20px;
}

.tabs-container {
    background: #faf8f5;
    border-radius: 20px;
    padding: 40px 50px 50px;
    max-width: 100%;
    border: 1px solid #B2A79B;
}

/* Navigation des onglets */
.tabs-nav {
    display: flex;
    gap: 15px;
    margin-bottom: 50px;
}

.tab-btn {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  background: #F5F0EB;
  border: 1px solid #B2A79B;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.tab-btn.active {
    background: #B2A79B;
    border-color: #B2A79B;
}

.tab-btn:not(.active):hover {
    border-color: var(--color-brown);
}

.iconTab {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #4A3728;
    border-radius: 6px;
    font-size: 1rem;
    color: var(--color-brown);
    flex-shrink: 0;
    position: relative;
    z-index: 2;
    transition: all 0.3s ease;
    padding: 8px;
}

.tab-btn.active .iconTab {
    background: rgba(255, 255, 255, 0.2);
    color: var(--color-cream);
}

.tab-text {
    font-family: var(--font-display);
    font-size: 22px;
    font-weight: 300 !important;
    color: var(--color-brown);
    white-space: nowrap;
    position: relative;
    z-index: 2;
    transition: all 0.3s ease;
    letter-spacing: .5px;
}

.tab-btn.active .tab-text {
    color: var(--color-cream);
}

/* Barre de progression en bas */
.tab-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 5px;
    width: 0%;
    background: rgba(74, 55, 40, 0.3);
    z-index: 3;
}

.tab-btn.active .tab-progress {
    background: var(--color-cream);
}

/* Contenu des onglets */
.tabs-content {
    position: relative;
}

.tab-panel {
    display: none;
    animation: fadeInTab 0.5s ease;
}

.tab-panel.active {
    display: block;
}

@keyframes fadeInTab {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.tab-panel-inner {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 60px;
    align-items: end;
}

/* Texte du panel */
.tab-panel-text {
    padding-right: 40px;
}

.tab-panel-text h3 {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 3vw, 2.5rem);
    font-weight: 300;
    color: var(--color-brown);
    margin-bottom: 20px;
    line-height: 1.2;
}

.tab-panel-text p {
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 300;
    line-height: 1.8;
    color: var(--color-brown);
    margin-bottom: 30px;
}

.btn-beige span:first-child {
    background: #B2A79B;
    color: var(--color-white);
}

.btn-beige .btn-arrow {
    background: rgba(140, 120, 100, 0.7);
}

.btn-beige:hover span:first-child {
    background: rgba(140, 120, 100, 0.8);
    color: var(--color-white);
}

.btn-beige:hover .btn-arrow {
    background: rgba(140, 120, 100, 0.8);
}

/* Image du panel */
.tab-panel-image {
    position: relative;
    border-radius: 15px;
    overflow: hidden;
    box-shadow: 0 15px 50px rgba(74, 55, 40, 0.15);
}

.tab-panel-image::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(
        135deg,
        rgba(210, 180, 140, 0.3) 0%,
        transparent 50%
    );
    z-index: 1;
    pointer-events: none;
}

.tab-panel-image img {
  width: 100%;
  height: 450px;
  object-fit: cover;
  display: block;
  transition: transform 0.6s ease, filter 0.6s ease;
  min-height: 570px;
}

.tab-panel-image:hover img {
    transform: scale(1.03);
    filter: sepia(10%) contrast(100%);
}

/* Responsive Section Tabs */
@media (max-width: 1400px) {
    .tabs-nav {
        flex-wrap: wrap;
    }

    .tab-btn {
        flex: 1 1 calc(33.333% - 10px);
        min-width: 200px;
    }
}

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

    .tab-panel-inner {
        gap: 40px;
    }

    .tab-panel-image img {
        height: 380px;
    }
}

@media (max-width: 768px) {
    .tabs-nav {
        flex-direction: column;
        gap: 10px;
    }

    .tab-btn {
        flex: none;
        width: 100%;
        padding: 10px 20px;
    }

    .tab-panel-inner {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .tab-panel-text {
        padding-right: 0;
        order: 2;
    }

    .tab-panel-image {
        order: 1;
    }

    .tab-panel-image img {
        min-height: auto;
    }
}

@media (max-width: 480px) {
    .section-tabs {
        padding: 0 10px 10px;
    }
    .headerPageAnex {
      margin: 15px;
    }
    .tabs-container {
        padding: 20px;
        border-radius: 15px;
    }

    .tabs-nav {
        margin-bottom: 30px;
    }

    .tab-btn {
        padding: 12px 15px;
    }

    .tab-icon {
        width: 30px;
        height: 30px;
        font-size: 0.85rem;
    }


    .tab-panel-image img {
        height: 250px;
    }
}

/* ================================
   Section 3: Image qui s'agrandit
   ================================ */
.section-expand {
    background: var(--color-cream);
    min-height: 200vh;
    position: relative;
}

.expand-container {
    position: sticky;
    top: 0;
    width: 100%;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.expand-image-wrapper {
    position: relative;
    width: 500px;
    height: 400px;
    border-radius: 20px;
    overflow: hidden;
    will-change: transform, width, height, border-radius;
}

.expand-image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.expand-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0);
    pointer-events: none;
    will-change: background;
}

/* Contenu qui apparaît */
.expand-content {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 60px 80px;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    opacity: 0;
    visibility: hidden;
}

.expand-text {
    max-width: 450px;
}

.expand-text h2 {
    font-family: var(--font-display);
    font-size: 100px;
    font-weight: 300;
    color: var(--color-cream);
    line-height: 1.1;
    margin-bottom: 30px;
}

.expand-text h2 em {
    font-style: italic;
}

.btn-light span:first-child {
    background: rgba(255, 255, 255, 0.2);
    color: var(--color-cream);
    border: 1px solid rgba(255, 255, 255, 0.3);
}

.btn-light .btn-arrow {
    background: rgba(255, 255, 255, 0.3);
    color: var(--color-cream);
}

.btn-light:hover span:first-child {
    background: rgba(255, 255, 255, 0.3);
    color: var(--color-cream);
}

.btn-light:hover .btn-arrow {
    background: rgba(255, 255, 255, 0.4);
}

/* Stats */
.expand-stats {
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(10px);
    padding: 30px 40px;
    border-radius: 10px;
    max-width: 400px;
}

.expand-stats h3 {
    font-family: var(--font-display);
    font-size: 1.3rem;
    font-weight: 300;
    color: var(--color-cream);
    margin-bottom: 20px;
}

.stats-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.stats-list li {
    display: flex;
    align-items: baseline;
    gap: 15px;
    margin-bottom: 12px;
}

.stat-value {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 300;
    color: var(--color-cream);
    min-width: 70px;
}

.stat-label {
    font-family: var(--font-body);
    font-size: 0.85rem;
    font-weight: 300;
    color: rgba(245, 240, 232, 0.8);
}

/* Responsive Section Expand */
@media (max-width: 1024px) {
    .expand-content {
        padding: 40px 50px;
        flex-direction: column;
        justify-content: flex-end;
        align-items: flex-start;
        gap: 30px;
    }

    .expand-stats {
        max-width: 100%;
        width: 100%;
    }
}

@media (max-width: 768px) {
    .expand-image-wrapper {
        width: 350px;
        height: 300px;
    }

    .expand-content {
        padding: 30px;
    }

    .expand-text h2 {
        font-size: 70px;
    }

    .expand-stats {
        padding: 20px 25px;
    }

    .stat-value {
        font-size: 1.2rem;
        min-width: 55px;
    }

    .stat-label {
        font-size: 0.75rem;
    }
}

@media (max-width: 480px) {
    h2{
        font-size: 33px !important;
        line-height: 40px !important;
    }
    .expand-image-wrapper {
        width: 300px;
        height: 250px;
    }

    .expand-content {
        padding: 20px;
    }

    .expand-text h2 {
        font-size: 48px !important;
        margin-bottom: 20px;
        line-height: 53px !important;
    }
    .menu-header img {
        max-width: 110px !important;
    }
    .menu-nav {
        margin-top: 20px !important;
    }
}

/* ================================
   Section 4: Cattenom 360 Projet
   ================================ */
   .section-projet {
    background: var(--color-cream);
    padding: 210px 20px;
    
    display: flex;
    align-items: center;
    font-family: ;
    justify-content: center;
}

.projet-container {
    max-width: 100%;
    
    text-align: center;
}

.projet-title {
    font-size: 100px;
    line-height: 110px;
    font-weight: 300;
    font-family: var(--font-display);
    color: var(--color-brown);
    line-height: 1.3;
    margin-bottom: 40px;
}

.projet-title em {
    font-style: italic;
}

.projet-line {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
}

.projet-image {
    display: inline-block;

    border-radius: 20px;
    overflow: hidden;
    vertical-align: middle;
    margin: 0 30px;
}

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

.projet-description {
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 300;
    line-height: 1.9;
    color: var(--color-brown);
    max-width: 700px;
    margin: 0 auto;
}

.projet-description sup {
    font-size: 0.6em;
}

/* Responsive Section Projet */
@media (max-width: 768px) {
    .section-projet {
        padding: 80px 30px;
    }

    .projet-title {
        font-size: 2rem;
    }

    .projet-image {
        width: 100px;
        height: 50px;
    }

    .projet-line {
        gap: 10px;
    }

    .projet-description {
        font-size: 0.85rem;
    }

    .projet-description br {
        display: none;
    }
}

@media (max-width: 480px) {
    .section-projet {
        padding: 60px 20px;
    }

    .projet-title {
        font-size: 1.6rem;
    }

    .projet-image {
        width: 80px;
        height: 40px;
        border-radius: 5px;
    }
}

/* ================================
   Section 5: Entreprises et artisans
   ================================ */
.section-entreprises {
    background: var(--color-cream);
    padding: 20px;
}
.entreprises-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 640px;
}

/* Image à gauche */
.entreprises-image {
    background: #e0ddd8;
    border-radius: 15px;
    overflow: hidden;
    width: 98%;
}

.entreprises-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.9;
    transition: opacity 0.3s ease, transform 0.6s ease;
}

.entreprises-image:hover img {
    opacity: 1;
    transform: scale(1.02);
}

/* Contenu à droite */
.entreprises-content {
    background: #faf8f5;
    border-radius: 0 15px 15px 0;
    padding: 60px 80px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 98%;
    border-radius: 20px;
}

.entreprises-tag {
    display: inline-block;
    background: var(--color-brown);
    color: var(--color-cream);
    font-family: var(--font-body);
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    padding: 8px 16px;
    border-radius: 50px;
    margin-bottom: 190px;
    width: fit-content;
}

.entreprises-title {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 3vw, 2.5rem);
    font-weight: 300;
    color: var(--color-brown);
    line-height: 1.2;
    margin-bottom: 20px;
}

.entreprises-text {
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 300;
    line-height: 1.8;
    color: var(--color-brown);
    margin-bottom: 30px;
    max-width: 450px;
}

.entreprises-text sup {
    font-size: 0.6em;
}

/* Responsive Section Entreprises */
@media (max-width: 1024px) {
    .entreprises-content {
        padding: 40px 50px;
    }
}

@media (max-width: 768px) {
    .entreprises-container {
        grid-template-columns: 1fr;
    }

    .entreprises-image {
        border-radius: 15px 15px 0 0;
        min-height: 300px;
    }

    .entreprises-content {
        border-radius: 0 0 15px 15px;
        padding: 40px 30px;
    }

    .entreprises-tag {
        margin-bottom: 25px;
    }
}

@media (max-width: 480px) {
    .section-entreprises {
        padding: 10px;
    }

    .entreprises-content {
        padding: 30px 20px;
    }

    .entreprises-title {
        font-size: 1.5rem;
    }

    .entreprises-text {
        font-size: 0.85rem;
    }
}
        /* ===== MARQUEE SECTION ===== */
        .marquee-section {
            position: relative;
            background-color: var(--cream);
            padding: 2rem 0;
            overflow: hidden;
            padding-top: 90px;
            background: #f5f0e8;
        }
        .footer {
            background: #f5f0e8 !important;
        }
        
        .marquee-container {
            display: flex;
            align-items: center;
            justify-content: center;
            position: relative;
            height: 180px;

        }
        
        .marquee-track {
            display: flex;
            align-items: center;
            white-space: nowrap;
            will-change: transform;
        }

        .marquee-text {
            font-family: var(--font-display);
            font-size: 249px;
            font-weight: 300;
            color: #5c5349;
            letter-spacing: -0.02em;
            padding: 0 1rem;
            display: inline-block;
        }
        

        
        /* ===== FOOTER ===== */
        .footer {
            background-color: var(--brown-dark);
            color: var(--text-light);
            padding: 30px 15px ;
            position: relative;
        }
        .marquee-track img{
            max-width: 210px;
            margin: 20px;
            transform: translate(3px, -12px);
        }
        .footer-content {
            max-width: 1500px;
            margin: 0 auto;
            display: grid;
            grid-template-columns: 1fr 1fr 1.2fr;
            gap: clamp(2rem, 5vw, 4rem);
            align-items: start;
            background: #5c5349;
            padding: 80px 30px;
            border-radius: 20px;
            color: #f5f0e8;
        }
        
        @media (max-width: 1150px) {

        }
        @media (max-width: 900px) {
            .footer-content {
                grid-template-columns: 1fr;
                gap: 3rem;
                text-align: center;
            }
        }
        
        /* Logo Section */
        .footer-logo {
            display: flex;
            flex-direction: column;
            align-items: flex-start;
        }
        
        @media (max-width: 900px) {
            .footer-logo {
                align-items: center;
            }
        }
        
        .footer-logo-badge {
            width: 280px;

            position: relative;
            opacity: 0;
            transform: scale(0.8) rotate(-10deg);
        }
        .footer-logo-badge svg {
            width: 100%;
            height: 100%;
        }
        
        /* Navigation */
        .footer-nav {
            display: flex;
            flex-direction: column;
            gap: 0.8rem;
        }
        
        .footer-nav a {
            font-family: var(--font-display);
            font-size: 32px;
            color: var(--text-light);
            text-decoration: none;
            transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
            position: relative;
            display: inline-block;
            opacity: 0;
            line-height: 50px !important;
            margin-bottom: -3px !important;
        }
        .footer-nav a::after {
            content: '';
            position: absolute;
            bottom: -2px;
            left: 0;
            width: 0;
            height: 1px;
            background-color: var(--text-muted);
            transition: width 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        }
        
        .footer-nav a:hover {
            color: #b2a79b;
            text-decoration: underline;
            transform: translateX(8px);
        }
        
        .footer-nav a:hover::after {
            width: 100%;
        }
        
        /* CTA Section */
        .footer-cta {
            display: flex;
            flex-direction: column;
            gap: 12px;
        }
        .footer-cta-title {
            font-family: var(--font-display);
            font-size: clamp(1.5rem, 3vw, 2rem);
            font-weight: 300;
            line-height: 1.3;
            opacity: 0;
            transform: translateY(20px);
        }
        
        .footer-cta-text {
            font-size: 16px;
            color: var(--text-muted);
            line-height: 24px;
            opacity: 0;
            transform: translateY(20px);
        }


        .footer-cta-description {
            font-size: 16px;
            color: var(--text-muted);
            line-height: 24px;
            margin-top: 0.5rem;
            opacity: 0;
            transform: translateY(20px);
        }
        
        /* Contact Button */
        .contact-btn {
            display: inline-flex;
            align-items: center;
            gap: 0;
            background: transparent;
            border: 1px solid var(--text-muted);
            border-radius: 50px;
            overflow: hidden;
            cursor: pointer;
            transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
            opacity: 0;
            transform: translateY(20px);
            width: fit-content;
        }
        
        .contact-btn-text {
            padding: 0.9rem 1.8rem;
            font-family: 'Instrument Sans', sans-serif;
            font-size: 0.85rem;
            letter-spacing: 0.08em;
            text-transform: uppercase;
            color: var(--text-light);
            transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        }
        
        .contact-btn-arrow {
            width: 45px;
            height: 45px;
            display: flex;
            align-items: center;
            justify-content: center;
            border-left: 1px solid var(--text-muted);
            transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        }
        
        .contact-btn-arrow svg {
            width: 14px;
            height: 14px;
            stroke: var(--text-light);
            transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        }
        
        .contact-btn:hover {
            background-color: var(--text-light);
            border-color: var(--text-light);
        }
        
        .contact-btn:hover .contact-btn-text {
            color: var(--brown-dark);
        }
        
        .contact-btn:hover .contact-btn-arrow {
            border-left-color: var(--brown-light);
        }
        
        .contact-btn:hover .contact-btn-arrow svg {
            stroke: var(--brown-dark);
            transform: translate(3px, -3px);
        }
        
        /* Footer Bottom */
        .footer-bottom {
            max-width: 1500px;
            margin: 0 auto;
            margin-top: 0px;
            padding-top: 1.5rem;
            border-top: 1px solid rgba(255, 255, 255, 0.1);
            display: flex;
            justify-content: space-between;
            align-items: center;
            flex-wrap: wrap;
            gap: 1rem;
        }
        
        .footer-copyright, .footer-tagline {
            font-family: var(--font-display);
            font-size: 23px;
            color: var(--text-muted);
        }
        
        .footer-tagline {
            font-family: var(--font-display);
            font-style: italic;
            font-size: 23px;
        }
        
        @media (max-width: 600px) {
            .footer-bottom {
                flex-direction: column;
                text-align: center;
            }
        }
        
        /* Decorative Elements */
        .footer-decoration {
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 1px;
            background: linear-gradient(90deg, transparent, var(--brown-light), transparent);
            opacity: 0.3;
        }

/* ================================
   Animation lettres
   ================================ */
.split-text .letter {
    display: inline-block;
    will-change: transform, opacity;
}

