/* ===== Redéfinition complète des éléments "primary" de Bootstrap ===== */
/* Font */
.ubuntu-light {
  font-family: "Ubuntu", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.ubuntu-regular {
  font-family: "Ubuntu", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.ubuntu-medium {
  font-family: "Ubuntu", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.ubuntu-bold {
  font-family: "Ubuntu", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.ubuntu-light-italic {
  font-family: "Ubuntu", sans-serif;
  font-weight: 300;
  font-style: italic;
}

.ubuntu-regular-italic {
  font-family: "Ubuntu", sans-serif;
  font-weight: 400;
  font-style: italic;
}

.ubuntu-medium-italic {
  font-family: "Ubuntu", sans-serif;
  font-weight: 500;
  font-style: italic;
}

.ubuntu-bold-italic {
  font-family: "Ubuntu", sans-serif;
  font-weight: 700;
  font-style: italic;
}

/* Boutons */
.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: #6d3ae4;
    --bs-btn-border-color: #6d3ae4;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #5a2bcb;
    --bs-btn-hover-border-color: #5427b8;
    --bs-btn-focus-shadow-rgb: 109, 58, 228;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #5427b8;
    --bs-btn-active-border-color: #4e24a6;
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #6d3ae4;
    --bs-btn-disabled-border-color: #6d3ae4;
}

/* Liens */
.link-primary {
    color: #6d3ae4;
}

.link-primary:hover,
.link-primary:focus {
    color: #5427b8;
}

/* Liens */
.nav-link-primary {
    color: #6d3ae4;
  text-decoration: none;
  display: block;
  transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out;
  padding: var(--bs-nav-link-padding-y) var(--bs-nav-link-padding-x);
  padding-right: var(--bs-navbar-nav-link-padding-x);
  padding-left: var(--bs-navbar-nav-link-padding-x);
}

.nav-link-primary:hover,
.nav-link-primary:focus {
    color: #5427b8;
}

/* Fond principal (alertes, badges, cartes, etc.) */
.bg-primary {
    background-color: #6d3ae4 !important;
}

.bg-primary-subtle {
    background-color: rgba(109, 58, 228, 0.1) !important;
}

/* Bordures */
.border-primary {
    border-color: #6d3ae4 !important;
}

/* Texte en couleur primary */
.text-primary {
    color: #6d3ae4 !important;
}

/* Badges */
.badge.bg-primary {
    background-color: #6d3ae4;
}

/* Alertes */
.alert-primary {
    --bs-alert-color: #5427b8;
    --bs-alert-bg: rgba(109, 58, 228, 0.1);
    --bs-alert-border-color: rgba(109, 58, 228, 0.2);
}

/* Barre de progression */
.progress-bar.bg-primary {
    background-color: #6d3ae4;
}

/* Liste groupée */
.list-group-item-primary {
    color: #5427b8;
    background-color: rgba(109, 58, 228, 0.1);
}

/* ===== Style des boutons .btn-light (orange) ===== */

/* État par défaut */
.btn-light {
    --bs-btn-color: #2c1810; /* Texte foncé pour contraste */
    --bs-btn-bg: #fff; /* Fond blanc */
    --bs-btn-border-color: #fd5901; /* Bordure orange */
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #fd5901; /* Fond orange au survol */
    --bs-btn-hover-border-color: #e04f00;
    --bs-btn-focus-shadow-rgb: 253, 89, 1; /* Ombre orange pour le focus */
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #e04f00; /* Fond orange plus foncé au clic */
    --bs-btn-active-border-color: #c74500;
    --bs-btn-disabled-color: #fff; /* Texte violet si désactivé */
    --bs-btn-disabled-bg: #fff;
    --bs-btn-disabled-border-color: #fd5901;

    /* Style personnalisé */
    background-color: var(--bs-btn-bg);
    border-color: var(--bs-btn-border-color);
    color: var(--bs-btn-color);
    font-weight: 500;
    padding: 0.5rem 1.25rem;
    border-radius: 0.375rem;
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(253, 89, 1, 0.2);
}

/* État au survol (hover) */
.btn-light:hover {
    background-color: var(--bs-btn-hover-bg);
    border-color: var(--bs-btn-hover-border-color);
    color: var(--bs-btn-hover-color);
    box-shadow: 0 4px 8px rgba(253, 89, 1, 0.3);
    transform: translateY(-1px);
}

/* État focus (clavier) */
.btn-light:focus {
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-btn-focus-shadow-rgb), 0.5);
    outline: none;
}

/* État actif (clic) */
.btn-light:active {
    background-color: var(--bs-btn-active-bg);
    border-color: var(--bs-btn-active-border-color);
    color: var(--bs-btn-active-color);
    box-shadow: 0 2px 4px rgba(253, 89, 1, 0.2);
    transform: translateY(0);
}

/* État désactivé */
.btn-light:disabled,
.btn-light.disabled {
    background-color: var(--bs-btn-disabled-bg);
    border-color: var(--bs-btn-disabled-border-color);
    color: var(--bs-btn-disabled-color);
    opacity: 0.8;
    box-shadow: none;
    transform: none;
}

/* Boutons larges (ex: .btn-lg) */
.btn-light.btn-lg {
    padding: 0.75rem 2rem;
    font-size: 1.1rem;
}

/* Boutons petits (ex: .btn-sm) */
.btn-light.btn-sm {
    padding: 0.25rem 0.75rem;
    font-size: 0.875rem;
}

/* Boutons avec icônes */
.btn-light i {
    margin-right: 0.5rem;
}

/*
========================================================================
*/

/* ===== Style des boutons .btn-outline-primary ===== */

/* État par défaut */
.btn-outline-primary {
    --bs-btn-color: #6d3ae4; /* Texte violet */
    --bs-btn-bg: transparent; /* Fond transparent */
    --bs-btn-border-color: #6d3ae4; /* Bordure violet */
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #6d3ae4; /* Fond violet au survol */
    --bs-btn-hover-border-color: #6d3ae4;
    --bs-btn-focus-shadow-rgb: 109, 58, 228;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #5a2bcb; /* Fond violet plus foncé au clic */
    --bs-btn-active-border-color: #5427b8;
    --bs-btn-disabled-color: #6d3ae4;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #6d3ae4;

    /* Style personnalisé */
    background-color: var(--bs-btn-bg);
    border-color: var(--bs-btn-border-color);
    color: var(--bs-btn-color);
    font-weight: 500;
    padding: 0.5rem 1.25rem;
    border-radius: 0.375rem;
    transition: all 0.3s ease;
}

/* État au survol (hover) */
.btn-outline-primary:hover {
    background-color: var(--bs-btn-hover-bg);
    border-color: var(--bs-btn-hover-border-color);
    color: var(--bs-btn-hover-color);
    box-shadow: 0 4px 8px rgba(109, 58, 228, 0.3);
    transform: translateY(-1px);
}

/* État focus (clavier) */
.btn-outline-primary:focus {
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-btn-focus-shadow-rgb), 0.5);
    outline: none;
}

