* {

  margin: 0;

  padding: 0;

  text-decoration: none;

  list-style-type: none;

  font-family: 'Fira Sans', sans-serif

}



@media (min-width:1200px) {

  body {

    font-size: 1.1rem

  }

}



@media (max-width:1199.98px) {

  body {

    font-size: 1rem

  }

}



.fixed {

  position: fixed !important;

  top: 0;

  left: 0;

  right: 0;

  z-index: 1030

}



@media (max-width:990px) {

  .fixed {

    position: static !important

  }



  .sidebar {

    border-left: none !important

  }



  .item-content {

    padding: 20px !important

  }

}



h1,

h2,

h3,

h4,

h5,

h6 {

  color: #205082;

  position: relative;

  display: inline-block;

  font-weight: 600

}



.d5 h2 {

  text-align: center;

  padding-bottom: 12px

}



.d5 h2:before {

  content: '';

  position: absolute;

  bottom: -4px;

  left: 50%;

  margin-left: -3px;

  width: 6px;

  height: 6px;

  border-radius: 50%;

  background: #12828b;

  z-index: 2

}



.d5 h2:after {

  content: '';

  position: absolute;

  bottom: -2px;

  left: 50%;

  margin-left: -25%;

  width: 50%;

  height: 2px;

  background: #12828b

}



.upperNav {

  background-color: #205082

}



#lienAide {

  color: #fff;

  font-size: 1rem;

  text-decoration: none

}



#lienAide,

.telNav {

  color: #fff;

  font-size: 1rem

}

.ticker {

  overflow: hidden;

  white-space: nowrap;

  position: relative;

}



.ticker-text {

  display: inline-block;

  padding-left: 100%; /* Crée un espace de défilement supplémentaire */

  animation: tickerScroll 30s linear infinite;

  font-size: 1rem;

  color: white;

}







@keyframes tickerScroll {

  0% {

    transform: translateX(100%); /* Commencer à droite */

  }

  10% {

    transform: translateX(0); /* Le texte commence à se déplacer dès que possible */

  }

  100% {

    transform: translateX(-100%); /* Se déplace jusqu'à disparaître à gauche */

  }

}

.nav-link .active li {

  color: #205082

}



.nav-item {

  text-transform: uppercase;

  font-family: 'Fira Sans', sans-serif !important

}



.dropdown-item,

.list-group a,

.navbar-light .navbar-nav .nav-item .nav-link {

  color: #636363

}



.dropdown-item:hover,

.list-group a:hover,

.navbar-light .navbar-nav .nav-item .nav-link:hover {

  color: #205082

}



#logo {

  width: 5rem

}



#logoText {

  font-size: .9rem;

  color: #205082;

  font-weight: 800;

  text-transform: uppercase;

  text-decoration: none;

  border-left: 2px solid #12828b;

  padding-left: 11px

}



@media (max-width:1066px) {



  .buttonsNav a,

  .navbar-expand-lg .navbar-collapse,

  a .navbar-expand-lg .navbar-collapse {

    font-size: .9rem

  }

}



@media (max-width:1380px) {

  #logoText {

    display: none

  }

}



#btnDeconnexion,

#btnEntreprise,

#btnRefuser {

  background-color: #636363

}



.dropdown-menu {

  width: 100%;

  background-color: #e3edf8 !important

}



.headerWrap {

  background-image: linear-gradient(to right, #205082, rgba(18, 130, 139, .3)), url(../img/banner/bg5.png);

  background-size: 100% 100%;

  margin-top: 4rem

}



.header {

  height: 360px

}



.headerSubTitre {

  font-weight: 400;

  font-size: 1.8rem !important;

  margin-top: 50px

}



@media (max-width:990px) {

  .headerWrap {

    margin-top: 0

  }



  .login,

  .offre,

  .publication,

  .publications_cat {

    margin-top: 0 !important

  }

}



section {

  padding: 4rem 1rem 5rem 1rem;

  min-height: 50vh

}



@media (max-width:768px) {

  section {

    padding: 1.2rem

  }

}



.service {

  background: #e3edf8 !important;

  width: 44%;

  padding: 20px;

  overflow: hidden;

  color: inherit;

  border-radius: 10px;

  box-shadow: 0 .3em .8em rgba(0, 0, 0, .1);

  transition: all .4s;

  transition-timing-function: cubic-bezier(.16, 1, .29, .99);

  margin-top: -80px;

  border-top: 3px solid #12828b !important

}



.service:hover {

  transform: scale(1.05);

  box-shadow: 10px 10px 15px rgba(0, 0, 0, .3)

}



.service li {

  margin-top: 5px

}



@media (max-width:930px) {

  .service {

    margin-top: -40px

  }

}



@media (max-width:800px) {

  .service {

    width: 90%;

    margin-top: 20px

  }



  .header {

    height: 180px

  }



  .textService {

    display: none

  }



  .headerSubTitre {

    font-weight: 400;

    font-size: 1.3rem !important;

    margin-top: 30px

  }

}
/*--------------------------------------------------------------
# Hero Section (merged) — PREMIUM
--------------------------------------------------------------*/

#hero{
  width: 100%;
  position: relative;

  background-image: url("/img/banner/bg6.webp");
  background-size: cover;
  background-position: center;

  height: auto;
  min-height: 85vh;
  padding: 5.5rem 0 4rem 0;
}

/* overlay */
#hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle, rgba(0,0,0,.62), #205082);
  pointer-events: none;
}

/* subtle spotlight (premium touch) */
#hero::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 50% 38%, rgba(18,130,139,.18), rgba(0,0,0,0) 55%);
  pointer-events:none;
}

#hero .container{
  position: relative;
  z-index: 1;
}

/* headline block — glass */
.hero-head{
  max-width: 980px;
  margin: 0 auto;
  padding: 12px 16px;
  border-radius: 16px;

  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 18px 50px rgba(0,0,0,.25);
  backdrop-filter: blur(10px);
}

.hero-title{
  font-size: 36px;
  line-height: 1.15;
  letter-spacing: .02em;
  text-shadow: 0 10px 30px rgba(0,0,0,.35);
}

.hero-subtitle{
  font-size: 1.15rem;
  line-height: 1.4;
  margin-top: 12px;
  opacity: .88;
  text-shadow: 0 6px 18px rgba(0,0,0,.28);
}


/* cards layout */
.hero-cards{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 28px;
  max-width: 1180px;
  margin: 22px auto 0;
  align-items: stretch;
}

/* card — premium */
.hero-card{
  box-sizing: border-box;
  flex: 0 0 calc(50% - 14px);

  background: rgba(227,237,248,.88);
  border: 1px solid rgba(255,255,255,.45);
  border-radius: 16px;
  box-shadow: 0 14px 34px rgba(0,0,0,.18);

  overflow: hidden;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  transition: transform .25s ease, box-shadow .25s ease;
  position: relative;
}

/* premium top accent line (static, no animation) */
.hero-card::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height: 3px;
  background: linear-gradient(90deg, rgba(18,130,139,.95), rgba(32,80,130,.95));
}

/* subtle inner stroke */
.hero-card::after{
  content:"";
  position:absolute;
  inset: 10px;
  border-radius: 14px;
  border: 1px solid rgba(32,80,130,.10);
  pointer-events:none;
}

.hero-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 22px 55px rgba(0,0,0,.24);
}

/* image area — IMPORTANT: no crop */
.hero-card-media{
  height: 240px;
  padding: 14px;

  display: flex;
  align-items: center;
  justify-content: center;

  background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(227,237,248,.55));
  border-bottom: 1px solid rgba(32,80,130,.10);
}

.hero-card-media img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;

  filter: drop-shadow(0 10px 18px rgba(0,0,0,.18));
}

/* body */
.hero-card-body{
  padding: 16px 18px 18px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;

  background: rgba(255,255,255,.28);
}

.hero-card-title{
  color: #205082;
  font-weight: 800;
  font-size: 1.12rem;
  line-height: 1.25;
  min-height: 46px;
}

.hero-card-text{
  color: #2f2f2f;
  font-size: 1rem;
  line-height: 1.45;
}

.hero-card-link{
  margin-top: auto;
  color: #205082;
  font-weight: 800;
  font-size: 0.98rem;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.hero-card:hover .hero-card-link{
  color: #12828b;
}

/* responsive */
@media (max-width: 992px){
  .hero-title{ font-size: 30px; }
  .hero-card{ flex: 0 0 100%; }
  .hero-card-media{ height: 210px; }
}

@media (max-width: 800px){
  #hero{ padding: 4.2rem 0 3rem 0; min-height: auto; }
  .hero-subtitle{ font-size: 1.05rem; }
}

/* =========================================
   Carnets d’Annonces — Міні картки з пілкою і фоновим зображенням для логотипу
   ========================================= */
.ca-mini-card {
  display: flex;
  flex-direction: column;


  border-radius: 12px; /* Менше округлення */
  text-decoration: none;
  background: #fff;
  border: 1px solid rgba(32, 80, 130, 0.10);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
  position: relative;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
  height: 170px; /* Висота картки */
}

/* Ефект при наведенні */
.ca-mini-card:hover {
  transform: scale(1.05);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.12);
  border-color: rgba(18, 130, 139, 0.22);
}

/* Пілка без фону */
.ca-mini-top {
  display: flex;
  justify-content: center;
  margin: 10px; /* Прибираємо відступ */
}

.ca-mini-pill {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px; /* Залишаємо мінімальний паддінг */
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.8rem; /* Менший шрифт */
  color: #205082;
  background: transparent;
  border: 1px solid rgba(32, 80, 130, 0.12);
}

.ca-mini-pill::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(240, 176, 70, 0.95);
  margin-right: 6px;
  box-shadow: 0 0 0 4px rgba(240, 176, 70, 0.12);
}

/* Основний блок з логотипом */
.ca-mini-main {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  height: 100px; /* Збільшена висота блоку з логотипом */
  background-image: url(../img/bgCards.png); /* Фонове зображення для логотипу */
  background-size: cover;
  background-position: center;
  border-radius: 10px;
  margin-top: 0; /* Прибираємо зайві відступи */
  margin-bottom: 0; /* Забираємо зайві відступи */
  flex-grow: 1; /* Фон покриває всю площу */
}

/* Логотип */
.ca-mini-thumb {
  width: 150px;
  height: 150px; /* Збільшена висота та ширина логотипу */
 
  background: rgba(255, 255, 255, 0.7); /* Напівпрозорий фон під логотип */
  padding: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
 
}

.ca-mini-thumb img {
  
  height: 100%;
  object-fit: contain;
  display: block;
  border-radius: 10px;
}

/* Адаптивні налаштування */
@media (max-width: 576px) {
  .ca-mini-card {
    padding: 8px; /* Менший паддінг для мобільних */
    height: 160px; /* Менша висота для мобільних */
  }
  .ca-mini-main {
    height: 110px; /* Менша висота для мобільних */
  }
  .ca-mini-thumb {
    width: 100px; /* Збільшені логотипи для мобільних */
    height: 100px; 
  }
}
/*--------------------------------------------------------------

# Counts

--------------------------------------------------------------*/

.counts .content {

  padding: 30px 0;

}



.counts .content h3 {

  font-weight: 700;

  font-size: 34px;

  

}



.counts .content p {

  margin-bottom: 0;

}



.counts .content .count-box {

  padding: 20px 0;

  width: 100%;

}



.counts .content .count-box i {

  display: block;

  font-size: 36px;

  color: #12828b;

  float: left;

}



.counts .content .count-box span {

  font-size: 36px;

  line-height: 30px;

  display: block;

  font-weight: 700;



  margin-left: 50px;

}



.counts .content .count-box p {

  padding: 15px 0 0 0;

  margin: 0 0 0 50px;

 

  font-size: 14px;

  color: #3b3b3b;

}



.counts .content .count-box a {

  font-weight: 600;

  display: block;

  margin-top: 20px;

  color: #3b3b3b;

  font-size: 15px;

  font-family: "Poppins", sans-serif;

  transition: ease-in-out 0.3s;

}



.counts .content .count-box a:hover {

  color: #626262;

}



.counts .image {

  background: url("../img/about.png") center center no-repeat;

  background-size: cover;

  min-height: 400px;

}



@media (max-width: 991px) {

  .counts .image {

    text-align: center;

  }



  .counts .image img {

    max-width: 80%;

  }

}



@media (max-width: 667px) {

  .counts .image img {

    max-width: 100%;

  }

}

/*--------------------------------------------------------------

# Partenaires

--------------------------------------------------------------*/

.partenaires {

  padding-top: 20px;

}



.partenaires .swiper-slide img {



  transition: 0.3s;

  /* filter: grayscale(100); */

}



.partenaires .swiper-slide img:hover {

  transform: scale(1.05);

 

}



.partenaires .swiper-pagination {

  margin-top: 20px;

  position: relative;

}



.partenaires .swiper-pagination .swiper-pagination-bullet {

  width: 12px;

  height: 12px;

  background-color: #fff;

  opacity: 1;

  background-color: #ddd;

}



.partenaires .swiper-pagination .swiper-pagination-bullet-active {

  background-color: #12828b

}



/*--------------------------------------------------------------

# More Services

--------------------------------------------------------------*/

.more-services {

  padding-top: 20px;

}



.more-services .card {

  border: 0;

  padding: 160px 20px 20px 20px;

  position: relative;

  width: 100%;

  background-size: cover;

  background-repeat: no-repeat;

  background-position: center center;

  

}



.more-services .card-body {

  z-index: 10;

  background: rgba(255, 255, 255, 0.9);

  padding: 15px 30px;

 

  box-shadow: 0 .3em .8em rgba(0, 0, 0, .1);

  transition: all .4s;

  transition-timing-function: cubic-bezier(.16, 1, .29, .99);

  border-radius: 5px;

}



.more-services .card-title {

  font-weight: 700;

  text-align: center;

  margin-bottom: 15px;

}



.more-services .card-title a {

  color: #205082;

  text-decoration: none;

}



.more-services .card-text {

  color: #5e5e5e;

}



.more-services .read-more a {

  color: #777777;

  text-transform: uppercase;

  font-weight: 600;

  font-size: 12px;

  transition: 0.4s;

}



.more-services .read-more a:hover {

  text-decoration: underline;

}



.more-services .card:hover .card-body {

  transform: scale(1.05);

  box-shadow: 10px 10px 15px rgba(0, 0, 0, .3)

}

/*--------------------------------------------------------------

# Cta

--------------------------------------------------------------*/

.cta {

  background: radial-gradient(circle,  rgba(0, 0, 0, .6),#205082 ), url("../img/banner2.png") fixed center center;

  background-size: cover;

  padding: 55px 0;

}

.cta1 {

  background: radial-gradient(circle,  rgba(0, 0, 0, .6),#205082 ), url("../img/banner1.png") fixed center center;

  background-size: cover;

  padding: 55px 0;

}



.cta h3, .cta1 h3 {

  color: #fff;

  font-size: 28px;

  font-weight: 700;

}



.cta p, .cta1 p, .cta1 ul li{

  color: #fff;

}





@media (max-width: 1024px) {

  .cta, .cta1 {

    background-attachment: scroll;

  }

}







footer a,

footer a:hover {

  color: #212529;

  text-decoration: none;

  font-size: .9rem

}



#zoneFooter {

  background-color: #205082

}



.navbar {

  background-color: #e3edf8 !important

}



.footerTop {

  border-bottom: solid #fff 2px;

  padding-top: 2rem;

  font-size: .9rem

}



.footerTop ::placeholder {

  font-size: .9rem

}



.footerText {

  text-align: justify

}





.fa-paper-plane,

.fa-search {

  color: #fff !important

}



.btn {

  background-color: #12828b

}



.footerList {

  margin-left: -2rem;

  color: #212529

}



.footerList a {

  color: #e3edf8 !important

}



.footerContact p,

.footerMenu p {

  margin-bottom: 0 !important;

  color: #fff !important

}









.card-text {

  text-align: left

}



.sidebarList a {

  color: #212529;

  text-decoration: none

}



.sidebarList a:hover {

  color: #205082

}



.sidebarList li {

  border-bottom: solid #e0dfdb 1px;

  padding-bottom: .5rem;

  margin-bottom: 1rem

}



.sidebar ul {

  margin-left: -2rem

}



.post-wrap {

  margin: 0 auto;

  display: flex;

  justify-content: space-between;

  flex-wrap: wrap

}



.post-wrap-enc {

  display: flex;

  justify-content: center;

  flex-wrap: wrap

}



.post-item,

.post-item1,

.post-item2,

.post-item3,

.post-item4 {

  padding: .7rem;

  cursor: pointer;

  display: flex

}



.post-item,

.post-item2,

.post-item4 {

  width: 33.333%

}



.post-item1 {

  width: 25%

}



.post-item3 {

  width: 50%

}



.post-item *,

.post-item1 *,

.post-item2 *,

.post-item3 *,

.post-item4 * {

  transition: .3s linear

}



@media (max-width:1399.98px) {



  .post-item,

  .post-item1,

  .post-item2 {

    width: 50%

  }

}



@media (max-width:768px) {



  .post-item,

  .post-item1,

  .post-item2,

  .post-item3,

  .post-item4 {

    width: 100%

  }

}



@media (min-width:1400px) {

  .container .post-wrap {

    max-width: 1110px

  }

}



.item-content {

  border: solid #e0dfdb 1px;

  padding: 40px;

  background-color: #e3edf8;

  box-shadow: 5px 5px 15px -3px rgba(206, 245, 248, .5);

  width: 100%

}



.item-icon {

  margin-bottom: 20px

}







.item-icon:before {

  content: '';

  font-family: FontAwesome;

  color: #12828b;

  font-size: 3rem;

  line-height: 1

}



.item-icon.one:before {

  content: '\31'

}



.item-icon.two:before {

  content: '\32'

}



.item-icon.three:before {

  content: '\33'

}



.item-icon.adresse:before {

  content: '\f5a0'

}



.item-icon.phone:before {

  content: '\f2a0'

}



.item-icon.email:before {

  content: '\f658'

}



.item-icon.individual:before {

  content: '\f406'

}



.item-icon.group:before {

  content: '\f500'

}



.item-icon.graduation-cap:before {

  content: '\f19d'

}



.item-icon.hands-helping:before {

  content: '\f4c4'

}



.item-icon.search-dollar:before {

  content: '\f688'

}



.item-icon.landmark:before {

  content: '\f66f'

}



.item-icon.chart-line:before {

  content: '\f201'

}



.item-icon.hand-point-right:before {

  content: '\f0a4'

}



.item-icon.print:before {

  content: '\f02f '

}



.item-icon.bullhorn:before {

  content: '\f0a1 '

}



.item-icon.cloud:before {

  content: '\f382 '

}



.item-icon.microphone:before {

  content: '\f3c9 '

}



.item-icon.users:before {

  content: '\f0c0 '

}



.item-icon.piggy:before {

  content: '\f4d3 '

}



.item-icon.network:before {

  content: '\f6ff '

}



.item-icon.file:before {

  content: '\f570 '

}



.item-icon.desktop:before {

  content: '\f108 '

}



.item-icon.money-check:before {

  content: '\f53c '

}



.item-icon.shield-alt:before {

  content: '\f3ed '

}



.item-icon.business:before {

  content: '\f64a '

}



.item-icon.location:before {

  content: '\f5a0'

}



.item-icon.laptop_file:before {

  content: '\e51d';

}



.item-icon.project:before {

  content: '\f542';

}



.item-icon.money-bill:before {

  content: '\e528';

}



.item-icon.traction1:before {

  content: '\f2b5';

  font-size: 2rem;

  color: #205082

}



.item-icon.traction2:before {

  content: '\f4c0';

  font-size: 2rem;

  color: #205082

}



.item-icon.traction3:before {

  content: '\f201';

  font-size: 2rem;

  color: #205082

}



.item-icon.traction4:before {

  content: '\f570';

  font-size: 2rem;

  color: #205082

}



.item-icon.traction5:before {

  content: '\f66f';

  font-size: 2rem;

  color: #205082

}



.item-icon.price:before {

  content: '\f53a';

  font-size: 2rem;

  color: #205082

}



.item-icon.time:before {

  content: '\f64a';

  font-size: 2rem;

  color: #205082

}



.item-icon.accord:before {

  content: '\f021';

  font-size: 2rem;

  color: #205082

}



.item-icon.formation:before {

  content: '\f501';

  font-size: 2rem;

  color: #205082

}



.post-item1:hover .item-body h3,

.post-item1:hover .item-body ul,

.post-item1:hover .item-icon,

.post-item2:hover .item-body h3,

.post-item2:hover .item-body p .post-item3:hover .item-icon,

.post-item2:hover .item-body ul,

.post-item2:hover .item-icon,

.post-item3:hover .item-body h3,

.post-item3:hover .item-body p,

.post-item:hover .item-body .iconEntr,

.post-item:hover .item-body h3,

.post-item:hover .item-body h5,

.post-item:hover .item-body p,

.post-item:hover .item-icon {

  transform: translateY(-8px)

}



.item-body {

  font-size: 1rem

}



.item-body h3 {

  font-weight: 500;

  margin-bottom: 15px;

  transition-delay: 50ms

}



.item-body .iconEntr,

.item-body h5,

.item-body p,

.item-body ul {

  transition-delay: 0.1s

}



.item-footer {

  padding-top: 15px

}



.link {

  text-decoration: none;

  display: inline-block;

  overflow: hidden;

  position: relative;

  padding-right: 50px;

  font-size: .9rem;

  text-transform: uppercase;

  font-weight: 600;

  color: #12828b

}



.link:before {

  content: '';

  position: absolute;

  top: 0;

  left: 0;

  width: 100%;

  bottom: 0;

  height: .125rem;

  margin: auto;

  background: #12828b;

  transform: scaleX(.2);

  transform-origin: left center;

  z-index: 0;

  transition: .6s cubic-bezier(.6, .01, 0, 1)

}



.link span {

  display: inline-block;

  position: relative;

  transform: translateX(-200%);

  transition: .6s cubic-bezier(.6, .01, 0, 1);

  color: #606060

}



.post-item1:hover .link span,

.post-item2:hover .link span,

.post-item:hover .link span {

  transform: translateX(0)

}



.post-item1:hover .link:before,

.post-item2:hover .link:before,

.post-item:hover .link:before {

  transform-origin: right center

}



.conseil {

  margin-left: -2rem

}



.logoRealisations{

  width: 24%;

  background-color: #fff;

  border: 1px solid #dee2e6;

  margin-bottom: .6rem;

  border-radius: 5px

}



@media (max-width:960px) {



  .logoRealisations{

    width: 31%

  }

}



@media (max-width:760px) {



  .logoRealisations{

    width: 48%

  }

}



.imgSociete img {

  width: 100%;

  height: 100%;

  object-fit: contain

}



.postcard__preview-txt ul {

  margin-left: -2rem;

  list-style-type: disc

}



.postcard__preview-txt li {

  list-style: disc

}



.bourseList li:before,

.etudeList li:before,

.fincircList li:before,

.footerList li:before,

.listHistoire li:before,

.objectifsList li:before,

.offreList li:before,

.programmeList li:before,

.sidebarList li:before {

  content: '\f061';

  font-family: FontAwesome;

  display: inline-block;

  width: 1.5em;

  color: #12828b;

  padding-top: .5rem

}



.postcard a,

.postcard a:hover {

  text-decoration: none;

  transition: color .3s ease-in-out

}



#pageHeaderTitle {

  margin: 2rem 0;

  text-transform: uppercase;

  text-align: center;

  font-size: 2.5rem

}



