/* Surcharge pour le menu Bootstrap à l’image de ton ancien menu */

/* Correction du lien Accueil dans le menu Bootstrap */
.navbar .navselect {
    background-color: transparent !important;
    color: white !important;
    font-weight: bold;
    font-size: 0.9rem;
    padding: 8px 12px;
    border-radius: 5px;
}

    /* Survol pour Accueil */
.navbar .navselect:hover {
        background-color: #ffffff !important;
        color: #000000 !important;
        text-decoration: none;
}

/* Espace horizontal 2px autour des liens de navbar */
.navbar .navbar-brand,
.navbar .nav-link,
.navbar .dropdown-toggle,
.navbar .navselect {
    border-left: 2px solid transparent;
    border-right: 2px solid transparent;
    background-clip: padding-box; /* le bg ne recouvre pas la "gouttière" */
}

.navbar .navselect.active,
.navbar .navselect[aria-current="page"] {
        background-color: #ffffff !important;
        color: #000000 !important;
        border-radius: 5px;
}

.navbar {
    background-color: #79644a !important;
    color: white !important;
    padding: 10px 0;
    margin-bottom: 10px;
    
}

    .navbar .navbar-brand,
    .navbar .nav-link,
    .navbar .dropdown-toggle {
        color: white !important;
        font-weight: bold;
        font-size: 0.9rem;
        padding: 8px 12px;
        border-radius: 5px;
        transition: all 0.2s ease-in-out;
    }

        .navbar .nav-link:hover,
        .navbar .navbar-brand:hover,
        .navbar .dropdown-toggle:hover {
            background-color: white !important;
            color: #000 !important;
            text-decoration: none;
        }

        .navbar .nav-link.front-mode-active {
            background-color: #ffffff !important;
            color: #000000 !important;
            text-decoration: none;
        }

    /* Dropdown menu Bootstrap */
    .navbar .dropdown-menu {
        background-color: #ffffff;
        border: none;
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
        min-width: 200px;
    }

        .navbar .dropdown-menu a {
            color: #000000 !important;
            padding: 10px 15px;
            font-size: 0.9rem;
        }

            .navbar .dropdown-menu a:hover {
                background-color: #f5f5f5;
                color: #79644a !important;
            }

/* Hamburger icon style */
.navbar-toggler {
    border: none;
    background-color: white !important;
    padding: 5px 10px;
    border-radius: 5px;
}

.navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='black' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}
@media (max-width: 768px) {
    /* diminue hauteur carousel smarphone */
    #carouselContainer {
        height: 108px !important;
        max-height: 108px !important;
        overflow: hidden !important;
    }

    #carouselExample,
    #carouselExample .carousel-inner,
    #carouselExample .carousel-item {
        height: 108px !important;
        max-height: 108px !important;
        overflow: hidden !important;
    }

    #carouselExample .carousel-item img {
        height: 108px !important;
        max-height: 108px !important;
        object-fit: cover !important;
        object-position: center top !important;
    }
}

/* Version desktop : liens étalés sur toute la largeur */
.navbar-nav {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

    .navbar-nav .nav-item {
        flex-grow: 1;
        text-align: center;
    }

    .navbar-nav .nav-link {
        width: 100%;
        padding: 10px;
    }

/* Responsive mobile : aligner à gauche */
@media (max-width: 768px) {
    .navbar-nav {
        flex-direction: column;
        align-items: flex-start;
    }

        .navbar-nav .nav-item {
            width: 100%;
            text-align: left;
        }

        .navbar-nav .nav-link {
            width: 100%;
            padding: 10px 15px;
        }

        /* dropdown full width en mobile */
        .navbar-nav .dropdown-menu {
            width: 100%;
            min-width: unset;
        }
}


/* Theme palette d'apres les visuels fournis */
:root {
    --fd-primary: #673ab7;
    --fd-primary-dark: #4f2a98;
    --fd-primary-soft: #efe9ff;
    --fd-action: #59657b;
    --fd-action-dark: #465167;
    --fd-accent: #00a6b4;
    --fd-warm: #ffb21f;
    --fd-ink: #111827;
    --fd-surface: #ffffff;
    --fd-border: #dedede;
}

body {
    background:
        linear-gradient(
            180deg,
            #ffffff 0%,
            #f4f0fb 9%,
            #d9c9f1 28%,
            #b491dd 52%,
            #8759c9 76%,
            var(--fd-primary) 100%
        ) fixed !important;
    background-color: var(--fd-primary) !important;
}

.containerhaut {
    background-color: var(--fd-surface) !important;
}

.navbar,
#navbar {
    background-color: var(--fd-primary) !important;
    color: #ffffff !important;
}

