/**************************/
/* Aspect global de l'app */
/**************************/

/* Supprime les marges par défaut de tous les Div */
html, body, .app-container, .dash-container, .container {
    margin: 0px;
    padding: 0px;
    font-family: 'Roboto', sans-serif;
    background-color: #f5f5f5;
}

/* Supprime les marges des `html.Div` spécifiquement */
div {
    margin: 0px;
    padding: 0px;
}

/********/
/* Tabs */
/********/

.my-tab {
    background-color: white;
}

/* Hover : léger pop */
.my-tab:hover {
    background-color: #f2f2f2 !important; /* <-- force le hover à overwrite la couleur par défaut de dash */
}

/***********/
/* Sign in */
/***********/

.signin-button {
    display: block;
    width: 140px;
    margin: 20px auto;
    padding: 10px;
    text-align: center;
    background-color: #4285F4;
    color: white;
    text-decoration: none;
    border-radius: 5px;
    font-size: 16px;
    transition: background-color 0.2s ease;
}

.signin-button:hover {
    background-color: navy; /* bleu plus foncé */
}

.footer-container {
    display: flex;
    justify-content: space-between; /* élément gauche / élément droit */
    align-items: center;
    padding: 10px 20px;
    color: grey;                     /* texte gris uniforme */
    font-size: 12px;
}

/* Couleur grise uniforme pour tout le footer */
.footer-text {
    color: grey;               /* même gris pour tout le texte */
    font-size: 12px;
    text-align: center;
}

/* Lien dans le footer */
.footer-link {
    color: grey;               /* même gris que le texte normal */
    text-decoration: none;     /* pas de soulignement par défaut */
    transition: text-decoration 0.2s ease;
    cursor: pointer;
}

.footer-link:hover {
    text-decoration: underline; /* underline uniquement au hover */
}

/***********/
/* Sidebar */
/***********/

/* Styles pour la barre latérale */
.sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: 250px;
    height: 100%;
    background-color: #e9ecef;
    padding: 20px;
    box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease-in-out;
}

/* Barre latérale visible */
.sidebar-visible {
    transform: translateX(0);
}

/* Barre latérale masquée */
.sidebar-hidden {
    transform: translateX(-100%);
}

/* Position par défaut du bouton (sidebar visible) */
.toggle-btn {
    position: fixed;
    top: 10px;
    left: 260px; /* Aligné avec le sidebar visible */
    z-index: 10;
    background-color: transparent;
    color: #495057; /* Gris foncé */
    border: none;
    border-radius: 4px;
    padding: 5px 10px;
    cursor: pointer;
    font-size: 20px; /* Taille de police augmentée */
    transition: left 0.3s ease-in-out; /* Transition fluide */
}

/* Position lorsque le sidebar est masqué */
.sidebar-hidden + .toggle-btn {
    left: 10px; /* Repositionné à gauche */
}

/* Styles pour la bannière */
.sidebar-banner {
    width: 90%;
    height: auto;
    display: block;
    margin: 0 auto;
    padding: 20px 0;
}

/* Conteneur du menu de navigation */
.sidebar-navigation {
    margin-top: 20px;
    margin-bottom: 20px;
    background-color: white; /* Fond par défaut */
    border-radius: 8px;
    padding: 10px; /* Ajoute un espacement autour des éléments du menu */
}

/* Élément individuel du menu de navigation */
.sidebar-nav-item {
    display: flex; /* Permet d'aligner les icônes et le texte */
    align-items: center; /* Centre verticalement les icônes */
    width: 88%; /* Chaque élément occupe toute la largeur */
    padding: 10px 15px;
    margin: 5px 0;
    border-radius: 5px;
    text-decoration: none; /* Supprime le soulignement */
    color: black; /* Couleur du texte */
    font-size: 16px; /* Taille de police */
    cursor: pointer;
    transition: background-color 0.1s, color 0.1s;
}

.sidebar-nav-item:hover {
    outline: 1px solid #66b3ff; /* Contour bleu sans modifier la taille */
}

.sidebar-nav-item:active {
    background-color: #cce7ff; /* Couleur légèrement plus foncée */
    outline: 1px solid #007bff;
}

/* Icône dans les éléments du menu */
.sidebar-nav-item i {
    margin-right: 10px; /* Espacement entre l'icône et le texte */
}

/* Élément sélectionné dans le menu */
.sidebar-nav-item-selected {
    background-color: #d4e6f1; /* Couleur pour l'option sélectionnée */
    color: #007bff; /* Texte bleu pour la sélection */
}

