/* ============================================================
   biodiv-listes-styles.css
   Styles pour le système de listes personnelles — Biodivothèque
   Ce fichier est chargé sur : biodivotest2.php + mes-listes.php
   ============================================================ */

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   1. BOUTON "MES LISTES" DANS LA NAVIGATION
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Wrapper : position relative pour le dropdown */
.nav-listes-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

/*
 * NOTE SPÉCIFICITÉ :
 * Les règles pour les buttons utilisent le préfixe .page-template-biodivotest2
 * pour surpasser le reset CSS global défini dans biodivotest2-styles.css.
 * Ce préfixe est ajouté à la fois sur le catalogue ET sur mes-listes.php
 * grâce au filtre body_class dans functions-listes-additions.php.
 */

/* Bouton principal : identique au style .btn-user-account / .btn-login-nav */
.main-header .btn-mes-listes-nav,
.page-template-biodivotest2 .btn-mes-listes-nav,
.btn-mes-listes-nav {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: transparent !important;
    border: 1.5px solid rgba(255, 255, 255, 0.35) !important;
    border-radius: var(--radius-md, 8px);
    color: white !important;
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
    white-space: nowrap;
    line-height: 1;
    box-shadow: none !important;
}

.main-header .btn-mes-listes-nav:hover,
.main-header .btn-mes-listes-nav.is-active,
.page-template-biodivotest2 .btn-mes-listes-nav:hover,
.page-template-biodivotest2 .btn-mes-listes-nav.is-active,
.btn-mes-listes-nav:hover,
.btn-mes-listes-nav.is-active {
    background: rgba(255, 255, 255, 0.15) !important;
    border-color: rgba(255, 255, 255, 0.6) !important;
}

.btn-mes-listes-nav svg {
    flex-shrink: 0;
}

/* Petite flèche du dropdown */
.chevron-listes {
    transition: transform 0.2s ease;
    opacity: 0.7;
}

.btn-mes-listes-nav.is-active .chevron-listes,
.nav-listes-wrapper:hover .chevron-listes {
    transform: rotate(180deg);
    opacity: 1;
}

/* ── Dropdown du bouton Mes listes ──────────────────────── */

.nav-listes-dropdown {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    min-width: 220px;
    background: white;
    border-radius: var(--radius-lg, 12px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15), 0 2px 6px rgba(0, 0, 0, 0.08);
    padding: 6px 0;
    z-index: 9999;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
    pointer-events: none;
}

/* Visible au survol du wrapper OU quand is-open */
.nav-listes-wrapper:hover .nav-listes-dropdown,
.nav-listes-dropdown.is-open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
}

/* Petite flèche décorative en haut du dropdown */
.nav-listes-dropdown::before {
    content: '';
    position: absolute;
    top: -6px;
    right: 20px;
    width: 12px;
    height: 12px;
    background: white;
    transform: rotate(45deg);
    border-radius: 2px;
    box-shadow: -2px -2px 4px rgba(0, 0, 0, 0.06);
}

.nav-listes-dropdown-header {
    padding: 8px 16px 6px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-light, #666);
}

