.elementor-kit-151{--e-global-color-primary:#1E1E1C;--e-global-color-secondary:#F2F0EF;--e-global-color-text:#F2F0EF;--e-global-color-accent:#FF5C00;--e-global-typography-primary-font-family:"Clash Grotesk Variable";--e-global-typography-primary-font-size:4vw;--e-global-typography-primary-font-weight:500;--e-global-typography-secondary-font-family:"Clash Grotesk Variable";--e-global-typography-secondary-font-weight:600;--e-global-typography-text-font-family:"Clash Grotesk Variable";--e-global-typography-text-font-size:1vw;--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Clash Grotesk Variable";--e-global-typography-accent-font-size:3.7vw;--e-global-typography-accent-font-weight:300;background-color:#21211F;color:var( --e-global-color-text );font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-size:var( --e-global-typography-text-font-size );font-weight:var( --e-global-typography-text-font-weight );}.elementor-kit-151 e-page-transition{background-color:#FFBC7D;}.elementor-kit-151 h1{color:var( --e-global-color-text );font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-size:var( --e-global-typography-primary-font-size );font-weight:var( --e-global-typography-primary-font-weight );}.elementor-kit-151 h2{color:var( --e-global-color-text );font-family:var( --e-global-typography-secondary-font-family ), Sans-serif;font-weight:var( --e-global-typography-secondary-font-weight );}.elementor-kit-151 h3{color:var( --e-global-color-accent );font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-size:var( --e-global-typography-accent-font-size );font-weight:var( --e-global-typography-accent-font-weight );}.elementor-kit-151 button,.elementor-kit-151 input[type="button"],.elementor-kit-151 input[type="submit"],.elementor-kit-151 .elementor-button{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-size:var( --e-global-typography-primary-font-size );font-weight:var( --e-global-typography-primary-font-weight );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;--container-default-padding-top:0rem;--container-default-padding-right:0rem;--container-default-padding-bottom:0rem;--container-default-padding-left:0rem;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-kit-151{font-size:var( --e-global-typography-text-font-size );}.elementor-kit-151 h1{font-size:var( --e-global-typography-primary-font-size );}.elementor-kit-151 h3{font-size:var( --e-global-typography-accent-font-size );}.elementor-kit-151 button,.elementor-kit-151 input[type="button"],.elementor-kit-151 input[type="submit"],.elementor-kit-151 .elementor-button{font-size:var( --e-global-typography-primary-font-size );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-kit-151{font-size:var( --e-global-typography-text-font-size );}.elementor-kit-151 h1{font-size:var( --e-global-typography-primary-font-size );}.elementor-kit-151 h3{font-size:var( --e-global-typography-accent-font-size );}.elementor-kit-151 button,.elementor-kit-151 input[type="button"],.elementor-kit-151 input[type="submit"],.elementor-kit-151 .elementor-button{font-size:var( --e-global-typography-primary-font-size );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS */.cha-sous-titre{
    background-color: #FF5C00;
    padding:5px 10px;
}

.bru-large-text {
  display: flex;
  justify-content: space-between;
  /*padding: 0 2vw;*/
  box-sizing: border-box;
  font-size: 8rem;
  white-space: nowrap;
}

.bru-large-text span {
  display: inline-block;
}