.postcard {

  flex-wrap: wrap;

  display: flex;

  box-shadow: 0 4px 21px -12px rgba(0, 0, 0, .66);

  border-radius: 10px;

  margin: 0 0 2rem 0;

  overflow: hidden;

  position: relative;

  color: #fff

}



.postcard.light {

  background-color: #e1e5ea

}



.postcard .t-dark {

  color: #18151f

}



.postcard a {

  color: inherit

}



.postcard .h3,

.postcard h3 {

  margin-bottom: .5rem;

  font-weight: 500

}



.postcard .small {

  font-size: 80%;

  margin-top: .5rem

}



.postcard .postcard__title {

  font-size: 1.75rem

}



.postcard .postcard__img {

  max-height: 180px;

  width: 100%;

  object-fit: cover;

  position: relative

}



.postcard .postcard__img_link {

  display: contents

}



.postcard .postcard__bar {

  width: 100px;

  height: 10px;

  margin-bottom: 20px;

  border-radius: 5px;

  background-color: #424242;

  transition: width .2s ease

}



.postcard .postcard__text {

  padding: 1.5rem;

  position: relative;

  display: flex;

  flex-direction: column

}



.postcard .postcard__preview-txt {

  overflow: hidden;

  text-overflow: ellipsis;

  text-align: justify;

  height: 100%

}



.postcard:before {

  content: '';

  position: absolute;

  top: 0;

  right: 0;

  bottom: 0;

  left: 0;

  background-image: linear-gradient(-70deg, #424242, transparent 50%);

  opacity: 1;

  border-radius: 10px

}



.postcard:hover .postcard__bar {

  width: 230px

}



@media screen and (min-width:769px) {

  .postcard {

    flex-wrap: inherit

  }



  .postcard .postcard__title {

    font-size: 2rem

  }



  .postcard .postcard__tagbox {

    justify-content: start

  }



  .postcard .postcard__img {

    max-width: 300px;

    max-height: 100%;

    transition: transform .3s ease

  }



  .postcard .postcard__text {

    padding: 3rem;

    width: 100%

  }



  .postcard .media.postcard__text:before {

    content: '';

    position: absolute;

    display: block;

    background: #18151f;

    top: -20%;

    height: 130%;

    width: 55px

  }



  .postcard:hover .postcard__img {

    transform: scale(1.1)

  }



  .postcard:nth-child(odd) {

    flex-direction: row

  }



  .postcard:nth-child(2n+0) {

    flex-direction: row-reverse

  }



  .postcard:nth-child(odd) .postcard__text::before {

    left: -12px !important;

    transform: rotate(4deg)

  }



  .postcard:nth-child(2n+0) .postcard__text::before {

    right: -12px !important;

    transform: rotate(-4deg)

  }

}



@media screen and (min-width:1024px) {

  .postcard__text {

    padding: 2rem 3.5rem

  }



  .postcard__text:before {

    content: '';

    position: absolute;

    display: block;

    top: -20%;

    height: 130%;

    width: 55px

  }



  .postcard.light .postcard__text:before {

    background: #e1e5ea

  }

}



.postcard__subtitle p {

  margin-bottom: .2rem

}



.blue .postcard__title:hover {

  color: #205082

}



.blue .postcard__bar {

  background-color: #205082

}



.blue::before {

  background-image: linear-gradient(-30deg, rgb(32, 80, 130, .1), transparent 50%)

}



.blue:nth-child(2n)::before {

  background-image: linear-gradient(30deg, rgb(32, 80, 130, .1), transparent 50%)

}



@media screen and (min-width:769px) {

  .blue::before {

    background-image: linear-gradient(-80deg, rgb(32, 80, 130, .1), transparent 50%)

  }



  .blue:nth-child(2n)::before {

    background-image: linear-gradient(80deg, rgb(32, 80, 130, .1), transparent 50%)

  }

}



.programmeList li:before {

  margin-left: -2em;

  text-align: justify

}



.contentList {

  padding-bottom: 3rem;

  padding-left: 3rem

}



.programme1 {

  color: #205082;

  font-weight: 500;

  border: solid #e0dfdb 1px;

  padding: .7rem;

  background-color: #f7fafe;

  box-shadow: 5px 5px 15px -3px #a0cffe

}



.fincircText {

  padding-left: 2rem

}



.accordProgrammeFormation {

  border: none !important

}



.nav-link {

  color: #606060

}



.histoire img {

  width: 6rem

}



.traction1 {

  color: #205082

}



.traction2 {

  color: #97c8fa

}



.traction1,

.traction2 {

  font-weight: 700

}



.btnAide::after,

.btnTraction::after {

  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='rgba(18, 130, 139, 1)' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z' clip-rule='evenodd'/%3e%3c/svg%3e") !important

}



.btnTraction:not(.collapsed)::after .btnAide:not(.collapsed)::after {

  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='rgba(108, 117, 125, 1)' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill-rule='evenodd' d='M7.646 4.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1-.708.708L8 5.707l-5.646 5.647a.5.5 0 0 1-.708-.708l6-6z' clip-rule='evenodd'/%3e%3c/svg%3e") !important

}



.btnAide:not(.collapsed),

.btnProgrForm:not(.collapsed),

.btnTraction:not(.collapsed) {

  background-color: #fff;

  box-shadow: none

}



.btnAide:not(.collapsed) {

  border-bottom: 1px solid rgba(0, 0, 0, .125)

}



.btnAide:focus,

.btnProgrForm:focus,

.btnTraction:focus {

  box-shadow: none;

  border-color: #fff

}



.btnProgrForm:not(.collapsed) {

  background-color: #12828b;

  box-shadow: none;

  color: #fff

}



.titleProgForm {

  font-size: 1.3rem

}



.circleFormation {

  border: 5px solid #12828b;

  height: 10rem;

  border-radius: 50%;

  width: 10rem;

  display: table

}



@media (max-width:516px) {

  .chiffresFormation {

    display: none

  }

}



.textCircleFormation {

  display: table-cell;

  vertical-align: middle;

  font-size: 3rem;

  font-weight: 700

}



.btnProgrForm:focus {

  box-shadow: none;

  border-color: #12828b

}



.accordion-item_questions,

.accordion-item_traction {

  border-right: none;

  border-left: none

}



.accordion-item_formation {

  border-right: none;

  border-left: none;

  border-top: none

}



.accordion-item_formation ul li p,

.accordion-item_questions ul li p,

.accordion-item_traction ul li p {

  font-size: 1rem

}



.accordion-item_formation ul li,

.accordion-item_questions ul li,

.accordion-item_traction ul li {

  margin-bottom: 2rem

}



.accordion-item_formation hr,

.accordion-item_questions hr,

.accordion-item_traction hr {

  margin-top: -.1rem

}



.accordion-button::after {

  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='rgba(18, 130, 139, 1)' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill-rule='evenodd' d='M8 0a1 1 0 0 1 1 1v6h6a1 1 0 1 1 0 2H9v6a1 1 0 1 1-2 0V9H1a1 1 0 0 1 0-2h6V1a1 1 0 0 1 1-1z' clip-rule='evenodd'/%3e%3c/svg%3e");

  transform: scale(.7) !important

}



.accordion-button:not(.collapsed)::after {

  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='rgba(255, 255, 255, 1)' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill-rule='evenodd' d='M0 8a1 1 0 0 1 1-1h14a1 1 0 1 1 0 2H1a1 1 0 0 1-1-1z' clip-rule='evenodd'/%3e%3c/svg%3e")

}



.accordion-item h2 {

  display: inline

}



.carousel-inner .carousel-item-next,

.carousel-inner .carousel-item-prev,

.carousel-inner .carousel-item.active {

  display: flex

}



.card-wrapper {

  display: flex;

  width: 32%

}



@media (min-width:768px) {



  .carousel-inner .carousel-item-end.active,

  .carousel-inner .carousel-item-next {

    transform: translateX(25%)

  }



  .carousel-inner .carousel-item-prev,

  .carousel-inner .carousel-item-start.active {

    transform: translateX(-25%)

  }



  .card-wrapper {

    width: 49%

  }

}



.carousel-inner .carousel-item-end,

.carousel-inner .carousel-item-start {

  transform: translateX(0)

}



.textHistoire {

  font-size: 1rem

}



.year {

  font-weight: 900;

  font-size: 2rem;

  color: #822a20

}



.cardHistoire_bar {

  width: 100%;

  height: 3px;

  border-radius: 5px;

  background-color: #205082

}



.our-team {

  padding: 20px 15px 30px;

  border-radius: 15px;

  text-align: center

}



.our-team .pic {

  display: inline-block;

  width: 80%;

  background: #fff;

  padding: 3px;

  margin-bottom: 25px

}



.our-team:hover .pic {

  background: #205082;

  border-radius: 50%

}



.pic img {

  width: 100%;

  height: auto;

  border-radius: 50%

}



.our-team .title {

  display: block;

  font-size: 20px;

  font-weight: 700;

  margin: 0 0 7px 0

}



.our-team .post {

  display: block;

  font-size: .9rem;

  text-transform: uppercase;

  margin-bottom: .2rem;

  color: #6c757d

}



.our-team .email {

  font-size: 1rem

}



.our-team .social {

  padding: 1rem 0 1rem 0;

  margin: 0;

  list-style: none

}



.our-team .social li {

  display: inline-block;

  margin-right: 5px

}



.our-team .social li a {

  display: block;

  width: 30px;

  height: 30px;

  line-height: 30px;

  border-radius: 50%;

  font-size: 15px;

  color: #205082 !important;

  border: 1px solid #205082;

  transition: all .5s ease 0s;

  text-decoration: none

}



.our-team:hover .social li a {

  background: #205082;

  color: #fff !important

}



@media only screen and (max-width:990px) {

  .our-team {

    margin-bottom: 30px

  }

}



.carnet {

  margin-top: 10rem

}



.tablinksSocietes {

  background-color: #205082;

  color: #fff;

  padding: 6px 12px;

  border: none;

  border-radius: 5px

}



.tablinksSocietes:hover {

  background-color: #fff;

  color: #205082;

  border: #205082

}



.dropdown {

  margin-right: 10px

}



.dropdown-menu {

  display: none

}



.menu-active {

  display: block

}



.companieBtn {

  background-color: #205082

}



#deconnexionBtn {

  background-color: #6c757d !important

}



.titleError {

  font-size: 20rem !important;

  margin: 5rem

}



.tableCA {

  width: 49%;

  border-radius: 5px

}



.scrollCA {

  height: 20em;

  overflow: hidden;

  overflow-y: scroll

}



@media (max-width:1200px) {

  .tableCA {

    width: 49%

  }

}



@media (max-width:993px) {

  .imageLogo {

    display: none

  }

}



@media (max-width:770px) {

  .tableCA {

    width: 100%

  }

}



.titleLogoCA {

  background-color: #205082

}

/* Supprimer la ligne sous les boutons */

.titleLogoCA .nav-tabs {

    border-bottom: none;

}



/* Style de base des boutons : pas de bordure */

.titleLogoCA .nav-tabs .nav-link {

    color: white;

    background-color: transparent;

    border: 2px solid transparent; /* Bordure invisible au repos */

    font-weight: 500;

   

    transition: background-color 0.3s, color 0.3s, border-color 0.3s;

    border-radius: 5px;

    padding: 8px 16px;

    cursor: pointer;

}



/* Onglet actif : fond transparent + bordure blanche visible */

.titleLogoCA .nav-tabs .nav-link.active {

    background-color: transparent;

    border-color: white;

    color: white;

}



/* Effet hover : changement de fond */

.titleLogoCA .nav-tabs .nav-link:hover {

    background-color: rgba(255, 255, 255, 0.2);

    color: #f0f0f0;

}



.titleAcheteurs {

  color: #468a12;

  text-transform: uppercase

}



.titleVendeurs {

  color: #8a1a12;

  text-transform: uppercase

}



.btnPasserAnnonce {

  display: block;

  width: 100%;

  padding: 10px 20px 10px 20px;

  text-align: center

}



.textPasserAnnonce {

  background-color: #205082;

  padding: 10px

}



.carnetCards {

  width: 23%;

  margin-bottom: 2rem;

  overflow: hidden;

  transition: .5s;

  padding: 0

}



.carnetCards:hover {

  transform: scale(1.05);

  box-shadow: 10px 10px 15px rgba(0, 0, 0, .3)

}



@media (max-width:1300px) {

  .carnetCards {

    width: 30%

  }

}



@media (max-width:960px) {

  .carnetCards {

    width: 30%

  }

}



@media (max-width:768px) {

  .carnetCards {

    width: 49%

  }

}



@media (max-width:600px) {

  .carnetCards {

    width: 100%

  }

}



.imgSociete {

  border-top: 3px solid #12828b;

}



.imgSociete img {

  width: 70%;

}



#part,

#entr {

  text-decoration: none;

}



.imgCA {

  height: 20rem;

  background-position: center;

  background-repeat: no-repeat;

  background-size: cover;

  text-align: center;

  color: white;

  font-size: 1.7rem;

  font-weight: 600;

  justify-content: center;

  align-items: center;

  padding-left: 4rem;

  padding-right: 4rem;

  transition: 0.5s;

  border: 5px solid white;

  cursor: grab;

}



.imgCA:hover {

  transform: scale(1.05);

  box-shadow: 10px 10px 15px rgba(0, 0, 0, 0.3);

}



.CApart {

  background-image: linear-gradient(to right,

          rgba(32, 80, 130, 0.6),

          rgba(18, 130, 139, 0.6)),

      url(../img/CA_part.png);

  background-size: 100% 100%;



}



.CAentr {

  background-image: linear-gradient(to right,

          rgba(32, 80, 130, 0.6),

          rgba(18, 130, 139, 0.6)),

      url(../img/CA_entr.png);

  background-size: 100% 100%;



}



.lienCompte {

  text-decoration: none;

  color: #12828b;

  font-weight: 700;

}



.mainBlock {

  background-color: #e3edf8;

  border: #e0dfdb 1px solid;

  border-radius: 5px

}



.banner {

  background-size: cover;

  text-align: center;

  border-radius: 5px

}