.navbar .navbar-brand,
.navbar .nav-link,
.navbar .dropdown-toggle,
.navbar .navselect,
#navbar a {
    color: #ffffff !important;
}

.navbar .navselect.active,
.navbar .navselect[aria-current="page"],
.navbar .nav-link.front-mode-active,
.navbar .navselect:hover,
.navbar .nav-link:hover,
.navbar .navbar-brand:hover,
.navbar .dropdown-toggle:hover,
#navbar a:hover {
    background-color: #ffffff !important;
    color: #000000 !important;
}

.navbar .dropdown-menu a:hover {
    color: var(--fd-primary) !important;
}

a,
.search-container a,
.result-item a,
.result-item h2 a,
.result-table a,
.home-title,
.author a,
.editor a,
.rubrique a,
.collections a,
.sources a,
.parcours a,
.formats a,
.sousrubrique a,
.keyword a,
.publisher a,
.thematique a,
.category-column a,
.subcategory-column a,
.mb-1 a,
.mb-2 a {
    color: var(--fd-primary) !important;
}

.btn-primary,
.btn-warning,
.fc-btn-primary,
#toggle-search,
.search-container button[type="submit"] {
    background-color: var(--fd-action) !important;
    border-color: var(--fd-action) !important;
    color: #ffffff !important;
}

.btn-primary:hover,
.btn-warning:hover,
.fc-btn-primary:hover,
#toggle-search:hover,
.search-container button[type="submit"]:hover {
    background-color: var(--fd-primary) !important;
    border-color: var(--fd-primary) !important;
    color: #ffffff !important;
}

.btn-outline-primary {
    --bs-btn-color: var(--fd-primary);
    --bs-btn-border-color: var(--fd-primary);
    --bs-btn-hover-color: #ffffff;
    --bs-btn-hover-bg: var(--fd-primary);
    --bs-btn-hover-border-color: var(--fd-primary);
    --bs-btn-active-color: #ffffff;
    --bs-btn-active-bg: var(--fd-primary);
    --bs-btn-active-border-color: var(--fd-primary);
    --bs-btn-disabled-color: var(--fd-primary);
    --bs-btn-disabled-border-color: var(--fd-primary);
}

.pagination .page-item.active .page-link,
.pagination .active,
.page-link.active {
    background-color: var(--fd-primary) !important;
    border-color: var(--fd-primary) !important;
    color: #ffffff !important;
}

.page-link {
    color: var(--fd-primary) !important;
}

.similaires .card-title.h2,
.similaires .card-title.h2 a {
    color: var(--fd-primary) !important;
}

.similaires .badge.text-bg-secondary,
.badge.text-bg-secondary,
.result-item .badge,
.card .badge {
    background-color: var(--fd-primary) !important;
    color: #ffffff !important;
}

.similaires .badge.text-bg-secondary:hover,
.badge.text-bg-secondary:hover,
.result-item .badge:hover,
.card .badge:hover {
    background-color: var(--fd-primary-dark) !important;
    color: #ffffff !important;
}