@media (max-width: 768px) {
    .bru-large-text {
  display: flex;
  justify-content: space-between;
  /*padding: 0 2vw;*/
  box-sizing: border-box;
  font-size: 3rem;
  white-space: nowrap;
}

.bru-large-text span {
  display: inline-block;
}
}

  .dotted-moving-line {
    width: 100%;
    height: 4px;
    background-image: repeating-linear-gradient(to right, #4E4E4B 0 6px, transparent 6px 12px);
    background-color: #1E1E1B;
    background-size: 18px 100%;
    background-repeat: repeat;
    margin: 1rem 0;
    animation:
      moveDashes 0.5s linear infinite,
      irregularBlink 0.8s ease-in-out infinite,
      launchCycle 10s ease-in-out infinite;
    transform-origin: left center;
  }

  @keyframes moveDashes {
    0%   { background-position: 0 0; }
    100% { background-position: 18px 0; }
  }

  @keyframes irregularBlink {
    0%   { opacity: 1; }
    12%  { opacity: 0.6; }
    25%  { opacity: 0.9; }
    37%  { opacity: 0.4; }
    48%  { opacity: 1; }
    63%  { opacity: 0.5; }
    74%  { opacity: 0.85; }
    88%  { opacity: 0.3; }
    100% { opacity: 1; }
  }

  @keyframes launchCycle {
    0%, 30% {
      transform: translateX(0) scaleX(1);
      opacity: 1;
    }
    31% {
      transform: translateX(20%) scaleX(1.1);
      opacity: 0.8;
    }
    33% {
      transform: translateX(60%) scaleX(1.5);
      opacity: 0.4;
    }
    35% {
      transform: translateX(150%) scaleX(2.5);
      opacity: 0;
    }
    36%, 69% {
      transform: translateX(-150%) scaleX(2.5);
      opacity: 0;
    }
    70% {
      transform: translateX(-60%) scaleX(1.5);
      opacity: 0.3;
    }
    72% {
      transform: translateX(-20%) scaleX(1.1);
      opacity: 0.8;
    }
    75%, 100% {
      transform: translateX(0) scaleX(1);
      opacity: 1;
    }
  }

  @media (max-width: 768px) {
    .dotted-moving-line {
      height: 2px;
      background-image: repeating-linear-gradient(to right, #1E1E1B 0 4px, transparent 4px 8px);
      background-size: 12px 100%;
    }
  }
 
.has-vertical-line {
  position: relative;
  overflow: hidden;
}

.has-vertical-line::before {
  content: "";
  position: absolute;
  top: 0;
  left: 5%;
  width: 4px;
  height: 100%;
  background-image: repeating-linear-gradient(to bottom, #4E4E4B 0 6px, transparent 6px 12px);
  background-color: #1E1E1B;
  background-size: 100% 18px;
  background-repeat: repeat;
  animation:
    moveDashesY 1.2s linear infinite,
    irregularBlink 3.8s ease-in-out infinite,
    launchCycleY 10s ease-in-out infinite;
  transform-origin: center top;
  z-index: -1;
}

@keyframes moveDashesY {
  0%   { background-position: 0 0; }
  100% { background-position: 0 18px; }
}

@keyframes irregularBlink {
  0%   { opacity: 1; }
  12%  { opacity: 0.6; }
  25%  { opacity: 0.9; }
  37%  { opacity: 0.4; }
  48%  { opacity: 1; }
  63%  { opacity: 0.5; }
  74%  { opacity: 0.85; }
  88%  { opacity: 0.3; }
  100% { opacity: 1; }
}

@keyframes launchCycleY {
  0%, 30% {
    transform: translateY(0) scaleY(1);
    opacity: 1;
  }
  31% {
    transform: translateY(20%) scaleY(1.1);
    opacity: 0.8;
  }
  33% {
    transform: translateY(60%) scaleY(1.5);
    opacity: 0.4;
  }
  35% {
    transform: translateY(150%) scaleY(2.5);
    opacity: 0;
  }
  36%, 69% {
    transform: translateY(-150%) scaleY(2.5);
    opacity: 0;
  }
  70% {
    transform: translateY(-60%) scaleY(1.5);
    opacity: 0.3;
  }
  72% {
    transform: translateY(-20%) scaleY(1.1);
    opacity: 0.8;
  }
  75%, 100% {
    transform: translateY(0) scaleY(1);
    opacity: 1;
  }
}

@media (max-width: 768px) {
  .has-vertical-line::before {
    width: 2px;
    background-image: repeating-linear-gradient(to bottom, #fff 0 4px, transparent 4px 8px);
    background-size: 100% 12px;
  }
}


.has-vertical-line {
  position: relative;
  overflow: hidden;
}

.has-vertical-line::after {
  content: "";
  position: absolute;
  top: 0;
  left: 30%;
  width: 4px;
  height: 100%;
  background-image: repeating-linear-gradient(to bottom, #4E4E4B 0 6px, transparent 6px 12px);
  background-color: #1E1E1B;
  background-size: 100% 18px;
  background-repeat: repeat;
  animation:
    moveDashesY 1.2s linear infinite,
    irregularBlink 3.8s ease-in-out infinite,
    launchCycleY 10s ease-in-out infinite;
  transform-origin: center top;
  z-index: -1;
}

@keyframes moveDashesY {
  0%   { background-position: 0 0; }
  100% { background-position: 0 18px; }
}

@keyframes irregularBlink {
  0%   { opacity: 1; }
  12%  { opacity: 0.6; }
  25%  { opacity: 0.9; }
  37%  { opacity: 0.4; }
  48%  { opacity: 1; }
  63%  { opacity: 0.5; }
  74%  { opacity: 0.85; }
  88%  { opacity: 0.3; }
  100% { opacity: 1; }
}

@keyframes launchCycleY {
  0%, 30% {
    transform: translateY(0) scaleY(1);
    opacity: 1;
  }
  31% {
    transform: translateY(20%) scaleY(1.1);
    opacity: 0.8;
  }
  33% {
    transform: translateY(60%) scaleY(1.5);
    opacity: 0.4;
  }
  35% {
    transform: translateY(150%) scaleY(2.5);
    opacity: 0;
  }
  36%, 49% {
    transform: translateY(-150%) scaleY(2.5);
    opacity: 0;
  }
  70% {
    transform: translateY(-60%) scaleY(1.5);
    opacity: 0.3;
  }
  72% {
    transform: translateY(-20%) scaleY(1.1);
    opacity: 0.8;
  }
  75%, 100% {
    transform: translateY(0) scaleY(1);
    opacity: 1;
  }
}


@media (max-width: 768px) {
  .has-vertical-line::before {
    width: 2px;
    background-image: repeating-linear-gradient(to bottom, #fff 0 4px, transparent 4px 8px);
    background-size: 100% 12px;
  }
}/* End custom CSS */
/* Start Custom Fonts CSS */@font-face {
	font-family: 'Clash Grotesk Variable';
	font-display: auto;
	src: url('https://tech-matters.fr/wp-content/uploads/2025/07/ClashGrotesk-Variable.ttf') format('truetype');
}
/* End Custom Fonts CSS */