/**
 * Fichier de styles personnalisés pour la page d'accueil Eufonie
 * 
 * Contient tous les styles CSS spécifiques à la page d'accueil
 * Organisé par sections pour faciliter la maintenance
 */

/* ============================================
   VARIABLES CSS
   ============================================ */
:root {
  --text-family: "Inter", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --stroke: 13;
  --ring-w: 172%;
  --ring-h: 236%;
  --ring-left: -39%;
  --ring-top: -40%;
}

/* ============================================
   TYPOGRAPHIE ET TITRES
   ============================================ */
.title {
  font-family: var(--text-family);
  font-weight: 800;
  font-size: 40px;
  line-height: 1.15;
  color: #000;
  margin: 0;
  text-align: center;
}

.highlight {
  position: relative;
  display: inline-block;
  margin-left: .35ch;
}

.word {
  position: relative;
  z-index: 1;
}



/* ============================================
   BOUTONS PERSONNALISÉS
   ============================================ */
.blog-card-button-hp {
  position: relative;
  overflow: hidden;
  padding: 0.625rem 2.063rem;
  border-radius: 999px;
  border: 1px solid #9E00A5;
  background: #9E00A5;
  font-size: 14px;
  color: #FFF;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  box-shadow: 0 1px 7px rgba(0, 0, 0, 0.08);
  z-index: 1;
}

.blog-card-button-hp span {
  position: relative;
  z-index: 1;
}

.blog-card-button-hp:hover {
  color: #9E00A5;
  transform: translateY(-1px);
  border: 1px solid #9E00A5;
}

.blog-card-button-hp:hover>.before, 
.blog-card-button-hp:hover>.after {
  height: 50%;
  background: #fff !important;
}

.blog-card-button-hp span.after {
  bottom: 0;
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  height: 0;
  background: #9E00A5;
  -webkit-transition: background .4s, height .4s;
  transition: background .4s, height .4s;
  z-index: -1;
}

.blog-card-button-hp span.before {
  top: 0;
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  height: 0;
  background: #9E00A5;
  -webkit-transition: background .4s, height .4s;
  transition: background .4s, height .4s;
  z-index: -1;
}

button.icon__btn.ieee.custom.num_5 {
  padding: 15px !important;
}

button.icon__btn.ieee.custom.num_4 {
  padding: 12px !important;
}

.btn-inside-out:hover {
  background: #3163d8 !important;
}

/* ============================================
   EFFETS SVG ET SOULIGNEMENT
   ============================================ */
.svg-ring {
  position: absolute;
  pointer-events: none;
  z-index: 0;
  width: var(--ring-w);
  height: var(--ring-h);
  left: var(--ring-left);
  top: var(--ring-top);
  transform: rotate(-6deg);
}

.loop {
  fill: none;
  stroke-width: var(--stroke);
  stroke-linecap: round;
  stroke-linejoin: round;
}

.tip {
  stroke-width: calc(var(--stroke) * 0.9);
}

/* Soulignement pour les titres */
.underline {
  position: absolute;
  bottom: -65px;
  width: 100%;
  left: 0;
  height: 76px;
  pointer-events: none;
  transform: rotate(-5deg);
  transform-origin: left center;
}