/* Styles pour le footer */
.sidebar-footer {
    position: absolute;
    bottom: 40px;
    width: calc(100% - 40px);
    text-align: center;
    padding: 10px;
    box-sizing: border-box;
}

/*********************/
/* Contenu principal */
/*********************/

/* Contenu principal lorsque le sidebar est visible */
.main-content {
    margin-left: 290px; /* Largeur du sidebar */
    transition: margin-left 0.3s ease-in-out;
    padding: 20px;
}

/* Contenu principal étendu lorsque le sidebar est masqué */
.main-content-expanded {
    margin-left: 0; /* Pas de sidebar */
    transition: margin-left 0.3s ease-in-out;
    padding: 20px;
}

/************/
/* SIGN OUT */
/************/

/* Styles pour le bouton Sign out */
.signout-button {
    height: 36px;
    line-height: 30px;
    padding: 0 10px; /* padding horizontal uniquement */
    background-color: white; /* Fond blanc par défaut */
    color: black; /* Texte noir */
    border: 1px solid #d3d3d3; /* Contour gris pâle */
    border-radius: 5px;
    font-size: 16px;
    cursor: pointer;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); /* Légère ombre */
    transition: background-color 0.1s, color 0.1s; /* Transition pour l'effet hover */
    margin: 0px;
    font-family: Arial, sans-serif;
    display: block;
}

.signout-button:hover {
    background-color: #ffc0cb; /* Rose clair */
    color: white; /* Texte blanc */
}

/******************/
/* df dash AgGrid */
/******************/

.ag-theme-balham {
    --ag-font-family: monospace !important;
    --ag-font-size: 12px !important;
}

/* Paramètres pour cellules dans le dataframe */
.ag-theme-balham .ag-cell {
    box-sizing: border-box;
    border: 1px solid transparent;  /* Reserve space for outline */
    color: 'black';                         /* Optional: font color */
}

/* Paramètres pour les cellulues séléctionnées */
.ag-theme-balham .ag-cell.ag-cell-focus,
.ag-theme-balham .ag-cell.ag-cell-range-selected {
    border: 1px solid #6496ff !important; /* outline color (light blue) */
    box-sizing: border-box !important;   /* ensures full cell coverage */
}

/* Paramètres pour les headers des colonnes */
.ag-theme-balham .ag-header-cell-label {
    color: #808080;                          /* optional */
}

/***************/
/* BOUTON BLEU */
/***************/

/* Style par défaut pour le bouton */
.blue-button {
    height: 32px;
    line-height: 30px;
    border-radius: 5px;
    text-align: center;
    margin: 0px;
    font-family: Arial, sans-serif;
    font-size: 16px;
    cursor: pointer;
    display: block;
    background-color: #5e9fcf; /* Bleu doux */
    color: white; /* Couleur du texte */
    border: none; /* Supprime la bordure */
    transition: background-color 0.1s ease, box-shadow 0.1s ease; /* Animation fluide */
}
/* Effet hover */
.blue-button:hover {
    background-color: #4b89b3; /* Bleu légèrement plus foncé */
    box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.2); /* Légère ombre */
    transform: scale(1.02); /* Légère mise en avant */
}
/* Effet au clic */
.blue-button:active {
    background-color: #3e6f8f; /* Bleu encore plus foncé */
    transform: scale(0.98); /* Effet d'appui */
}

/* Style par défaut pour le bouton */
.red-button {
    height: 32px;
    line-height: 30px;
    border-radius: 5px;
    text-align: center;
    margin: 0px;
    font-family: Arial, sans-serif;
    font-size: 16px;
    cursor: pointer;
    display: block;
    background-color: #cf5e5e; /* Rouge doux */
    color: white; /* Couleur du texte */
    border: none; /* Supprime la bordure */
    transition: background-color 0.1s ease, box-shadow 0.1s ease; /* Animation fluide */
}
/* Effet hover */
.red-button:hover {
    background-color: #b34b4b; /* Rouge plus foncé */
    box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.2); /* Légère ombre */
    transform: scale(1.02); /* Légère mise en avant */
}
/* Effet au clic */
.red-button:active {
    background-color: #9e3f3f; /* Rouge encore plus foncé */
    transform: scale(0.98); /* Effet d'appui */
}