/* État actif (clic) */
.btn-outline-primary:active {
    background-color: var(--bs-btn-active-bg);
    border-color: var(--bs-btn-active-border-color);
    color: var(--bs-btn-active-color);
    box-shadow: 0 2px 4px rgba(109, 58, 228, 0.2);
    transform: translateY(0);
}

/* État désactivé */
.btn-outline-primary:disabled,
.btn-outline-primary.disabled {
    background-color: var(--bs-btn-disabled-bg);
    border-color: var(--bs-btn-disabled-border-color);
    color: var(--bs-btn-disabled-color);
    opacity: 0.6;
    box-shadow: none;
    transform: none;
}

/* Boutons larges (ex: .btn-lg) */
.btn-outline-primary.btn-lg {
    padding: 0.75rem 2rem;
    font-size: 1.1rem;
}

/* Boutons petits (ex: .btn-sm) */
.btn-outline-primary.btn-sm {
    padding: 0.25rem 0.75rem;
    font-size: 0.875rem;
}

/* Boutons avec icônes */
.btn-outline-primary i {
    margin-right: 0.5rem;
}


/*
========================================================================
*/

/* Formulaires (input, select, etc.) */
.form-control:focus,
.form-select:focus,
.form-check-input:focus {
    border-color: #6d3ae4;
    box-shadow: 0 0 0 0.25rem rgba(109, 58, 228, 0.25);
}

/* Pagination */
.page-item.active .page-link {
    background-color: #6d3ae4;
    border-color: #6d3ae4;
}

.form-check-input:checked {
  background-color: #6d3ae4!important;
  border-color: #6d3ae4!important;
}


/* ===== Style des accordions ===== */

/* Conteneur principal de l'accordéon */
.accordion {
    --bs-accordion-color: #2c1810;
    --bs-accordion-bg: #fff;
    --bs-accordion-border-color: #e0e0e0;
    --bs-accordion-border-width: 1px;
    --bs-accordion-border-radius: 0.375rem;
    --bs-accordion-inner-border-radius: calc(0.375rem - 1px);
    --bs-accordion-btn-padding-x: 1.25rem;
    --bs-accordion-btn-padding-y: 1rem;
    --bs-accordion-btn-color: #2c1810;
    --bs-accordion-btn-bg: #f8f9fa;
    --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%236d3ae4'%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'/%3e%3c/svg%3e");
    --bs-accordion-btn-icon-width: 1.25rem;
    --bs-accordion-btn-icon-transform: rotate(-180deg);
    --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%236d3ae4'%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'/%3e%3c/svg%3e");
    --bs-accordion-btn-focus-border-color: #6d3ae4;
    --bs-accordion-btn-focus-box-shadow: 0 0 0 0.25rem rgba(109, 58, 228, 0.25);
    --bs-accordion-body-padding-x: 1.25rem;
    --bs-accordion-body-padding-y: 1rem;
    --bs-accordion-active-color: #6d3ae4;
    --bs-accordion-active-bg: #f0f0ff;
}