.banner1 {

  background-image: linear-gradient(to right, #205082, rgba(18, 130, 139, .6)), url(../img/banner1.png);

  background-size: 100% 100%

}



.banner2 {

  background-image: linear-gradient(to right, #205082, rgba(18, 130, 139, .6)), url(../img/banner2.png);

  background-size: 100% 100%

}



.banner3 {

  background-image: linear-gradient(to right, #205082, rgba(18, 130, 139, .6)), url(../img/banner3.png);

  background-size: 100% 100%

}



.banner4 {

  background-image: linear-gradient(to right, #205082, rgba(18, 130, 139, .6)), url(../img/banner4.png);

  background-size: 100% 100%

}



@media (max-width:600px) {

  .carnetCards {

    width: 100%

  }

}



@media (max-width:800px) {

  .banner h2 {

    font-size: 1.2rem

  }

}


.breadcrumb-item a {

  text-decoration: none;

  color: #205082;

  font-weight: 600

}



.breadcrumb-item {

  font-size: 1rem

}



.annonce_detail {

  max-height: 63vh;

  overflow-y: scroll

}



.cursor {

  cursor: pointer

}



.inline {

  display: inline

}



.contact {

  border-bottom: solid #e0dfdb 1px

}



.map_image path {

  fill: #e0dfdb;

  stroke: white;

  stroke-width: 1px;

  transition: fill .3s;

  width: 50%

}



path:hover {

  fill: #12828b;

  cursor: grab

}



.active {

  fill: #e0dfdb

}



.coordinates {

  display: none;

  font-size: .7rem

}



.coordinates .fas,

.coordinates span {

  font-size: .8rem

}



.coordinates b,

.coordinates strong {

  font-size: .9rem

}



.coordinates table td,

.coordinates table th {

  padding-left: 1rem

}



.lienConnexion a {

  color: #205082

}



.titleTableIPO th {

  background: #205082;

  color: #fff

}



.IPO tbody td {

  border: 1px solid #d3d3d3

}



.IPO th {

  padding: 1.5rem

}



.IPO h6 span {

  text-transform: uppercase;

  letter-spacing: .2rem;

  font-weight: 800

}



.IPO h6 {

  padding-bottom: .5rem;

  line-height: 1.5;

  color: #fff

}





    :root {

        --accent-1: #0ea5a4; /* teal */

        --accent-2: #7c3aed; /* purple */

        --accent-3: #f59e0b; /* amber */

     --accent-4: #ef4444; /* red */

        --glass: rgba(255, 255, 255, 0.6);

        --card-shadow: 0 10px 30px rgba(15, 23, 42, 0.06);

        --radius: 24px;

    }



    .steps {

        display: flex;

        flex-wrap: wrap;

        gap: 2.5rem;

       justify-content: center;

    }



    .step-card {

        background: linear-gradient(180deg, rgba(255, 255, 255, 0.8), var(--card));

        border-radius: var(--radius);

        padding: 2.5rem 1.75rem;

        box-shadow: var(--card-shadow);

        transition: transform 0.35s ease-in-out, box-shadow 0.35s;

        border-top: 6px solid rgba(0, 0, 0, 0.03);

        width: 48%; /* 2 cards per row */

    }



    /* Effet au survol */

    .step-card:hover {

        transform: translateY(-10px) scale(1.01);

        box-shadow: 0 18px 40px rgba(15, 23, 42, 0.11);

    }



    .step-num {

        position: absolute;

        left: 12px;

        top: -18px;

        font-weight: 900;

        color: rgba(15, 23, 42, 0.06);

        font-size: clamp(64px, 10vw, 128px);

        line-height: 0.8;

        pointer-events: none;

        user-select: none;

        letter-spacing: -6px;

    }



    .step-card .icon {

        font-size: 3rem; /* Taille de l'icône */

        margin: 0 auto 1rem;

        color: var(--accent-1);

    }



    .step-card h2 {

        font-size: 1.25rem;

        margin: 0 0 0.75rem 0;

        text-align: center;

    }



    .step-card ul {

        list-style: none;

        padding: 0;

        margin: 0;

        color: var(--muted);

        font-size: 0.98rem;

    }



    .step-card ul li {

        margin-bottom: 0.9rem;

        position: relative;

        padding-left: 1.6rem;

    }



    .step-card ul li:before {

        content: "";

        position: absolute;

        left: 0.2rem;

        top: 0.6rem;

        width: 10px;

        height: 10px;

        border-radius: 50%;

        background: var(--accent-1);

        box-shadow: 0 2px 8px rgba(14, 165, 164, 0.14);

    }



    .step-card.accent-1 {

        border-top-color: var(--accent-1);

    }



    .step-card.accent-2 {

        border-top-color: var(--accent-2);

    }



    .step-card.accent-3 {

        border-top-color: var(--accent-3);

    }

   .step-card.accent-4 {

        border-top-color: var(--accent-4);

    }

    @media (max-width: 768px) {

        .step-card {

            width: 100%; /* 1 carte par ligne sur mobile */

        }

    }



    /* Accessibilité : focus */

    .step-card:focus-within {

        outline: 3px solid rgba(124, 58, 237, 0.12);

        outline-offset: 6px;

    }

.card-text {

  font-size: 1rem

}



.contact,

.contact .form-select {

  font-size: .9rem

}



.CACards {

  width: 24%;

  margin-bottom: 2rem;

  transition: .5s;

  font-size: .9rem

}



.CACards:hover {

  transform: scale(1.05);

  box-shadow: 10px 10px 15px rgba(0, 0, 0, .3)

}



@media (max-width:1260px) {

  .CACards {

    width: 49%

  }

}



@media (max-width:760px) {

  .CACards {

    width: 100%

  }

}



.lienFormation a {

  text-decoration: none;

  color: #212529

}



.realisationsCard a,

.textRealisations {

  margin-top: 2rem;

  font-size: .9rem

}



.realisationsCard a {

  text-decoration: none;

  color: #212529

}



.realisationsCard {

  width: 15%;

  height: 100%;

  margin-left: 5px;

  margin-right: 5px;

  margin-bottom: 2rem

}



@media (max-width:1200px) {

  .realisationsCard {

    width: 19%

  }

}



@media (max-width:986px) {

  .realisationsCard {

    width: 31%

  }

}



@media (max-width:760px) {

  .realisationsCard {

    width: 47%

  }

}



.lienModalRealisations:hover {

  cursor: pointer

}



.cl {

  text-align: justify;

  border-width: 4px;

  border-style: double;

  border-color: #205082;

  padding: 1rem

}



.conditions_generales_utilisation,

.infoSociete,

.login,

.mentions_legales,

.programme,

.publication,

.publications_cat,

.reinitialiser_password,

.reset_password,

.reset_password-email,

.resultat_diagnostic,
.politique_confidentialite
 {

  margin-top: 7rem

}



@media (max-width:990px) {



  .infoSociete,

  .programme {

    margin-top: 0

  }

}



.imginvitFormation {

  position: relative;

  width: 100%

}



.textInvitForm {

  position: absolute;

  width: 100%;

  height: auto;

  top: 10%;

  left: 2%

}



.textInvit {

  letter-spacing: .2em;

  font-size: .7em

}



.titleInvit {

  margin: 1.5em 0 1.5em 0

}



.dateInvit {

  letter-spacing: .1em;

  font-size: .85em

}



@media (max-width:1650px) {

  .titleInvit {

    margin: 1em 0 1em 0

  }

}



@media (max-width:1530px) {

  .titleInvit {

    margin: .5em 0 .5em 0

  }

}



@media (max-width:1390px) {

  .titleInvit {

    font-size: 1.2em

  }



  .textInvit {

    letter-spacing: 0

  }

}



@media (max-width:1330px) {

  .buttonsInvitForm a {

    font-size: .7em;

    padding: .3em

  }



  .dateInvit {

    letter-spacing: 0;

    font-size: .7em

  }

}



@media (max-width:1280px) {

  .imageinvitForm {

    display: none

  }



  .imageInvit {

    display: none

  }



  .logoInvit {

    display: none

  }



  .textInvitForm {

    position: relative

  }

}



.lienModalFormation {

  cursor: pointer

}







.companieDescription {

  font-size: .9rem

}



.postCards {

  width: 23%;

  height: auto;

  overflow: hidden;

  box-shadow: 0 .3em .8em rgba(0, 0, 0, .1);

  transition: all .4s;

  transition-timing-function: cubic-bezier(.16, 1, .29, .99);

  padding: 0

}



.postCards1 {

  width: 90%;

  height: auto;

  overflow: hidden;

  transition: .5s;

  padding: 0;

  margin-right: 2rem

}

.postCards img {

  transition: 0.5s;

}



.postCards img:hover {

  transform: scale(1.1);

}









@media (max-width:1440px) {

  .postCards {

    width: 26%

  }

}



@media (max-width:1250px) {

  .postCards {

    width: 32%

  }

}



@media (max-width:1070px) {

  .postCards {

    width: 40%

  }



  .imgPost {

    height: 13rem

  }

}



@media (max-width:992px) {

  .postCards {

    width: 30% !important

  }

}



@media (max-width:820px) {

  .postCards {

    width: 35% !important

  }

}



@media (max-width:700px) {

  .postCards {

    width: 40% !important

  }

}



@media (max-width:580px) {

  .postCards {

    width: 60% !important

  }

}



@media (max-width:440px) {

  .postCards {

    width: 70% !important

  }



  .imgPost {

    height: 15rem

  }

}



@media (max-width:360px) {

  .postCards {

    width: 90% !important

  }

}



.imgPost {

  width: 100%;

  height: 10rem

}







.postCard-top {

  font-size: smaller

}



.imgPostPrincipal {

  height: 18rem;

  margin: auto

}



.imgPostContenu {

  height: 30rem;

  margin: auto

}



.block {

  display: block;

  width: 100%

}



:root {

  --primary: #12828b;

  --secondary: #bfc0c0;

  --white: #fff;

  --text-clr: #5b6475;

  --header-clr: #25273d;

  --next-btn-hover: #12828b;

  --back-btn-hover: #636363

}



.wrapper .headerDiagnostic {

  display: flex;

  justify-content: center

}



.wrapper .headerDiagnostic .title {

  font-size: .9rem;

  color: #12828b;

  font-weight: 800

}



.wrapper .headerDiagnostic ul {

  display: flex

}



.wrapper .headerDiagnostic ul li {

  margin-right: 50px;

  position: relative

}



.wrapper .headerDiagnostic ul li:last-child {

  margin-right: 0

}



.wrapper .headerDiagnostic ul li:before {

  content: '';

  position: absolute;

  top: 30%;

  transform: translateY(-50%);

  left: 55px;

  width: 100%;

  height: 2px;

  background: var(--secondary)

}



.wrapper .headerDiagnostic ul li:last-child:before {

  display: none

}



.wrapper .headerDiagnostic ul li div {

  padding: 5px;

  border-radius: 50%

}



.wrapper .headerDiagnostic ul li p {

  width: 50px;

  height: 50px;

  background: var(--secondary);

  color: var(--white);

  text-align: center;

  line-height: 50px;

  border-radius: 50%

}



.wrapper .headerDiagnostic ul li.active:before {

  background: var(--primary)

}



.wrapper .headerDiagnostic ul li.active p {

  background: var(--primary)

}



.wrapper .form_wrap {

  margin-bottom: 35px

}



.wrapper .form_wrap p {

  color: #205082;

  font-weight: 700;

  text-transform: uppercase

}



.wrapper .form_wrap h2 {

  color: var(--header-clr);

  text-align: center;

  text-transform: uppercase;

  margin-bottom: 20px

}



.wrapper .btns_wrap {

  margin: 0 auto

}



.wrapper .btns_wrap .common_btns {

  display: flex;

  justify-content: space-between

}



.wrapper .btns_wrap .common_btns.form_1_btns {

  justify-content: flex-end

}



.wrapper .btns_wrap .common_btns button {

  border: 0;

  padding: 12px 15px;

  background: var(--primary);

  color: var(--white);

  width: 135px;

  justify-content: center;

  display: flex;

  align-items: center;

  font-size: 16px;

  border-radius: 3px;

  transition: .5s ease;

  cursor: pointer

}



.wrapper .btns_wrap .common_btns button.btn_back {

  background: var(--secondary)

}



.wrapper .btns_wrap .common_btns button.btn_next .icon {

  display: flex;

  margin-left: 10px

}



.wrapper .btns_wrap .common_btns button.btn_back .icon {

  display: flex;

  margin-right: 10px

}



.wrapper .btns_wrap .common_btns button.btn_done:hover,

.wrapper .btns_wrap .common_btns button.btn_next:hover {

  background: var(--next-btn-hover)

}



.wrapper .btns_wrap .common_btns button.btn_back:hover {

  background: var(--back-btn-hover)

}



@media (max-width:500px) {

  .wrapper .headerDiagnostic ul {

    display: none

  }

}



.footerDescription {

  font-size: .8rem

}



@media (max-width:991px) {

  .tab-content>.tab-pane {

    display: block;

    opacity: 1

  }

}



#analyse_financiere-tab.nav-link.active,

#carnetsAnnonces-tab.nav-link.active,

#communicationFin-tab.nav-link.active,

#compte-tab.nav-link.active,

#contrat_liquidite-tab.nav-link.active,

#cotation-tab.nav-link.active,

#depannage-tab.nav-link.active,

#dispositifFinancementLocal-tab.nav-link.active,

#etudeFaisabilite-tab.nav-link.active,

#etude_optimisation-tab.nav-link.active,

#financeCirculaire-tab.nav-link.active,

#formation-tab.nav-link.active,

#initiation-tab.nav-link.active,

#introduction-tab.nav-link.active,

#investir-tab.nav-link.active,

#lever_fonds-tab.nav-link.active,

#reglesEuronext-tab.nav-link.active,

#tenueDeRegistres-tab.nav-link.active {

  color: #12828b;

  font-weight: 700;

  text-transform: uppercase;

  border-bottom: 2px solid #12828b;

  border-top: none;

  border-left: none;

  border-right: none;

  font-size: 1.1rem

}



#analyse_financiere-tab.nav-link,

#carnetsAnnonces-tab.nav-link,

#communicationFin-tab.nav-link,

#compte-tab.nav-link,

#contrat_liquidite-tab.nav-link,

#cotation-tab.nav-link,

#depannage-tab.nav-link,

#dispositifFinancementLocal-tab.nav-link,

#etudeFaisabilite-tab.nav-link,

#etude_optimisation-tab.nav-link,

#financeCirculaire-tab.nav-link,

#formation-tab.nav-link,

#initiation-tab.nav-link,

#introduction-tab.nav-link,

#investir-tab.nav-link,

#lever_fonds-tab.nav-link,

#reglesEuronext-tab.nav-link,

#tenueDeRegistres-tab.nav-link {

  color: #636363;

  text-transform: uppercase

}



.iconEntr {

  color: #12828b;

  font-size: 2rem;

  margin-right: 30px

}



.checkQuest {

  color: #12828b;

  font-weight: 700

}

/*--------------------------------------------------------------

# Video

--------------------------------------------------------------*/

/* Styles pour le conteneur et la section */

.container.video_play {

  position: relative;

  text-align: center;

}



/* Bouton pulsant */

.video_play .pulsating-play-btn {

  position: absolute;

  left: 50%;

  top: 50%;

  transform: translate(-50%, -50%);

  width: 94px;

  height: 94px;

  background-color: rgba(0, 123, 255, 0.7); /* Couleur bleue translucide */

  border-radius: 50%;

  display: flex;

  justify-content: center;

  align-items: center;

  text-decoration: none;

  box-shadow: 0 0 10px rgba(0, 123, 255, 0.5);

  animation: pulse 2s infinite;

}



.video_play .pulsating-play-btn:before {

  content: '';

  position: absolute;

  width: 20px;

  height: 20px;

  background-color: white;

  clip-path: polygon(0% 0%, 100% 50%, 0% 100%);

}



/* Effet de pulsation */

@keyframes pulse {

  0% {

  transform: translate(-50%, -50%) scale(1);

  box-shadow: 0 0 10px rgba(0, 123, 255, 0.5);

  }

  50% {

  transform: translate(-50%, -50%) scale(1.05);

  box-shadow: 0 0 20px rgba(0, 123, 255, 0.6);

  }

  100% {

  transform: translate(-50%, -50%) scale(1);

  box-shadow: 0 0 10px rgba(0, 123, 255, 0.5);

  }

}



/* Positionnement du texte sous la vidéo */

.video_play small {

  display: block;

  margin-top: 10px;

  font-size: 14px;

  color: #555;

}
   /* Corporate color */
  .docsAccordionIcon {
    color: #12828b;
  }

  .badge-corporate {
    background-color: #12828b;
  }

  /* Accordion styling */
  #docsAccordion .accordion-button {
    font-weight: 600;
    background-color: #f8f9fa;
  }

  #docsAccordion .accordion-button:not(.collapsed) {
    background-color: #eef7f8;
    color: #12828b;
    box-shadow: none;
  }

  #docsAccordion .accordion-button:focus {
    box-shadow: none;
  }
  /* прибрати стандартну bootstrap стрілку */
  #docsAccordion .accordion-button::after {
    display: none;
  }

  /* плюс/мінус */
  .acc-plusminus {
    width: 18px;
    display: inline-flex;
    justify-content: center;
    font-weight: 700;
    color: #12828b;
    font-size: 1.05rem;
    line-height: 1;
  }

  /* коли закрито -> плюс */
  #docsAccordion .accordion-button.collapsed .acc-plusminus::before {
    content: "+";
  }

  /* коли відкрито -> мінус */
  #docsAccordion .accordion-button:not(.collapsed) .acc-plusminus::before {
    content: "−";
  }

  /* Mot du président text same size as links */
  .mot-president-text {
    font-size: 0.92rem; /* як doc-title */
    font-weight: 400;
    line-height: 1.55;
    color: #212529;
  }
  /* Document list improvements */
   .doc-item {
    padding: 7px 0;
    border-bottom: 1px solid #f0f0f0;
  }

  .doc-item:last-child {
    border-bottom: none;
  }

  .doc-link {
    color: #212529;
  }

  .doc-link:hover {
    color: #12828b;
  }

   .mot-president-text {
    font-size: 0.92rem; /* як doc-title */
    font-weight: 400;
    line-height: 1.55;
    color: #212529;
  }

  /* doc link text */
  .doc-title {
    font-size: 0.92rem;
    font-weight: 400;
  }

  .doc-date {
    font-size: 0.80rem;
    color: #9aa3ab;
    white-space: nowrap;
  }
/* ===== CIIB Auth UI (Register / Complete Profile / Confirm / Reset) ===== */

.auth-shell,
.confirm-shell{
  background:
    radial-gradient(1100px 520px at 25% 20%, rgba(32,80,130,.10), transparent 60%),
    radial-gradient(900px 480px at 85% 35%, rgba(18,130,139,.12), transparent 55%),
    #f6f9fc;
  padding: 48px 0;
}

/* Titles */
.reg-title{
  font-weight: 800;
  color: #205082;
  margin: 0 0 6px 0;
}
.reg-subtitle{
  color: #6b7280;
  font-size: 14px;
  margin: 0 0 18px 0;
}

/* Card layout */
.reg-card,
.confirm-card{
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 12px 40px rgba(0,0,0,.10);
}

/* Ensure both columns stretch equally */
.reg-card .row.g-0{ align-items: stretch; }

.reg-left{
  padding: 44px 42px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height: 520px;
}

/* Right image panel */
.reg-right{
  position: relative;
  height: 100%;
  min-height: 520px;
  background:
    linear-gradient(135deg, rgba(32,80,130,.85), rgba(18,130,139,.75)),
    url(/img/banner/inscriptionForm.png);
  background-size: cover;
  background-position: center;
}

/* soft highlight */
.reg-right::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.10), transparent 55%);
  pointer-events:none;
}

/* darker veil for readability of centered text */
.reg-right::before{
  content:"";
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.18);
  pointer-events:none;
}

/* Centered text overlay */
.reg-right-center{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding: 24px;
  color:#fff;
  z-index: 1;
}
.reg-right-kicker{
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .85rem;
  opacity: .95;
  margin-bottom: 10px;
}
.reg-right-title{
  font-weight: 900;
  font-size: 1.9rem;
  line-height: 1.15;
  margin-bottom: 10px;
}
.reg-right-subtitle{
  max-width: 360px;
  font-size: 1rem;
  line-height: 1.45;
  opacity: .95;
}

/* Form labels + inputs */
.reg-label{
  font-size: .82rem;
  color: #6b7280;
  margin-bottom: .35rem;
}

.reg-input{
  border-radius: 12px !important;
  padding: 12px 14px !important;
}

/* Focus ring in CIIB color */
.reg-input:focus{
  border-color: rgba(18,130,139,.75);
  box-shadow: 0 0 0 4px rgba(18,130,139,.14);
}

/* Terms block */
.reg-terms{
  display:flex;
  gap:.6rem;
  align-items:flex-start;
  margin: 6px 0 14px;
}
.reg-terms a{ text-decoration:none; }

.reg-hint{
  font-size: .85rem;
  color: #6b7280;
  margin-top: 10px;
}

.reg-bottom-note{
  max-width: 980px;
  margin: 18px auto 0;
  color: #6b7280;
  font-size: .95rem;
  text-align: center;
}