/* Checkbox pour activer/désactiver une étape de préparation de données */
.checkbox-prepare-data-unchecked {
    font-weight: bold;
    font-size: 1.05rem; /* Taille équivalente à H4 */
}
/* Survol des labels avec padding élargi */
.checkbox-prepare-data-unchecked label {
    display: inline-block; /* Permet d'ajouter un padding à l'ensemble du label */
    padding: 5px 10px; /* Ajoute un peu d'espace autour du texte */
    border-radius: 5px; /* Optionnel : arrondi pour un effet plus agréable */
    transition: background-color 0.1s ease-in-out; /* Animation douce */
}
/* Effet hover légèrement gris */
.checkbox-prepare-data-unchecked label:hover {
    background-color: #f0f0f0; /* Gris clair */
    cursor: pointer; /* Indique que c'est cliquable */
}
.checkbox-prepare-data-checked {
    font-weight: bold;
    font-size: 1.05rem; /* Taille équivalente à H4 */
}
/* Survol des labels avec padding élargi */
.checkbox-prepare-data-checked label {
    display: inline-block; /* Permet d'ajouter un padding à l'ensemble du label */
    padding: 5px 10px; /* Ajoute un peu d'espace autour du texte */
    border-radius: 5px; /* Optionnel : arrondi pour un effet plus agréable */
    transition: background-color 0.1s ease-in-out; /* Animation douce */
    background-color: #e0e7ef; /* e6f7ff bleu pâle,  e0e7ef bleu pâle grisonnant, edf2f7 bleu très léger */
}
/* Effet hover légèrement gris */
.checkbox-prepare-data-checked label:hover {
    background-color: #f0f0f0; /* Gris clair */
    cursor: pointer; /* Indique que c'est cliquable */
}

/*********************************************/
/* PARAMÉTRAGE DE LA MATRICE D'APPRENTISSAGE */
/*********************************************/

/* Pour le bouton radio permettant de sélectionner la variable cible */
.radio-button-parametrize-learning-matrix-target {
}
/* Survol des labels avec padding élargi */
.radio-button-parametrize-learning-matrix-target label {
    display: flex; /* Active Flexbox */
    justify-content: flex-start; /* Aligne à gauche horizontalement */
    align-items: center; /* Centre verticalement */
    height: 36px; /* Hauteur du conteneur */
    border-width: 1px; /* Épaisseur de la bordure */
    border-radius: 5px; /* Coins arrondis */
    border-style: solid; /* Style de la bordure */
    border-color: #e0e0e0; /* Couleur de la bordure */
    padding: 0 10px; /* Ajoute un peu d'espace à gauche/droite */
    line-height: 36px; /* Alignement vertical en dernier recours */
    box-sizing: border-box; /* Inclut les bordures dans le calcul de la taille */
}
/* Effet hover légèrement gris */
.radio-button-parametrize-learning-matrix-target label:hover {
    cursor: pointer; /* Indique que c'est cliquable */
}

/* Slider de l'intervalle cible */
.rc-slider-track {
    background-color: #4b89b3; /* Bleu légèrement plus foncé */
    height: 6px; /* Ajuste la hauteur de la barre */
}
/* Personnaliser les labels des marks */
.rc-slider-mark-text {
    font-size: 14px; /* Augmente la taille du texte */
    color: #333333; /* Texte plus foncé */
    font-weight: bold; /* Met le texte en gras */
    user-select: none; /* Empêche de sélectionner les labels */
    margin-top: 5px; /* Ajoute un peu d'espace au-dessus du label */
}
/* Barre inactive avant le premier handle et après le second */
.rc-slider-rail {
    background-color: #a9a9a9; /* Gris clair pour la barre inactive */
    height: 6px; /* Même hauteur que la barre active */
}
/* Personnaliser la taille des boules (handles) */
.rc-slider-handle {
    width: 20px; /* Largeur de la boule */
    height: 20px; /* Hauteur de la boule */
    background-color: #007bff; /* Couleur de la boule */
    border: 2px solid #0056b3; /* Couleur de la bordure */
    box-shadow: none; /* Retire l'ombre si nécessaire */
    margin-top: -7px; /* Ajuste la position verticale */
}
/* Au survol des boules */
.rc-slider-handle:hover {
    background-color: #0056b3; /* Couleur de fond au survol */
    cursor: pointer; /* Indique que c'est interactif */
}
/* Poignée en cours de glissement */
.rc-slider-handle:active {
    background-color: #004494; /* Couleur de fond lors du glissement */
    border-color: #003366; /* Couleur de la bordure lors du glissement */
}
/* Désactiver l'effet de focus */
.rc-slider-handle:focus {
    outline: none; /* Supprime l'effet de focus par défaut */
    border-color: #0056b3; /* Rétablit la bordure normale */
    background-color: #007bff; /* Rétablit la couleur normale */
}
/* Personnaliser les tooltips */
/* Ajuster la position des tooltips */
.rc-slider-tooltip.rc-slider-tooltip-placement-bottom {
    margin-top: 30px !important; /* Forcer la distance entre la tooltip et la barre */
    position: absolute; /* Positionnement absolu pour fixer la position */
}