/* Liens de liste dans le dropdown nav */
.nav-listes-option {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    color: var(--text-dark, #2c2c2c);
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    transition: background 0.15s ease, color 0.15s ease;
    cursor: pointer;
}

.nav-listes-option:hover {
    background: var(--pale-green, #e8f3e6);
    color: var(--primary-green, #4a6051);
}

.nav-listes-option svg {
    flex-shrink: 0;
    color: var(--text-light, #666);
    transition: color 0.15s ease;
}

.nav-listes-option:hover svg {
    color: var(--primary-green, #4a6051);
}

/* Mobile : groupe listes */
.mobile-nav-listes-group {
    padding: 6px 0 2px;
    border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.mobile-nav-listes-titre {
    display: block;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: rgba(255, 255, 255, 0.6);
    padding: 4px 0 6px;
}

.mobile-nav-listes-links {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.mobile-nav-listes-links a {
    color: rgba(255, 255, 255, 0.88);
    font-size: 0.9rem;
    padding: 6px 0;
    text-decoration: none;
    transition: color 0.15s ease;
}

.mobile-nav-listes-links a:hover {
    color: white;
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   2. BOUTON SIGNET SUR LES CARTES LIVRE
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* La .book-card doit être relative pour positionner le bouton et le menu */
.book-card {
    position: relative;
}

/* book-info n'a plus besoin d'être relative pour le signet */
.book-card .book-info {
    position: static;
}

/* Bouton signet : discret, positionné en bas à droite de book-card */
.page-template-biodivotest2 .btn-bookmark,
.btn-bookmark {
    position: absolute;
    bottom: 8px;
    right: 8px;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.85);
    border: none;
    border-radius: var(--radius-sm, 6px);
    cursor: pointer;
    color: var(--medium-gray, #d0d0d0);
    padding: 0;
    transition: color 0.2s ease, transform 0.15s ease, background 0.2s ease;
    z-index: 10;
    flex-shrink: 0;
}

.page-template-biodivotest2 .btn-bookmark:hover,
.btn-bookmark:hover {
    color: var(--primary-green, #4a6051);
    background: var(--pale-green, #e8f3e6);
    transform: scale(1.1);
}

/* Icônes du signet : contour visible par défaut, rempli masqué */
.btn-bookmark .icon-bookmark-outline { display: block; }
.btn-bookmark .icon-bookmark-filled  { display: none;  }

/* État : livre enregistré (au moins dans une liste) */
.btn-bookmark.is-saved .icon-bookmark-outline { display: none;  }
.btn-bookmark.is-saved .icon-bookmark-filled  { display: block; }

/* Couleurs prioritaires : cœur > bibliothèque > souhaits */
.btn-bookmark.has-heart    { color: var(--accent-orange, #d9824d); }
.btn-bookmark.has-library  { color: var(--primary-green, #4a6051); }
.btn-bookmark.has-wishlist { color: var(--accent-yellow, #d9a566); }

/* Hover même avec couleur : toujours un retour visuel */
.btn-bookmark.is-saved:hover { opacity: 0.8; transform: scale(1.1); }

/* Animation d'ajout (pulsation rapide) */
@keyframes bookmark-pulse {
    0%   { transform: scale(1); }
    40%  { transform: scale(1.35); }
    70%  { transform: scale(0.92); }
    100% { transform: scale(1); }
}

.btn-bookmark.animate-add {
    animation: bookmark-pulse 0.35s ease forwards;
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   3. MENU FLOTTANT DES LISTES (sur les cartes)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.bookmark-menu {
    position: absolute;
    bottom: 44px; /* juste au-dessus du bouton signet */
    right: 8px;
    width: 210px;
    background: white;
    border-radius: var(--radius-lg, 12px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15), 0 2px 8px rgba(0, 0, 0, 0.08);
    padding: 4px 0;
    z-index: 9990;
    opacity: 0;
    visibility: hidden;
    transform: translateY(6px) scale(0.97);
    transform-origin: bottom right;
    transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
    pointer-events: none;
}

/* Menu ouvert */
.bookmark-menu.is-open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}

/* Si pas assez de place en haut, le menu s'ouvre vers le bas */
.bookmark-menu.open-below {
    top: auto;
    bottom: auto;
    top: calc(100% - 44px);
    transform-origin: top right;
    transform: translateY(-6px) scale(0.97);
}
.bookmark-menu.open-below.is-open {
    transform: translateY(0) scale(1);
}

.bookmark-menu-header {
    padding: 8px 14px 5px;
    font-size: 0.68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--text-light, #666);
    border-bottom: 1px solid var(--pale-green, #e8f3e6);
    margin-bottom: 3px;
}

/* ── Options du menu — design checkboxes ─────────────── */
.page-template-biodivotest2 .bookmark-option,
.bookmark-option {
    display: flex;
    align-items: center;
    gap: 9px;
    width: 100%;
    padding: 9px 12px;
    background: transparent;
    border: none;
    text-align: left;
    cursor: pointer;
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--text-dark, #2c2c2c);
    transition: background 0.15s ease;
    border-radius: 0;
}

.bookmark-option:last-child { border-radius: 0 0 var(--radius-lg, 12px) var(--radius-lg, 12px); }

.page-template-biodivotest2 .bookmark-option:hover,
.bookmark-option:hover {
    background: var(--pale-green, #e8f3e6);
}

/* ── Checkbox visuelle ───────────────────────────────── */
.bm-checkbox {
    width: 16px;
    height: 16px;
    border-radius: 4px;
    border: 2px solid var(--medium-gray, #ccc);
    background: white;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background 0.15s ease, border-color 0.15s ease;
}

.bm-check-icon {
    opacity: 0;
    color: white;
    transition: opacity 0.12s ease;
}

/* Checkbox cochée */
.bm-checkbox[data-checked="1"] {
    background: var(--primary-green, #4a6051);
    border-color: var(--primary-green, #4a6051);
}
.bm-checkbox[data-checked="1"] .bm-check-icon {
    opacity: 1;
}

/* Couleurs cochées par type */
.bookmark-option--heart .bm-checkbox[data-checked="1"] {
    background: var(--accent-orange, #d9824d);
    border-color: var(--accent-orange, #d9824d);
}
.bookmark-option--wishlist .bm-checkbox[data-checked="1"] {
    background: var(--accent-yellow, #d9a566);
    border-color: var(--accent-yellow, #d9a566);
}

/* Couleur de la checkbox au survol (non cochée) */
.bookmark-option--library:hover .bm-checkbox:not([data-checked="1"]) { border-color: var(--primary-green, #4a6051); }
.bookmark-option--heart:hover .bm-checkbox:not([data-checked="1"])    { border-color: var(--accent-orange, #d9824d); }
.bookmark-option--wishlist:hover .bm-checkbox:not([data-checked="1"]) { border-color: var(--accent-yellow, #d9a566); }

/* ── Icône de la liste ───────────────────────────────── */
.bookmark-option-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    flex-shrink: 0;
    color: var(--text-light, #666);
    transition: color 0.15s ease;
}

.bookmark-option--library:hover .bookmark-option-icon { color: var(--primary-green, #4a6051); }
.bookmark-option--heart:hover   .bookmark-option-icon { color: var(--accent-orange, #d9824d); }
.bookmark-option--wishlist:hover .bookmark-option-icon { color: var(--accent-yellow, #d9a566); }

.bookmark-option.is-active .bookmark-option-icon { color: var(--primary-green, #4a6051); }
.bookmark-option--heart.is-active .bookmark-option-icon    { color: var(--accent-orange, #d9824d); }
.bookmark-option--wishlist.is-active .bookmark-option-icon { color: var(--accent-yellow, #d9a566); }

.bookmark-option-label {
    flex: 1;
}

/* En cours de traitement (chargement AJAX) */
.bookmark-option.is-loading {
    opacity: 0.6;
    pointer-events: none;
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   4. NOTIFICATION TOAST (feedback utilisateur)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.biodiv-toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%) translateY(12px);
    background: var(--dark-green, #3d4f42);
    color: white;
    padding: 10px 20px;
    border-radius: var(--radius-xl, 20px);
    font-size: 0.875rem;
    font-weight: 500;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
    z-index: 99999;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.25s ease, transform 0.25s ease;
    white-space: nowrap;
    max-width: 90vw;
    text-align: center;
}

.biodiv-toast.is-visible {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

/* Toast d'avertissement (connexion requise) */
.biodiv-toast--warning {
    background: var(--accent-orange, #d9824d);
    cursor: pointer;
    pointer-events: auto;
}

/* Toast de succès */
.biodiv-toast--success {
    background: var(--primary-green, #4a6051);
}

/* Toast retiré */
.biodiv-toast--remove {
    background: var(--text-light, #666);
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   5. PAGE MES LISTES
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.mes-listes-page {
    min-height: 100vh;
    background: var(--light-gray, #f5f5f5);
    padding: 100px 0 60px; /* espace pour la nav fixe */
}

/* ── En-tête de la page ─────────────────────────────── */
.mes-listes-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 32px;
    flex-wrap: wrap;
}

.mes-listes-titre {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--primary-green, #4a6051);
    margin: 0 0 4px;
}

.mes-listes-bienvenue {
    font-size: 0.9rem;
    color: var(--text-light, #666);
    margin: 0;
}

.btn-retour-catalogue {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: white;
    border: 1.5px solid var(--medium-gray, #d0d0d0);
    border-radius: var(--radius-md, 8px);
    color: var(--text-dark, #2c2c2c);
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
    white-space: nowrap;
}

.btn-retour-catalogue:hover {
    border-color: var(--primary-green, #4a6051);
    color: var(--primary-green, #4a6051);
    background: var(--pale-green, #e8f3e6);
}

/* ── Mise en page corps (sidebar + main) ─────────────── */
.mes-listes-body {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 28px;
    align-items: start;
}

/* ── Sidebar ─────────────────────────────────────────── */
.mes-listes-sidebar {
    background: white;
    border-radius: var(--radius-lg, 12px);
    box-shadow: var(--shadow-sm, 0 2px 4px rgba(0,0,0,0.08));
    padding: 12px 8px;
    position: sticky;
    top: 90px; /* sous la nav */
}

/* Boutons de liste dans la sidebar */
.page-template-biodivotest2 .sidebar-liste-btn,
.sidebar-liste-btn {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 11px 12px;
    border-radius: var(--radius-md, 8px);
    color: var(--text-dark, #2c2c2c);
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    transition: background 0.15s ease, color 0.15s ease;
    margin-bottom: 3px;
    cursor: pointer;
}

.sidebar-liste-btn:hover {
    background: var(--pale-green, #e8f3e6);
    color: var(--primary-green, #4a6051);
}

/* État actif */
.sidebar-liste-btn.is-active {
    background: var(--pale-green, #e8f3e6);
    color: var(--primary-green, #4a6051);
    font-weight: 600;
}
.sidebar-liste-btn.is-active .sidebar-liste-icone {
    color: var(--primary-green, #4a6051);
}

/* Couleurs actives spécifiques */
.sidebar-liste-btn--heart.is-active {
    background: #fef2ec;
    color: var(--accent-orange, #d9824d);
}
.sidebar-liste-btn--heart.is-active .sidebar-liste-icone { color: var(--accent-orange, #d9824d); }
.sidebar-liste-btn--heart:hover { background: #fef2ec; color: var(--accent-orange, #d9824d); }

.sidebar-liste-btn--wishlist.is-active {
    background: #fdf6ec;
    color: var(--accent-yellow, #d9a566);
}
.sidebar-liste-btn--wishlist.is-active .sidebar-liste-icone { color: var(--accent-yellow, #d9a566); }
.sidebar-liste-btn--wishlist:hover { background: #fdf6ec; color: var(--accent-yellow, #d9a566); }

.sidebar-liste-icone {
    display: flex;
    align-items: center;
    color: var(--text-light, #666);
    flex-shrink: 0;
    transition: color 0.15s ease;
}

.sidebar-liste-label {
    flex: 1;
}

/* Badge compteur */
.sidebar-liste-count {
    min-width: 22px;
    height: 22px;
    background: var(--pale-green, #e8f3e6);
    color: var(--primary-green, #4a6051);
    border-radius: 11px;
    font-size: 0.75rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 6px;
    flex-shrink: 0;
}

.sidebar-liste-btn.is-active .sidebar-liste-count {
    background: var(--primary-green, #4a6051);
    color: white;
}
.sidebar-liste-btn--heart.is-active .sidebar-liste-count {
    background: var(--accent-orange, #d9824d);
    color: white;
}
.sidebar-liste-btn--wishlist.is-active .sidebar-liste-count {
    background: var(--accent-yellow, #d9a566);
    color: white;
}

.sidebar-footer {
    margin-top: 12px;
    padding: 10px 12px 4px;
    border-top: 1px solid var(--pale-green, #e8f3e6);
}

.sidebar-lien-catalogue {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 0.8rem;
    color: var(--text-light, #666);
    text-decoration: none;
    transition: color 0.15s ease;
}
.sidebar-lien-catalogue:hover { color: var(--primary-green, #4a6051); }

/* ── Séparateur listes perso ─────────────────────── */
.sidebar-separator-custom {
    height: 1px;
    background: var(--pale-green, #e8f3e6);
    margin: 8px 4px;
}

/* ── Item liste perso : wrapper position:relative, lien identique aux listes de base ── */
.sidebar-custom-item {
    position: relative !important;
    display: block !important;
    margin-bottom: 3px !important;
}

/* Le lien est identique aux .sidebar-liste-btn standards, juste avec un padding-right pour l'espace du X */
.sidebar-custom-item .sidebar-liste-btn {
    padding-right: 32px !important;
    margin-bottom: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* Bouton × en absolu, centré verticalement, visible uniquement au survol ou si actif */
.sidebar-delete-custom-btn {
    position: absolute !important;
    right: 4px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 22px !important;
    height: 22px !important;
    border: none !important;
    background: transparent !important;
    cursor: pointer !important;
    border-radius: 5px !important;
    color: transparent !important;
    transition: background 0.15s, color 0.15s !important;
    padding: 0 !important;
    z-index: 2 !important;
}
/* Apparaît au survol de l'item */
.sidebar-custom-item:hover .sidebar-delete-custom-btn {
    color: #aaa !important;
}
/* Rouge au survol direct du bouton */
.sidebar-delete-custom-btn:hover {
    background: #fde9e9 !important;
    color: #c0392b !important;
}
/* Visible aussi quand la liste est active */
.sidebar-custom-item.is-active .sidebar-delete-custom-btn {
    color: #b3c9b3 !important;
}
.sidebar-custom-item.is-active .sidebar-delete-custom-btn:hover {
    background: #fde9e9 !important;
    color: #c0392b !important;
}

/* Couleurs liste perso — identiques aux listes fixes */
.sidebar-liste-btn--custom.is-active {
    background: #e8f3e6 !important;
    color: #4a6051 !important;
    font-weight: 600 !important;
}
.sidebar-liste-btn--custom.is-active .sidebar-liste-icone { color: #4a6051 !important; }
.sidebar-liste-btn--custom.is-active .sidebar-liste-count { background: #4a6051 !important; color: white !important; }
.sidebar-liste-btn--custom:hover { background: #e8f3e6 !important; color: #4a6051 !important; }
.liste-active-icone--custom { color: #4a6051 !important; }

/* Emoji dans l'en-tête de liste active */
.liste-active-icone--custom .biodiv-icon-emoji {
    font-size: 1.5rem !important;
    line-height: 1 !important;
    display: inline-block !important;
}
/* Emoji dans la sidebar */
.sidebar-liste-icone .biodiv-icon-emoji {
    font-size: 1rem !important;
    line-height: 1 !important;
    display: inline-block !important;
}
/* Emoji dans l'état vide */
.empty-icone .biodiv-icon-emoji {
    font-size: 2.5rem !important;
    display: block !important;
    line-height: 1 !important;
}

/* ══════════════════════════════════════════════════════
   MODAL CRÉER UNE LISTE (page mes-listes)
   Tous les styles en !important pour écraser le thème
══════════════════════════════════════════════════════ */

/* ── Bouton "Nouvelle liste" sidebar ── */
.sidebar-btn-create-liste {
    display: flex !important;
    align-items: center !important;
    gap: 7px !important;
    width: calc(100% - 16px) !important;
    margin: 8px 8px 4px !important;
    padding: 9px 12px !important;
    border: 1.5px dashed #4a6051 !important;
    border-radius: 8px !important;
    background: transparent !important;
    color: #4a6051 !important;
    font-size: 0.82rem !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    opacity: 0.8 !important;
    transition: background 0.15s !important;
    box-shadow: none !important;
    font-family: inherit !important;
    line-height: 1.2 !important;
}
.sidebar-btn-create-liste:hover {
    background: #e8f3e6 !important;
    opacity: 1 !important;
}

.ml-modal-overlay {
    display: none !important;
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0, 0, 0, 0.50) !important;
    z-index: 999999 !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 20px !important;
    margin: 0 !important;
}
.ml-modal-overlay.is-open {
    display: flex !important;
    animation: mlFadeIn 0.18s ease !important;
}
@keyframes mlFadeIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}
.ml-modal-box {
    background: #ffffff !important;
    border-radius: 14px !important;
    box-shadow: 0 24px 80px rgba(0,0,0,0.25) !important;
    width: 100% !important;
    max-width: 440px !important;
    margin: auto !important;
    padding: 0 !important;
    border: none !important;
    animation: mlSlideUp 0.22s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
    overflow: hidden !important;
}
@keyframes mlSlideUp {
    from { transform: translateY(20px) scale(0.97); opacity: 0; }
    to   { transform: translateY(0)    scale(1);    opacity: 1; }
}
.ml-modal-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 20px 22px 16px !important;
    border-bottom: 1px solid #e8f0e8 !important;
    background: white !important;
    margin: 0 !important;
}
.ml-modal-title {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    color: #4a6051 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
    line-height: 1.3 !important;
}
.ml-modal-close {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    border: none !important;
    background: #f4f7f4 !important;
    border-radius: 8px !important;
    color: #666 !important;
    cursor: pointer !important;
    transition: background 0.15s, color 0.15s !important;
    padding: 0 !important;
    line-height: 1 !important;
}
.ml-modal-close:hover {
    background: #fde9e9 !important;
    color: #c0392b !important;
}
.ml-modal-body {
    padding: 20px 22px 16px !important;
    background: white !important;
}
.ml-modal-label {
    display: block !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    color: #4a6051 !important;
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.07em !important;
    background: none !important;
    border: none !important;
}
.ml-modal-input {
    display: block !important;
    width: 100% !important;
    padding: 11px 14px !important;
    border: 2px solid #d5e5d5 !important;
    border-radius: 10px !important;
    font-size: 0.95rem !important;
    color: #2c2c2c !important;
    background: #f8fcf8 !important;
    outline: none !important;
    transition: border-color 0.15s, box-shadow 0.15s !important;
    box-sizing: border-box !important;
    margin: 0 0 14px 0 !important;
    font-family: inherit !important;
    box-shadow: none !important;
}
.ml-modal-input:focus {
    border-color: #4a6051 !important;
    box-shadow: 0 0 0 3px rgba(74, 96, 81, 0.15) !important;
    background: white !important;
}
.ml-modal-input::placeholder {
    color: #aaa !important;
    font-style: italic !important;
}
.ml-modal-error {
    font-size: 0.82rem !important;
    color: #c0392b !important;
    min-height: 18px !important;
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
    background: none !important;
    border: none !important;
}
.ml-icon-picker {
    display: grid !important;
    grid-template-columns: repeat(6, 1fr) !important;
    gap: 7px !important;
    margin: 8px 0 0 0 !important;
}
.ml-icon-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    aspect-ratio: 1 !important;
    min-height: 44px !important;
    border: 2px solid transparent !important;
    border-radius: 10px !important;
    background: #f0f5f0 !important;
    cursor: pointer !important;
    transition: background 0.12s, border-color 0.12s, transform 0.1s !important;
    padding: 4px !important;
    margin: 0 !important;
    line-height: 1 !important;
    box-shadow: none !important;
}
.ml-icon-btn:hover {
    background: #e0ede0 !important;
    border-color: #4a6051 !important;
    transform: scale(1.1) !important;
}
.ml-icon-btn.is-selected {
    background: #4a6051 !important;
    border-color: #4a6051 !important;
    transform: scale(1.1) !important;
    box-shadow: 0 2px 8px rgba(74, 96, 81, 0.35) !important;
}
.ml-icon-btn .biodiv-icon-emoji,
.bm-icon-btn .biodiv-icon-emoji {
    font-size: 1.4rem !important;
    line-height: 1 !important;
    display: block !important;
    user-select: none !important;
}
.ml-modal-footer {
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 14px 22px 20px !important;
    border-top: 1px solid #e8f0e8 !important;
    background: white !important;
    margin: 0 !important;
}
.ml-btn-cancel {
    display: inline-flex !important;
    align-items: center !important;
    padding: 10px 18px !important;
    border: 1.5px solid #d5e5d5 !important;
    border-radius: 9px !important;
    background: white !important;
    color: #555 !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    text-decoration: none !important;
    line-height: 1.2 !important;
    box-shadow: none !important;
    font-family: inherit !important;
    transition: background 0.15s !important;
}
.ml-btn-cancel:hover {
    background: #f2f2f2 !important;
    border-color: #999 !important;
}
.ml-btn-submit {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 10px 20px !important;
    border: none !important;
    border-radius: 9px !important;
    background: #4a6051 !important;
    color: #ffffff !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    text-decoration: none !important;
    line-height: 1.2 !important;
    box-shadow: 0 2px 8px rgba(74, 96, 81, 0.3) !important;
    font-family: inherit !important;
    transition: background 0.15s, transform 0.1s !important;
}
.ml-btn-submit:hover  { background: #3a4f40 !important; }
.ml-btn-submit:active { transform: scale(0.97) !important; }
.ml-btn-submit:disabled { opacity: 0.55 !important; cursor: not-allowed !important; transform: none !important; }
.ml-btn-submit svg { color: white !important; stroke: white !important; }

/* ── bm-icon-btn (picker menu signet) ── */
.bm-icon-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 2px solid transparent !important;
    border-radius: 7px !important;
    background: #f0f5f0 !important;
    cursor: pointer !important;
    padding: 4px !important;
    line-height: 1 !important;
    transition: background 0.12s, border-color 0.12s !important;
}
.bm-icon-btn.is-selected {
    background: #4a6051 !important;
    border-color: #4a6051 !important;
    box-shadow: 0 1px 5px rgba(74,96,81,0.3) !important;
}
.bm-icon-btn:hover {
    background: #e0ede0 !important;
    border-color: #4a6051 !important;
}

/* ── Zone principale ─────────────────────────────────── */
.mes-listes-main {
    min-height: 300px;
}

.liste-active-header {
    margin-bottom: 24px;
}

.liste-active-titre-group {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 6px;
}

.liste-active-icone {
    display: flex;
    align-items: center;
    color: var(--primary-green, #4a6051);
}
.liste-active-icone--heart    { color: var(--accent-orange, #d9824d); }
.liste-active-icone--wishlist { color: var(--accent-yellow, #d9a566); }

.liste-active-titre {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text-dark, #2c2c2c);
    margin: 0;
}

.liste-active-description {
    font-size: 0.875rem;
    color: var(--text-light, #666);
    margin: 0;
    padding-left: 34px; /* aligner avec le titre (après icône) */
}

/* ── Grille de livres (hérite du catalogue) ──────────── */
.mes-listes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 16px;
}

/* ── Compteur ─────────────────────────────────────────── */
.mes-listes-compteur {
    margin-top: 20px;
    font-size: 0.8rem;
    color: var(--text-light, #666);
    text-align: right;
}

/* ── État vide ─────────────────────────────────────────── */
.mes-listes-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 60px 24px;
    background: white;
    border-radius: var(--radius-lg, 12px);
    box-shadow: var(--shadow-sm);
}

.empty-icone {
    color: var(--medium-gray, #d0d0d0);
    margin-bottom: 16px;
    transform: scale(2);
    display: flex;
}

.empty-message {
    font-size: 1rem;
    color: var(--text-light, #666);
    margin: 0 0 20px;
}

.empty-cta,
a.empty-cta,
.mes-listes-page .empty-cta,
.page-template-biodivotest2 .empty-cta {
    display: inline-flex;
    align-items: center;
    padding: 10px 22px;
    background: var(--primary-green, #4a6051);
    color: white !important;
    border-radius: var(--radius-xl, 20px);
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none !important;
    transition: background 0.2s ease, transform 0.15s ease;
}
.empty-cta:hover {
    background: var(--dark-green, #3d4f42);
    transform: translateY(-1px);
}

/* ── Animation de retrait d'un livre (page mes-listes) ── */
@keyframes card-fade-out {
    0%   { opacity: 1;  transform: scale(1);    }
    50%  { opacity: 0.4; transform: scale(0.95); }
    100% { opacity: 0;  transform: scale(0.9); max-height: 0; margin: 0; padding: 0; }
}

.book-card.is-removing {
    animation: card-fade-out 0.35s ease forwards;
    pointer-events: none;
    overflow: hidden;
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   6. RESPONSIVE
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

@media (max-width: 900px) {
    .mes-listes-body {
        grid-template-columns: 1fr;
    }

    .mes-listes-sidebar {
        position: static;
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        padding: 10px;
    }

    .mes-listes-sidebar nav {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        width: 100%;
    }

    .sidebar-liste-btn {
        flex: 1;
        min-width: 140px;
        justify-content: center;
        margin-bottom: 0;
    }

    .sidebar-footer {
        width: 100%;
        border-top: 1px solid var(--pale-green, #e8f3e6);
        margin-top: 6px;
        padding: 8px 6px 2px;
    }

    .liste-active-description {
        padding-left: 0;
    }
}

@media (max-width: 600px) {
    .mes-listes-page {
        padding: 80px 0 40px;
    }

    .mes-listes-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .mes-listes-titre {
        font-size: 1.3rem;
    }

    .btn-mes-listes-nav span {
        display: none; /* Masquer le texte, garder l'icône sur mobile */
    }

    .btn-mes-listes-nav .chevron-listes {
        display: none;
    }

    .mes-listes-grid {
        grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
        gap: 12px;
    }
}  
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LISTES PERSONNALISÉES — MENU SIGNET
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Séparateur entre listes fixes et listes perso */
.bm-separator-custom {
    height: 1px;
    background: var(--pale-green, #e8f3e6);
    margin: 3px 10px;
}

/* Option custom : même base que .bookmark-option + icône couleur */
.bookmark-option--custom {
    position: relative;
}

.bookmark-option--custom .bookmark-option-icon {
    color: var(--primary-green, #4a6051);
}

.bookmark-option--custom:hover .bookmark-option-icon {
    color: var(--primary-green, #4a6051);
}

.bookmark-option--custom.is-active .bm-checkbox {
    background: var(--primary-green, #4a6051);
    border-color: var(--primary-green, #4a6051);
}

.bookmark-option--custom.is-active .bm-check-icon {
    opacity: 1;
}

/* Bouton supprimer liste (×) */
.bm-delete-list {
    all: unset !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 18px !important;
    height: 18px !important;
    border-radius: 50% !important;
    color: var(--text-light, #888) !important;
    cursor: pointer !important;
    margin-left: auto !important;
    flex-shrink: 0 !important;
    opacity: 0 !important;
    transition: opacity 0.15s, background 0.15s, color 0.15s !important;
}

.bookmark-option--custom:hover .bm-delete-list {
    opacity: 1 !important;
}

.bm-delete-list:hover {
    background: #fee2e2 !important;
    color: #ef4444 !important;
}

/* ── Bouton "Nouvelle liste" ───────────────────────────────── */
.bm-create-wrapper {
    padding: 4px 10px 6px;
}

.page-template-biodivotest2 .bm-create-list-btn,
.bm-create-list-btn {
    all: revert !important;
    box-sizing: border-box !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    width: 100% !important;
    padding: 5px 8px !important;
    background: transparent !important;
    border: 1.5px dashed var(--medium-gray, #ccc) !important;
    border-radius: 6px !important;
    font-size: 0.78rem !important;
    font-weight: 500 !important;
    color: var(--text-light, #888) !important;
    cursor: pointer !important;
    transition: all 0.18s !important;
    font-family: inherit !important;
}

.page-template-biodivotest2 .bm-create-list-btn:hover,
.bm-create-list-btn:hover {
    border-color: var(--primary-green, #4a6051) !important;
    color: var(--primary-green, #4a6051) !important;
    background: var(--pale-green, #e8f3e6) !important;
}

/* ── Formulaire de création inline ────────────────────────── */
.bm-create-form {
    display: flex;
    flex-direction: column;
    gap: 7px;
    padding-top: 2px;
}

.bm-create-input {
    all: revert !important;
    box-sizing: border-box !important;
    width: 100% !important;
    padding: 5px 9px !important;
    border: 1.5px solid var(--medium-gray, #ccc) !important;
    border-radius: 6px !important;
    font-size: 0.8rem !important;
    font-family: inherit !important;
    color: var(--text-dark, #2c2c2c) !important;
    outline: none !important;
    transition: border-color 0.15s !important;
}

.bm-create-input:focus {
    border-color: var(--primary-green, #4a6051) !important;
}

/* ── Picker d'icônes ───────────────────────────────────────── */
.bm-icon-picker {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 4px;
}

.page-template-biodivotest2 .bm-icon-btn,
.bm-icon-btn {
    all: revert !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    aspect-ratio: 1 !important;
    padding: 4px !important;
    border: 1.5px solid transparent !important;
    border-radius: 6px !important;
    background: transparent !important;
    color: var(--text-light, #888) !important;
    cursor: pointer !important;
    transition: all 0.15s !important;
    font-family: inherit !important;
}

.page-template-biodivotest2 .bm-icon-btn:hover,
.bm-icon-btn:hover {
    background: var(--pale-green, #e8f3e6) !important;
    color: var(--primary-green, #4a6051) !important;
    border-color: var(--pale-green, #e8f3e6) !important;
}

.page-template-biodivotest2 .bm-icon-btn.is-selected,
.bm-icon-btn.is-selected {
    background: var(--pale-green, #e8f3e6) !important;
    border-color: var(--primary-green, #4a6051) !important;
    color: var(--primary-green, #4a6051) !important;
}

/* ── Boutons Annuler / Créer ───────────────────────────────── */
.bm-create-actions {
    display: flex;
    gap: 5px;
}

.page-template-biodivotest2 .bm-create-cancel,
.bm-create-cancel {
    all: revert !important;
    box-sizing: border-box !important;
    flex: 1 !important;
    padding: 5px 8px !important;
    background: transparent !important;
    border: 1.5px solid var(--medium-gray, #ccc) !important;
    border-radius: 6px !important;
    font-size: 0.78rem !important;
    font-weight: 500 !important;
    color: var(--text-light, #888) !important;
    cursor: pointer !important;
    transition: all 0.15s !important;
    font-family: inherit !important;
}

.page-template-biodivotest2 .bm-create-cancel:hover,
.bm-create-cancel:hover {
    border-color: #aaa !important;
    color: var(--text-dark, #2c2c2c) !important;
}

.page-template-biodivotest2 .bm-create-submit,
.bm-create-submit {
    all: revert !important;
    box-sizing: border-box !important;
    flex: 1 !important;
    padding: 5px 8px !important;
    background: var(--primary-green, #4a6051) !important;
    border: 1.5px solid var(--primary-green, #4a6051) !important;
    border-radius: 6px !important;
    font-size: 0.78rem !important;
    font-weight: 600 !important;
    color: white !important;
    cursor: pointer !important;
    transition: all 0.15s !important;
    font-family: inherit !important;
}

.page-template-biodivotest2 .bm-create-submit:hover,
.bm-create-submit:hover {
    background: var(--dark-green, #3d4f42) !important;
    border-color: var(--dark-green, #3d4f42) !important;
}

/* ── Footer + bouton Enregistrer ──────────────────────────── */
.bm-footer {
    padding: 6px 10px 8px;
    border-top: 1px solid var(--pale-green, #e8f3e6);
    margin-top: 2px;
}

.page-template-biodivotest2 .bm-btn-valider,
.bm-btn-valider {
    all: revert !important;
    box-sizing: border-box !important;
    width: 100% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 7px 16px !important;
    background: var(--pale-green, #e8f3e6) !important;
    color: var(--primary-green, #4a6051) !important;
    border: 1.5px solid var(--pale-green, #e8f3e6) !important;
    border-radius: 20px !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    font-family: inherit !important;
    line-height: 1.4 !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    cursor: default !important;
    opacity: 0.45 !important;
    outline: none !important;
}

.page-template-biodivotest2 .bm-btn-valider.has-changes,
.bm-btn-valider.has-changes {
    background: var(--primary-green, #4a6051) !important;
    border-color: var(--primary-green, #4a6051) !important;
    color: white !important;
    opacity: 1 !important;
    cursor: pointer !important;
}

.page-template-biodivotest2 .bm-btn-valider.has-changes:hover,
.bm-btn-valider.has-changes:hover {
    background: var(--dark-green, #3d4f42) !important;
    border-color: var(--dark-green, #3d4f42) !important;
    transform: scale(1.04) !important;
    box-shadow: 0 4px 12px rgba(74, 96, 81, 0.35) !important;
}

/* ── Bouton signet : couleur pour liste custom ─────────────── */
.btn-bookmark.has-custom {
    color: var(--primary-green, #4a6051);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   NAVIGATION — listes perso dans le dropdown
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.nav-listes-separator {
    height: 1px;
    background: var(--pale-green, #e8f3e6);
    margin: 4px 12px;
}

.nav-listes-option--custom svg {
    color: var(--primary-green, #4a6051);
    flex-shrink: 0;
}

/* ── Bouton nav + dropdown (conservé du fix précédent) ───────  */
.main-header .btn-mes-listes-nav,
.page-template-biodivotest2 .btn-mes-listes-nav,
.btn-mes-listes-nav {
    display: flex !important;
    align-items: center !important;
    gap: 0.45rem !important;
    background: none !important;
    border: 2px solid #4a6051 !important;
    color: #4a6051 !important;
    padding: 0.45rem 1rem !important;
    border-radius: 20px !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.25s ease !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    line-height: inherit !important;
    box-sizing: border-box !important;
}

.main-header .btn-mes-listes-nav:hover,
.main-header .btn-mes-listes-nav.is-active,
.page-template-biodivotest2 .btn-mes-listes-nav:hover,
.page-template-biodivotest2 .btn-mes-listes-nav.is-active,
.nav-listes-wrapper:hover .btn-mes-listes-nav,
.btn-mes-listes-nav:hover,
.btn-mes-listes-nav.is-active {
    background-color: #4a6051 !important;
    color: #ffffff !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(74, 96, 81, 0.25) !important;
}

.nav-listes-wrapper::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    height: 12px;
    display: block;
}
/* ══════════════════════════════════════════════════════
   MODAL DÉTAIL D'UN LIVRE (page mes-listes)
   Reprend exactement le même rendu que le catalogue
══════════════════════════════════════════════════════ */
#mlBookModal {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 99998 !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 20px !important;
}
#mlBookModal.active {
    display: flex !important;
}
#mlBookModal .modal-overlay {
    position: absolute !important;
    inset: 0 !important;
    background: rgba(0,0,0,0.70) !important;
    backdrop-filter: blur(4px) !important;
}
#mlBookModal .modal-content {
    position: relative !important;
    background: #ffffff !important;
    border-radius: 12px !important;
    max-width: 900px !important;
    width: 100% !important;
    max-height: 90vh !important;
    overflow: hidden !important;
    box-shadow: 0 20px 60px rgba(0,0,0,0.3) !important;
    animation: mlBookSlideIn 0.28s ease !important;
}
@keyframes mlBookSlideIn {
    from { opacity:0; transform:translateY(-24px); }
    to   { opacity:1; transform:translateY(0); }
}
#mlBookModal .modal-close {
    position: absolute !important;
    top: 16px !important;
    right: 16px !important;
    background: #ffffff !important;
    border: none !important;
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 10 !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15) !important;
    transition: transform 0.2s, background 0.2s !important;
    padding: 0 !important;
}
#mlBookModal .modal-close:hover {
    transform: scale(1.1) !important;
    background: #e8f3e6 !important;
    color: #4a6051 !important;
}
#mlBookModal .modal-body {
    display: grid !important;
    grid-template-columns: 280px 1fr !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
}
#mlBookModal .modal-image {
    background: linear-gradient(135deg, #f5f5f5 0%, #e8e8e8 100%) !important;
    padding: 28px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
}
#mlBookModal .modal-image img {
    width: 100% !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.2) !important;
    display: block !important;
}
#mlBookModal .modal-info {
    padding: 28px !important;
    overflow-y: visible !important;
}
#mlBookModal .modal-info h2 {
    font-size: 1.7rem !important;
    font-weight: 600 !important;
    color: #2c2c2c !important;
    margin: 0 0 20px 0 !important;
    line-height: 1.3 !important;
}
#mlBookModal .modal-badge-container {
    display: flex !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
    margin-bottom: 16px !important;
    padding-bottom: 16px !important;
    border-bottom: 1px solid #ddd !important;
}
#mlBookModal .modal-badge-container:empty { display:none !important; }
#mlBookModal .modal-badge-container .book-badge {
    position: static !important;
    font-size: 0.9rem !important;
    padding: 6px 12px !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
}
#mlBookModal .modal-meta {
    background: #f7f7f7 !important;
    padding: 16px !important;
    border-radius: 8px !important;
    margin-bottom: 20px !important;
}
#mlBookModal .meta-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 3px !important;
    margin-bottom: 12px !important;
}
#mlBookModal .meta-group:last-child { margin-bottom: 0 !important; }
#mlBookModal .meta-group strong {
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    color: #888 !important;
    letter-spacing: 0.05em !important;
}
#mlBookModal .meta-group span {
    font-size: 1rem !important;
    color: #2c2c2c !important;
    font-weight: 400 !important;
}
#mlBookModal .meta-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
}
#mlBookModal .modal-separator {
    height: 1px !important;
    background: #ddd !important;
    margin: 12px 0 !important;
}
#mlBookModal .modal-price-group {
    margin-top: 12px !important;
    padding-top: 12px !important;
    border-top: 2px solid #ddd !important;
}
#mlBookModal .modal-price {
    font-size: 1.4rem !important;
    font-weight: 500 !important;
    color: #4a6051 !important;
}
#mlBookModal .btn-download-pdf-modal {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    margin-top: 12px !important;
    padding: 10px 20px !important;
    background: linear-gradient(135deg, #4a6051, #2f3f35) !important;
    color: white !important;
    text-decoration: none !important;
    border-radius: 8px !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    width: 100% !important;
    box-sizing: border-box !important;
    transition: opacity 0.2s !important;
}
#mlBookModal .btn-download-pdf-modal:hover { opacity: 0.88 !important; }
#mlBookModal .modal-section {
    margin-bottom: 20px !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}
#mlBookModal .modal-section h3 {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: #4a6051 !important;
    margin: 0 0 8px 0 !important;
}
#mlBookModal .modal-section p,
#mlBookModal .modal-section div p {
    color: #2c2c2c !important;
    line-height: 1.6 !important;
    margin: 0 0 6px 0 !important;
    font-size: 0.95rem !important;
}
/* Responsive */
@media (max-width: 640px) {
    #mlBookModal .modal-body { grid-template-columns: 1fr !important; }
    #mlBookModal .modal-image { padding: 20px !important; max-height: 200px !important; }
    #mlBookModal .modal-image img { max-height: 160px !important; width: auto !important; }
    #mlBookModal .modal-info { padding: 16px !important; }
    #mlBookModal .meta-row { grid-template-columns: 1fr !important; }
}