/* Buttons */
.btn-ciib{
  background: linear-gradient(90deg, #205082, #12828b);
  border: none;
  border-radius: 12px;
  padding: 12px 16px;
  font-weight: 700;
  box-shadow: 0 10px 22px rgba(32,80,130,.18);
}
.btn-ciib:hover{ filter: brightness(.98); }

.btn-ghost{
  border-radius: 12px;
  padding: 12px 16px;
  font-weight: 700;
  border: 1px solid rgba(32,80,130,.25);
  color: #205082;
  background: #fff;
  text-decoration: none;
}
.btn-ghost:hover{
  background: rgba(32,80,130,.06);
  color: #205082;
}

/* ===== Eye button (Bootstrap Icons) ===== */
.input-group .reg-input{
  border-top-right-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}
.input-group > .form-control,
.input-group > .btn{
  height: 52px;
}
.eye-btn{
  border-top-left-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
  border-top-right-radius: 12px !important;
  border-bottom-right-radius: 12px !important;

  min-width: 54px;
  padding: 0 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: #fff;
  border-color: #d1d5db;
  color: #205082;
}
.eye-btn:hover{
  background: rgba(18,130,139,.06);
  border-color: rgba(18,130,139,.35);
  color: #12828b;
}
.eye-btn:focus,
.eye-btn:focus-visible{
  box-shadow: 0 0 0 .2rem rgba(18,130,139,.20);
}
.eye-btn i{
  font-size: 1.05rem;
  line-height: 1;
}

/* ===== Confirmation text helpers ===== */
.confirm-steps{
  padding-left: 18px;
  color: #475569;
}
.confirm-steps li{ margin-bottom: .5rem; }

.confirm-note{
  color: #6b7280;
  font-size: .95rem;
  line-height: 1.5;
}

/* ===== Responsive ===== */
@media (max-width: 991px){
  .auth-shell,
  .confirm-shell{ padding: 22px 0; }

  .reg-left{ min-height: auto; padding: 30px 22px; }
  .reg-right{ min-height: 240px; }

  .reg-right-title{ font-size: 1.5rem; }
  .reg-right-subtitle{ font-size: .95rem; }
}
/* Fix global reset only inside Privacy Policy page */
.politique_confidentialite p { 
  margin: 0 0 12px; 
}

.politique_confidentialite h5 {
  margin: 18px 0 10px;
  font-weight: 800;
  color: #205082;
}

.politique_confidentialite ul {
  list-style: disc;
  padding-left: 1.25rem;
  margin: 8px 0 16px;
}

.politique_confidentialite ul li {
  list-style: disc;           /* because global * killed it */
  margin-bottom: .45rem;
  line-height: 1.55;
}

.politique_confidentialite a {
  text-decoration: underline; /* restore links */
  color: #205082;
}

.politique_confidentialite a:hover {
  color: #12828b;
}

.politique_confidentialite .table {
  margin-top: 10px;
}

.politique_confidentialite .table td,
.politique_confidentialite .table th {
  padding: .55rem .6rem;
  vertical-align: top;
}
.infoSociete .container-fluid { max-width: none !important; }
/* =============================
   Banqueinfo (scoped temporary patch)
   Scope everything to .infoSociete
============================= */

.infoSociete .titleLogoCA {
  background-color: #205082;
  border: 1px solid #dbe3ec;
  min-height: 120px;
  overflow: hidden;
}

.infoSociete .titleLogoCA > div:first-child {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.infoSociete .titleLogoCA .h1 {
  display: block;
  margin: 0 0 .2rem;
  color: #fff;
  font-size: 2.05rem;
  line-height: 1.08;
  font-weight: 700;
}

.infoSociete .titleLogoCA .h2 {
  display: block;
  margin: 0;
  color: rgba(255,255,255,.95);
  font-size: 1.02rem;
  line-height: 1.3;
  font-weight: 500;
}

.infoSociete .titleLogoCA .nav-tabs {
  border-bottom: none;
  gap: .35rem;
  margin-top: .55rem;
}

.infoSociete .titleLogoCA .nav-tabs hr {
  display: none;
}

.infoSociete .titleLogoCA .nav-tabs .nav-link {
  color: #fff;
  background: transparent;
  border: 2px solid transparent;
  border-radius: 5px;
  padding: 7px 14px;
  font-size: .9rem;
  font-weight: 500;
  transition: background-color .3s, color .3s, border-color .3s;
}

.infoSociete .titleLogoCA .nav-tabs .nav-link.active {
  background: transparent;
  border-color: #fff;
  color: #fff;
}

.infoSociete .titleLogoCA .nav-tabs .nav-link:hover {
  background: rgba(255,255,255,.16);
  color: #f0f0f0;
}

.infoSociete .imageLogo {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 120px;
  background: rgba(255,255,255,.04);
}

.infoSociete .imageLogo img {
  max-width: 130px;
  width: 100%;
  height: auto;
  object-fit: contain;
}

.infoSociete .mainBlock {
  background-color: #dde9f5;
  border: 1px solid #d8e0ea;
  border-radius: 4px;
  padding: 1.1rem 0.95rem;
}

.infoSociete .mainBlock .d5 h2 {
  margin-bottom: 0;
  color: #205082;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.15;
}

.infoSociete .tableCA {
  width: 49%;
  border: 1px solid #dde3ea !important;
  border-radius: 0;
  background: #fff;
}

.infoSociete .scrollCA {
  height: 18.5em;
  overflow: hidden;
  overflow-y: auto;
}

.infoSociete .tableCA table,
.infoSociete .scrollCA table {
  margin-bottom: 0;
}

.infoSociete .tableCA thead th,
.infoSociete .scrollCA thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: #fff;
  border-bottom: 1px solid #cfd8e3;
  color: #1f2d3d;
  font-size: 0.95rem;
  font-weight: 700;
}

.infoSociete .tableCA th,
.infoSociete .tableCA td,
.infoSociete .scrollCA th,
.infoSociete .scrollCA td {
  padding: 0.72rem 0.8rem;
  vertical-align: middle;
}

.infoSociete .tableCA tbody tr:nth-child(even),
.infoSociete .scrollCA tbody tr:nth-child(even) {
  background-color: #fafbfd;
}

.infoSociete .tableCA tbody tr:hover,
.infoSociete .scrollCA tbody tr:hover {
  background-color: #f2f7fc;
}

.infoSociete .titleAcheteurs,
.infoSociete .titleVendeurs {
  margin: 1rem 0 0.9rem;
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: .01em;
}

.infoSociete .titleAcheteurs {
  color: #4b8a1c;
}

.infoSociete .titleVendeurs {
  color: #9b2419;
}

.infoSociete .block {
  display: block;
  width: 100%;
  padding: 10px 18px;
  border-radius: 4px;
  font-weight: 600;
  background-color: #0f8b94;
  border: 1px solid #0f8b94;
}

.infoSociete .block:hover {
  background-color: #0c7680;
  border-color: #0c7680;
  color: #fff;
}

.infoSociete .mainBlock .text-primary {
  color: #205082 !important;
  font-weight: 600;
}

.infoSociete .mainBlock .table td a {
  color: #0d6efd;
  text-decoration: none;
}

.infoSociete .mainBlock .table td a:hover {
  text-decoration: underline;
}

.infoSociete .banqueinfo-sidebar-legacy {
  display: block;
}

.infoSociete .companieDescription {
  margin-top: 1rem;
  color: #3f4d5c;
  font-size: 0.92rem;
  line-height: 1.65;
}

.infoSociete .companieDescription p:last-child {
  margin-bottom: 0;
}

.infoSociete .sidebarListDocs {
  margin-top: 1rem;
}

.infoSociete .sidebarListDocs h4 {
  margin-bottom: .75rem;
  font-size: 1.75rem;
  line-height: 1.2;
}

.infoSociete .sidebarListDocs .input-group {
  margin-bottom: 1rem !important;
}

.infoSociete .sidebarListDocs .accordion-item {
  border-radius: 0;
}

.infoSociete .sidebarListDocs .accordion-button {
  padding: .85rem 1rem;
  font-size: .95rem;
  font-weight: 600;
}

.infoSociete .sidebarListDocs .doc-date {
  white-space: nowrap;
  font-size: .82rem;
  color: #6c757d;
}

@media (max-width: 993px) {
  .infoSociete .imageLogo {
    display: none;
  }

  .infoSociete .banqueinfo-sidebar-legacy {
    margin-top: 1.25rem;
  }
}

@media (max-width: 770px) {
  .infoSociete .tableCA {
    width: 100%;
  }

  .infoSociete .titleLogoCA .h1 {
    font-size: 1.6rem;
  }

  .infoSociete .titleLogoCA .h2 {
    font-size: .95rem;
  }

  .infoSociete .mainBlock {
    padding: 0.9rem 0.75rem;
  }

  .infoSociete .mainBlock .d5 h2 {
    font-size: 1.45rem;
  }

  .infoSociete .tableCA th,
  .infoSociete .tableCA td,
  .infoSociete .scrollCA th,
  .infoSociete .scrollCA td {
    padding: 0.62rem 0.65rem;
    font-size: 0.9rem;
  }

}

.textPasserAnnonce .bi-exclamation-circle {
  display: inline-block;
  width: 60px;
  height: 60px;
  font-size: 60px;
  line-height: 1;
  color: currentColor;
  flex: 0 0 60px;
}
.veracash-update-wrapper {
	position: relative;
}

.veracash-update-table {
	min-width: 1800px;
	border-collapse: separate;
	border-spacing: 0;
}

.veracash-update-table th,
.veracash-update-table td {
	vertical-align: middle;
	white-space: nowrap;
	background: #fff;
}

/* widths */
.veracash-update-table .col-num {
	min-width: 60px;
	width: 60px;
}

.veracash-update-table .col-name {
	min-width: 220px;
	width: 220px;
}

.veracash-update-table .col-email {
	min-width: 260px;
	width: 260px;
}

.veracash-update-table .col-last-email {
	min-width: 170px;
	width: 170px;
}

.veracash-update-table .col-action {
	min-width: 150px;
	width: 150px;
}

/* sticky left columns */
.veracash-update-table .sticky-num {
	position: sticky;
	left: 0;
	z-index: 4;
	background: #fff;
}

.veracash-update-table .sticky-name {
	position: sticky;
	left: 60px;
	z-index: 4;
	background: #fff;
}

.veracash-update-table .sticky-email {
	position: sticky;
	left: 280px; /* 60 + 220 */
	z-index: 4;
	background: #fff;
}

.veracash-update-table .sticky-last-email {
	position: sticky;
	left: 540px; /* 60 + 220 + 260 */
	z-index: 4;
	background: #fff;
}

.veracash-update-table .sticky-action {
	position: sticky;
	left: 710px; /* 60 + 220 + 260 + 170 */
	z-index: 5;
	background: #fff;
	box-shadow: 4px 0 6px rgba(0, 0, 0, 0.08);
}

/* header above td */
.veracash-update-table thead th.sticky-num,
.veracash-update-table thead th.sticky-name,
.veracash-update-table thead th.sticky-email,
.veracash-update-table thead th.sticky-last-email,
.veracash-update-table thead th.sticky-action {
	z-index: 10;
	background: #f8f9fa;
}

/* optional: button smaller but readable */
.veracash-update-table .btn-sm {
	white-space: nowrap;
}
.veracash-update-wrapper {
	position: relative;
}

.veracash-update-table {
	min-width: 1450px;
	border-collapse: separate;
	border-spacing: 0;
	font-size: 13px;
}

.veracash-update-table th,
.veracash-update-table td {
	vertical-align: middle;
	white-space: nowrap;
	background: #fff;
	padding: 0.45rem 0.5rem;
}

.veracash-update-table thead th {
	font-size: 12px;
	font-weight: 600;
}

.veracash-update-table .badge {
	font-size: 11px;
	padding: 0.35em 0.5em;
}

.veracash-update-table .btn-compact-email {
	padding: 0.25rem 0.5rem;
	font-size: 12px;
	line-height: 1.2;
}

/* widths */
.veracash-update-table .col-num {
	min-width: 45px;
	width: 45px;
}

.veracash-update-table .col-name {
	min-width: 180px;
	width: 180px;
}

.veracash-update-table .col-email {
	min-width: 210px;
	width: 210px;
}

.veracash-update-table .col-last-email {
	min-width: 110px;
	width: 110px;
}

.veracash-update-table .col-action {
	min-width: 95px;
	width: 95px;
}

/* sticky left columns */
.veracash-update-table .sticky-num {
	position: sticky;
	left: 0;
	z-index: 4;
	background: #fff;
}

.veracash-update-table .sticky-name {
	position: sticky;
	left: 45px;
	z-index: 4;
	background: #fff;
}

.veracash-update-table .sticky-email {
	position: sticky;
	left: 225px; /* 45 + 180 */
	z-index: 4;
	background: #fff;
}

.veracash-update-table .sticky-last-email {
	position: sticky;
	left: 435px; /* 45 + 180 + 210 */
	z-index: 4;
	background: #fff;
}

.veracash-update-table .sticky-action {
	position: sticky;
	left: 545px; /* 45 + 180 + 210 + 110 */
	z-index: 5;
	background: #fff;
	box-shadow: 4px 0 6px rgba(0, 0, 0, 0.08);
}

.veracash-update-table thead th.sticky-num,
.veracash-update-table thead th.sticky-name,
.veracash-update-table thead th.sticky-email,
.veracash-update-table thead th.sticky-last-email,
.veracash-update-table thead th.sticky-action {
	z-index: 10;
	background: #f8f9fa;
}

.veracash-update-wrapper.is-scrolled-x .sticky-action {
	box-shadow: 4px 0 8px rgba(0, 0, 0, 0.12);
}
.vu-legend {
	padding: 0.85rem 1rem;
	background: #f8fbff;
	border: 1px solid #dbeafe;
	border-left: 4px solid #0d6efd;
	border-radius: 0.5rem;
}

.vu-legend-title {
	font-size: 0.9rem;
	font-weight: 600;
	color: #1d4f91;
	margin-bottom: 0.5rem;
}

.vu-legend-item {
	font-size: 0.9rem;
	line-height: 1.45;
	color: #334155;
	display: flex;
	align-items: flex-start;
}

.vu-legend-item .badge {
	min-width: 38px;
	text-align: center;
	margin-top: 2px;
}
/* =========================================================
   HOME PAGE — CLEAN CUSTOM SECTIONS
   Solutions / Publications / CTA / Footer
========================================================= */

:root {
  --ciib-blue: #274c8e;
  --ciib-blue-dark: #062344;
  --ciib-blue-mid: #0b3c67;
  --ciib-cyan: #23afc5;
  --ciib-cyan-dark: #179db1;
  --ciib-teal: #168a93;
  --ciib-soft-bg: #f7fbff;
  --ciib-border: #e6edf6;
  --ciib-text: #2c3440;
  --ciib-muted: #657386;
}

/* Avoid global section min-height problem on these home sections */
.solutions-section,
.home-annonces,
.home-publications,
.ecosystem-section {
  min-height: 0 !important;
}

/* =========================================================
   NOS SOLUTIONS
========================================================= */

.solutions-section {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 10% 10%, rgba(26, 160, 184, .12), transparent 32%),
    radial-gradient(circle at 90% 0%, rgba(39, 76, 142, .10), transparent 30%),
    linear-gradient(180deg, #ffffff 0%, var(--ciib-soft-bg) 100%);
}

.solutions-kicker {
  display: inline-flex;
  margin-bottom: .75rem;
  color: var(--ciib-teal);
  font-weight: 800;
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.solutions-hero {
  position: relative;
  padding: 38px;
  border-radius: 28px;
  color: #ffffff;
  overflow: hidden;
  background:
    radial-gradient(circle at 85% 20%, rgba(26, 160, 184, .35), transparent 28%),
    linear-gradient(135deg, rgba(15, 39, 71, .98), rgba(30, 76, 130, .96));
  box-shadow: 0 24px 60px rgba(11, 37, 69, .18);
}

.solutions-hero::after {
  content: "";
  position: absolute;
  right: -70px;
  bottom: -90px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  border: 42px solid rgba(255, 255, 255, .06);
  pointer-events: none;
}

.solutions-hero h3,
.solutions-hero p,
.solutions-main-btn {
  position: relative;
  z-index: 1;
}

.solutions-hero h3 {
  max-width: 720px;
  margin-bottom: 16px;
  color: #ffffff;
  font-size: clamp(1.45rem, 2.2vw, 2rem);
  line-height: 1.25;
  font-weight: 800;
}

.solutions-hero p {
  max-width: 760px;
  margin-bottom: 0;
  color: rgba(255, 255, 255, .84);
  font-size: 1.03rem;
  line-height: 1.85;
}

.solutions-main-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-width: 225px;
  padding: 16px 22px;
  border-radius: 16px;
  background: #1aa0b8;
  color: #ffffff;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 14px 30px rgba(0, 0, 0, .18);
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
}

.solutions-main-btn:hover {
  color: #ffffff;
  background: var(--ciib-cyan-dark);
  transform: translateY(-3px);
  box-shadow: 0 18px 36px rgba(0, 0, 0, .22);
}

.solution-card {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 410px;
  padding: 28px;
  border-radius: 24px;
  background: rgba(255, 255, 255, .94);
  border: 1px solid rgba(226, 236, 248, .95);
  color: inherit;
  text-decoration: none;
  overflow: hidden;
  box-shadow: 0 16px 38px rgba(31, 59, 97, .08);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.solution-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 5px;
  background: linear-gradient(90deg, #1aa0b8, var(--ciib-blue));
  opacity: .9;
}

.solution-card:hover {
  color: inherit;
  transform: translateY(-8px);
  border-color: rgba(26, 160, 184, .35);
  box-shadow: 0 26px 60px rgba(31, 59, 97, .14);
}

.solution-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 26px;
}

.solution-icon {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #eef9fb;
  color: var(--ciib-teal);
  font-size: 1.8rem;
}

.solution-badge {
  padding: 7px 12px;
  border-radius: 999px;
  background: #eef4ff;
  color: var(--ciib-blue);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.solution-card h4 {
  margin-bottom: 14px;
  color: var(--ciib-blue);
  font-size: 1.2rem;
  line-height: 1.3;
  font-weight: 800;
}

.solution-card p {
  margin-bottom: 22px;
  color: var(--ciib-text);
  line-height: 1.75;
}

.solution-card ul {
  margin: 0 0 26px;
  padding: 0;
  list-style: none;
}

.solution-card li {
  position: relative;
  padding-left: 24px;
  margin-bottom: 10px;
  color: var(--ciib-muted);
  line-height: 1.5;
}

.solution-card li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--ciib-teal);
  font-weight: 900;
}

.solution-link {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid var(--ciib-border);
  color: #2456a4;
  font-weight: 800;
}

.solution-link span,
.solutions-main-btn span {
  display: inline-block;
  transition: transform .25s ease;
}

.solution-card:hover .solution-link span,
.solutions-main-btn:hover span {
  transform: translateX(4px);
}

/* =========================================================
   PUBLICATIONS
========================================================= */

.home-publications {
  background: #ffffff;
}

.home-publications .container {
  max-width: 1320px;
}

.home-publications-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 32px;
}

.home-publications-head .d5 {
  text-align: left;
}

.home-publications-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
}

/* important: neutralize old Bootstrap/card widths */
.home-publications-grid > * {
  min-width: 0;
}

.publication-card-home {
  width: 100%;
  min-width: 0;
  height: 100%;
  border-radius: 22px;
  overflow: hidden;
  background: #ffffff;
  border: 1px solid var(--ciib-border);
  box-shadow: 0 16px 38px rgba(31, 59, 97, .08);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.publication-card-home:hover {
  transform: translateY(-6px);
  border-color: rgba(26, 160, 184, .35);
  box-shadow: 0 24px 55px rgba(31, 59, 97, .14);
}

.publication-card-link {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.publication-card-image {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #eef4ff;
}

.publication-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}

.publication-card-home:hover .publication-card-image img {
  transform: scale(1.04);
}

.publication-card-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 18px;
}

.publication-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  margin-bottom: 12px;
  color: #6b7788;
  font-size: .7rem;
  font-weight: 800;
  text-transform: uppercase;
}

.publication-card-body h3 {
  margin-bottom: 18px;
  color: var(--ciib-blue);
  font-size: .92rem;
  line-height: 1.35;
  font-weight: 800;
}

.publication-card-more {
  margin-top: auto;
  color: var(--ciib-teal);
  font-size: .92rem;
  font-weight: 800;
}

.home-section-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--ciib-teal);
  font-weight: 800;
  text-decoration: none;
  white-space: nowrap;
}

.home-section-link:hover {
  color: var(--ciib-blue);
}

@media (max-width: 1199.98px) {
  .home-publications-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 575.98px) {
  .home-publications-head {
    align-items: center;
    flex-direction: column;
    text-align: center;
  }

  .home-publications-head .d5 {
    text-align: center;
  }

  .home-publications-grid {
    grid-template-columns: 1fr;
  }
}
/* =========================================================
   PRIMARY CTA
========================================================= */

.home-primary-cta {
  padding: 42px 0 46px;
  background: linear-gradient(180deg, #ffffff 0%, var(--ciib-soft-bg) 100%);
}

.enterprise-cta-card {
  border-radius: 26px;
  overflow: hidden;
}

.enterprise-cta-card-dark {
  position: relative;
  padding: 34px 40px;
  color: #ffffff;
  background:
    radial-gradient(circle at 92% 20%, rgba(26, 160, 184, .28), transparent 28%),
    linear-gradient(135deg, #17365f 0%, var(--ciib-blue) 100%);
  box-shadow: 0 22px 52px rgba(31, 59, 97, .18);
}

.enterprise-cta-card-dark::after {
  content: "";
  position: absolute;
  right: -70px;
  bottom: -95px;
  width: 230px;
  height: 230px;
  border-radius: 50%;
  border: 38px solid rgba(255, 255, 255, .06);
  pointer-events: none;
}

.enterprise-cta-content,
.enterprise-cta-btn {
  position: relative;
  z-index: 1;
}

.enterprise-cta-kicker {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 12px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .12);
  color: #d8f8ff;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.enterprise-cta-card h3 {
  display: block;
  margin: 0 0 12px;
  color: #ffffff;
  font-size: clamp(1.45rem, 2.1vw, 2rem);
  line-height: 1.2;
  font-weight: 800;
}

.enterprise-cta-card p {
  max-width: 760px;
  margin-bottom: 0;
  color: rgba(255, 255, 255, .84);
  line-height: 1.7;
}

.enterprise-cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-width: 245px;
  padding: 15px 22px;
  border-radius: 14px;
  background: #1aa0b8;
  color: #ffffff;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 14px 28px rgba(0, 0, 0, .18);
  transition: transform .25s ease, background .25s ease, box-shadow .25s ease;
}

.enterprise-cta-btn:hover {
  color: #ffffff;
  background: var(--ciib-cyan-dark);
  transform: translateY(-3px);
  box-shadow: 0 18px 34px rgba(0, 0, 0, .22);
}