/* Style de l'élément accordéon */
.accordion-item {
    background-color: var(--bs-accordion-bg);
    border: var(--bs-accordion-border-width) solid var(--bs-accordion-border-color);
    border-radius: var(--bs-accordion-border-radius);
    margin-bottom: 0.5rem;
    overflow: hidden;
}

/* Premier élément de l'accordéon (suppression de la bordure supérieure) */
.accordion-item:first-of-type {
    border-top-left-radius: var(--bs-accordion-border-radius);
    border-top-right-radius: var(--bs-accordion-border-radius);
}

/* Dernier élément de l'accordéon (suppression de la bordure inférieure) */
.accordion-item:last-of-type {
    border-bottom: 0;
    border-bottom-left-radius: var(--bs-accordion-border-radius);
    border-bottom-right-radius: var(--bs-accordion-border-radius);
}

/* En-tête de l'accordéon */
.accordion-header {
    margin: 0;
}

/* Bouton de l'accordéon */
.accordion-button {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    padding: var(--bs-accordion-btn-padding-y) var(--bs-accordion-btn-padding-x);
    font-size: 1rem;
    color: var(--bs-accordion-btn-color);
    text-align: left;
    background-color: var(--bs-accordion-btn-bg);
    border: 0;
    border-radius: 0;
    overflow-anchor: none;
    transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out, border-radius 0.2s ease;
}

/* Bouton de l'accordéon au survol */
.accordion-button:hover {
    z-index: 2;
    color: var(--bs-accordion-active-color);
    background-color: var(--bs-accordion-active-bg);
}

/* Bouton de l'accordéon lorsqu'il est actif */
.accordion-button:not(.collapsed) {
    color: var(--bs-accordion-active-color);
    background-color: var(--bs-accordion-active-bg);
    box-shadow: inset 0 -1px 0 var(--bs-accordion-border-color);
}

/* Bouton de l'accordéon lorsqu'il est focus */
.accordion-button:focus {
    z-index: 3;
    border-color: var(--bs-accordion-btn-focus-border-color);
    outline: 0;
    box-shadow: var(--bs-accordion-btn-focus-box-shadow);
}

/* Icône du bouton de l'accordéon */
.accordion-button::after {
    flex-shrink: 0;
    width: var(--bs-accordion-btn-icon-width);
    height: var(--bs-accordion-btn-icon-width);
    margin-left: auto;
    content: "";
    background-image: var(--bs-accordion-btn-icon);
    background-repeat: no-repeat;
    background-size: var(--bs-accordion-btn-icon-width);
    transition: transform 0.2s ease-in-out;
}

/* Icône du bouton de l'accordéon lorsqu'il est actif */
.accordion-button:not(.collapsed)::after {
    background-image: var(--bs-accordion-btn-active-icon);
    transform: var(--bs-accordion-btn-icon-transform);
}

/* Corps de l'accordéon */
.accordion-body {
    padding: var(--bs-accordion-body-padding-y) var(--bs-accordion-body-padding-x);
    color: var(--bs-accordion-color);
    background-color: var(--bs-accordion-bg);
}

/* Contenu du corps de l'accordéon */
.accordion-collapse {
    border: 0;
}

/* ===== Style du carousel ===== */

/* Style pour les contrôles du carrousel */
.carousel-control-prev,
.carousel-control-next {
    width: 5%; /* Réduit la largeur des contrôles */
    opacity: 0.7; /* Rend les contrôles légèrement transparents */
    transition: opacity 0.3s; /* Animation pour le survol */
}

.carousel-control-prev:hover,
.carousel-control-next:hover {
    opacity: 1; /* Rendre les contrôles opaques au survol */
}

/* Positionnement des contrôles pour éviter la superposition */
.carousel-control-prev {
    left: -5%; /* Décale le bouton "Précédent" vers la gauche */
}

.carousel-control-next {
    right: -5%; /* Décale le bouton "Suivant" vers la droite */
}

/* Assure que les cartes ne dépassent pas et que les contrôles sont accessibles */
.carousel-inner {
    padding: 0 10%; /* Ajoute un padding pour éviter la superposition */
}

/* Style pour les cartes */
.card {
    margin: 0 auto; /* Centre les cartes */
}

/* ===== Style les items du détail du contenu ===== */

ul.itemContentDetail {
  list-style: none;
  margin-left: 0;
  padding-left: 0;
}

li.itemContentDetail {
  padding-left: 1em;
  text-indent: -1em;
}

li.itemContentDetail:before {
  content: "+";
  padding-right: 5px;
}

/* =============== Notes bas de formations ======= */
.text-small-information {
  font-size: 0.8em;
  text-align: center;
}