.underline path {
  stroke: url(#gradient);
  stroke-width: 4;
  fill: none;
}

.underline-freq {
  position: absolute;
  bottom: -77px;
  width: 100%;
  left: 0;
  height: 76px;
  pointer-events: none;
  transform: rotate(-5deg);
  transform-origin: left center;
}

.underline-freq path {
  stroke: url(#gradient);
  stroke-width: 4;
  fill: none;
}

.underline-freq-article path {
  stroke: url(#gradient-article);
  stroke-width: 4;
  fill: none;
}

/* ============================================
   TEXTE AVEC GRADIENT
   ============================================ */
.gradient-text {
  background: linear-gradient(192deg, #3163d8 26%, #9E00A5 70%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  position: relative;
}

.gradient-text-article {
  background: linear-gradient(192deg, #fff 26%, #fff 70%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  position: relative;
}

/* ============================================
   CONTENEUR PERSONNALISÉ
   ============================================ */
.container-wide {
  width: 100%;
  padding-right: var(--bs-gutter-x, 0.75rem);
  padding-left: var(--bs-gutter-x, 0.75rem);
  margin-right: auto;
  margin-left: auto;
}

/* Breakpoints pour container-wide */
@media (min-width: 576px) {
  .container-wide {
    max-width: 620px;
  }
}

@media (min-width: 768px) {
  .container-wide {
    max-width: 800px;
  }
}

@media (min-width: 992px) {
  .container-wide {
    max-width: 1100px;
  }
}

@media (min-width: 1200px) {
  .container-wide {
    max-width: 1320px;
  }
}

@media (min-width: 1400px) {
  .container-wide {
    max-width: 1520px;
  }
}

/* ============================================
   SECTION HERO - CONTENEUR PRINCIPAL
   ============================================ */
.container-custom {
  position: relative;
  max-width: 1200px;
  width: 100%;
  padding: 40px;
  transform: translateX(-5%);
}

.video-box {
  position: relative;
  background: #fff;
  border-radius: 15px;
  overflow: hidden;
  width: auto;
  max-width: 600px;
  height: auto;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
  z-index: 1;
  object-fit: cover;
  visibility: hidden;
}

.video-box img {
  width: 100%;
  height: 100%;
}

/* ============================================
   ÉLÉMENTS FLOTTANTS (ICÔNES ANIMÉES)
   ============================================ */
.floating {
  position: absolute;
  border-radius: 15px;
  display: none;
}

.floating.logo-badge {
  top: 70%;
  left: 80%;
  width: 100px;
  height: 100px;
}

.stats-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  bottom: -142px;
  right: 50px;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: cover;
  -webkit-mask-size: cover;
  width: 280px;
  height: auto;
}

.prompt-bar {
  position: absolute;
  top: 60%;
  left: 46%;
  width: 200px;
  height: 200px;
  gap: 15px;
  display: none;
  z-index: 6;
}

.prompt-bar.floating.globe {
  background-image: url("/wp-content/uploads/2025/11/Rectangle-BKG-Compressed-1.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  width: 260px !important;
  transform: scale(0.8);
}

img.image-globe {
  transform: translateY(-15px);
}

.prompt-bar-content {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  bottom: 45%;
}

img.nation {
  width: 14%;
  margin: 5px;
}

.floating.envelope {
  top: 28%;
  left: 4%;
  width: 200px;
}

.floating.phone {
  width: 100px;
  bottom: 79%;
  left: 16%;
}

.floating.hand {
  width: 120px;
  top: -1rem;
  right: -1rem;
}

.floating.chat {
  width: 100px;
  top: -23%;
  left: 45%;
}

.floating.rgpd-image {
  width: 65px;
  top: 8rem;
  right: -6rem;
}

.person {
  position: absolute;
  right: -33px;
  bottom: 44px;
  width: 713px;
  z-index: 1;
  display: none;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: cover;
  -webkit-mask-size: cover;
}

.counter {
  font-size: 2rem;
  font-weight: 600;
  color: #fff;
}

/* ============================================
   NAVIGATION ET MENU
   ============================================ */
.brk-nav__menu>li.active>a>span {
  border-bottom: solid 2px #fff !important;
}

.brk-header-mobile-wrap .brk-nav__menu>li.active>a>span {
  border-bottom: solid 2px #000 !important;
}

.brk-header_scroll .brk-nav__menu>li.active>a>span {
  border-bottom: solid 2px rgba(39, 39, 39, .5) !important;
}

.brk-nav__menu>li.active:hover {
  border-bottom: none !important;
}

.brk-nav__menu>li.active>a {
  color: #fff !important;
  font-weight: bold !important;
}

.brk-header-mobile-wrap .brk-nav__menu>li.active>a {
  color: #000 !important;
}

ul.brk-nav__sub-menu>li.active>a {
  font-weight: bold !important;
  color: rgba(39, 39, 39, .8) !important;
  border-bottom: solid 2px var(--brand-primary);
}

/* ============================================
   SECTIONS DE CONTENU
   ============================================ */
.post-rounded__text {
  background-color: #fff;
  padding: 65px 38px 45px;
  height: 556px;
}

.post-rounded__btn {
  position: absolute !important;
  left: 50%;
  bottom: -27px;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  margin: 0 !important;
}

.post-rounded__thumb {
  height: 0 !important;
  padding-bottom: 100% !important;
  position: relative !important;
}

.shop-setout__img {
  background-repeat: no-repeat !important;
}

.brk-white-font-color p {
  line-height: 1.6;
}

.arrow-right-card {
  position: absolute;
  bottom: 0;
  right: 15px;
  font-size: 20px !important;
  color: #3163d8;
}

/* ============================================
   FAQ
   ============================================ */
.Faq {
  margin-bottom: 7%;
}

.Faq h2 {
  color: #292b2c;
  font-size: 56px;
  text-align: center;
  font-family: 'Roboto', sans-serif;
}

.faqs {
  margin-top: 3%;
  margin-left: 1%;
  text-align: justify;
}

.solid {
  border-top: 2px solid #a549a1;
  margin: 0 auto;
  width: 3%;
  margin-top: 25px;
}

/* ============================================
   DIVIDER PERSONNALISÉ
   ============================================ */
hr.divider-custom.wow.zoomIn.brk-library-rendered {
  width: 35px;
  height: 2px;
  background: white;
  margin: 30px auto 40px;
  border: 0;
}

/* ============================================
   ANIMATIONS
   ============================================ */
.heade-phone {
  animation: phoneVibrate-heade 1s cubic-bezier(.36, .07, .19, .97) infinite;
  transform-origin: 38px 13px;
}

/* ============================================
   RESPONSIVE - MEDIA QUERIES
   ============================================ */

/* Petits écrans */
@media (max-width: 420px) {
  :root {
    --stroke: 14;
    --ring-w: 178%;
    --ring-h: 262%;
    --ring-left: -27%;
    --ring-top: -92%;
  }
}

/* Tablettes et desktop */
@media screen and (max-width: 1300px) {
  .font__weight-bold.font__size-24.line__height-36.mb-40.brk-white-font-color {
    font-size: 22px;
  }
  
  .mt-5 p {
    font-size: 16px;
  }
}

@media screen and (max-width: 1500px) {
  .btn.btn-prime.btn-lg.border-radius-25.font__family-open-sans.font__weight-bold.brk-white-font-color.rendered.brk-library-rendered.eufonie-btn.eufonie-btn2 {
    /* border: none; */
  }
}

/* Grande résolution */
@media screen and (min-width: 2000px) {
  .katk {
    padding-top: 4% !important;
  }
  
  .katk2 {
    margin-top: -1%;
  }
}

@media screen and (max-width: 2000px) {
  .katk2 {
    margin-top: -5%;
  }
  
  .katk {
    padding-top: 4% !important;
  }
}

/* Responsive pour éléments flottants */
@media screen and (max-width: 1750px) {
  .floating.envelope {
    left: -9%;
  }
  
  .floating.phone {
    left: 5%;
  }
  
  .floating.chat {
    left: 38%;
  }
  
  .prompt-bar {
    left: 40%;
  }
}

@media screen and (max-width: 1550px) {
  .carouslide {
    top: 22% !important;
    width: 109% !important;
  }

  .floating.rgpd-image {
    width: 50px;
    top: 10rem;
  }

  .floating.logo-badge {
    top: 70%;
    left: 82%;
    width: 76px;
    height: 76px;
  }

  .floating.hand {
    top: 3%;
    right: 0rem;
    width: 96px;
  }
  
  .floating.chat {
    top: -20%;
    left: 37%;
    width: 80px;
  }
  
  .floating.phone {
    left: 8%;
    width: 80px;
  }
  
  .floating.envelope {
    left: -6%;
    width: 150px;
  }
  
  .logo-badge {
    left: 36px;
    width: 120px;
    height: 120px;
  }
  
  .language-badge {
    bottom: -86px;
    left: -2px;
    width: 209px;
    height: 161px;
  }
  
  .stats-badge {
    width: 210px;
  }
  
  .person {
    width: 648px;
  }
  
  .prompt-bar.floating.globe {
    transform: scale(0.7);
    left: 36%;
  }
  
  .video-box {
    height: auto;
  }
}

@media screen and (max-width: 1440px) {
  .person {
    width: 490px;
    bottom: 60px;
  }

  .katk {
    padding-bottom: 5% !important;
    padding-top: 4% !important;
  }
  
  .prompt-bar.floating.globe {
    transform: scale(0.6) !important;
    left: 30%;
    top: 136px;
  }
  
  .floating.rgpd-image {
    transform: scale(0.7);
    top: 33%;
  }
  
  .floating.logo-badge {
    transform: scale(0.7);
    top: 59%;
  }
  
  .floating.hand {
    transform: scale(0.7);
    top: 1%;
    right: -3%;
  }
  
  .floating.chat {
    transform: scale(0.7);
    top: -19%;
    left: 41%;
  }
  
  .floating.phone {
    transform: scale(0.7);
    left: 13%;
  }
  
  .floating.envelope {
    width: 128px;
    left: 1%;
  }
  
  .carouslide {
    top: 30% !important;
    width: 109% !important;
  }
  
  .language-badge {
    bottom: -53px;
    left: -2px;
    width: 141px;
    height: 118px;
  }
  
  .stats-badge {
    bottom: -81px;
    width: 163px;
  }
  
  .video-box {
    height: auto;
  }
}

@media screen and (max-width: 1260px) {
  .person {
    width: 390px;
    bottom: 60px;
  }

  .floating.envelope {
    width: 100px;
    left: 3%;
  }

  .prompt-bar.floating.globe {
    transform: scale(0.4) !important;
    left: 24%;
    top: 94px;
  }
  
  .floating.hand {
    top: 1%;
    right: -5%;
    width: 75px;
  }
  
  .floating.phone {
    transform: scale(0.6);
  }

  .floating.chat {
    transform: scale(0.6);
  }

  .descript p {
    font-size: 15px;
    line-height: 22px;
  }
  
  .btncontact {
    margin-top: -6%;
  }
}

@media screen and (max-width: 1100px) {
  .descript p {
    font-size: 15px;
    line-height: 22px;
  }
  
  .btncontact {
    margin-top: -10%;
  }
  
  .logo-badge {
    width: 102px;
    height: 86px;
    left: -7px;
  }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
  .descript p {
    font-size: 16px;
  }
  
  .btncontact {
    margin-top: 1%;
  }
}

/* ============================================
   SLICK CAROUSEL
   ============================================ */
#slider img:not(:last-child) {
  transform: skew(20deg);
  margin-right: 0%;
  padding-left: 0.1%;
  padding-right: 1.5%;
}

#dernier_actualite .slick-list.draggable {
  overflow: hidden;
}

/* ============================================
   CRISP CHAT
   ============================================ */
.crisp-client span.cc-xkyq.cc-qvio {
  background: #3163d8 !important;
}

/* ============================================
   HISTOIRE EN IMAGES
   ============================================ */
.notre-histoire-en-image i.fa {
  font-size: 1.5em !important;
}


h2 {
  font-size: 2.5rem;
  color: #222 !important;
  position: relative;
  display: inline-block !important;
}