/* =========================================================
   FOOTER — FINAL CLEAN VERSION
========================================================= */

.site-footer {
  width: 100%;
  background:
    radial-gradient(circle at 86% 8%, rgba(35, 175, 197, .12), transparent 26%),
    linear-gradient(135deg, var(--ciib-blue-dark) 0%, var(--ciib-blue-mid) 52%, #0a3157 100%);
  color: #ffffff;
  margin-top: 32px;
}

.site-footer #zoneFooter {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 48px clamp(36px, 5vw, 82px) 24px !important;
  background: transparent !important;
}

.site-footer a {
  color: rgba(255, 255, 255, .94);
  text-decoration: none;
  transition: color .2s ease, opacity .2s ease;
}

.site-footer a:hover {
  color: #63ddeb;
}

/* Footer grid */
.footerTop.footer-grid {
  display: grid;
  grid-template-columns:
    minmax(360px, 1.2fr)
    minmax(240px, .8fr)
    minmax(240px, .8fr)
    minmax(320px, .9fr);
  column-gap: clamp(44px, 5vw, 100px);
  row-gap: 34px;
  align-items: start;
  padding-bottom: 34px;
}

.footer-grid-col {
  min-width: 0;
}

.footer-grid-newsletter {
  width: 100%;
}

.footer-newsletter-block {
  width: 100%;
  max-width: 360px;
  margin-left: 0;
  background: transparent !important;
  padding: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Footer headings */
.footer-heading,
.newsletter-footer .footer-title {
  position: relative;
  display: inline-block;
  margin-bottom: 22px;
  color: #ffffff;
  font-size: 1.02rem;
  line-height: 1.35;
  font-weight: 800;
  text-decoration: none;
}

.footer-heading::after,
.newsletter-footer .footer-title::after {
  content: "";
  display: block;
  width: 42px;
  height: 3px;
  margin-top: 10px;
  border-radius: 999px;
  background: var(--ciib-cyan);
}

/* Footer about */
.footer-intro {
  max-width: 620px;
  margin-bottom: 18px;
  color: rgba(255, 255, 255, .9);
  font-size: .96rem;
  line-height: 1.7;
}

.footer-bullets {
  margin: 0 0 18px;
  padding: 0;
  list-style: none;
}

.footer-bullets li {
  position: relative;
  padding-left: 18px;
  margin-bottom: 8px;
  color: rgba(255, 255, 255, .82);
  font-size: .92rem;
  line-height: 1.55;
}

.footer-bullets li::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  color: #55d6e8;
  font-weight: 900;
}

.footer-legal-text {
  max-width: 620px;
  margin-bottom: 20px;
  color: rgba(255, 255, 255, .7);
  font-size: .86rem;
  line-height: 1.55;
}

/* Footer socials */
.footer-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 11px;
}

.footer-socials a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 39px;
  height: 39px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .24);
  color: #ffffff;
  font-size: 1.05rem;
}

.footer-socials a:hover {
  background: rgba(255, 255, 255, .08);
  border-color: rgba(99, 221, 235, .75);
}

/* Footer links */
.footer-links,
.footer-contact-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.footer-links-lined li {
  border-bottom: 1px solid rgba(255, 255, 255, .12);
}

.footer-links-lined li:last-child {
  border-bottom: 0;
}

.footer-links-lined a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 11px 0;
  color: rgba(255, 255, 255, .92);
  font-size: .94rem;
}

.footer-links-lined a::after {
  content: "›";
  color: var(--ciib-cyan);
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1;
  transition: transform .2s ease;
}

.footer-links-lined a:hover::after {
  transform: translateX(4px);
}

/* Footer contact */
.footerContact {
  width: 100%;
}

.footer-contact-list li {
  display: flex;
  align-items: flex-start;
  gap: 13px;
  margin-bottom: 16px;
  color: rgba(255, 255, 255, .92);
  font-size: .94rem;
  line-height: 1.5;
}

.footer-contact-icon {
  flex: 0 0 40px;
  width: 40px;
  height: 40px;
  margin-top: 1px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .16);
  color: #55d6e8;
  font-size: 1rem;
}

.footer-contact-list a,
.footer-contact-list span {
  color: rgba(255, 255, 255, .94);
  text-decoration: none;
}

/* Footer newsletter */
.newsletter-footer {
  color: #ffffff;
}

.newsletter-footer p {
  margin-bottom: 16px;
  color: rgba(255, 255, 255, .84);
  font-size: .93rem;
  line-height: 1.55;
}

.newsletter-alert {
  margin-bottom: 14px;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: .82rem;
  line-height: 1.4;
  font-weight: 700;
}

.newsletter-alert-success {
  background: rgba(49, 211, 135, .16);
  color: #d9ffe9;
  border: 1px solid rgba(49, 211, 135, .35);
}

.newsletter-alert-error {
  background: rgba(255, 99, 99, .16);
  color: #ffe1e1;
  border: 1px solid rgba(255, 99, 99, .35);
}

.newsletter-inline-form {
  margin: 0;
}

.newsletter-inline-group {
  display: flex;
  align-items: stretch;
  width: 100%;
  height: 44px;
  border-radius: 9px;
  overflow: hidden;
  background: rgba(255, 255, 255, .98);
  border: 1px solid rgba(255, 255, 255, .18);
}

.newsletter-inline-group input,
.newsletter-inline-group .form-control,
.newsletter-inline-group .newsletter-input {
  flex: 1;
  min-width: 0;
  height: 44px;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 14px;
  color: #24364b;
  background: transparent;
  font-size: .9rem;
}

.newsletter-inline-group input:focus,
.newsletter-inline-group .form-control:focus,
.newsletter-inline-group .newsletter-input:focus {
  outline: none;
  box-shadow: none !important;
}

.newsletter-inline-group .newsletter-submit,
.newsletter-inline-group button,
.newsletter-inline-group .btn {
  width: 50px !important;
  min-width: 50px;
  height: 44px;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: var(--ciib-cyan);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  font-weight: 800;
  box-shadow: none !important;
}

.newsletter-inline-group .newsletter-submit:hover,
.newsletter-inline-group button:hover,
.newsletter-inline-group .btn:hover {
  background: var(--ciib-cyan-dark);
  color: #ffffff;
}

.newsletter-inline-form .invalid-feedback,
.newsletter-inline-form ul {
  margin-top: 8px;
  padding-left: 0;
  list-style: none;
  color: #ffd8d8;
  font-size: .82rem;
}

/* Footer bottom */
.footer-bottom {
  padding-top: 8px;
}

.footer-bottom-line {
  height: 1px;
  margin-bottom: 18px;
  background: rgba(255, 255, 255, .22);
}

.footer-copy {
  margin-bottom: 8px;
  color: #ffffff;
  font-size: .96rem;
  font-weight: 800;
}

.footer-bottom-links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px 14px;
  color: rgba(255, 255, 255, .42);
}

.footer-bottom-links a {
  color: rgba(255, 255, 255, .82);
  font-size: .9rem;
}

.footer-bottom-links a:hover {
  color: #63ddeb;
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width: 1399.98px) {
  .footerTop.footer-grid {
    grid-template-columns:
      minmax(340px, 1.2fr)
      minmax(220px, .8fr)
      minmax(230px, .8fr)
      minmax(300px, .95fr);
    column-gap: 42px;
  }

  .footer-newsletter-block {
    max-width: 330px;
  }
}

@media (max-width: 1199.98px) {
  .footerTop.footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 44px;
  }

  .footer-newsletter-block {
    max-width: 380px;
  }
}

@media (max-width: 991px) {
  .solutions-hero {
    padding: 28px;
  }

  .solutions-main-btn,
  .enterprise-cta-btn {
    width: 100%;
  }

  .home-publications-head {
    align-items: center;
    flex-direction: column;
    text-align: center;
  }

  .home-publications-head .d5 {
    text-align: center;
  }

  .home-publications-grid {
    grid-template-columns: 1fr;
  }

  .home-primary-cta {
    padding: 34px 0;
  }

  .enterprise-cta-card-dark {
    padding: 28px;
  }
}

@media (max-width: 767.98px) {
  .site-footer #zoneFooter {
    padding: 34px 24px 18px !important;
  }

  .footerTop.footer-grid {
    grid-template-columns: 1fr;
    row-gap: 28px;
  }

  .footer-newsletter-block {
    max-width: 100%;
  }
}

@media (max-width: 575px) {
  .solutions-section {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }

  .solutions-hero {
    padding: 24px;
    border-radius: 22px;
  }

  .solution-card {
    min-height: auto;
    padding: 24px;
  }

  .footer-bottom-links {
    flex-direction: column;
    gap: 6px;
  }

  .footer-bottom-links span {
    display: none;
  }
}
/* =========================================================
   Publications / Accueil publication cards
   Final clean scoped styles
   ========================================================= */

/* =========================
   Publications index page
   ========================= */

body .publications-index-page {
  padding-top: 11.5rem !important;
  padding-bottom: 4rem !important;
  background: #ffffff !important;
}

body .publications-index-page > .container-fluid {
  width: 100% !important;
  max-width: 1680px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 2.25rem !important;
  padding-right: 2.25rem !important;
}

/* Breadcrumb */

body .publications-index-page .publication-breadcrumb {
  margin: 0 0 1.2rem !important;
}

body .publications-index-page .publication-breadcrumb a {
  color: #205082;
  text-decoration: none;
  font-weight: 700;
}

/* Header */

body .ciib-publications-hero {
  display: block !important;
  width: 100%;
  margin: 0 0 1.5rem !important;
  padding: 0 !important;
  min-height: 0 !important;
}

body .ciib-publications-hero-content {
  max-width: 920px;
}

body .ciib-publications-kicker {
  display: block !important;
  margin-bottom: .35rem;
  color: #12828b;
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}

body .ciib-publications-title {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: static !important;
  width: auto !important;
  height: auto !important;
  overflow: visible !important;
  margin: 0 0 .45rem !important;
  padding: 0 !important;
  color: #205082 !important;
  font-size: clamp(2.25rem, 3.2vw, 3.6rem) !important;
  font-weight: 800 !important;
  line-height: 1.08 !important;
  text-transform: none !important;
  text-align: left !important;
}

body .ciib-publications-title::before,
body .ciib-publications-title::after {
  content: none !important;
  display: none !important;
}

body .ciib-publications-subtitle {
  display: block !important;
  max-width: 780px;
  margin: 0 !important;
  color: #5f6f85 !important;
  font-size: 1rem !important;
  line-height: 1.55 !important;
}

/* Filters */

body .publications-index-page .publication-filter-card {
  border: 1px solid #dfe8f3;
  border-radius: 16px;
  background: #ffffff;
  padding: .9rem;
  box-shadow: 0 10px 24px rgba(15, 31, 58, .05);
  margin-bottom: 1.4rem !important;
}

body .publications-index-page .publication-filter-form {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(180px, .6fr) auto;
  gap: .75rem;
  align-items: end;
}

body .publications-index-page .publication-filter-field label {
  display: block;
  margin-bottom: .3rem;
  color: #6b7a90;
  font-size: .7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}

body .publications-index-page .publication-filter-field .form-select {
  min-height: 40px;
  border-radius: 10px;
  border-color: #dbe6f3;
  color: #24364f;
  font-weight: 700;
  font-size: .88rem;
}

body .publications-index-page .publication-filter-actions {
  display: flex;
  align-items: center;
  gap: .5rem;
  white-space: nowrap;
}

body .publications-index-page .publication-filter-submit,
body .publications-index-page .publication-filter-reset {
  min-height: 40px;
  border-radius: 10px;
  font-weight: 800;
  padding-inline: .95rem;
  font-size: .88rem;
}

body .publications-index-page .publication-filter-submit {
  background: #205082 !important;
  color: #ffffff !important;
  border: 1px solid #205082 !important;
}

body .publications-index-page .publication-filter-submit:hover {
  background: #163f7a !important;
  color: #ffffff !important;
}

body .publications-index-page .publication-filter-reset {
  background: #ffffff !important;
  color: #5f6f85 !important;
  border: 1px solid #dbe6f3 !important;
}

body .publications-index-page .publication-filter-reset:hover {
  background: #f8fbff !important;
  color: #205082 !important;
}

/* Layout */

body .publications-index-page .publication-layout,
body .publications-index-page .publication-layout-full {
  display: block !important;
}

body .publications-index-page .publication-main {
  width: 100%;
  max-width: none;
  min-width: 0;
}

body .publications-index-page .publication-sidebar {
  display: none !important;
}

/* Results */

body .publications-index-page .publication-section-header {
  display: none !important;
}

body .publications-index-page .publication-results-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin: 0 0 1rem;
}

body .publications-index-page .publication-results-title {
  color: #205082;
  font-size: 1.15rem;
  font-weight: 800;
  line-height: 1.2;
}

body .publications-index-page .publication-count {
  display: inline-flex;
  align-items: center;
  padding: .38rem .65rem;
  border-radius: 999px;
  background: #eef5ff;
  border: 1px solid #d7e4f5;
  color: #205082;
  font-size: .78rem;
  font-weight: 800;
  white-space: nowrap;
}

body .publications-index-page .publication-active-filters {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 1rem;
}

body .publications-index-page .publication-active-filters span {
  display: inline-flex;
  align-items: center;
  padding: .35rem .7rem;
  border-radius: 999px;
  background: #eef5ff;
  border: 1px solid #d7e4f5;
  color: #205082;
  font-size: .82rem;
  font-weight: 700;
}

/* Cards */

body .publications-index-page .publication-grid {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 1rem !important;
}

body .publications-index-page .publication-card {
  display: flex !important;
  flex-direction: column !important;
  border: 1px solid #e2eaf5;
  border-radius: 15px;
  background: #ffffff;
  overflow: hidden;
  box-shadow: 0 10px 22px rgba(15, 31, 58, .07);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

body .publications-index-page .publication-card:hover {
  transform: translateY(-2px);
  border-color: #c9d9ee;
  box-shadow: 0 16px 30px rgba(15, 31, 58, .11);
}

body .publications-index-page .publication-card-link {
  display: flex !important;
  flex-direction: column !important;
  color: inherit;
  text-decoration: none;
  height: 100% !important;
}

body .publications-index-page .publication-card-image-wrap,
body .publication-page .publication-card-image-wrap {
  height: auto !important;
  aspect-ratio: 708 / 360 !important;
  background: #f8fbff !important;
  overflow: hidden !important;
}

body .publications-index-page .publication-card-image,
body .publication-page .publication-card-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center !important;
  background: #f8fbff !important;
  display: block !important;
}

body .publications-index-page .publication-card-image-empty,
body .publication-page .publication-card-image-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #205082;
  font-size: 2rem;
}

body .publications-index-page .publication-card-body {
  display: flex;
  flex-direction: column;
  flex: 1 !important;
  padding: .7rem .75rem .8rem !important;
}

body .publications-index-page .publication-card-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .35rem;
  margin-bottom: .45rem;
}

body .publications-index-page .publication-card-category {
  display: inline-flex;
  align-items: center;
  padding: .18rem .4rem !important;
  border-radius: 999px;
  background: #eef5ff;
  color: #205082;
  font-size: .58rem !important;
  font-weight: 800;
  letter-spacing: .035em;
}

body .publications-index-page .publication-card-date {
  color: #6b7a90;
  font-size: .68rem !important;
  font-weight: 700;
}

body .publications-index-page .publication-card-title {
  display: block !important;
  position: static !important;
  color: #0f376f !important;
  font-size: .86rem !important;
  font-weight: 800 !important;
  line-height: 1.28 !important;
  margin: 0 0 .65rem !important;
  text-transform: none !important;
}

body .publications-index-page .publication-card-readmore {
  margin-top: auto;
  color: #12828b;
  font-size: .74rem !important;
  font-weight: 800;
}

body .publications-index-page .publication-empty {
  grid-column: 1 / -1;
  border: 1px dashed #d7e4f5;
  border-radius: 16px;
  background: #f8fbff;
  color: #6b7a90;
  padding: 2rem;
  text-align: center;
  font-weight: 700;
}

/* Pagination */

body .publications-index-page .publication-pagination {
  display: flex;
  justify-content: center;
  margin-top: 1.75rem;
}

body .publications-index-page .publication-pagination .pagination {
  gap: .35rem;
}

body .publications-index-page .publication-pagination .page-link {
  border-radius: 10px;
  border-color: #dbe6f3;
  color: #205082;
  font-weight: 700;
}

body .publications-index-page .publication-pagination .page-item.active .page-link {
  background: #205082;
  border-color: #205082;
  color: #ffffff;
}

/* Index responsive */

@media (max-width: 1600px) {
  body .publications-index-page .publication-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 1200px) {
  body .publications-index-page .publication-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 991.98px) {
  body .publications-index-page {
    padding-top: 3rem !important;
  }

  body .publications-index-page > .container-fluid {
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
  }

  body .publications-index-page .publication-filter-form {
    grid-template-columns: 1fr !important;
  }

  body .publications-index-page .publication-filter-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: .65rem;
    width: 100%;
  }

  body .publications-index-page .publication-filter-actions .btn {
    width: 100%;
    justify-content: center;
  }

  body .publications-index-page .publication-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  body .publications-index-page .publication-card-title {
    font-size: .95rem !important;
  }
}

@media (max-width: 767.98px) {
  body .publications-index-page > .container-fluid {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  body .ciib-publications-title {
    font-size: 2.35rem !important;
    line-height: 1.05 !important;
  }

  body .ciib-publications-subtitle {
    font-size: 1rem !important;
  }

  body .publications-index-page .publication-filter-actions {
    grid-template-columns: 1fr !important;
  }

  body .publications-index-page .publication-results-header {
    flex-direction: column;
    align-items: flex-start;
    gap: .55rem;
  }

  body .publications-index-page .publication-grid {
    grid-template-columns: 1fr !important;
  }

  body .publications-index-page .publication-card-body {
    padding: .9rem 1rem 1rem !important;
  }

  body .publications-index-page .publication-card-title {
    font-size: 1rem !important;
    line-height: 1.32 !important;
  }

  body .publications-index-page .publication-card-category {
    font-size: .68rem !important;
  }

  body .publications-index-page .publication-card-date {
    font-size: .78rem !important;
  }

  body .publications-index-page .publication-card-readmore {
    font-size: .84rem !important;
  }
}

@media (max-width: 480px) {
  body .ciib-publications-title {
    font-size: 2rem !important;
  }
}

/* =========================
   Publication detail page
   ========================= */

body .publication-detail-page {
  padding-top: 11.5rem !important;
  padding-bottom: 4rem !important;
  background: #ffffff !important;
}

body .publication-detail-page > .container-fluid {
  width: 100% !important;
  max-width: 1680px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 2.25rem !important;
  padding-right: 2.25rem !important;
}

/* Detail breadcrumb */

body .publication-detail-breadcrumb {
  margin: 0 0 1.35rem !important;
}

body .publication-detail-breadcrumb a {
  color: #205082;
  text-decoration: none;
  font-weight: 700;
}

body .publication-detail-breadcrumb .breadcrumb-item.active {
  color: #6b7a90;
}

/* Detail layout */

body .publication-detail-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 430px !important;
  gap: 2rem !important;
  align-items: stretch !important;
}

body .publication-detail-article {
  min-width: 0 !important;
  max-width: none !important;
}

body .publication-detail-header,
body .publication-detail-main-image,
body .publication-detail-content,
body .publication-detail-second-image {
  max-width: 980px !important;
}

/* Detail header */

body .publication-detail-header {
  margin-bottom: 1.6rem !important;
}

body .publication-detail-category {
  display: inline-flex;
  align-items: center;
  margin-bottom: .85rem !important;
  color: #12828b;
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}

body .publication-detail-title {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: static !important;
  width: auto !important;
  height: auto !important;
  overflow: visible !important;
  max-width: 980px !important;
  margin: 0 0 1rem !important;
  padding: 0 !important;
  color: #205082 !important;
  font-size: clamp(2rem, 3vw, 3.15rem) !important;
  font-weight: 800 !important;
  line-height: 1.12 !important;
  letter-spacing: -0.02em !important;
  text-transform: none !important;
  text-align: left !important;
}

body .publication-detail-title::before,
body .publication-detail-title::after {
  content: none !important;
  display: none !important;
}

body .publication-detail-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: .15rem !important;
  margin-bottom: 1.35rem !important;
  color: #6b7a90;
  font-size: .92rem;
  font-weight: 700;
}

body .publication-detail-meta span {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
}

body .publication-detail-meta i {
  color: #12828b;
}