select.filtre-actif,
.filtre-actif {
    color: var(--fd-primary) !important;
    background-color: var(--fd-primary-soft) !important;
    border-color: var(--fd-primary) !important;
}

hr {
    border-top-color: var(--fd-primary) !important;
}

.search-container,
.result-container,
.page-container,
.page-similaire {
    border-color: var(--fd-border) !important;
}

.fa,
fa-brands,
a i.fa-brands {
    color: var(--fd-primary) !important;
}

.fa-facebook-f {
    color: #1877f2 !important;
}

.fa-x-twitter {
    color: #000000 !important;
}

footer,
.footer {
    background-color: #000000 !important;
    color: #ffffff !important;
}

footer a,
.footer a {
    color: #ffffff !important;
}


/* Supprime la bande blanche sous la navigation */
.containerhaut {
    background-color: transparent !important;
    padding-bottom: 0 !important;
}

.wrapper,
main {
    background: transparent !important;
}

.navbar {
    margin-bottom: 0 !important;
}

.page-container.detail-page-container {
    margin-top: 20px !important;
}


/* Presentation en panneaux blancs sur fond violet */
main {
    background: transparent !important;
}

.containerhaut {
    background: transparent !important;
}

.page-container,
.search-container,
.result-container,
.page-similaire {
    background-color: #ffffff !important;
    border: 1px solid #dedede !important;
    border-radius: 6px !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, .16) !important;
}

.page-container {
    padding: 28px 20px !important;
}

.search-container,
.result-container,
.page-similaire {
    padding: 22px 20px !important;
    margin-top: 18px !important;
    margin-bottom: 22px !important;
}

.result-container.list .result-item,
.result-item {
    background-color: #ffffff !important;
    border: 1px solid #d8d8d8 !important;
    border-radius: 4px !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .12) !important;
    margin-bottom: 22px !important;
}

.result-container.grid .result-item {
    border-radius: 4px !important;
}

.page-container.detail-page-container {
    margin-top: 20px !important;
}

@media (max-width: 768px) {
    .page-container,
    .search-container,
    .result-container,
    .page-similaire {
        border-radius: 4px !important;
        padding: 14px !important;
    }
}

/* Layout width overrides */
.page-container {
    max-width: 93% !important;
    width: 93% !important;
}

.result-container {
    max-width: 93% !important;
    width: 93% !important;
}

.container-fluid {
    max-width: 93% !important;
    width: 93% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
/* Switch admin/visiteur actif sur le front */
.navbar .navbar-nav .nav-item > a.nav-link.front-mode-active,
.navbar .navbar-nav .nav-item > a.nav-link.front-mode-active:visited,
.navbar .navbar-nav .nav-item > a.nav-link.front-mode-active:focus,
.navbar .navbar-nav .nav-item > a.nav-link.front-mode-active:hover {
    background: #ffffff !important;
    background-color: #ffffff !important;
    color: #000000 !important;
    border-radius: 5px !important;
    text-decoration: none !important;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,.12) !important;
}

.navbar .navbar-nav .nav-item > a.nav-link.front-mode-active i {
    color: #000000 !important;
}

/* Normalisation hauteur bouton Accueil / liens navbar front et admin */
.navbar .navbar-brand,
.navbar .navbar-brand-logo,
.navbar .nav-link,
.navbar .dropdown-toggle,
.navbar .navselect {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 38px !important;
    line-height: 1.2 !important;
}

.navbar .navbar-brand-logo {
    color: #ffffff !important;
    font-weight: bold !important;
    font-size: 0.9rem !important;
    padding: 8px 12px !important;
    border-radius: 5px !important;
    text-decoration: none !important;
}

.navbar .navbar-brand-logo:hover,
.navbar .navbar-brand-logo.navselect.active {
    background-color: #ffffff !important;
    color: #000000 !important;
    text-decoration: none !important;
}

