/* Styles généraux du body */
body {
    font-family: Arial, sans-serif;
}

/* Styles pour les éléments numstyle, numstylepink, etc. */
.numstyle, .numstylepink, .opstyle, .textstyle, .centerstyle, .centerstyle1, .formstyle, .form, .entetetab, .offline, .underOffline, .facultatif, .underFacultatif, .obligatoire, .underObligatoire, .examen, .underExamen {
    border-radius: 10px;
    padding: 10px;
    font-family: "Arial";
}

.numstyle, .numstylepink {
    border: 1px solid; 
    font-size: 50px;
    margin: 4px;
    color: white;
}

.numstyle {
    background-color: lightblue;
}

.numstylepink {
    background-color: pink;
}

.opstyle {
    border: 1px solid;
    background-color: pink;
    padding: 10px;
    border-radius: 20px;
    color: white;
    font-size: 40px;
}

.textstyle, .centerstyle, .centerstyle1 {
    font-weight: bold;
    font-size: 50px;
}

.centerstyle, .centerstyle1 {
    text-align: center;
}

.centerstyle1 {
    border: 1px solid; 
    background-color: lightblue;
    margin: 4px;
    color: white;
}

.formstyle {
    width: 100px;
    height: 60px;
    font-size: 50px; 
}

.form {
    display: inline;
}

.entetetab, .offline, .underOffline, .facultatif, .underFacultatif, .obligatoire, .underObligatoire, .examen, .underExamen {
    border: 1px solid white;
    color: #383d56;
}

.entetetab {
    background-color: black;
    color: white;
}

.offline {
    background-color: #e2e3e5;
    color: #383d56;
}

.underOffline {
    background-color: #f6f7f8;
    color: #383d56;
}

.facultatif {
    background-color: #d1ecf1;
    color: #383d41;
}

.underFacultatif {
    background-color: #e5f3e8;
    color: #383d41;
}

.obligatoire {
    background-color: #cce5ff;
    color: #383d41;
}

.underObligatoire {
    background-color: #deedfc;
    color: #383d41;
}

.examen {
    background-color: #f8d7da;
    color: #383d41;
}

.underExamen {
    background-color: #faecee;
    color: #383d41;
}

/* Styles pour les ombres et alertes */
.shadow {
    box-shadow: 1px 1px 12px #555;
}

.custom-alert, .custom-alert-primary, .custom-alert-warning {
    border-radius: 15px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    color: white;
    padding: 20px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.custom-alert-primary-no-hover {
    background: linear-gradient(#6a11cb 20%, #2575fc 80%);
    color: #333333;
}

.custom-alert-primary-no-hover:hover {
    transform: none;
    box-shadow: none;
}

.custom-alert {
    background: linear-gradient(#6a11cb 20%, #2575fc 80%);
}

.custom-alert-primary {
    border-left: 8px solid #007bff;
    background: #d9edf7;
    color: #31708f;
}

.custom-alert-warning {
    background: linear-gradient(#FFFF66 20%, #f9eb9a 80%);
    color: #333333;
}

.custom-alert:hover {
    transform: translateY(-5px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
}

.custom-btn {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.custom-btn:hover {
    transform: translateY(-5px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
}

/* Styles pour les cartes de cours */
.course-card {
    transition: transform 0.2s;
    margin-bottom: 20px;
}

.course-card:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.course-icon {
    font-size: 40px;
    color: #ffffff;
}

.btn-course {
    display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 15px;
            text-align: left;
}

.btn-course span {
    flex-grow: 1;
    margin-left: 10px;
    color: #ffffff;
}

.card-container {
    margin-bottom: 20px;
}

.margin-5 {
    margin: 5px 0;
}

/* Styles pour le fond du modal */
.custom-modal {
    display: none; /* Masquer le modal par défaut */
    position: fixed; /* Fixer le modal par rapport à la fenêtre du navigateur */
    top: 0;
    left: 0;
    width: 100%; /* Prendre toute la largeur de la fenêtre */
    height: 100%; /* Prendre toute la hauteur de la fenêtre */
    overflow: auto; /* Ajouter un défilement si nécessaire */
    background-color: rgba(0, 0, 0, 0.5); /* Fond semi-transparent */
    z-index: 1; /* Assurer que le modal est au-dessus des autres éléments */
}

/* Styles pour le contenu du modal */
.custom-modal-content {
    box-sizing: border-box;
    position: absolute; /* Positionner le modal par rapport à son conteneur parent */
    top: 20%; /* Ajuste la position verticale du modal */
    left: 5%; /* Positionner à 5% de la largeur de la fenêtre */
    width: 90%; /* Largeur du modal, ajustez selon vos besoins */
    padding: 20px; /* Espacement interne du modal */
    background-color: #fff; /* Fond blanc pour le modal */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Ombre légère autour du modal */
    text-align: center; /* Alignement du texte au centre */
    font-size: 1em; /* Taille du texte, ajustez selon vos besoins */
    border-radius: 8px; /* Coins arrondis du modal */
    animation: pulse 1s ease-out; /* Animation d'illumination */
    max-height: 80%; /* Limite la hauteur maximale pour éviter de sortir de l'écran */
    overflow-y: auto; /* Ajoute un défilement si le contenu dépasse la hauteur max */
}


/* Styles pour le bouton de fermeture du modal */
.custom-close {
    color: #aaa; /* Couleur du bouton de fermeture */
    float: right; /* Positionner à droite */
    font-size: 28px; /* Taille de la police du bouton */
    font-weight: bold; /* Gras pour le bouton */
    position: absolute; /* Positionné par rapport au modal-content */
    top: 10px;
    right: 10px;
}

.custom-close:hover,
.custom-close:focus {
    color: black; /* Couleur lorsque survolé ou en focus */
    text-decoration: none; /* Supprimer la décoration du texte */
    cursor: pointer; /* Curseur en forme de main */
}

/* Animation d'illumination */
@keyframes pulse {
    0% {
        transform: scale(1);
        box-shadow: 0 0 10px rgba(255, 215, 0, 0.5);
    }
    50% {
        transform: scale(1.05);
        box-shadow: 0 0 20px rgba(255, 215, 0, 0.7);
    }
    100% {
        transform: scale(1);
        box-shadow: 0 0 10px rgba(255, 215, 0, 0.5);
    }
}

/* Container for buttons */
.btn-container {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 20px; /* Space between score and buttons */
}

/* Custom button styling */
.custom-btn {
    margin: 5px; /* Space between buttons */
    padding: 10px 20px; /* Adjust padding for better button size */
    font-size: 1em; /* Consistent font size */
    border-radius: 5px; /* Rounded corners */
}