/* Detail images */

body .publication-detail-main-image {
  width: 100% !important;
  max-width: 980px !important;
  aspect-ratio: 708 / 360 !important;
  margin: 1.4rem 0 2rem !important;
  border-radius: 18px !important;
  overflow: hidden;
  border: 1px solid #e2eaf5;
  box-shadow: 0 16px 34px rgba(15, 31, 58, .09);
  background: #f8fbff !important;
}

body .publication-detail-main-image img {
  width: 100% !important;
  height: 100% !important;
  max-height: none !important;
  object-fit: contain !important;
  object-position: center !important;
  background: #f8fbff !important;
  display: block;
}

body .publication-detail-second-image {
  margin: 2rem 0 0 !important;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid #e2eaf5;
  box-shadow: 0 14px 30px rgba(15, 31, 58, .08);
  background: #f8fbff;
}

body .publication-detail-second-image img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

/* Detail content */

body .publication-detail-content {
  padding-top: .25rem !important;
  color: #24364f;
  font-size: 1.05rem;
  line-height: 1.78;
}

body .publication-detail-content p {
  margin-bottom: 1.15rem;
}

body .publication-detail-content h2,
body .publication-detail-content h3,
body .publication-detail-content h4 {
  display: block !important;
  position: static !important;
  color: #205082 !important;
  text-transform: none !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  margin: 2rem 0 1rem !important;
}

body .publication-detail-content h2:first-child,
body .publication-detail-content h3:first-child,
body .publication-detail-content h4:first-child,
body .publication-detail-content p:first-child {
  margin-top: 0 !important;
}

body .publication-detail-content h2 {
  font-size: 1.75rem !important;
}

body .publication-detail-content h3 {
  font-size: 1.4rem !important;
}

body .publication-detail-content h4 {
  font-size: 1.18rem !important;
}

body .publication-detail-content ul,
body .publication-detail-content ol {
  padding-left: 1.35rem;
  margin-bottom: 1.2rem;
}

body .publication-detail-content li {
  margin-bottom: .45rem;
}

body .publication-detail-content a {
  color: #12828b;
  font-weight: 800;
  text-decoration: none;
}

body .publication-detail-content a:hover {
  text-decoration: underline;
}

body .publication-detail-content img {
  max-width: 100%;
  height: auto;
  border-radius: 14px;
}

/* Detail aside */

body .publication-detail-aside {
  position: static !important;
  top: auto !important;
  min-width: 0 !important;
  height: 100% !important;
}

body .publication-detail-aside-card {
  height: 100% !important;
  border: 1px solid #e2eaf5 !important;
  border-radius: 20px !important;
  background: #fbfdff !important;
  padding: 1.15rem !important;
  box-shadow: 0 14px 30px rgba(15, 31, 58, .06) !important;
}

body .publication-detail-aside-header {
  padding-bottom: .9rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid #e7eef7;
}

body .publication-detail-aside-header span {
  display: block;
  margin-bottom: .25rem;
  color: #12828b;
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}

body .publication-detail-aside-header h2 {
  display: block !important;
  position: static !important;
  margin: 0 !important;
  color: #205082 !important;
  font-size: 1.35rem !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
  text-transform: none !important;
}

body .publication-detail-related-section {
  margin-bottom: 1.25rem;
}

body .publication-detail-related-section-title {
  margin-bottom: .65rem;
  color: #24364f;
  font-size: .86rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
}

body .publication-detail-related-list {
  display: flex !important;
  flex-direction: column !important;
  gap: .7rem !important;
}

body .publication-detail-related-item {
  display: grid !important;
  grid-template-columns: 135px minmax(0, 1fr) !important;
  gap: .75rem !important;
  align-items: center !important;
  padding: .7rem !important;
  border: 1px solid #e7eef7 !important;
  border-radius: 15px !important;
  background: #ffffff !important;
  color: inherit !important;
  text-decoration: none !important;
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

body .publication-detail-related-item:hover {
  border-color: #c9d9ee !important;
  box-shadow: 0 10px 22px rgba(15, 31, 58, .08) !important;
  transform: translateY(-1px);
}

body .publication-detail-related-thumb {
  width: 135px !important;
  height: auto !important;
  aspect-ratio: 708 / 360 !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  background: #f8fbff !important;
  border: 1px solid #e2eaf5 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #205082 !important;
}

body .publication-detail-related-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center !important;
  background: #f8fbff !important;
  display: block !important;
}

body .publication-detail-related-body {
  min-width: 0 !important;
}

body .publication-detail-related-category {
  display: inline-flex !important;
  margin-bottom: .28rem !important;
  padding: .16rem .42rem !important;
  border-radius: 999px !important;
  background: #eef5ff !important;
  color: #205082 !important;
  font-size: .58rem !important;
  font-weight: 800 !important;
  letter-spacing: .035em !important;
}

body .publication-detail-related-body strong {
  display: block !important;
  color: #0f376f !important;
  font-size: .86rem !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
}

body .publication-detail-related-body small {
  display: block !important;
  margin-top: .3rem !important;
  color: #6b7a90 !important;
  font-size: .74rem !important;
  font-weight: 700 !important;
}

body .publication-detail-all-link {
  display: inline-flex !important;
  align-items: center !important;
  margin-top: .4rem !important;
  color: #12828b !important;
  font-size: .88rem !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

body .publication-detail-all-link:hover {
  color: #205082 !important;
}

/* Detail responsive */

@media (max-width: 1300px) {
  body .publication-detail-layout {
    grid-template-columns: minmax(0, 1fr) 380px !important;
    gap: 1.5rem !important;
  }

  body .publication-detail-related-item {
    grid-template-columns: 125px minmax(0, 1fr) !important;
  }

  body .publication-detail-related-thumb {
    width: 125px !important;
  }
}

@media (max-width: 991.98px) {
  body .publication-detail-page {
    padding-top: 3rem !important;
  }

  body .publication-detail-page > .container-fluid {
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
  }

  body .publication-detail-layout {
    grid-template-columns: 1fr !important;
  }

  body .publication-detail-aside-card {
    height: auto !important;
  }

  body .publication-detail-related-list {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 767.98px) {
  body .publication-detail-page > .container-fluid {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  body .publication-detail-title {
    font-size: 2.15rem !important;
  }

  body .publication-detail-content {
    font-size: 1rem;
    line-height: 1.68;
  }

  body .publication-detail-related-list {
    grid-template-columns: 1fr !important;
  }

  body .publication-detail-related-item {
    grid-template-columns: 125px minmax(0, 1fr) !important;
  }

  body .publication-detail-related-thumb {
    width: 125px !important;
  }
}

/* =========================
   Accueil publications cards
   ========================= */

body .home-publications .container {
  max-width: 1680px;
}

body .home-publications-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 1.25rem !important;
  align-items: stretch;
}

body .home-publication-card {
  border: 1px solid #e2eaf5;
  border-radius: 20px;
  background: #ffffff;
  overflow: hidden;
  box-shadow: 0 16px 34px rgba(15, 31, 58, .08);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

body .home-publication-card:hover {
  transform: translateY(-2px);
  border-color: #c9d9ee;
  box-shadow: 0 20px 42px rgba(15, 31, 58, .12);
}

body .home-publication-card-link {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

body .home-publication-card-image-wrap {
  width: 100%;
  aspect-ratio: 708 / 360;
  background: #f8fbff;
  overflow: hidden;
}

body .home-publication-card-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  background: #f8fbff;
  display: block;
}

body .home-publication-card-image-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #205082;
  font-size: 2rem;
}

body .home-publication-card-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 1rem 1.1rem 1.15rem;
}

body .home-publication-card-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .45rem;
  margin-bottom: .75rem;
  color: #6b7a90;
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
}

body .home-publication-card-meta span:first-child {
  display: inline-flex;
  align-items: center;
  padding: .22rem .52rem;
  border-radius: 999px;
  background: #eef5ff;
  color: #205082;
  font-size: .68rem;
  letter-spacing: .035em;
}

body .home-publication-card h3 {
  display: block !important;
  position: static !important;
  margin: 0 0 1rem !important;
  color: #0f376f !important;
  font-size: 1rem !important;
  font-weight: 800 !important;
  line-height: 1.32 !important;
  text-transform: none !important;
}

body .home-publication-card-more {
  margin-top: auto;
  color: #12828b;
  font-size: .9rem;
  font-weight: 800;
}

/* Accueil responsive */

@media (max-width: 1200px) {
  body .home-publications-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 991.98px) {
  body .home-publications-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 575.98px) {
  body .home-publications-grid {
    grid-template-columns: 1fr !important;
  }

  body .home-publication-card-body {
    padding: .9rem 1rem 1rem;
  }
}
/* Accueil publications width: align with next CTA block */
body .home-publications > .container {
  width: 100% !important;
  max-width: 1320px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: .75rem !important;
  padding-right: .75rem !important;
}

body .home-publications-grid {
  gap: 1rem !important;
}

@media (max-width: 767.98px) {
  body .home-publications > .container {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
}
/* =========================
   Site standard pages
   ========================= */

body .site-standard-page {
    --site-container-width: 1400px;
    --site-page-offset: 8.25rem;
    --site-section-gap: clamp(2rem, 3vw, 3.25rem);

    min-height: 100vh;
    padding-top: var(--site-page-offset);
    padding-bottom: clamp(3rem, 6vw, 6rem);
    background: #ffffff;
    color: #10233f;
}

body .site-container {
    width: min(calc(100% - 2rem), var(--site-container-width));
    margin-inline: auto;
}

body .site-standard-page section {
    min-height: 0;
    padding: 0;
}

body .site-page-hero {
    padding: clamp(2.25rem, 3.8vw, 3.75rem) 0 clamp(1rem, 2vw, 1.5rem);
}

body .site-page-section {
    padding: 0 0 var(--site-section-gap);
}

body .site-page-hero-inner {
    max-width: 980px;
}

body .site-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-bottom: clamp(1.1rem, 1.8vw, 1.6rem);
    color: #6b7a90;
    font-size: 0.92rem;
    font-weight: 600;
}

body .site-breadcrumb a {
    color: #164b7f;
    font-weight: 900;
    text-decoration: none;
}

body .site-breadcrumb a:hover {
    color: #008c95;
}

body .site-breadcrumb-separator {
    color: #9aa8ba;
}

body .site-kicker {
    margin-bottom: 0.55rem;
    color: #008c95;
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

body .site-page-title {
    margin: 0;
    color: #205082;
    font-size: clamp(2.15rem, 4.2vw, 4rem);
    font-weight: 900;
    line-height: 0.98;
    letter-spacing: -0.04em;
}

body .site-page-subtitle {
    max-width: 760px;
    margin: 1rem 0 0;
    color: #5f6f85;
    font-size: clamp(1rem, 1.25vw, 1.15rem);
    line-height: 1.6;
}

body .site-section {
    padding: var(--site-section-gap) 0;
}

body .site-section-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: clamp(1.25rem, 2vw, 2rem);
}

body .site-section-title {
    margin: 0;
    color: #205082;
    font-size: clamp(1.75rem, 2.6vw, 2.75rem);
    font-weight: 900;
    line-height: 1.08;
    letter-spacing: -0.035em;
}

body .site-section-subtitle {
    max-width: 760px;
    margin: 0.75rem 0 0;
    color: #5f6f85;
    font-size: 1rem;
    line-height: 1.6;
}

body .site-card {
    border: 1px solid #dfe8f3;
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 16px 36px rgba(15, 31, 58, 0.08);
}

@media (max-width: 1199.98px) {
    body .site-standard-page {
        --site-page-offset: 7.5rem;
    }
}

@media (max-width: 991.98px) {
    body .site-standard-page {
        --site-page-offset: 2rem;
    }

    body .site-page-title {
        font-size: clamp(2rem, 9vw, 3.1rem);
        line-height: 1.02;
    }
}

@media (max-width: 767.98px) {
    body .site-container {
        width: min(calc(100% - 1.25rem), var(--site-container-width));
    }

    body .site-page-hero {
        padding-top: 1.75rem;
    }

    body .site-section-header {
        display: block;
    }
}
body .formation-index-page .site-page-hero {
    padding-top: clamp(3rem, 4.5vw, 4.5rem);
}
body .formation-index-page .site-breadcrumb {
    margin-bottom: 1.25rem;
}
/* =========================
   Formation index page
   ========================= */

