/* ======================================================================
   BLUEBOX – composant réutilisable
   ----------------------------------------------------------------------
   .bluebox              – conteneur principal
   .bluebox--large       – largeur max 1200 px
   .bluebox--compact     – largeur & padding réduits
   .bluebox--wide-gap    – écart de colonnes plus grand
   .bluebox--separator   – trait vertical entre colonnes (desktop)
   .bluebox__icon        – pictogramme circulaire
   .bluebox__cols        – grille flex de colonnes
   .bluebox__col         – colonne
   .bluebox__note        – texte centré sous la grille
   ====================================================================== */

/* === SECTION WRAPPER ================================================= */
.bluebox-section {
  display: flex;
  justify-content: center;
  background: #fff;
  padding: 60px 20px;
}

/* === BLOC PRINCIPAL ================================================== */
.bluebox {
  /* variables CSS personnalisables */
  --bb-max: 1100px; /* largeur par défaut            */
  --bb-gap: 40px; /* écart entre colonnes           */

  position: relative;
  width: 100%;
  max-width: var(--bb-max);
  padding: 60px;
  border-radius: 10px;
  background: #f0f7fe;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
  display: flex;
  flex-direction: column;
}

/* --- Modificateurs --------------------------------------------------- */
.bluebox--large {
  --bb-max: 1200px;
}
.bluebox--wide-gap {
  --bb-gap: 50px;
}
.bluebox--compact {
  --bb-max: 700px;
  padding: 40px;
}

@media (max-width: 768px) {
  .bluebox--compact {
    padding: 30px 20px;
  }
}

/* === Icône circulaire =============================================== */
.bluebox__icon {
  position: absolute;
  top: -35px;
  left: 40px;
  width: 70px;
  height: 70px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #eef5fb;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
}
.bluebox__icon i {
  font-size: 24px;
  color: #4e7c8d;
}

/* === Grille interne ================================================== */
.bluebox__cols {
  display: flex;
  gap: var(--bb-gap);
  width: 100%;
  justify-content: center;
  flex-wrap: wrap;
}
.bluebox__col {
  flex: 0 1 calc(50% - var(--bb-gap) / 2);
  color: #555;
  line-height: 1.6;
}

/* --- variante compact : une seule colonne --------------------------- */
.bluebox--compact .bluebox__col {
  flex: 1 1 100%;
  text-align: center;
}
.bluebox--compact .bluebox__col p {
  margin: 8px 0;
}

/* --- séparateur vertical (desktop) ---------------------------------- */
.bluebox--separator .bluebox__col:first-child {
  position: relative;
}
.bluebox--separator .bluebox__col:first-child::after {
  content: "";
  position: absolute;
  top: 0;
  right: calc(var(--bb-gap) / -2);
  width: 1px;
  height: 100%;
  background: rgba(0, 0, 0, 0.1);
}

/* === Typographie & liens ============================================ */
.bluebox h2 {
  font-size: 1.8rem;
  font-weight: 700;
  color: #4e7c8d;
  margin: 0 0 12px;
}
.bluebox ul {
  list-style: disc inside;
  margin: 15px 0;
  padding: 0;
}
.bluebox li {
  margin-bottom: 10px;
}
.bluebox li strong {
  color: #4e7c8d;
}
.bluebox a {
  color: #1d7aa8;
  text-decoration: none;
}

/* === Note / CTA centré ============================================== */
.bluebox__note {
  width: 100%;
  margin-top: 30px;
  text-align: center;
  font-weight: 600;
  color: #4e7c8d;
}
.bluebox__note a {
  color: #1d7aa8;
}

.bluebox__col hr {
  border: none;
  border-top: 1px solid #ccc;
  margin: 24px auto;
  width: 60%;
}

/* ======================================================================
   RESPONSIVE GÉNÉRAL
   ====================================================================== */
@media (max-width: 768px) {
  .bluebox {
    padding: 40px 25px;
  }
  .bluebox__cols {
    flex-direction: column;
    gap: 25px;
  }
  .bluebox__col {
    flex: 1 1 100%;
  }
  .bluebox--separator .bluebox__col:first-child::after {
    display: none;
  }
}

/* --- Correctif spécifique aux .bluebox--large ----------------------- */
@media (max-width: 768px) {
  .bluebox--large {
    --bb-gap: 25px;
  }
  .bluebox--large .bluebox__cols {
    display: block; /* annule flex pour éviter débordement */
  }
  .bluebox--large .bluebox__col {
    width: 100%;
    max-width: 100%;
    margin-bottom: var(--bb-gap);
  }
  .bluebox--large .bluebox__col:last-child {
    margin-bottom: 0;
  }

  .bluebox--large.bluebox--separator .bluebox__col:first-child::after {
    display: none;
  }

  .bluebox h2 {
    text-align: center;
    overflow-wrap: anywhere;
    word-wrap: break-word;
    hyphens: auto;
  }
}