/***********/
/* TOOLTIP */
/***********/

.tooltip-container {
  position: relative; 
}

.tooltip-trigger {
  cursor: default; /* garde le curseur normal */
}

.tooltip-text {
  visibility: hidden;
  position: absolute;
  opacity: 0;
  background-color: rgba(50, 50, 50, 0.95);
  color: white;
  text-align: left;
  border-radius: 6px;
  padding: 8px 10px;
  top: 120%;
  left: 50%;
  transform: translateX(-50%);
  transition: opacity 1.0s ease-in-out 0.0s; /* délai de 0.3s avant fade-in */
  font-size: 12px;
  width: max-content;
  white-space: normal;
  word-wrap: break-word;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
  z-index: 999999;
  pointer-events: none;
}

/* Affiche l’infobulle après le hover */
.tooltip-trigger:hover + .tooltip-text {
  visibility: visible;
  opacity: 1;
  transition-delay: 0s;
}

/************************************/
/* INSPECTION DES RÈGLES DU RULESET */
/************************************/


/**********************************/
/* BOUTON POUR FERMER LE À PROPOS */
/**********************************/

.about-close-button:hover {
    background-color: #f0f0f0;  /* Gris clair au survol */
}

/****************************/
/* AJUSTEMENTS AUX DROPDOWN */
/****************************/

/* Hauteur du conteneur du dropdown */
.dash-dropdown {
    height: 36px !important;
    min-height: 36px !important;
}

/* Contrôle principal */
.dash-select {
    height: 36px !important;
    min-height: 36px !important;
}

/* Zone cliquable */
.dash-select__control {
    min-height: 36px !important;
    height: 36px !important;
    padding: 0 !important;
}

/* Texte affiché */
.dash-select__single-value {
    line-height: 36px !important;
}

/* Placeholder */
.dash-select__placeholder {
    line-height: 36px !important;
}

/* Input interne */
.dash-select__input-container {
    padding: 0 !important;
    margin: 0 !important;
    height: 36px !important;
}


/***********************************************/
/* dataframe_navigator component               */
/* (this must be copied to the css of the app) */
/***********************************************/

/* Container for the dataframe */
.dataframe-navigator {
    width: 730px;
    margin: 0 auto;
    overflow: hidden;
    transition: max-height 0.4s ease-in-out, opacity 0.4s ease-in-out;
    opacity: 1;
    max-height: 1000px;  /* Large enough for your dataframe */
}

/* When hidden, collapse and fade out */
.dataframe-navigator-hidden {
    max-height: 0;
    opacity: 0;
    transition: max-height 0.4s ease-in-out, opacity 0.4s ease-in-out;
    pointer-events: none;
}

/* When visible */
.dataframe-navigator-visible {
    max-height: 1000px;
    opacity: 1;
}

/* Common base style for all DF buttons */
button.dataframe-navigator-button-base {
    width: 20px !important;
    height: 20px !important;
    border-radius: 4px !important;
    font-size: 14px !important;
    line-height: 24px !important;
    padding: 0 !important;
    margin: 4px !important;
    transition: background-color 0.2s ease, box-shadow 0.2s ease !important;
}

/* When visible */
button.dataframe-navigator-buttons {
    border: 1px solid #ccc !important;
    background-color: #f0f0f0 !important;
    color: rgb(0, 0, 0) !important;
    cursor: pointer !important;
}

/* When hidden */
button.dataframe-navigator-hidden-df-buttons {
    border: 1px solid #ccc !important;
    background-color: #e6e6e6 !important;
    color: rgb(93, 93, 93) !important;
    cursor: not-allowed !important;
}

/* Hover only applies when active */
button.dataframe-navigator-buttons:hover {
    color: #757575 !important;
    box-shadow: 0 2px 2px rgba(0, 0, 0, 0.15) !important;
    transform: scale(1.03) !important;
}

/* Base style */
/* button.dataframe-navigator-toggle-button {
    transition: color 0.2s ease !important;
} */

/* Hover effect */
button.dataframe-navigator-toggle-button:hover {
    color: #6f6f6f !important; /* Lighter grey on hover */
}

.dataframe-navigator-bar {
    color: #6f6f6f !important;
}