body .formation-index-page {
    background: linear-gradient(180deg, #f7fbff 0%, #ffffff 34%, #f8fbff 100%);
}

body .formation-index-page .site-page-hero {
    padding-bottom: 0.75rem;
}

body .formation-index-page .site-page-section {
    padding-top: 0;
}

/* Overview */

body .formation-overview {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 390px;
    gap: 1.25rem;
    align-items: stretch;
    margin-bottom: clamp(3rem, 5vw, 5rem);
}

body .formation-overview-main,
body .formation-overview-side {
    height: 100%;
}

body .formation-overview-side {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

body .formation-doc-card {
    flex: 1;
}

body .formation-overview-main {
    padding: clamp(1.4rem, 2.2vw, 2rem);
    background:
        radial-gradient(circle at top right, rgba(19, 174, 184, 0.08), transparent 34%),
        #ffffff;
}

body .formation-overview-side {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

body .formation-overview-kicker,
body .formation-side-kicker,
body .formation-doc-kicker {
    display: inline-flex;
    margin-bottom: 0.65rem;
    color: #008c95;
    font-size: 0.74rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

body .formation-overview-main h2 {
    max-width: 880px;
    margin: 0;
    color: #205082;
    font-size: clamp(2rem, 3vw, 3.35rem);
    font-weight: 900;
    line-height: 1.04;
    letter-spacing: -0.045em;
}

body .formation-overview-lead {
    max-width: 980px;
    margin: 1.15rem 0 0;
    color: #24364f;
    font-size: clamp(1rem, 1.2vw, 1.12rem);
    line-height: 1.7;
    font-weight: 800;
}

body .formation-overview-body {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
    margin-top: 1.25rem;
}

body .formation-overview-body p {
    margin: 0;
    color: #5f6f85;
    font-size: 0.98rem;
    line-height: 1.75;
}

body .formation-overview-photo {
    margin: 1.35rem 0 2.25rem 0;
    width: 100%;
    min-height: 190px;
    max-height: 230px;
    border-radius: 22px;
    overflow: hidden;
    background: #eef5ff;
    border: 1px solid #d9e6f2;
    box-shadow: 0 14px 32px rgba(15, 31, 58, 0.08);
}

body .formation-overview-photo img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 190px;
    max-height: 230px;
    object-fit: cover;
}

body .formation-overview-points {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
    margin-top: 1.15rem;
}

body .formation-overview-points article {
    min-height: 145px;
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    padding: 1.1rem;
    border-radius: 20px;
    background: #ffffff;
    border: 1px solid #dfe8f3;
    box-shadow: 0 12px 26px rgba(15, 31, 58, 0.055);
}

body .formation-overview-points i {
    width: 42px;
    height: 42px;
    flex: 0 0 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #e5f7f5;
    color: #008c95;
    font-size: 1.05rem;
}

body .formation-overview-points h3 {
    margin: 0 0 0.45rem;
    color: #123b68;
    font-size: 1rem;
    font-weight: 900;
    line-height: 1.2;
}

body .formation-overview-points p {
    margin: 0;
    color: #5f6f85;
    font-size: 0.9rem;
    line-height: 1.5;
}

/* Quality panel */

body .formation-quality-panel {
    padding: 1.55rem;
    background: #fafdff;
}

body .formation-quality-panel h2 {
    margin: 0 0 1.1rem;
    color: #205082;
    font-size: 1.55rem;
    font-weight: 900;
    line-height: 1.12;
}

body .formation-quality-item {
    width: 100%;
    display: grid;
    grid-template-columns: 104px minmax(0, 1fr);
    gap: 0.9rem;
    align-items: center;
    padding: 0.95rem;
    border: 1px solid #dfe8f3;
    border-radius: 18px;
    background: #ffffff;
    text-align: left;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

body .formation-quality-item + .formation-quality-item {
    margin-top: 0.85rem;
}

body .formation-quality-item:hover {
    transform: translateY(-2px);
    border-color: rgba(19, 174, 184, 0.45);
    box-shadow: 0 14px 28px rgba(15, 31, 58, 0.08);
}

body .formation-quality-logo {
    min-height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.45rem;
    border-radius: 14px;
    background: #ffffff;
    border: 1px solid #edf2f8;
    overflow: hidden;
}

body .formation-quality-logo img {
    max-width: 92px;
    max-height: 54px;
    object-fit: contain;
    display: block;
}

body .formation-quality-content strong {
    display: block;
    color: #123b68;
    font-size: 0.98rem;
    font-weight: 900;
    line-height: 1.25;
}

body .formation-quality-content small {
    display: block;
    margin-top: 0.25rem;
    color: #6b7a90;
    font-size: 0.84rem;
    line-height: 1.35;
}

/* Documentation */

body .formation-doc-card {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    padding: 1.25rem;
    border: 1px solid #dfe8f3;
    border-radius: 24px;
    background: #ffffff;
    text-decoration: none;
    color: #123b68;
    box-shadow: 0 14px 32px rgba(15, 31, 58, 0.06);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

body .formation-doc-card:hover {
    transform: translateY(-2px);
    border-color: rgba(19, 174, 184, 0.35);
    box-shadow: 0 18px 36px rgba(15, 31, 58, 0.1);
}

body .formation-doc-preview {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 125px;
    padding: 0.85rem;
    border: 1px solid #e5edf7;
    border-radius: 18px;
    background:
        linear-gradient(135deg, rgba(19, 174, 184, 0.06), rgba(35, 86, 154, 0.03)),
        #f8fbff;
    overflow: hidden;
}

body .formation-doc-preview img {
    display: block;
    width: 100%;
    max-width: 230px;
    max-height: 125px;
    object-fit: contain;
}

body .formation-doc-content {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

body .formation-doc-content strong {
    color: #123b68;
    font-size: 1.35rem;
    font-weight: 900;
    line-height: 1.15;
}

body .formation-doc-content small {
    color: #6b7a90;
    font-size: 0.95rem;
    line-height: 1.5;
}

body .formation-doc-link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    width: fit-content;
    margin-top: 0.15rem;
    color: #008c95;
    font-size: 0.95rem;
    font-weight: 900;
}

body .formation-doc-link i {
    color: inherit;
}

/* Programs */

body .formation-programs-section {
    padding-top: 0;
}

body .formation-program-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.15rem;
}

body .formation-program-card {
    display: grid;
    grid-template-columns: 210px minmax(0, 1fr);
    overflow: hidden;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

body .formation-program-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 20px 44px rgba(15, 31, 58, 0.12);
}

body .formation-program-image {
    min-height: 100%;
    background: #eef5ff;
    overflow: hidden;
    text-decoration: none;
}

body .formation-program-image img {
    width: 100%;
    height: 100%;
    min-height: 230px;
    object-fit: cover;
    display: block;
}

body .formation-program-image span {
    width: 100%;
    height: 100%;
    min-height: 230px;
    display: grid;
    place-items: center;
    color: #7b8aa0;
    font-size: 2rem;
}

body .formation-program-content {
    padding: 1.2rem;
    display: flex;
    flex-direction: column;
    min-width: 0;
}

body .formation-program-meta,
body .formation-program-details {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.55rem;
    color: #6b7a90;
    font-size: 0.82rem;
    font-weight: 800;
}

body .formation-program-meta span,
body .formation-program-details span {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

body .formation-program-meta i,
body .formation-program-details i {
    color: #008c95;
}

body .formation-program-card h3 {
    margin: 0.65rem 0 0.55rem;
    font-size: 1.05rem;
    font-weight: 900;
    line-height: 1.25;
}

body .formation-program-card h3 a {
    color: #123b68;
    text-decoration: none;
}

body .formation-program-card h3 a:hover {
    color: #008c95;
}

body .formation-program-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: auto;
}


body .formation-empty-card {
    grid-column: 1 / -1;
    padding: 2rem;
    color: #6b7a90;
    text-align: center;
}

/* =========================
   Formation stats
   ========================= */

body .formation-stats-section {
    margin-top: clamp(2.5rem, 5vw, 5rem);
}

body .formation-stats-header {
    margin-bottom: 1.25rem;
}

body .formation-stats-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

body .formation-stat-card {
    position: relative;
    min-height: 150px;
    padding: 1.35rem;
    overflow: hidden;
}

body .formation-stat-card::after {
    content: "";
    position: absolute;
    right: -28px;
    bottom: -28px;
    width: 110px;
    height: 110px;
    border-radius: 999px;
    background: rgba(19, 174, 184, 0.08);
}

body .formation-stat-icon {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.85rem;
    border-radius: 999px;
    background: #e5f7f5;
    color: #008c95;
    font-size: 1.1rem;
}

body .formation-stat-card strong {
    display: block;
    color: #205082;
    font-size: clamp(2rem, 3vw, 2.7rem);
    font-weight: 900;
    line-height: 1;
}

body .formation-stat-card > span:last-child {
    display: block;
    margin-top: 0.45rem;
    color: #5f6f85;
    font-size: 0.95rem;
    font-weight: 800;
}


/* =========================
   Formation CTA
   ========================= */

body .formation-index-page .formation-cta {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 230px;
    gap: clamp(1.5rem, 3vw, 2.5rem);
    align-items: center;
    margin-top: clamp(2.5rem, 5vw, 5rem);
    padding: clamp(2rem, 3.5vw, 3rem) !important;
    border-radius: 24px;
    background:
        radial-gradient(circle at top right, rgba(19, 174, 184, 0.28), transparent 34%),
        linear-gradient(135deg, #205082 0%, #123b68 100%);
    color: #ffffff;
    box-shadow: 0 22px 48px rgba(15, 31, 58, 0.18);
    overflow: hidden;
}

body .formation-index-page .formation-cta .site-kicker {
    display: inline-flex;
    margin-bottom: 0.75rem;
    color: #22d0d9;
}

body .formation-index-page .formation-cta h2 {
    max-width: 760px;
    margin: 0;
    color: #ffffff;
    font-size: clamp(1.9rem, 3vw, 3rem);
    font-weight: 900;
    line-height: 1.05;
    letter-spacing: -0.035em;
}

body .formation-index-page .formation-cta p {
    max-width: 760px;
    margin: 1rem 0 0;
    color: rgba(255, 255, 255, 0.88);
    font-size: 1.02rem;
    line-height: 1.65;
}

body .formation-index-page .formation-cta-contact {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    margin-top: 1.25rem;
}

body .formation-index-page .formation-cta-contact span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.55rem 0.8rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.13);
    color: #ffffff;
    font-size: 0.9rem;
    font-weight: 800;
}

body .formation-index-page .formation-cta-contact i {
    color: #22d0d9;
}

body .formation-index-page .formation-cta-actions {
    display: grid;
    gap: 0.75rem;
}

body .formation-index-page .formation-cta-button {
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    padding: 0.8rem 1.15rem;
    border-radius: 14px;
    font-weight: 900;
    text-decoration: none;
    white-space: nowrap;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

body .formation-index-page .formation-cta-button:hover {
    transform: translateY(-1px);
}

body .formation-index-page .formation-cta-button-primary {
    background: #13aeb8;
    color: #ffffff;
    box-shadow: 0 12px 24px rgba(19, 174, 184, 0.22);
}

body .formation-index-page .formation-cta-button-primary:hover {
    background: #0f9fa8;
    color: #ffffff;
}

body .formation-index-page .formation-cta-button-secondary {
    border: 1px solid rgba(255, 255, 255, 0.32);
    background: rgba(255, 255, 255, 0.08);
    color: #ffffff;
}

body .formation-index-page .formation-cta-button-secondary:hover {
    background: rgba(255, 255, 255, 0.14);
    color: #ffffff;
}


/* =========================
   Formation program cards refinements
   ========================= */

body .formation-program-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

body .formation-program-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.45rem;
}

body .formation-program-meta span {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
    padding: 0.28rem 0.5rem;
    border-radius: 999px;
    background: #f0f8fb;
    color: #205082;
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1;
}

body .formation-program-meta i {
    color: #008c95;
}

body .formation-program-card h3 {
    margin: 0.7rem 0 0.65rem;
    font-size: 1rem;
    font-weight: 900;
    line-height: 1.24;
}

body .formation-program-context {
    display: grid;
    gap: 0.45rem;
    margin-top: 0.8rem;
    padding: 0.75rem 0.85rem;
    border-radius: 14px;
    background: #f7fbff;
    border: 1px solid #e3edf8;
}

body .formation-program-context span {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    gap: 0.45rem;
    align-items: start;
    max-height: 2.7em;
    overflow: hidden;
    color: #65788f;
    font-size: 0.81rem;
    font-weight: 650;
    line-height: 1.35;
}

body .formation-program-context i {
    color: #008c95;
    font-size: 0.86rem;
    line-height: 1.35;
    opacity: 0.85;
}

body .formation-program-summary {
    margin-top: 0.95rem;
    padding-top: 0.85rem;
    border-top: 1px solid #edf2f8;
    color: #5f6f85;
    font-size: 0.92rem;
    line-height: 1.55;
}

body .formation-program-actions {
    display: grid;
    grid-template-columns: repeat(2, 170px);
    gap: 0.65rem;
    justify-content: center;
    align-items: center;
    margin-top: auto;
    padding-top: 0.95rem;
    border-top: 1px solid #edf2f8;
}

body .formation-program-btn {
    width: 170px;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding: 0.55rem 0.8rem;
    border-radius: 11px;
    font-size: 0.86rem;
    font-weight: 900;
    text-decoration: none;
    line-height: 1;
    white-space: nowrap;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

body .formation-program-btn:hover {
    transform: translateY(-1px);
}

body .formation-program-btn i {
    font-size: 0.95em;
    line-height: 1;
}

body .formation-program-btn-primary {
    background: #008c95;
    color: #ffffff;
    box-shadow: 0 10px 22px rgba(0, 140, 149, 0.18);
}

body .formation-program-btn-primary:hover {
    color: #ffffff;
    background: #087f8c;
}

body .formation-program-btn-secondary {
    border: 1px solid #d7e4f1;
    background: #ffffff;
    color: #205082;
}

body .formation-program-btn-secondary:hover {
    color: #008c95;
    border-color: rgba(0, 140, 149, 0.35);
}


/* =========================
   Formation modals
   ========================= */

body .formation-modal-content {
    border-radius: 18px;
    border: 0;
    overflow: hidden;
}

body .formation-modal-highlight {
    padding: 1rem;
    border-radius: 14px;
    background: #f7fbff;
    border: 1px solid #dfe8f3;
    color: #123b68;
    font-weight: 800;
}

body .formation-modal-list {
    margin: 1rem 0;
    padding-left: 1.2rem;
    color: #344966;
    line-height: 1.65;
}


/* =========================
   Formation responsive
   ========================= */

@media (max-width: 1199.98px) {
    body .formation-overview {
        grid-template-columns: 1fr;
    }

    body .formation-overview-side {
        display: grid;
        grid-template-columns: 1fr 1fr;
        align-items: start;
    }

    body .formation-program-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    body .formation-overview-body,
    body .formation-overview-points,
    body .formation-overview-side,
    body .formation-stats-grid {
        grid-template-columns: 1fr;
    }

    body .formation-program-card {
        grid-template-columns: 1fr;
    }

    body .formation-program-image img,
    body .formation-program-image span {
        min-height: 220px;
    }

    body .formation-index-page .formation-cta {
        grid-template-columns: 1fr;
    }

    body .formation-index-page .formation-cta-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    body .formation-overview-main {
        padding: 1.25rem;
    }

    body .formation-quality-item {
        grid-template-columns: 88px minmax(0, 1fr);
    }

    body .formation-doc-preview img {
        max-width: 200px;
        max-height: 110px;
    }

    body .formation-index-page .formation-cta {
        display: block !important;
        width: 100%;
        padding: 1.35rem !important;
        border-radius: 22px;
        overflow: hidden;
    }


    body .formation-index-page .formation-cta .site-kicker {
        display: block;
        margin-bottom: 0.65rem;
        font-size: 0.72rem;
        line-height: 1.2;
    }

    body .formation-index-page .formation-cta h2 {
        width: 100%;
        max-width: none;
        margin: 0;
        font-size: clamp(1.8rem, 9vw, 2.35rem);
        line-height: 1.08;
        letter-spacing: -0.035em;
        overflow-wrap: normal;
        word-break: normal;
    }

    body .formation-index-page .formation-cta p {
        width: 100%;
        max-width: none;
        margin-top: 0.9rem;
        font-size: 0.98rem;
        line-height: 1.55;
        overflow-wrap: normal;
        word-break: normal;
    }

    body .formation-index-page .formation-cta-contact {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.55rem;
        margin-top: 1rem;
    }

    body .formation-index-page .formation-cta-contact span {
        width: 100%;
        justify-content: center;
        border-radius: 14px;
    }

    body .formation-index-page .formation-cta-actions {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 0.7rem;
        width: 100%;
        min-width: 0;
        margin-top: 1.15rem;
    }

    body .formation-index-page .formation-cta-button,
    body .formation-program-btn {
        width: 100%;
        min-width: 0;
        white-space: normal;
        text-align: center;
    }

    body .formation-program-actions {
        grid-template-columns: 1fr;
    }
}
/* CTA kicker position fix */

body .formation-index-page .formation-cta-content {
    display: block;
    min-width: 0;
}

body .formation-index-page .formation-cta .site-kicker {
    display: block;
    width: 100%;
    float: none;
    clear: both;
    margin: 0 0 0.75rem 0;
    color: #22d0d9;
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1.2;
    text-transform: uppercase;
}

body .formation-index-page .formation-cta h2 {
    display: block;
    clear: both;
    margin: 0;
}
/* =========================
   Programme detail page
   ========================= */

body .programme-detail-page {
    --site-container-width: 1480px;

    background: linear-gradient(180deg, #f7fbff 0%, #ffffff 34%, #f8fbff 100%);
}

body .programme-detail-page .site-page-hero {
    padding-top: clamp(3rem, 4.5vw, 4.5rem);
    padding-bottom: 1rem;
}

body .programme-detail-page .site-page-hero-inner {
    max-width: 1120px;
}

body .programme-detail-page .site-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-bottom: clamp(1.1rem, 1.8vw, 1.6rem);
    color: #6b7a90;
    font-size: 0.92rem;
    font-weight: 600;
}

body .programme-detail-page .site-breadcrumb a {
    color: #164b7f;
    font-weight: 900;
    text-decoration: none;
}

body .programme-detail-page .site-breadcrumb a:hover {
    color: #008c95;
}

body .programme-detail-page .site-breadcrumb-separator {
    color: #9aa8ba;
}

body .programme-detail-page .site-page-title {
    max-width: 1080px;
    color: #205082;
    font-size: clamp(2.25rem, 3.35vw, 3.6rem);
    line-height: 1.02;
}

body .programme-detail-page .site-page-subtitle {
    max-width: 760px;
}

/* Layout */

body .programme-detail-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 1.15rem;
    align-items: start;
}

body .programme-detail-main,
body .programme-detail-side {
    min-width: 0;
}

body .programme-detail-side {
    position: sticky;
    top: 8rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

/* Hero card */

body .programme-hero-card {
    display: grid;
    grid-template-columns: 360px minmax(0, 1fr);
    overflow: hidden;
}

body .programme-hero-image {
    margin: 0;
    min-height: 100%;
    background: #eef5ff;
    overflow: hidden;
}

body .programme-hero-image img {
    width: 100%;
    height: 100%;
    min-height: 390px;
    object-fit: cover;
    display: block;
}

body .programme-hero-content {
    padding: clamp(1.35rem, 2.2vw, 2rem);
}

body .programme-hero-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-bottom: 0.9rem;
}

body .programme-hero-meta span {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.32rem 0.55rem;
    border-radius: 999px;
    background: #f0f8fb;
    color: #205082;
    font-size: 0.82rem;
    font-weight: 900;
    line-height: 1;
}

body .programme-hero-meta i {
    color: #008c95;
}

body .programme-hero-content h2,
body .programme-objectives h2,
body .programme-accordion-section h2,
body .programme-side-card h2 {
    margin: 0;
    color: #205082;
    font-weight: 900;
    line-height: 1.12;
    letter-spacing: -0.025em;
}

body .programme-hero-content h2 {
    font-size: clamp(1.55rem, 2.1vw, 2.15rem);
}

body .programme-description {
    margin-top: 1rem;
    color: #5f6f85;
    font-size: 0.94rem;
    line-height: 1.62;
}

body .programme-description p {
    margin: 0 0 0.85rem;
}

body .programme-description p:last-child {
    margin-bottom: 0;
}

/* Context */

body .programme-context {
    display: grid;
    gap: 0.65rem;
    margin-top: 1rem;
    padding: 0.9rem;
    border-radius: 16px;
    background: #f7fbff;
    border: 1px solid #e3edf8;
}

body .programme-context div {
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr);
    gap: 0.55rem;
    color: #65788f;
    font-size: 0.9rem;
    line-height: 1.45;
}

body .programme-context i {
    color: #008c95;
    line-height: 1.45;
}

body .programme-context strong {
    display: block;
    margin-bottom: 0.12rem;
    color: #123b68;
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

/* Objectives */

body .programme-objectives {
    margin-top: 1.35rem;
    padding: clamp(1.7rem, 2.8vw, 2.4rem);
}

body .programme-objectives .site-kicker {
    margin-bottom: 0.75rem;
}

body .programme-objectives h2 {
    margin-bottom: 1.15rem;
    font-size: clamp(1.45rem, 2vw, 2rem);
}

body .programme-objectives .programme-rich-text {
    margin-top: 0;
    padding-top: 0.25rem;
}

/* Programme accordion */

body .programme-accordion-section {
    margin-top: 1.35rem;
    padding: clamp(1.7rem, 2.8vw, 2.4rem);
}

body .programme-section-header {
    margin-bottom: 1.35rem;
}

body .programme-accordion-section .site-kicker {
    margin-bottom: 0.75rem;
}

body .programme-accordion-section h2 {
    margin-bottom: 0;
    font-size: clamp(1.45rem, 2vw, 2rem);
}

body .programme-rich-text {
    color: #5f6f85;
    font-size: 0.95rem;
    line-height: 1.65;
}

body .programme-rich-text ul {
    display: grid;
    gap: 0.55rem;
    margin: 0;
    padding-left: 1.15rem;
}

body .programme-rich-text li {
    margin: 0;
}

body .programme-accordion {
    display: grid;
    gap: 0.9rem;
}

body .programme-accordion-item {
    border: 1px solid #dfe8f3;
    border-radius: 18px;
    background: #ffffff;
    overflow: hidden;
}

body .programme-accordion-button {
    width: 100%;
    min-height: 66px;
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) auto;
    gap: 0.85rem;
    align-items: center;
    padding: 1.15rem 1.25rem;
    border: 0;
    background: #ffffff;
    color: #123b68;
    text-align: left;
}

body .programme-accordion-button:hover {
    background: #f7fbff;
}

body .programme-accordion-number {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #e5f7f5;
    color: #008c95;
    font-weight: 900;
}

body .programme-accordion-title {
    color: #123b68;
    font-size: 0.95rem;
    font-weight: 900;
    line-height: 1.3;
}

body .programme-accordion-button i {
    color: #008c95;
    transition: transform 0.18s ease;
}

body .programme-accordion-button:not(.collapsed) i {
    transform: rotate(180deg);
}

body .programme-accordion-body {
    margin-top: 0;
    padding: 1.1rem 1.35rem 1.35rem 5.1rem;
    border-top: 1px solid #edf2f8;
}

body .programme-empty {
    padding: 1.25rem;
    border-radius: 16px;
    background: #f7fbff;
    color: #6b7a90;
}

/* Sidebar */

body .programme-side-card {
    padding: 1.2rem;
}

body .programme-side-card-primary {
    background:
        radial-gradient(circle at top right, rgba(19, 174, 184, 0.12), transparent 38%),
        #ffffff;
}

body .programme-side-card h2 {
    font-size: 1.22rem;
}

body .programme-side-card p {
    margin: 0.85rem 0 0;
    color: #5f6f85;
    font-size: 0.9rem;
    line-height: 1.55;
}

body .programme-side-button {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    width: 100%;
    margin-top: 1rem;
    padding: 0.75rem 1rem;
    border-radius: 13px;
    background: #008c95;
    color: #ffffff;
    font-weight: 900;
    text-decoration: none;
    box-shadow: 0 10px 22px rgba(0, 140, 149, 0.18);
}

body .programme-side-button:hover {
    background: #087f8c;
    color: #ffffff;
}

body .programme-side-list {
    display: grid;
    gap: 0.7rem;
}

body .programme-side-list div {
    display: grid;
    grid-template-columns: 30px minmax(0, 1fr);
    gap: 0.6rem;
    align-items: start;
}

body .programme-side-list i {
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #e5f7f5;
    color: #008c95;
    font-size: 0.9rem;
}

body .programme-side-list strong {
    display: block;
    margin-bottom: 0.2rem;
    color: #123b68;
    font-size: 0.9rem;
    font-weight: 900;
}

body .programme-side-list span {
    color: #5f6f85;
    font-size: 0.84rem;
    line-height: 1.45;
}

body .programme-contact-list {
    display: grid;
    gap: 0.55rem;
    margin-top: 1rem;
}

body .programme-contact-list span {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.65rem 0.75rem;
    border-radius: 14px;
    background: #f7fbff;
    color: #123b68;
    font-weight: 900;
}

body .programme-contact-list i {
    color: #008c95;
}

/* Responsive */

@media (max-width: 1199.98px) {
    body .programme-detail-layout {
        grid-template-columns: 1fr;
    }

    body .programme-detail-side {
        position: static;
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    body .programme-detail-page .site-page-title {
        font-size: clamp(2rem, 7vw, 3rem);
    }

    body .programme-hero-card {
        grid-template-columns: 1fr;
    }

    body .programme-hero-image img {
        min-height: 260px;
    }

    body .programme-detail-side {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    body .programme-detail-page .site-page-hero {
        padding-top: 2rem;
    }

    body .programme-hero-content,
    body .programme-objectives,
    body .programme-accordion-section,
    body .programme-side-card {
        padding: 1.2rem;
    }

    body .programme-accordion-button {
        min-height: 58px;
        grid-template-columns: 34px minmax(0, 1fr) auto;
        gap: 0.65rem;
        padding: 0.95rem;
    }

    body .programme-accordion-number {
        width: 34px;
        height: 34px;
    }

    body .programme-accordion-body {
        padding: 1rem;
    }
}
/* =========================
   Programme detail spacing fix
   ========================= */

body .programme-detail-page .programme-objectives.site-card,
body .programme-detail-page .programme-accordion-section.site-card {
    padding: clamp(2rem, 3vw, 2.75rem) clamp(2.4rem, 4vw, 3.4rem) !important;
}

body .programme-detail-page .programme-objectives .site-kicker,
body .programme-detail-page .programme-accordion-section .site-kicker {
    margin: 0 0 0.85rem;
}

body .programme-detail-page .programme-objectives h2,
body .programme-detail-page .programme-accordion-section h2 {
    margin: 0 0 1.35rem;
}

body .programme-detail-page .programme-objectives .programme-rich-text {
    margin-top: 0;
}

body .programme-detail-page .programme-accordion {
    margin-top: 0;
}

/* Трохи більше повітря всередині accordion items */
body .programme-detail-page .programme-accordion-button {
    padding-left: 1.35rem;
    padding-right: 1.35rem;
}

body .programme-detail-page .programme-accordion-body {
    padding-left: 5.25rem;
    padding-right: 1.5rem;
}
@media (max-width: 767.98px) {
    body .programme-detail-page .programme-objectives.site-card,
    body .programme-detail-page .programme-accordion-section.site-card {
        padding: 1.25rem !important;
    }

    body .programme-detail-page .programme-accordion-body {
        padding: 1rem;
    }
}
/* ==========================================================================
   Diagnostic Minibourse - Form
   ========================================================================== */

#diagnostic-form.diagnostic-mini {
    max-width: 1120px;
    margin: 0 auto 3rem;
}

#diagnostic-form .diagnostic-mini-intro {
    max-width: 1050px;
    margin: 2.5rem auto 2rem;
    text-align: center;
}

#diagnostic-form .diagnostic-mini-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    width: fit-content;
    margin: 0 auto 0.85rem;
    padding: 0.45rem 0.9rem;
    border-radius: 999px;
    background: rgba(18, 130, 139, 0.1);
    color: #12828b;
    font-size: 0.9rem;
    font-weight: 800;
    line-height: 1;
}

#diagnostic-form .diagnostic-mini-title {
    max-width: 980px;
    margin: 0 auto 0.75rem;
    color: #174a7c;
    font-size: clamp(1.65rem, 2.6vw, 2.35rem);
    font-weight: 900;
    line-height: 1.15;
    text-align: center;
}