/* Alignement fin du lien Accueil et espacement des icones navbar */
.navbar .navbar-brand,
.navbar .navbar-brand-logo,
.navbar .nav-link,
.navbar .dropdown-toggle,
.navbar .navselect {
    vertical-align: middle !important;
    gap: .38rem !important;
}

.navbar .navbar-brand i,
.navbar .navbar-brand-logo i,
.navbar .nav-link i,
.navbar .dropdown-toggle i,
.navbar .navselect i,
.navbar .dropdown-item i {
    margin-right: .38rem !important;
    line-height: 1 !important;
    display: inline-block !important;
}

.navbar .navbar-brand.navselect,
.navbar .navbar-brand-logo.navselect {
    transform: translateY(-1px);
}

/* Admin : rendre Accueil exactement aussi haut que les liens du menu */
.admin-navbar .navbar-brand-logo.navselect,
.admin-navbar .navbar-brand-logo.navselect.active {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 44px !important;
    height: 44px !important;
    padding: 10px 14px !important;
    margin: 0 !important;
    line-height: 1.2 !important;
    box-sizing: border-box !important;
    transform: none !important;
}

.admin-navbar .nav-link {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 44px !important;
    height: 44px !important;
    box-sizing: border-box !important;
}

/* Admin : alignement vertical strict de toute la barre */
.admin-navbar .container-fluid,
.admin-navbar .navbar-collapse,
.admin-navbar .navbar-nav {
    align-items: center !important;
}

.admin-navbar .navbar-nav {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

.admin-navbar .navbar-brand-logo.navselect {
    align-self: center !important;
    position: relative !important;
    top: -2px !important;
}

/* Front/admin : espacement plus serré entre icône Font Awesome et libellé navbar */
.navbar .navbar-brand,
.navbar .navbar-brand-logo,
.navbar .nav-link,
.navbar .dropdown-toggle,
.navbar .navselect {
    gap: .24rem !important;
}

.navbar .navbar-brand i,
.navbar .navbar-brand-logo i,
.navbar .nav-link i,
.navbar .dropdown-toggle i,
.navbar .navselect i,
.navbar .dropdown-item i {
    margin-right: .16rem !important;
}

/* Parent de sous-menu actif sur le front */
.navbar .nav-item.dropdown.is-active-parent > .nav-link,
.navbar .nav-item.dropdown:has(.dropdown-item.navselect.active) > .nav-link,
.navbar .nav-item.dropdown:has(.dropdown-item.active) > .nav-link {
    background-color: #ffffff !important;
    color: #000000 !important;
    border-radius: 5px !important;
    text-decoration: none !important;
}

.navbar .nav-item.dropdown.is-active-parent > .nav-link i,
.navbar .nav-item.dropdown:has(.dropdown-item.navselect.active) > .nav-link i,
.navbar .nav-item.dropdown:has(.dropdown-item.active) > .nav-link i {
    color: #000000 !important;
}

/* Modale suppression : contraste RGAA du bouton danger */
#deleteConfirmButton,
#deleteConfirmButton:visited,
#deleteConfirmButton:hover,
#deleteConfirmButton:focus {
    color: #ffffff !important;
}

#deleteConfirmButton i {
    color: #ffffff !important;
}

/* Admin mobile : aligner les liens du menu hamburger à gauche */
@media (max-width: 991.98px) {
    .admin-navbar .navbar-collapse,
    .admin-navbar .navbar-nav {
        align-items: stretch !important;
        text-align: left !important;
        width: 100% !important;
    }

    .admin-navbar .navbar-nav .nav-item {
        width: 100% !important;
    }

    .admin-navbar .nav-link,
    .admin-navbar .dropdown-toggle,
    .admin-navbar .dropdown-item {
        justify-content: flex-start !important;
        text-align: left !important;
        width: 100% !important;
    }

    .admin-navbar .dropdown-menu {
        text-align: left !important;
        width: 100% !important;
    }
}