#diagnostic-form .diagnostic-mini-text {
    max-width: 980px;
    margin: 0 auto;
    color: #26384d;
    font-size: 1.1rem;
    font-weight: 400;
    line-height: 1.55;
    text-align: center;
    text-transform: none;
}

/* Progress */
#diagnostic-form .diagnostic-mini-progress {
    max-width: 820px;
    margin: 1.7rem auto 2rem;
}

#diagnostic-form .diagnostic-mini-progress ul {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    padding: 0;
    margin: 0;
    list-style: none;
}

#diagnostic-form .diagnostic-mini-progress li {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 0.65rem;
    padding: 0;
    margin: 0;
    background: transparent;
    border: 0;
    min-height: auto;
    color: #778391;
}

#diagnostic-form .diagnostic-mini-progress li::before {
    content: "";
    position: absolute;
    top: 30px;
    left: -50%;
    width: 100%;
    height: 3px;
    background: #c9cdd2;
    z-index: 1;
}

#diagnostic-form .diagnostic-mini-progress li:first-child::before {
    display: none;
}

#diagnostic-form .diagnostic-mini-progress li.active::before {
    background: #12828b;
}

#diagnostic-form .diagnostic-mini-progress li > div:first-child {
    position: relative;
    z-index: 2;
    width: 60px;
    min-width: 60px;
    height: 60px;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #c9cdd2;
    border: 0;
    box-shadow: 0 0 0 8px #ffffff;
}

#diagnostic-form .diagnostic-mini-progress li.active > div:first-child {
    background: #12828b;
}

#diagnostic-form .diagnostic-mini-progress li p {
    margin: 0;
    color: #ffffff;
    font-size: 1.05rem;
    font-weight: 900;
    line-height: 1;
}

#diagnostic-form .diagnostic-mini-progress .title {
    color: #12828b;
    font-size: 0.9rem;
    font-weight: 900;
    line-height: 1.2;
    text-align: center;
    text-transform: none;
}

#diagnostic-form .diagnostic-mini-progress .title small {
    display: block;
    margin-top: 0.18rem;
    color: #6d7b8c;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: none;
}

/* Card */
#diagnostic-form .diagnostic-mini-card {
    max-width: 1120px;
    margin: 0 auto;
    padding: 2.2rem;
    border: 1px solid #dce7f2;
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 18px 45px rgba(23, 57, 94, 0.11);
}

/* Step header */
#diagnostic-form .diagnostic-mini-step-header {
    margin-bottom: 1.8rem;
    text-align: left;
}

#diagnostic-form .diagnostic-mini-step-header > span {
    display: block;
    margin-bottom: 0.35rem;
    color: #12828b;
    font-size: 0.92rem;
    font-weight: 900;
    text-transform: none;
}

#diagnostic-form .diagnostic-mini-step-header h3 {
    display: block;
    margin-bottom: 0.7rem;
    color: #174a7c;
    font-size: 1.75rem;
    font-weight: 900;
    line-height: 1.2;
    text-transform: none;
}

#diagnostic-form .diagnostic-mini-step-header p {
    display: block;
    margin-top: 0.75rem;
    color: #526579;
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.55;
    text-transform: none;
}

/* Fields */
#diagnostic-form .diagnostic-mini-field {
    height: 100%;
    padding: 1.15rem;
    border: 1px solid #e1ebf5;
    border-radius: 18px;
    background: #fbfdff;
}

#diagnostic-form .diagnostic-mini-label {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    margin-bottom: 0.45rem;
    color: #17395e;
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.35;
    text-transform: none;
}

#diagnostic-form .diagnostic-mini-label i {
    margin-top: 0.12rem;
    color: #12828b;
}

#diagnostic-form .diagnostic-mini-help {
    margin-bottom: 0.75rem;
    color: #667789;
    font-size: 0.86rem;
    font-weight: 500;
    line-height: 1.45;
    text-transform: none;
}

#diagnostic-form .diagnostic-mini-options,
#diagnostic-form .diagnostic-mini-options > div {
    display: grid;
    gap: 0.55rem;
}

#diagnostic-form .diagnostic-mini-options label {
    color: #23374d;
    font-size: 0.95rem;
    font-weight: 600;
    text-transform: none;
}

#diagnostic-form .diagnostic-mini-input {
    border-radius: 6px;
}

/* Note */
#diagnostic-form .diagnostic-mini-note,
#diagnostic-form .diagnostic-mini-note * {
    text-transform: none;
}

#diagnostic-form .diagnostic-mini-note strong {
    display: block;
    margin-bottom: 0.55rem;
    color: #17395e;
    font-size: 1rem;
    font-weight: 900;
    line-height: 1.3;
}

#diagnostic-form .diagnostic-mini-note p {
    margin: 0;
    color: #5f7086;
    font-size: 0.95rem;
    font-weight: 500;
    line-height: 1.55;
}

/* Actions */
#diagnostic-form .diagnostic-mini-actions {
    padding-top: 1.25rem;
    border-top: 1px solid #edf2f7;
}

#diagnostic-form .diagnostic-action-group {
    display: none;
}

#diagnostic-form .diagnostic-action-group.is-active {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 0.75rem;
}

#diagnostic-form .diagnostic-action-group.form_1_btns.is-active {
    justify-content: flex-end;
}

#diagnostic-form .form_4_btns.diagnostic-action-group.is-active {
    justify-content: space-between;
}

#diagnostic-form .diagnostic-mini-btn,
#diagnostic-form .diagnostic-mini-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 8px;
    padding: 0.85rem 1.35rem;
    background: #12828b;
    color: #ffffff;
    font-weight: 800;
    line-height: 1.2;
    text-align: center;
    text-decoration: none;
    white-space: nowrap;
}

#diagnostic-form .diagnostic-mini-btn.is-back {
    background: #eef2f7;
    color: #17395e;
}

#diagnostic-form .diagnostic-mini-submit {
    min-width: 210px;
}

/* Form mobile */
@media (max-width: 768px) {
    #diagnostic-form .diagnostic-mini-card {
        padding: 1.25rem;
    }

    #diagnostic-form .diagnostic-mini-progress ul {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        row-gap: 1.4rem;
    }

    #diagnostic-form .diagnostic-mini-progress li::before {
        display: none;
    }

    #diagnostic-form .diagnostic-action-group.is-active {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    #diagnostic-form .diagnostic-mini-btn,
    #diagnostic-form .diagnostic-mini-submit {
        width: 100%;
    }
}

/* ==========================================================================
   Diagnostic Minibourse - Result page
   ========================================================================== */

.diagnostic-result-page {
    min-height: 0;
    padding-bottom: 4rem;
    background: linear-gradient(180deg, #ffffff 0%, #f7fafc 100%);
}

/* Hero */
.diagnostic-result-hero {
    max-width: 1120px;
    margin: 2rem auto 1.4rem;
    padding: 2rem;
    border: 1px solid #dbe8f0;
    border-radius: 28px;
    background: linear-gradient(180deg, #f8fcfd 0%, #f4f8fb 100%);
    box-shadow: 0 10px 30px rgba(19, 55, 92, 0.05);
}

.diagnostic-result-hero-with-image {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
    gap: 2rem;
    align-items: center;
    text-align: left;
}

.diagnostic-result-copy {
    max-width: 620px;
}

.diagnostic-result-icon {
    width: 62px;
    height: 62px;
    margin-bottom: 1rem;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #eef8fa;
    color: #12828b;
    font-size: 2rem;
}

.diagnostic-result-badge,
.diagnostic-answer-heading > span,
.diagnostic-result-profile-badge,
.diagnostic-result-process-kicker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 30px;
    padding: 0.38rem 0.78rem;
    border-radius: 999px;
    background: rgba(18, 130, 139, 0.12);
    color: #0f7e88;
    font-size: 0.82rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0;
    text-transform: none;
    white-space: nowrap;
}

.diagnostic-result-badge {
    margin-bottom: 0.85rem;
}

.diagnostic-result-hero h1 {
    max-width: 620px;
    margin: 0 0 1rem;
    color: #174a7c;
    font-size: clamp(2rem, 3vw, 3.2rem);
    font-weight: 900;
    line-height: 1.08;
}

.diagnostic-result-hero p {
    max-width: 650px;
    margin: 0;
    color: #53677f;
    font-size: 1rem;
    line-height: 1.65;
}

.diagnostic-result-actions {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 1.4rem;
}

.diagnostic-result-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    min-height: 38px;
    border-radius: 7px;
    padding: 0.55rem 0.85rem;
    color: inherit;
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1.2;
    text-decoration: none;
    transition: all 0.18s ease;
}

.diagnostic-result-btn:hover {
    transform: translateY(-1px);
    text-decoration: none;
}

.diagnostic-result-btn.is-primary {
    background: #12828b;
    color: #ffffff;
    box-shadow: 0 12px 22px rgba(18, 130, 139, 0.18);
}

.diagnostic-result-btn.is-secondary {
    background: #eef2f7;
    color: #17395e;
}

/* Hero visual */
.diagnostic-result-visual {
    position: relative;
    min-height: 320px;
    border-radius: 24px;
    overflow: hidden;
    background: #eef8fa;
    box-shadow: 0 18px 40px rgba(23, 57, 94, 0.12);
}

.diagnostic-result-visual::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(23, 74, 124, 0.08), rgba(18, 130, 139, 0.2)),
        radial-gradient(circle at 80% 10%, rgba(255, 255, 255, 0.35), transparent 32%);
    pointer-events: none;
}

.diagnostic-result-visual img {
    width: 100%;
    height: 100%;
    min-height: 320px;
    object-fit: cover;
    display: block;
}

.diagnostic-result-floating-card {
    position: absolute;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.92);
    color: #17395e;
    box-shadow: 0 16px 34px rgba(23, 57, 94, 0.16);
    backdrop-filter: blur(8px);
}

.diagnostic-result-floating-card.is-top {
    top: 1rem;
    left: 1rem;
    padding: 0.7rem 0.85rem;
    font-weight: 900;
}

.diagnostic-result-floating-card.is-top i {
    color: #12828b;
}

.diagnostic-result-floating-card.is-bottom {
    right: 1rem;
    bottom: 1rem;
    display: grid;
    gap: 0.15rem;
    padding: 0.8rem 0.95rem;
}

.diagnostic-result-floating-card.is-bottom strong {
    color: #12828b;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.diagnostic-result-floating-card.is-bottom span {
    color: #17395e;
    font-weight: 900;
}

/* Personalized answer */
.diagnostic-answer-section {
    max-width: 1120px;
    min-height: 0;
    margin: 0 auto 1.6rem;
    padding: 1.15rem;
    border: 1px solid rgba(18, 130, 139, 0.24);
    border-radius: 28px;
    background:
        linear-gradient(135deg, rgba(18, 130, 139, 0.08) 0%, rgba(23, 74, 124, 0.035) 100%),
        #ffffff;
    box-shadow: 0 18px 44px rgba(23, 57, 94, 0.08);
}

.diagnostic-answer-heading {
    display: block;
    margin-bottom: 1rem;
}

.diagnostic-answer-heading > span {
    margin-bottom: 0.55rem;
}

.diagnostic-answer-heading h2 {
    display: block;
    margin: 0 0 0.35rem;
    color: #17395e;
    font-size: 1.8rem;
    font-weight: 900;
    line-height: 1.15;
}

.diagnostic-answer-heading p {
    display: block;
    margin: 0;
    color: #60748c;
    line-height: 1.55;
}

.diagnostic-result-personal {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 1rem;
    align-items: stretch;
    margin: 0 0 1rem;
}

.diagnostic-result-score,
.diagnostic-result-profile {
    min-height: 0;
    border: 1px solid #dce7f2;
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 16px 40px rgba(23, 57, 94, 0.08);
}

.diagnostic-result-score {
    position: relative;
    overflow: hidden;
    padding: 1.35rem 1.2rem;
}

.diagnostic-result-score::before,
.diagnostic-result-profile::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 6px;
    background: linear-gradient(180deg, #1496a1 0%, #0f7e88 100%);
}

.diagnostic-result-score span {
    display: block;
    margin-bottom: 0.45rem;
    color: #60748c;
    font-size: 0.95rem;
    font-weight: 800;
}

.diagnostic-result-score strong {
    display: block;
    margin-bottom: 1rem;
    color: #184b7d;
    font-size: 4rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: -0.03em;
}

.diagnostic-result-score-bar {
    height: 12px;
    border-radius: 999px;
    background: #e8eef5;
    overflow: hidden;
}

.diagnostic-result-score-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #1496a1 0%, #0f7e88 100%);
}

.diagnostic-result-profile {
    position: relative;
    overflow: hidden;
    padding: 1.45rem 1.5rem;
    background:
        linear-gradient(135deg, rgba(20, 150, 161, 0.06) 0%, rgba(24, 75, 125, 0.03) 100%),
        #ffffff;
}

.diagnostic-result-profile::before {
    width: 8px;
    background: linear-gradient(180deg, #1496a1 0%, #1f5c97 100%);
}

.diagnostic-result-profile-top {
    display: flex;
    align-items: center;
    margin-bottom: 0.75rem;
}

.diagnostic-result-profile h2 {
    margin: 0 0 0.75rem;
    color: #17395e;
    font-size: 1.85rem;
    font-weight: 900;
    line-height: 1.2;
}

.diagnostic-result-profile p {
    margin-bottom: 0;
    color: #5c6f86;
    font-size: 1.04rem;
    line-height: 1.65;
}

/* Personalized insight cards */
.diagnostic-result-insights {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    min-height: 0;
    margin: 0;
}

.diagnostic-result-insight-card {
    min-height: 0;
    padding: 1.25rem;
    border: 1px solid #dce7f2;
    border-radius: 22px;
    background: #ffffff;
    box-shadow: 0 12px 32px rgba(23, 57, 94, 0.07);
}

.diagnostic-result-insight-card h2 {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.85rem;
    color: #17395e;
    font-size: 1.12rem;
    font-weight: 900;
}

.diagnostic-result-insight-card ul {
    margin: 0;
    padding-left: 1.1rem;
}

.diagnostic-result-insight-card li,
.diagnostic-result-insight-card p {
    margin-bottom: 0.55rem;
    color: #5d6f85;
    font-size: 0.98rem;
    line-height: 1.55;
}

.diagnostic-result-insight-card li:last-child,
.diagnostic-result-insight-card p:last-child {
    margin-bottom: 0;
}

.diagnostic-result-insight-card.is-positive {
    background: linear-gradient(180deg, #f8fdfc 0%, #ffffff 100%);
    border-color: #d6efe9;
}

.diagnostic-result-insight-card.is-warning {
    background: linear-gradient(180deg, #fffaf3 0%, #ffffff 100%);
    border-color: #f2dfba;
}

.diagnostic-result-insight-card.is-next {
    background: linear-gradient(180deg, #f6fbff 0%, #ffffff 100%);
    border-color: #d9e7f6;
}

.diagnostic-result-insight-card.is-positive h2 i {
    color: #1496a1;
}

.diagnostic-result-insight-card.is-warning h2 i {
    color: #c58a1c;
}

.diagnostic-result-insight-card.is-next h2 i {
    color: #1f5c97;
}

/* Process */
.diagnostic-result-process {
    max-width: 1120px;
    min-height: 0;
    margin: 0 auto 1.6rem;
    padding: 0;
}

.diagnostic-result-process-heading {
    margin-bottom: 1rem;
    padding: 1rem 1.15rem;
    border: 1px solid #dce7f2;
    border-radius: 22px;
    background:
        linear-gradient(135deg, rgba(238, 248, 250, 0.95) 0%, rgba(255, 255, 255, 0.96) 100%);
}

.diagnostic-result-process-kicker {
    margin-bottom: 0.55rem;
}

.diagnostic-result-process-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.diagnostic-result-process-heading h2 {
    margin: 0 0 0.25rem;
    color: #17395e;
    font-size: 1.35rem;
    font-weight: 900;
}

.diagnostic-result-process-heading p {
    margin-bottom: 0;
    color: #5f7086;
    line-height: 1.55;
}

.diagnostic-result-process-icon {
    width: 44px;
    min-width: 44px;
    height: 44px;
    border-radius: 15px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #ffffff;
    color: #12828b;
    font-size: 1.25rem;
    box-shadow: 0 10px 24px rgba(23, 57, 94, 0.08);
}

.diagnostic-result-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
    margin: 0;
}

.diagnostic-result-card {
    position: relative;
    height: auto;
    padding: 1.15rem 1.15rem 1.15rem 1.3rem;
    border: 1px solid #dce7f2;
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 10px 28px rgba(23, 57, 94, 0.045);
}

.diagnostic-result-step-number {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #eef8fa;
    color: #12828b;
    font-size: 0.82rem;
    font-weight: 900;
}

.diagnostic-result-card-icon {
    width: 38px;
    height: 38px;
    margin-bottom: 0.75rem;
    border-radius: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #eef8fa;
    color: #12828b;
    font-size: 1.1rem;
}

.diagnostic-result-card h2 {
    margin-bottom: 0.45rem;
    padding-right: 2rem;
    color: #17395e;
    font-size: 1.02rem;
    font-weight: 900;
}

.diagnostic-result-card p {
    margin-bottom: 0;
    color: #5f7086;
    font-size: 0.95rem;
    line-height: 1.55;
}

/* CTA */
.diagnostic-result-next {
    max-width: 1120px;
    margin: 0 auto;
    padding: 1.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border: 1px solid rgba(18, 130, 139, 0.2);
    border-radius: 22px;
    background: #eef8fa;
}

.diagnostic-result-next h2 {
    margin-bottom: 0.3rem;
    color: #17395e;
    font-size: 1.15rem;
    font-weight: 700;
}

.diagnostic-result-next p {
    margin-bottom: 0;
    color: #53677f;
    line-height: 1.55;
}

.diagnostic-result-next .diagnostic-result-btn {
    min-width: 150px;
    padding: 0.6rem 0.9rem;
}

/* Result mobile */
@media (max-width: 992px) {
    .diagnostic-result-hero-with-image,
    .diagnostic-result-personal,
    .diagnostic-result-insights,
    .diagnostic-result-grid {
        grid-template-columns: 1fr;
    }

    .diagnostic-result-hero-with-image {
        text-align: center;
    }

    .diagnostic-result-copy {
        max-width: none;
    }

    .diagnostic-result-icon {
        margin-left: auto;
        margin-right: auto;
    }

    .diagnostic-result-hero h1,
    .diagnostic-result-hero p {
        margin-left: auto;
        margin-right: auto;
        text-align: center;
    }

    .diagnostic-result-actions {
        justify-content: center;
    }

    .diagnostic-result-next {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 768px) {
    .diagnostic-result-hero,
    .diagnostic-answer-section {
        padding: 1.2rem;
        border-radius: 22px;
    }

    .diagnostic-result-visual,
    .diagnostic-result-visual img {
        min-height: 260px;
    }

    .diagnostic-result-floating-card.is-bottom {
        left: 1rem;
        right: 1rem;
    }

    .diagnostic-result-actions,
    .diagnostic-result-btn {
        width: 100%;
    }

    .diagnostic-result-btn {
        text-align: center;
    }

    .diagnostic-result-score strong {
        font-size: 3.1rem;
    }

    .diagnostic-result-profile h2 {
        font-size: 1.45rem;
    }

    .diagnostic-result-process-title-row {
        align-items: flex-start;
    }

    .diagnostic-result-process-icon {
        display: none;
    }
}
.diagnostic-mini-alert {
    margin-bottom: 1.25rem;
    color: #dc3545;
    font-weight: 700;
}

.diagnostic-mini-error,
.diagnostic-mini-error ul,
.diagnostic-mini-error li {
    margin: 0.35rem 0 0;
    padding-left: 0;
    color: #dc3545;
    list-style: none;
    font-weight: 500;
}
/* Diagnostic Minibourse - RGPD note */
#diagnostic-form .diagnostic-submit-area {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.65rem;
    max-width: 520px;
}

#diagnostic-form .diagnostic-rgpd-note {
    margin: 0;
    color: #64758a;
    font-size: 0.82rem;
    font-weight: 500;
    line-height: 1.45;
    text-align: right;
    text-transform: none;
}

@media (max-width: 768px) {
    #diagnostic-form .diagnostic-submit-area {
        width: 100%;
        max-width: none;
        align-items: stretch;
    }

    #diagnostic-form .diagnostic-rgpd-note {
        text-align: left;
    }
}