/* LE VERT */
.btn-primary, #back-to-top {
    background-color: #9fef00!important;
}
.btn-primary {
    color: #141d2b!important;
}
.btn-outline-primary, .offer_title_in_mail, .color-green, .link_active, .dark-mode.horizontal .side-menu>li>a:hover, .dark-mode .text-primary, .dark-mode .side-menu__item.active, .dark-mode .side-menu__item:hover, .dark-mode .side-menu__item:focus, .dark-mode .side-menu__item.active .side-menu__icon, .btn-outline-primary, .dark-mode .text-primary, .dark-mode .side-menu__item.active, .dark-mode .side-menu__item:hover, .dark-mode .side-menu__item:focus, .dark-mode .side-menu__item.active .side-menu__icon, .dark-mode .side-menu__item:hover, .dark-mode .side-menu__item:focus, .side-menu__item:hover {
    color: #9fef00!important;
}
.btn-primary, .dark-mode .btn-outline-primary, #back-to-top, .landing-page .top-footer h6::before {
    border-color: #9fef00!important;
}
.btn-outline-primary:hover, .dark-mode #back-to-top:hover {
    background-color: #406000!important;
}
.offer_categories_1ere_categorie, .conversations_profile:hover {
    background-color: #282743;
}
.landing-page .testimonial-owl-landing::before {
    position: unset;
}
.main-footer {
    padding: 2px 21px 20px 280px;
}
.testimonia .title {
    font-size: 16px;
}
a.card-body.conversations_profile.block.active, .message-body:hover {
    background-color: #282848;
}
.demo-footer2, .profile-cover__action.bg-img {
    background-color: #1a2332;
}
.top-footer img.footerfull {
    width: unset;
    height: unset;
}
.messsage_profil_name {
    color: #dedefd
}
.header .message-menu-scroll {
    height: unset;
}
.profile-cover__action.bg-img {
    background-image: unset;
}

/* ANIMATION SPINNING */
@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.spinning {
    animation: spin 1s linear infinite;
}

/* BADGE RATING VERT HACKERSDATE */
.badge-rating-green {
    background-color: #9fef00 !important;
    color: #141d2b !important;
    font-weight: bold;
    padding: 6px 12px;
    font-size: 14px;
}

/* NOTIFICATIONS AMÉLIORÉES */
#ui_notifIt {
    max-width: 500px;
    min-height: 60px;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12), 0 2px 8px rgba(0, 0, 0, 0.08);
    cursor: pointer;
    position: fixed !important;
    z-index: 10000 !important;
    word-wrap: break-word;
    border: 1px solid rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    transition: all 0.3s ease;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    
    /* Positionnement centré par défaut */
    top: 10px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
}

/* Ajustement pour la layout full avec topbar */
body.app #ui_notifIt {
    top: 80px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
}

/* Fallback pour d'autres sélecteurs si nécessaire */
.app-header + * #ui_notifIt,
.horizontal-main #ui_notifIt {
    top: 80px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
}

#ui_notifIt:hover {
    transform: translateX(-50%) translateY(-2px) !important;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.18), 0 4px 12px rgba(0, 0, 0, 0.12);
}

#ui_notifIt::after {
    content: "✕";
    position: absolute;
    top: 12px;
    right: 15px;
    font-size: 18px;
    font-weight: bold;
    opacity: 0.6;
    transition: all 0.2s ease;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
}

#ui_notifIt:hover::after {
    opacity: 1;
    background: rgba(255, 255, 255, 0.2);
    transform: scale(1.1);
}

#ui_notifIt p {
    padding: 18px 50px 18px 20px;
    margin: 0;
    word-wrap: break-word;
    line-height: 1.6;
    font-size: 14px;
    font-weight: 500;
    display: flex;
    align-items: center;
    min-height: 24px;
}

#ui_notifIt p b {
    font-weight: 600;
    margin-right: 8px;
}

#ui_notifIt.success {
    background: linear-gradient(135deg, #9fef00 0%, #7cc500 100%);
    color: #1A2332;
    border-color: rgba(159, 239, 0, 0.3);
}

#ui_notifIt.success::after {
    background: rgba(26, 35, 50, 0.1);
    color: #1A2332;
}

#ui_notifIt.success:hover::after {
    background: rgba(26, 35, 50, 0.2);
}

#ui_notifIt.error {
    background: linear-gradient(135deg, #ff6b6b 0%, #ff5252 100%);
    color: white;
    border-color: rgba(255, 107, 107, 0.3);
}

#ui_notifIt.info {
    background: linear-gradient(135deg, #4fc3f7 0%, #29b6f6 100%);
    color: white;
    border-color: rgba(79, 195, 247, 0.3);
}

#ui_notifIt.warning {
    background: linear-gradient(135deg, #ffb74d 0%, #ff9800 100%);
    color: #1A2332;
    border-color: rgba(255, 183, 77, 0.3);
}

#ui_notifIt.warning::after {
    background: rgba(26, 35, 50, 0.1);
    color: #1A2332;
}

#ui_notifIt.warning:hover::after {
    background: rgba(26, 35, 50, 0.2);
}

/* Responsive */
@media (max-width: 768px) {
    #ui_notifIt {
        max-width: 95% !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        min-height: 50px;
    }
    
    /* Ajustement responsive pour layout full */
    body.app #ui_notifIt {
        top: 75px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
    }
    
    #ui_notifIt:hover {
        transform: translateX(-50%) translateY(-2px) !important;
    }
    
    #ui_notifIt p {
        padding: 15px 45px 15px 15px;
        font-size: 13px;
        line-height: 1.5;
    }
    
    #ui_notifIt::after {
        top: 10px;
        right: 12px;
        font-size: 16px;
        width: 18px;
        height: 18px;
    }
}

@media (max-width: 480px) {
    #ui_notifIt {
        max-width: 98% !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        border-radius: 8px;
    }
    
    /* Ajustement responsive pour layout full */
    body.app #ui_notifIt {
        top: 70px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
    }
    
    #ui_notifIt:hover {
        transform: translateX(-50%) translateY(-2px) !important;
    }
    
    #ui_notifIt p {
        padding: 12px 40px 12px 12px;
        font-size: 12px;
    }
}

/* COULEURS SOMBRES */

.fond1, .top.sticky.overflow-hidden, .dark-mode .card, .jumps-prevent, .app-sidebar.ps.ps--active-y.horizontal-main, .dark-mode .footer, .app-sidebar.ps.horizontal-main {
    background-color: #1A2332!important;
}

.fond2, .dark-mode .header, .sidebar.sidebar-right.sidebar-animate.ps.ps--active-y.sidebar-open, div#home, .sidebar .list-group-flush .list-group-item, .page-main, .main-container, .dark-mode .bg-white, div#Features, .dark-mode.landing-page .bg-landing, .bg-landing.section.bg-image-style, .dark-mode.landing-page .bg-landing, .dark-mode.landing-page .demo-footer {
    background-color: #141d2b!important;
}

button.btn.btn-lg.btn-primary-gradient.text-white.btn-block, .dark-mode .app-sidebar {
    color: #1a2332!important;
}
.usernameInMessage, .timeMailinConversation {
    color: #9f9f9f;
}

/* FFW CSS */
img.ffw_edit, img.ffw_pastille {
    width: 16px;
}
.ffw_right {
    float: right;
}
.w100 {
    width: 100%;
}
.ffw_center {
    text-align: center;
}
.ffw_clear {
    clear: both;
}

i.fe.fe-edit-3.text-primary.mx-2.edit-profile {
    font-size: 1.2em;
}

.unset-block {
    display: unset;
    width: unset;
}

.table-fixed {
    table-layout: fixed;
}

.no_photo_offer {
    max-width: 100%;
}

.yellow_stars > .fa-star-by-fifi {
    color: #f7b731;
}

.listing {
    padding-left: 10px;
}
.offer_categories_deporte {
    padding: 3px 23px;
}
.offer_categories_deporte_offerlist {
    padding: 3px 23px;
}
.offer_categories_1ere_categorie {
    float: left;
    margin-right: 1%;
    margin-bottom: 1%;
    padding: 1%;
    width: 31%;
    border-radius: 20px;
    height: 235px;
}
.offer_categories_1ere_categorie_offerlist {
    float: left;
    margin-right: 1%;
    margin-bottom: 1%;
    padding: 1%;
    border-radius: 20px;
}
.offer_img {
    max-height: 100px;
}
.ffw_offer_img {
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    height: 261px;
    margin: 0px;
}
.dark-mode .form-control {
    color: #ffffff;
}

.tags_custom {
    margin-right: 10px;
    margin-bottom: 10px;
}
.ffw_pointer:hover {
    cursor: pointer;
}

.flex.justify-between.flex-1.sm\:hidden {
    display: none;
}

nav.flex.items-center.justify-between, .timeMailinConversation {
    float: right;
}
.a_block > a {
    display: block;
    margin-top: 0.5rem !important;
}
.landing-page .testimonial-owl-landing {
    background-image: unset;
    background-color: #141d2b;
}

.profile_image {
    width: 135px;
    height: 135px;
    border: 3px solid white;
    background-size: cover;
    background-position: center center;
    border-radius: 50%;
    background-color: #1a2332;
}
.unset_text_decoration {
    text-decoration: unset!important;
}
.bouton_signaler {
    margin-left: 10px;
}

.profile_image_on_profiles {
    width: 100%;
    height: 220px;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
.profile-cover__action.bg-img {
    background-position: center;
}
.news_date {
    color: #7a7a7a;
}
.nom_client {
    margin-left: 10px;
}
.dropdown-menu.dropdown-menu-end.dropdown-menu-arrow.show {
    min-width: 300px;
    text-align: left;
}
a.list-group-item.d-flex.align-items-center.mx-4 {
    background-color: unset;
}


.margin-right-profil {
    margin-right: 30px;
}

/* CHECKBOX HACKERSDATE STYLE */
input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 18px;
    height: 18px;
    border: 2px solid #c6c7e4;
    border-radius: 3px;
    background-color: transparent;
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
}

input[type="checkbox"]:hover {
    border-color: #b3ff33;
    box-shadow: 0 0 5px rgba(159, 239, 0, 0.3);
}

input[type="checkbox"]:checked {
    background-color: #9fef00;
    border-color: #9fef00;
}

input[type="checkbox"]:checked::after {
    content: "✓";
    position: absolute;
    top: -2px;
    left: 2px;
    color: #141d2b;
    font-size: 12px;
    font-weight: bold;
}

input[type="checkbox"]:focus {
    outline: none;
    box-shadow: 0 0 0 2px rgba(159, 239, 0, 0.4);
}


@media only screen and (max-width: 800px) {
    .offer_categories_1ere_categorie {
        float: unset;
        margin-right: 0%;
        margin-bottom: 3%;
        padding: 4% 9%;
        width: 100%;
        border-radius: 20px;
    }
}

/* ========================================
   ADMIN OFFERS LIST - INTERFACE INTELLIGENTE
   ======================================== */

/* Styles pour l'affichage des cartes mobiles */
.admin-offers-mobile .offer-card-mobile {
    border-left: 4px solid #9fef00;
    transition: all 0.3s ease;
}

.admin-offers-mobile .offer-card-mobile:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(159, 239, 0, 0.1);
}

.admin-offers-mobile .offer-content-mobile {
    font-size: 0.85rem;
    line-height: 1.4;
}

/* Styles pour le tableau desktop */
.admin-offers-table .table td {
    vertical-align: middle;
    padding: 12px 8px;
}

.admin-offers-table .admin-offer-details {
    max-width: 350px;
}

.admin-offers-table .admin-offer-title {
    font-size: 0.95rem;
    line-height: 1.3;
    margin-bottom: 4px;
}

.admin-offers-table .admin-offer-title a:hover {
    color: #9fef00 !important;
}

.admin-offers-table .admin-offer-content {
    font-size: 0.8rem;
    line-height: 1.3;
    margin-bottom: 8px;
    color: #6c757d;
}

.admin-offers-table .admin-offer-meta {
    flex-wrap: wrap;
    gap: 8px;
}

.admin-offers-table .admin-offer-meta small {
    font-size: 0.75rem;
    white-space: nowrap;
}

/* Styles pour les informations utilisateur */
.admin-offers-table .admin-user-info {
    max-width: 140px;
}

.admin-offers-table .admin-user-name {
    font-size: 0.85rem;
    line-height: 1.2;
    margin-bottom: 2px;
}

.admin-offers-table .admin-user-email {
    font-size: 0.7rem;
    line-height: 1.1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100px;
}

.admin-offers-table .admin-user-avatar {
    font-size: 0.8rem;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    min-height: 32px;
}

/* Styles pour les actions */
.admin-offers-table .admin-offer-actions .btn {
    padding: 4px 8px;
    font-size: 0.8rem;
}

.admin-offers-table .admin-offer-actions .btn i {
    font-size: 0.75rem;
}

/* Responsive - Amélioration pour tablettes */
@media (max-width: 1200px) {
    .admin-offers-table .admin-offer-details {
        max-width: 250px;
    }
    
    .admin-offers-table .admin-offer-title {
        font-size: 0.9rem;
    }
    
    .admin-offers-table .admin-offer-content {
        font-size: 0.75rem;
    }
    
    .admin-offers-table .admin-user-info {
        max-width: 120px;
    }
}

@media (max-width: 992px) {
    .admin-offers-table .admin-offer-meta {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .admin-offers-table .admin-offer-meta small {
        margin-right: 0 !important;
        margin-bottom: 2px;
    }
}

/* Styles pour les badges de statut */
.badge.bg-warning {
    color: #141d2b !important;
}

.badge.bg-success {
    background-color: #9fef00 !important;
    color: #141d2b !important;
}

/* Amélioration de la barre d'actions groupées */
.bulk-actions-bar {
    border-top: 1px solid #dee2e6;
    animation: slideDown 0.3s ease;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Styles pour les compteurs de statistiques */
.counter-status .counter-icon {
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
}

.counter-status .counter-icon i {
    font-size: 1.5rem;
}

/* Amélioration du formulaire de filtres */
.card-header h3.card-title {
    color: #9fef00;
    font-weight: 600;
}

.form-label {
    font-weight: 500;
    color: #495057;
    font-size: 0.9rem;
}

/* Animation pour le survol des lignes du tableau */
.admin-offers-table .table-hover tbody tr:hover {
    background-color: rgba(159, 239, 0, 0.05);
    transition: background-color 0.2s ease;
}

/* Amélioration de l'affichage des budgets */
.text-success.fw-bold {
    color: #28a745 !important;
    font-size: 0.95rem;
}

/* Styles pour les messages vides */
.text-center.py-5 i.display-1 {
    color: rgba(159, 239, 0, 0.3) !important;
}

/* Responsive pour les statistiques */
@media (max-width: 768px) {
    .counter-status {
        text-align: center;
    }
    
    .counter-status .ms-auto {
        margin: 0 !important;
        margin-top: 8px !important;
    }
    
    .counter-status .counter-icon {
        margin: 0 auto 8px;
    }
}

/* ========================================
   ADMIN USERS LIST - INTERFACE INTELLIGENTE
   ======================================== */

/* Styles pour l'affichage des cartes mobiles */
.admin-users-mobile .user-card-mobile {
    border-left: 4px solid #9fef00;
    transition: all 0.3s ease;
}

.admin-users-mobile .user-card-mobile:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(159, 239, 0, 0.1);
}

/* Styles pour le tableau desktop */
.admin-users-table .table td {
    vertical-align: middle;
    padding: 12px 8px;
}

.admin-users-table .admin-user-details {
    max-width: 250px;
}

.admin-users-table .admin-user-name {
    font-size: 0.95rem;
    line-height: 1.3;
    margin-bottom: 2px;
}

.admin-users-table .admin-user-email {
    font-size: 0.85rem;
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.admin-users-table .admin-user-avatar {
    font-size: 0.8rem;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    min-height: 32px;
}

/* Styles pour les actions */
.admin-users-table .admin-user-actions .btn {
    padding: 4px 8px;
    font-size: 0.8rem;
}

.admin-users-table .admin-user-actions .btn i {
    font-size: 0.75rem;
}

/* Styles spéciaux pour les badges utilisateur */
.badge.bg-warning {
    color: #141d2b !important;
    background-color: #ffc107 !important;
}

.badge.bg-info {
    color: #fff !important;
    background-color: #17a2b8 !important;
}

.badge.bg-success {
    background-color: #9fef00 !important;
    color: #141d2b !important;
}

.badge.bg-secondary {
    color: #fff !important;
    background-color: #6c757d !important;
}

/* Amélioration des statistiques pour les utilisateurs */
.counter-status .counter-icon.bg-primary {
    background-color: #9fef00 !important;
    color: #141d2b !important;
}

.counter-status .counter-icon.bg-success {
    background-color: #28a745 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-warning {
    background-color: #ffc107 !important;
    color: #141d2b !important;
}

.counter-status .counter-icon.bg-info {
    background-color: #17a2b8 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-danger {
    background-color: #dc3545 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-secondary {
    background-color: #6c757d !important;
    color: #fff !important;
}

/* Responsive - Amélioration pour tablettes */
@media (max-width: 1200px) {
    .admin-users-table .admin-user-details {
        max-width: 200px;
    }
    
    .admin-users-table .admin-user-name {
        font-size: 0.9rem;
    }
    
    .admin-users-table .admin-user-email {
        font-size: 0.8rem;
        max-width: 150px;
    }
}

@media (max-width: 992px) {
    .admin-users-mobile .user-card-mobile .row.g-2 {
        margin-bottom: 0.5rem;
    }
    
    .admin-users-mobile .user-card-mobile .badge {
        font-size: 0.7rem;
    }
}

/* Animation pour le survol des lignes du tableau */
.admin-users-table .table-hover tbody tr:hover {
    background-color: rgba(159, 239, 0, 0.05);
    transition: background-color 0.2s ease;
}

/* Amélioration de l'affichage des adresses IP */
.font-monospace {
    font-family: 'Courier New', Courier, monospace !important;
    font-size: 0.8rem;
}

/* Styles pour les messages vides */
.text-center.py-5 i.fe-users {
    color: rgba(159, 239, 0, 0.3) !important;
}

/* Responsive pour les statistiques utilisateurs */
@media (max-width: 768px) {
    .admin-users-mobile .user-card-mobile {
        margin: 0.5rem 0;
    }
    
    .admin-users-mobile .user-card-mobile .card {
        margin: 0.5rem;
    }
    
    .admin-users-mobile .avatar.avatar-md {
        width: 50px;
        height: 50px;
    }
}

/* Amélioration de l'affichage des initiales */
.avatar {
    font-weight: 600;
    font-size: 0.85rem;
}

.avatar.avatar-sm {
    width: 32px;
    height: 32px;
    font-size: 0.7rem;
}

.avatar.avatar-md {
    width: 48px;
    height: 48px;
    font-size: 0.9rem;
}

/* ========================================
   ADMIN CONVERSATIONS LIST - INTERFACE INTELLIGENTE
   ======================================== */

/* Styles pour l'affichage des cartes mobiles */
.admin-conversations-mobile .conversation-card-mobile {
    border-left: 4px solid #9fef00;
    transition: all 0.3s ease;
}

.admin-conversations-mobile .conversation-card-mobile:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(159, 239, 0, 0.1);
}

/* Styles pour le tableau desktop */
.admin-conversations-table .table td {
    vertical-align: middle;
    padding: 12px 8px;
}

.admin-conversations-table .admin-conversation-participants {
    max-width: 250px;
}

.admin-conversations-table .admin-conversation-participants .d-flex {
    min-height: 36px;
}

.admin-conversations-table .admin-conversation-participants small.fw-semibold {
    font-size: 0.8rem;
    line-height: 1.2;
}

.admin-conversations-table .admin-conversation-participants small.text-muted {
    font-size: 0.7rem;
    line-height: 1.1;
}

/* Styles pour les liens d'offres */
.admin-conversations-table .admin-offer-link {
    max-width: 200px;
}

.admin-conversations-table .admin-offer-link strong {
    font-size: 0.85rem;
    line-height: 1.2;
    display: block;
    margin-bottom: 2px;
}

.admin-conversations-table .admin-offer-link a:hover {
    color: #9fef00 !important;
}

.admin-conversations-table .admin-offer-link small {
    font-size: 0.7rem;
}

/* Styles pour les avatars dans les conversations */
.admin-conversations-table .avatar.avatar-xs {
    width: 24px;
    height: 24px;
    font-size: 0.6rem;
    min-width: 24px;
    min-height: 24px;
}

/* Styles spéciaux pour les badges de conversations */
.badge.bg-primary {
    background-color: #007bff !important;
    color: #fff !important;
}

.badge.bg-secondary {
    background-color: #6c757d !important;
    color: #fff !important;
}

.badge.bg-success {
    background-color: #9fef00 !important;
    color: #141d2b !important;
}

.badge.bg-danger {
    background-color: #dc3545 !important;
    color: #fff !important;
}

/* Amélioration des statistiques pour les conversations */
.counter-status .counter-icon.bg-primary {
    background-color: #9fef00 !important;
    color: #141d2b !important;
}

.counter-status .counter-icon.bg-success {
    background-color: #28a745 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-danger {
    background-color: #dc3545 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-info {
    background-color: #17a2b8 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-warning {
    background-color: #ffc107 !important;
    color: #141d2b !important;
}

/* Responsive - Amélioration pour tablettes */
@media (max-width: 1200px) {
    .admin-conversations-table .admin-conversation-participants {
        max-width: 200px;
    }
    
    .admin-conversations-table .admin-offer-link {
        max-width: 150px;
    }
    
    .admin-conversations-table .admin-offer-link strong {
        font-size: 0.8rem;
    }
}

@media (max-width: 992px) {
    .admin-conversations-mobile .conversation-card-mobile .row.g-2 {
        margin-bottom: 0.5rem;
    }
    
    .admin-conversations-mobile .conversation-card-mobile .badge {
        font-size: 0.7rem;
    }
}

/* Animation pour le survol des lignes du tableau */
.admin-conversations-table .table-hover tbody tr:hover {
    background-color: rgba(159, 239, 0, 0.05);
    transition: background-color 0.2s ease;
}

/* Styles pour les messages vides */
.text-center.py-5 i.fe-message-circle {
    color: rgba(159, 239, 0, 0.3) !important;
}

/* Responsive pour les conversations mobiles */
@media (max-width: 768px) {
    .admin-conversations-mobile .conversation-card-mobile {
        margin: 0.5rem 0;
    }
    
    .admin-conversations-mobile .conversation-card-mobile .card {
        margin: 0.5rem;
    }
}

/* Amélioration des badges pour les types et statuts de conversations */
.badge.bg-light {
    background-color: #f8f9fa !important;
    color: #6c757d !important;
    border: 1px solid #dee2e6;
}

/* Styles pour les statistiques des conversations */
.admin-conversations-mobile .badge {
    font-size: 0.75rem;
}

.admin-conversations-table .badge {
    font-size: 0.75rem;
    white-space: nowrap;
}

/* Amélioration de l'affichage des ID de conversations */
.text-primary {
    font-weight: 600;
}

/* Styles pour les liens de conversation */
.admin-conversations-table .admin-offer-link a {
    transition: color 0.2s ease;
}

/* Responsive pour les participants dans les conversations */
@media (max-width: 1200px) {
    .admin-conversations-table .admin-conversation-participants .d-flex {
        min-height: 32px;
    }
    
    .admin-conversations-table .admin-conversation-participants small.fw-semibold {
        font-size: 0.75rem;
    }
    
    .admin-conversations-table .admin-conversation-participants small.text-muted {
        font-size: 0.65rem;
    }
}

/* ========================================
   ADMIN MESSAGES LIST - INTERFACE INTELLIGENTE
   ======================================== */

/* Styles pour l'affichage des cartes mobiles */
.admin-messages-mobile .message-card-mobile {
    border-left: 4px solid #9fef00;
    transition: all 0.3s ease;
}

.admin-messages-mobile .message-card-mobile:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(159, 239, 0, 0.1);
}

/* Styles pour le tableau desktop */
.admin-messages-table .table td {
    vertical-align: middle;
    padding: 12px 8px;
}

.admin-messages-table .admin-message-content {
    max-width: 300px;
}

.admin-messages-table .message-text {
    font-size: 0.85rem;
    line-height: 1.3;
    margin-bottom: 4px;
    color: #495057;
}

.admin-messages-table .message-attachments {
    font-size: 0.75rem;
}

.admin-messages-table .message-offer {
    font-size: 0.75rem;
}

/* Styles pour les participants dans les messages */
.admin-messages-table .admin-message-participants {
    max-width: 200px;
}

.admin-messages-table .admin-message-participants .d-flex {
    min-height: 32px;
}

.admin-messages-table .admin-message-participants small.fw-semibold {
    font-size: 0.75rem;
    line-height: 1.2;
}

.admin-messages-table .admin-message-participants small.text-muted {
    font-size: 0.65rem;
    line-height: 1.1;
}

/* Styles pour les badges de messages */
.badge.bg-warning {
    background-color: #ffc107 !important;
    color: #141d2b !important;
}

.badge.bg-success {
    background-color: #9fef00 !important;
    color: #141d2b !important;
}

.badge.bg-primary {
    background-color: #007bff !important;
    color: #fff !important;
}

.badge.bg-info {
    background-color: #17a2b8 !important;
    color: #fff !important;
}

.badge.bg-secondary {
    background-color: #6c757d !important;
    color: #fff !important;
}

/* Mise en évidence des messages non lus */
.admin-messages-table .table-warning {
    background-color: rgba(255, 193, 7, 0.1) !important;
}

.admin-messages-table .table-warning:hover {
    background-color: rgba(255, 193, 7, 0.2) !important;
}

/* Amélioration des statistiques pour les messages */
.counter-status .counter-icon.bg-primary {
    background-color: #9fef00 !important;
    color: #141d2b !important;
}

.counter-status .counter-icon.bg-warning {
    background-color: #ffc107 !important;
    color: #141d2b !important;
}

.counter-status .counter-icon.bg-success {
    background-color: #28a745 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-info {
    background-color: #17a2b8 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-danger {
    background-color: #dc3545 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-secondary {
    background-color: #6c757d !important;
    color: #fff !important;
}

/* Responsive - Amélioration pour tablettes */
@media (max-width: 1200px) {
    .admin-messages-table .admin-message-content {
        max-width: 250px;
    }
    
    .admin-messages-table .admin-message-participants {
        max-width: 150px;
    }
    
    .admin-messages-table .message-text {
        font-size: 0.8rem;
    }
}

@media (max-width: 992px) {
    .admin-messages-mobile .message-card-mobile .row.g-2 {
        margin-bottom: 0.5rem;
    }
    
    .admin-messages-mobile .message-card-mobile .badge {
        font-size: 0.7rem;
    }
}

/* Animation pour le survol des lignes du tableau */
.admin-messages-table .table-hover tbody tr:hover {
    background-color: rgba(159, 239, 0, 0.05);
    transition: background-color 0.2s ease;
}

/* Styles pour les messages vides */
.text-center.py-5 i.fe-mail {
    color: rgba(159, 239, 0, 0.3) !important;
}

/* Responsive pour les messages mobiles */
@media (max-width: 768px) {
    .admin-messages-mobile .message-card-mobile {
        margin: 0.5rem 0;
    }
    
    .admin-messages-mobile .message-card-mobile .card {
        margin: 0.5rem;
    }
}

/* Amélioration des badges pour les messages */
.admin-messages-mobile .badge {
    font-size: 0.7rem;
}

.admin-messages-table .badge {
    font-size: 0.7rem;
    white-space: nowrap;
}

/* Styles pour les icônes dans les badges */
.badge i {
    font-size: 0.8em;
}

/* Amélioration du contenu des messages */
.admin-messages-table .admin-message-content .message-text {
    word-break: break-word;
}

.admin-messages-mobile .admin-message-content {
    font-size: 0.85rem;
    line-height: 1.4;
    color: #6c757d;
    background-color: #f8f9fa;
    padding: 8px 12px;
    border-radius: 6px;
    border-left: 3px solid #9fef00;
}

/* Styles pour les flèches entre expéditeur et destinataire */
.admin-messages-table .fe-arrow-down {
    opacity: 0.6;
}

/* Responsive pour les participants dans les messages */
@media (max-width: 1200px) {
    .admin-messages-table .admin-message-participants .d-flex {
        min-height: 28px;
    }
    
    .admin-messages-table .admin-message-participants small.fw-semibold {
        font-size: 0.7rem;
    }
    
    .admin-messages-table .admin-message-participants small.text-muted {
        font-size: 0.6rem;
    }
}

/* Amélioration de l'affichage des âges des messages */
.text-info {
    font-size: 0.7rem !important;
}

/* Styles pour les liens de conversation */
.admin-messages-table a.text-decoration-none:hover {
    color: #9fef00 !important;
}

/* Amélioration de l'affichage des badges avec gap */
.d-flex.gap-1 {
    gap: 0.25rem !important;
}

/* Styles pour les avatars dans les messages */
.admin-messages-table .avatar.avatar-xs {
    width: 24px;
    height: 24px;
    font-size: 0.6rem;
    min-width: 24px;
    min-height: 24px;
}

.admin-messages-mobile .avatar.avatar-xs {
    width: 28px;
    height: 28px;
    font-size: 0.65rem;
}

/* ========================================
   ADMIN PAGES LIST - INTERFACE INTELLIGENTE
   ======================================== */

/* Styles pour l'affichage des cartes mobiles */
.admin-pages-mobile .page-card-mobile {
    border-left: 4px solid #9fef00;
    transition: all 0.3s ease;
}

.admin-pages-mobile .page-card-mobile:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(159, 239, 0, 0.1);
}

/* Styles pour le tableau desktop */
.admin-pages-table .table td {
    vertical-align: middle;
    padding: 12px 8px;
}

/* Contenu des pages avec multilangue */
.admin-pages-table .admin-page-content {
    max-width: 350px;
}

.admin-pages-table .page-current-title {
    border-bottom: 1px solid rgba(159, 239, 0, 0.2);
    padding-bottom: 4px;
}

.admin-pages-table .page-current-title strong {
    font-size: 0.95rem;
    line-height: 1.2;
}

.admin-pages-table .page-multilang-content {
    margin-top: 8px;
}

.admin-pages-table .page-multilang-content .d-flex > div {
    min-width: 0; /* Allow text truncation */
}

.admin-pages-table .page-multilang-content small.fw-bold {
    font-size: 0.7rem;
    color: #9fef00;
}

.admin-pages-table .page-multilang-content .small {
    font-size: 0.75rem;
    line-height: 1.2;
    margin-bottom: 2px;
}

.admin-pages-table .page-multilang-content .very-small {
    font-size: 0.65rem;
    line-height: 1.1;
}

.admin-pages-table .page-excerpt {
    background-color: rgba(248, 249, 250, 0.8);
    padding: 4px 8px;
    border-radius: 4px;
    border-left: 2px solid #9fef00;
}

/* Badges pour les pages */
.admin-pages-table .badge.bg-primary {
    background-color: #007bff !important;
    color: #fff !important;
}

.admin-pages-table .badge.bg-info {
    background-color: #17a2b8 !important;
    color: #fff !important;
}

.admin-pages-table .badge.bg-success {
    background-color: #9fef00 !important;
    color: #141d2b !important;
}

.admin-pages-table .badge.bg-warning {
    background-color: #ffc107 !important;
    color: #141d2b !important;
}

.admin-pages-table .badge.bg-danger {
    background-color: #dc3545 !important;
    color: #fff !important;
}

.admin-pages-table .badge.bg-dark {
    background-color: #343a40 !important;
    color: #fff !important;
}

.admin-pages-table .badge.bg-secondary {
    background-color: #6c757d !important;
    color: #fff !important;
}

/* Styles pour les cartes mobiles des pages */
.admin-pages-mobile .admin-page-content {
    background-color: #f8f9fa;
    padding: 12px;
    border-radius: 8px;
    border-left: 3px solid #9fef00;
    margin-bottom: 12px;
}

.admin-pages-mobile .admin-page-content h6 {
    color: #141d2b;
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 8px;
}

.admin-pages-mobile .admin-page-content p {
    font-size: 0.85rem;
    line-height: 1.4;
}

/* Amélioration des statistiques pour les pages */
.counter-status .counter-icon.bg-primary {
    background-color: #9fef00 !important;
    color: #141d2b !important;
}

.counter-status .counter-icon.bg-info {
    background-color: #17a2b8 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-warning {
    background-color: #ffc107 !important;
    color: #141d2b !important;
}

.counter-status .counter-icon.bg-success {
    background-color: #28a745 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-dark {
    background-color: #343a40 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-secondary {
    background-color: #6c757d !important;
    color: #fff !important;
}

/* Responsive - Amélioration pour tablettes */
@media (max-width: 1200px) {
    .admin-pages-table .admin-page-content {
        max-width: 300px;
    }
    
    .admin-pages-table .page-multilang-content .small {
        font-size: 0.7rem;
    }
    
    .admin-pages-table .page-multilang-content .very-small {
        font-size: 0.6rem;
    }
}

@media (max-width: 992px) {
    .admin-pages-mobile .page-card-mobile .row.g-2 {
        margin-bottom: 0.5rem;
    }
    
    .admin-pages-mobile .page-card-mobile .badge {
        font-size: 0.7rem;
    }
}

/* Animation pour le survol des lignes du tableau */
.admin-pages-table .table-hover tbody tr:hover {
    background-color: rgba(159, 239, 0, 0.05);
    transition: background-color 0.2s ease;
}

/* Styles pour les pages vides */
.text-center.py-5 i.fe-file {
    color: rgba(159, 239, 0, 0.3) !important;
}

/* Responsive pour les pages mobiles */
@media (max-width: 768px) {
    .admin-pages-mobile .page-card-mobile {
        margin: 0.5rem 0;
    }
    
    .admin-pages-mobile .page-card-mobile .card {
        margin: 0.5rem;
    }
    
    .admin-pages-mobile .admin-page-content {
        padding: 8px 10px;
    }
    
    .admin-pages-mobile .admin-page-content h6 {
        font-size: 0.9rem;
    }
}

/* Amélioration des badges pour les pages */
.admin-pages-mobile .badge {
    font-size: 0.7rem;
    white-space: nowrap;
}

.admin-pages-table .badge {
    font-size: 0.7rem;
    white-space: nowrap;
    margin-bottom: 2px;
}

/* Styles pour les icônes dans les badges */
.badge i {
    font-size: 0.8em;
}

/* Amélioration du multilangue */
.admin-pages-table .d-flex.gap-3 {
    gap: 1rem !important;
}

.admin-pages-mobile .d-flex.gap-1 {
    gap: 0.25rem !important;
}

.admin-pages-mobile .d-flex.flex-wrap {
    flex-wrap: wrap !important;
}

/* Styles pour les liens de pages */
.admin-pages-table a.btn-outline-success:hover {
    background-color: #9fef00;
    border-color: #9fef00;
    color: #141d2b;
}

.admin-pages-table a.btn-outline-primary:hover {
    background-color: #007bff;
    border-color: #007bff;
    color: #fff;
}

/* Amélioration de l'affichage des colonnes Type & Vue */
.admin-pages-table .d-flex.flex-column.gap-1 {
    gap: 0.25rem !important;
}

/* Styles pour les informations de traduction */
.admin-pages-table .text-center small.text-muted {
    font-size: 0.7rem;
}

.admin-pages-table .text-center small.text-info {
    font-size: 0.65rem;
    color: #17a2b8 !important;
}

/* Responsive pour les colonnes multilingues */
@media (max-width: 1200px) {
    .admin-pages-table .d-flex.gap-3 {
        gap: 0.5rem !important;
    }
    
    .admin-pages-table .page-multilang-content .small {
        font-size: 0.7rem;
    }
    
    .admin-pages-table .page-current-title strong {
        font-size: 0.85rem;
    }
}

@media (max-width: 992px) {
    .admin-pages-table .admin-page-content {
        max-width: 250px;
    }
}

/* Amélioration de l'affichage des dates */
.admin-pages-table .text-center {
    font-size: 0.8rem;
}

.admin-pages-table .text-center .text-muted {
    font-size: 0.75rem;
}

.admin-pages-table .text-center .text-info {
    font-size: 0.7rem;
}

/* Styles pour les boutons d'actions */
.admin-pages-table .d-flex.gap-1 {
    gap: 0.25rem !important;
}

/* Amélioration de l'affichage du contenu principal */
.admin-pages-mobile .admin-page-content h6 {
    border-bottom: 2px solid #9fef00;
    padding-bottom: 6px;
    margin-bottom: 8px;
}

/* Styles pour la gestion des langues dans les formulaires */
.form-label {
    font-weight: 600;
    color: #495057;
    font-size: 0.875rem;
}

/* Amélioration des filtres */
.card-header .card-title {
    color: #9fef00;
    font-weight: 600;
}

/* Styles pour le bouton "Créer une page" */
.btn-success {
    background-color: #9fef00!important;
    border-color: #9fef00!important;
    color: #141d2b!important;
}

.btn-success:hover {
    background-color: #8fd600!important;
    border-color: #8fd600!important;
    color: #141d2b!important;
}
.dark-mode .text-success {
    color: #8fd600 !important;
  }

/* Amélioration des pages vides */
.text-center.py-5 h4 {
    color: #495057;
    font-weight: 600;
}

.text-center.py-5 .text-muted {
    font-size: 1.1rem;
}

/* Responsive final pour très petits écrans */
@media (max-width: 576px) {
    .admin-pages-mobile .row.g-2 .col-6 {
        font-size: 0.8rem;
    }
    
    .admin-pages-mobile .admin-page-content {
        padding: 8px;
    }
    
    .admin-pages-mobile .d-flex.flex-wrap.gap-1 .badge {
        font-size: 0.65rem;
        padding: 0.2rem 0.4rem;
    }
}

/* ========================================
   ADMIN REVIEWS LIST - INTERFACE INTELLIGENTE
   ======================================== */

/* Styles pour l'affichage des cartes mobiles */
.admin-reviews-mobile .review-card-mobile {
    border-left: 4px solid #9fef00;
    transition: all 0.3s ease;
}

.admin-reviews-mobile .review-card-mobile:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(159, 239, 0, 0.1);
}

/* Styles pour le tableau desktop */
.admin-reviews-table .table td {
    vertical-align: middle;
    padding: 12px 8px;
}

/* Contenu des avis */
.admin-reviews-table .admin-review-content {
    max-width: 300px;
}

.admin-reviews-table .review-text {
    font-size: 0.85rem;
    line-height: 1.3;
    margin-bottom: 4px;
    color: #495057;
    word-break: break-word;
}

.admin-reviews-table .review-meta {
    font-size: 0.75rem;
}

/* Styles pour l'affichage des étoiles */
.review-stars-display {
    display: inline-flex;
    gap: 2px;
    align-items: center;
}

.review-stars-display .fe-star {
    font-size: 1rem;
    color: #ffc107;
}

.review-stars-display .fe-star.text-muted {
    color: #dee2e6 !important;
}

.review-stars-display .fe-star.text-warning {
    color: #ffc107 !important;
}

/* Styles pour les participants dans les avis */
.admin-reviews-table .admin-review-participants {
    max-width: 200px;
}

.admin-reviews-table .admin-review-participants .d-flex {
    min-height: 32px;
}

.admin-reviews-table .admin-review-participants small.fw-semibold {
    font-size: 0.75rem;
    line-height: 1.2;
}

.admin-reviews-table .admin-review-participants small.text-muted {
    font-size: 0.65rem;
    line-height: 1.1;
}

/* Badges pour les avis */
.admin-reviews-table .badge.bg-success {
    background-color: #9fef00 !important;
    color: #141d2b !important;
}

.admin-reviews-table .badge.bg-warning {
    background-color: #ffc107 !important;
    color: #141d2b !important;
}

.admin-reviews-table .badge.bg-danger {
    background-color: #dc3545 !important;
    color: #fff !important;
}

.admin-reviews-table .badge.bg-info {
    background-color: #17a2b8 !important;
    color: #fff !important;
}

.admin-reviews-table .badge.bg-secondary {
    background-color: #6c757d !important;
    color: #fff !important;
}

.admin-reviews-table .badge.bg-primary {
    background-color: #007bff !important;
    color: #fff !important;
}

/* Badges pour les notes */
.admin-reviews-table .badge.bg-orange {
    background-color: #fd7e14 !important;
    color: #fff !important;
}

/* Styles pour les cartes mobiles des avis */
.admin-reviews-mobile .admin-review-content {
    background-color: #f8f9fa;
    padding: 12px;
    border-radius: 8px;
    border-left: 3px solid #9fef00;
    margin-bottom: 12px;
    font-size: 0.85rem;
    line-height: 1.4;
}

/* Amélioration des statistiques pour les avis */
.counter-status .counter-icon.bg-primary {
    background-color: #9fef00 !important;
    color: #141d2b !important;
}

.counter-status .counter-icon.bg-success {
    background-color: #28a745 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-danger {
    background-color: #dc3545 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-warning {
    background-color: #ffc107 !important;
    color: #141d2b !important;
}

.counter-status .counter-icon.bg-info {
    background-color: #17a2b8 !important;
    color: #fff !important;
}

.counter-status .counter-icon.bg-secondary {
    background-color: #6c757d !important;
    color: #fff !important;
}

/* Coloration spéciale des lignes selon le sentiment */
.admin-reviews-table .table-success {
    background-color: rgba(40, 167, 69, 0.08) !important;
}

.admin-reviews-table .table-success:hover {
    background-color: rgba(40, 167, 69, 0.15) !important;
}

.admin-reviews-table .table-danger {
    background-color: rgba(220, 53, 69, 0.08) !important;
}

.admin-reviews-table .table-danger:hover {
    background-color: rgba(220, 53, 69, 0.15) !important;
}

/* Responsive - Amélioration pour tablettes */
@media (max-width: 1200px) {
    .admin-reviews-table .admin-review-content {
        max-width: 250px;
    }
    
    .admin-reviews-table .admin-review-participants {
        max-width: 150px;
    }
    
    .admin-reviews-table .review-text {
        font-size: 0.8rem;
    }
}

@media (max-width: 992px) {
    .admin-reviews-mobile .review-card-mobile .row.g-2 {
        margin-bottom: 0.5rem;
    }
    
    .admin-reviews-mobile .review-card-mobile .badge {
        font-size: 0.7rem;
    }
    
    .review-stars-display .fe-star {
        font-size: 0.9rem;
    }
}

/* Animation pour le survol des lignes du tableau */
.admin-reviews-table .table-hover tbody tr:hover {
    background-color: rgba(159, 239, 0, 0.05);
    transition: background-color 0.2s ease;
}

/* Styles pour les avis vides */
.text-center.py-5 i.fe-star {
    color: rgba(159, 239, 0, 0.3) !important;
}

/* Responsive pour les avis mobiles */
@media (max-width: 768px) {
    .admin-reviews-mobile .review-card-mobile {
        margin: 0.5rem 0;
    }
    
    .admin-reviews-mobile .review-card-mobile .card {
        margin: 0.5rem;
    }
    
    .admin-reviews-mobile .admin-review-content {
        padding: 8px 10px;
    }
    
    .review-stars-display {
        justify-content: center;
    }
}

/* Amélioration des badges pour les avis */
.admin-reviews-mobile .badge {
    font-size: 0.7rem;
    white-space: nowrap;
}

.admin-reviews-table .badge {
    font-size: 0.7rem;
    white-space: nowrap;
    margin-bottom: 2px;
}

/* Styles pour les icônes dans les badges */
.badge i {
    font-size: 0.8em;
}

/* Amélioration du contenu des avis */
.admin-reviews-mobile .d-flex.gap-1 {
    gap: 0.25rem !important;
}

.admin-reviews-mobile .d-flex.flex-wrap {
    flex-wrap: wrap !important;
}

/* Styles pour les étoiles en mode mobile */
.admin-reviews-mobile .review-stars-display {
    justify-content: center;
    margin-bottom: 8px;
}

.admin-reviews-mobile .review-stars-display .fe-star {
    font-size: 1.1rem;
    margin: 0 1px;
}

/* Styles pour les participants en mode mobile */
.admin-reviews-mobile .row.g-2 .col-6 {
    text-align: left;
}

/* Amélioration de l'affichage des notes et sentiments */
.admin-reviews-table .text-center {
    min-width: 120px;
}

.admin-reviews-table .text-center .review-stars-display {
    justify-content: center;
    margin-bottom: 4px;
}

/* Styles pour les badges de sentiment empilés */
.admin-reviews-table .text-center .badge {
    display: inline-block;
    margin: 1px 0;
}

/* Responsive pour les colonnes de notes */
@media (max-width: 1200px) {
    .admin-reviews-table .text-center {
        min-width: 100px;
    }
    
    .review-stars-display .fe-star {
        font-size: 0.85rem;
    }
}

@media (max-width: 992px) {
    .admin-reviews-table .admin-review-content {
        max-width: 200px;
    }
}

/* Amélioration de l'affichage des dates */
.admin-reviews-table .text-center {
    font-size: 0.8rem;
}

.admin-reviews-table .text-center .text-muted {
    font-size: 0.75rem;
}

.admin-reviews-table .text-center .text-info {
    font-size: 0.7rem;
}

/* Styles pour les boutons d'actions */
.admin-reviews-table .btn-sm {
    padding: 0.25rem 0.5rem;
    font-size: 0.8rem;
}

/* Amélioration de l'affichage du contenu principal en mode mobile */
.admin-reviews-mobile .admin-review-content {
    border-left: 3px solid #9fef00;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
}

/* Styles pour la gestion des types d'avis */
.admin-reviews-table .badge.bg-info i,
.admin-reviews-table .badge.bg-success i {
    margin-right: 4px;
}

/* Amélioration des filtres */
.card-header .card-title {
    color: #dedefd;
    font-weight: 600;
}

/* Styles pour le bouton "Créer un avis" */
.btn-success {
    background-color: #9fef00;
    border-color: #9fef00;
    color: #141d2b;
}

.btn-success:hover {
    background-color: #8fd600;
    border-color: #8fd600;
    color: #141d2b;
}

/* Amélioration des avis vides */
.text-center.py-5 h4 {
    color: #495057;
    font-weight: 600;
}

.text-center.py-5 .text-muted {
    font-size: 1.1rem;
}

/* Styles pour les flèches entre auteur et destinataire */
.admin-reviews-table .fe-arrow-down {
    opacity: 0.6;
}

/* Responsive pour les participants dans les avis */
@media (max-width: 1200px) {
    .admin-reviews-table .admin-review-participants .d-flex {
        min-height: 28px;
    }
    
    .admin-reviews-table .admin-review-participants small.fw-semibold {
        font-size: 0.7rem;
    }
    
    .admin-reviews-table .admin-review-participants small.text-muted {
        font-size: 0.6rem;
    }
}

/* Styles pour les avatars dans les avis */
.admin-reviews-table .avatar.avatar-xs {
    width: 24px;
    height: 24px;
    font-size: 0.6rem;
    min-width: 24px;
    min-height: 24px;
}

.admin-reviews-mobile .avatar.avatar-xs {
    width: 28px;
    height: 28px;
    font-size: 0.65rem;
}

/* Responsive final pour très petits écrans */
@media (max-width: 576px) {
    .admin-reviews-mobile .row.g-2 .col-6 {
        font-size: 0.8rem;
    }
    
    .admin-reviews-mobile .admin-review-content {
        padding: 8px;
    }
    
    .admin-reviews-mobile .d-flex.flex-wrap.gap-1 .badge {
        font-size: 0.65rem;
        padding: 0.2rem 0.4rem;
    }
    
    .review-stars-display .fe-star {
        font-size: 1rem;
    }
}

/* Amélioration spéciale pour les avis positifs et négatifs */
.admin-reviews-mobile .review-card-mobile .card.border-success {
    border-color: #28a745 !important;
}

.admin-reviews-mobile .review-card-mobile .card.border-danger {
    border-color: #dc3545 !important;
}

/* Amélioration de l'affichage des métadonnées des avis */
.admin-reviews-table .review-meta .badge.bg-info {
    background-color: #17a2b8 !important;
    font-size: 0.65rem;
}

/* =============================================
   ADMIN REPORTS LIST - INTERFACE INTELLIGENTE  
   ============================================= */

/* Cartes de signalements mobile */
.report-card-mobile {
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    transition: all 0.3s ease;
}

.report-card-mobile:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.report-card-mobile.border-warning {
    border-left: 4px solid #ffc107 !important;
    background: linear-gradient(135deg, #fff8e1 0%, #ffffff 100%);
}

/* Tableau desktop optimisé */
.reports-admin-table {
    border-radius: 8px;
    overflow: hidden;
}

.reports-admin-table th {
    background: #2c3e50 !important;
    color: white !important;
    font-weight: 600;
    font-size: 0.875rem;
    padding: 12px 8px;
    border: none !important;
    text-align: center;
    vertical-align: middle;
}

.reports-admin-table td {
    padding: 12px 8px;
    vertical-align: middle;
    border-color: #e9ecef;
    font-size: 0.875rem;
}

.reports-admin-table tbody tr:hover {
    background-color: #f8f9fa;
}

.reports-admin-table tbody tr.table-warning {
    background-color: #fff3cd;
    border-left: 4px solid #ffc107;
}

/* Contenu des messages de signalement */
.report-message-content .message-excerpt {
    max-height: 60px;
    overflow: hidden;
    line-height: 1.4;
    font-size: 0.85rem;
    color: #495057;
    background: #f8f9fa;
    padding: 8px;
    border-radius: 4px;
    margin-top: 4px;
}

.report-card-mobile .message-content {
    font-size: 0.85rem;
    line-height: 1.4;
    max-height: 80px;
    overflow: hidden;
}

/* Responsive adjustments pour signalements */
@media (max-width: 991.98px) {
    .report-card-mobile .row {
        margin: 0 -5px;
    }
    
    .report-card-mobile .col-6 {
        padding: 0 5px;
    }
}

@media (max-width: 767.98px) {
    .report-card-mobile {
        margin-bottom: 15px;
    }
    
    .report-card-mobile .card-body {
        padding: 15px;
    }
}

/* Alignement vertical des checkboxes */
.form-check {
    display: flex !important;
    align-items: center !important;
}

.form-check .form-check-input {
    margin-top: 0 !important;
    margin-right: 8px !important;
}

.form-check .form-check-label {
    margin-bottom: 0 !important;
    line-height: 1.2 !important;
}

/* ========================================
   HACKERSDATE CUSTOM LOADER
   ======================================== */

/* Container du loader */
.hackersdate-loader {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    gap: 15px;
}

/* Animation du cercle de chargement externe */
.loading-circle {
    animation: circleProgress 2s ease-in-out infinite;
    transform-origin: center;
}

@keyframes circleProgress {
    0% {
        stroke-dashoffset: 220;
        opacity: 0.3;
    }
    50% {
        stroke-dashoffset: 110;
        opacity: 0.8;
    }
    100% {
        stroke-dashoffset: 0;
        opacity: 0.3;
    }
}

/* Animation des lignes de code qui défilent */
.code-lines {
    animation: codeFlow 1.5s linear infinite;
}

@keyframes codeFlow {
    0% {
        opacity: 0.3;
        transform: translateX(-5px);
    }
    50% {
        opacity: 1;
        transform: translateX(2px);
    }
    100% {
        opacity: 0.3;
        transform: translateX(-5px);
    }
}

/* Animation du curseur clignotant */
.cursor-blink {
    animation: blink 1s step-end infinite;
}

@keyframes blink {
    0%, 50% {
        opacity: 1;
    }
    51%, 100% {
        opacity: 0;
    }
}

/* Texte de chargement */
.loader-text {
    font-size: 14px;
    font-weight: 500;
    color: #9fef00;
    animation: textPulse 2s ease-in-out infinite;
    font-family: 'Courier New', monospace;
    letter-spacing: 1px;
}

@keyframes textPulse {
    0%, 100% {
        opacity: 0.7;
    }
    50% {
        opacity: 1;
    }
}

/* Animation de pulsation globale pour le SVG */
.hackersdate-loader svg {
    animation: svgPulse 3s ease-in-out infinite;
}

@keyframes svgPulse {
    0%, 100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.05);
    }
}

/* Amélioration de l'arrière-plan du loader global */
#global-loader {
    background: linear-gradient(135deg, #141d2b 0%, #1A2332 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Animation d'apparition du loader */
.hackersdate-loader {
    animation: loaderAppear 0.5s ease-out;
}

@keyframes loaderAppear {
    0% {
        opacity: 0;
        transform: translateY(20px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Responsive pour le loader */
@media (max-width: 768px) {
    .hackersdate-loader svg {
        width: 60px;
        height: 60px;
    }
    
    .loader-text {
        font-size: 12px;
    }
}

/* ==========================================
   MESSAGES SYSTÈME
   ========================================== */

/* Messages système */
.system-message-container {
    margin: 15px 0;
}

.system-message-container .alert {
    border-radius: 15px;
    border: 2px solid rgba(0,0,0,0.1);
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    margin: 10px 20px;
}

.system-message-container .alert-success {
    background: linear-gradient(135deg, #d4edda, #c3e6cb);
    border-color: #b8dabc;
}

.system-message-container .alert-warning {
    background: linear-gradient(135deg, #fff3cd, #ffeaa7);
    border-color: #ffeaa7;
}

.system-message-container .alert-danger {
    background: linear-gradient(135deg, #f8d7da, #f5c6cb);
    border-color: #f5c6cb;
}

.system-message-container .alert-info {
    background: linear-gradient(135deg, #d1ecf1, #bee5eb);
    border-color: #bee5eb;
}

.system-message-container .alert-secondary {
    background: linear-gradient(135deg, #e2e3e5, #d6d8db);
    border-color: #d6d8db;
}

/* Animation pour les nouveaux messages système */
@keyframes systemMessageAppear {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.system-message-container {
    animation: systemMessageAppear 0.5s ease-out;
}
.dark-mode .form-control {
    background-color: #141d2b;
}

/* 🎯 Accordéon des catégories d'offres */
.category-header-wrapper {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 8px 0;
    position: relative;
}

.category-header-wrapper input[type="checkbox"] {
    cursor: pointer;
    margin-right: 10px;
    flex-shrink: 0;
    z-index: 10;
}

.category-header-wrapper .category-name {
    flex: 1;
    cursor: pointer;
    user-select: none;
}

.category-toggle-icon {
    margin-left: 10px;
    transition: transform 0.3s ease;
    cursor: pointer;
    color: #9fef00;
    font-size: 16px;
    flex-shrink: 0;
    padding: 5px;
}

.category-toggle-icon:hover {
    color: #b0ff20;
}

.offer_categories_1ere_categorie_offerlist {
    margin-bottom: 12px;
    display: block;
    width: 100%;
}

.offer_categories_deporte {
    margin-left: 25px;
    margin-top: 8px;
    padding-left: 12px;
    border-left: 2px solid rgba(159, 239, 0, 0.3);
    display: block;
    width: 100%;
}

/* Min-height pour cover-profile uniquement sur desktop (PC) */
@media (min-width: 992px) {
    .card-body.cover-profile {
        min-height: 415px !important;
    }
}

/* Bouton noir pour les liens dans les notifications */
.notif-btn-dark {
    display: inline-block;
    background-color: #000 !important;
    color: #fff !important;
    padding: 6px 16px !important;
    border-radius: 4px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    margin-left: 8px !important;
    transition: all 0.3s ease !important;
}

.notif-btn-dark:hover {
    background-color: #333 !important;
    color: #fff !important;
    text-decoration: none !important;
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

/* Shop Stores - Cover et Avatar */
.store-cover {
    position: relative;
    overflow: hidden;
    border-radius: 8px 8px 0 0;
}

.avatar.avatar-xxl {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

/* Grille responsive pour les produits shop */
.product-grid6 {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.product-grid6:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}
/* End::Width */
.btn-secondary {
    background-color: #101723!important;
}
.active.active-black-text {
    color: black !important;
}

/* Liens de produits dans les messages de conversation */
.product-link-message {
    text-decoration: none;
    display: inline-block;
    transition: all 0.3s ease;
}

.product-link-message:hover {
    transform: translateY(-2px);
    text-decoration: none;
}

.product-link-message .badge {
    font-size: 0.95rem;
    font-weight: 500;
}

.product-link-message:hover .badge {
    box-shadow: 0 2px 8px rgba(159, 239, 0, 0.3);
}

/* Badge de produit dans les messages */
.product-link-message .badge {
    font-size: 1rem;
    padding: 8px 12px;
    border-radius: 6px;
}

.product-link-message .fe-shopping-bag {
    font-size: 1.1rem;
}

/* Badge de type de conversation dans la liste */
.messsage_profil_name .badge {
    font-size: 0.75rem;
    padding: 3px 8px;
}

.offer_title_in_mail {
    color: #495057;
    font-size: 0.9rem;
    display: block;
    margin-bottom: 4px;
}

.offer_title_in_mail .fe-briefcase {
    color: #007bff;
}

/* ========================================
   SEO PAGES - BACKGROUNDS SOMBRES
   ======================================== */

/* Fond sombre principal pour sections SEO */
.bg-seo-dark {
    background-color: #141d2b !important;
}

/* Fond sombre secondaire pour cartes SEO */
.bg-seo-card-dark {
    background-color: #1f2837 !important;
}

/* Fond clair alterné pour sections SEO */
.bg-seo-light {
    background-color: #f8f9fa !important;
}

/* Hover effect pour liens footer SEO */
a.hover-success:hover {
    color: #9fef00 !important;
    transition: color 0.3s ease;
}

.dark-mode .bg-success {
    background: #9fef00 !important;
    color: black;
  }

.dark-mode .bg-secondary {
background-color:#1e293a !important;
}

/* ========================================
   HOMEPAGE STYLES - Inspired by France Vérification
   ======================================== */

/* Hero Section */
.hero-section {
    background: linear-gradient(135deg, #1f2937 0%, #111827 100%);
    position: relative;
    overflow: hidden;
}

.hero-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"><rect fill="%239fef00" opacity="0.05" width="100" height="100"/></svg>');
    opacity: 0.1;
}

/* Gradient Backgrounds */
.bg-gradient-primary {
    background: linear-gradient(135deg, #1f2937 0%, #111827 100%) !important;
}

.bg-gradient-success {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
}

/* Text white with opacity */
.text-white-80 {
    color: rgba(255, 255, 255, 0.8) !important;
}

/* Hover shadow effect */
.hover-shadow {
    transition: all 0.3s ease;
}

.hover-shadow:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15) !important;
}

/* Avatar sizes */
.avatar {
    width: 3rem;
    height: 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.avatar-md {
    width: 2.5rem;
    height: 2.5rem;
}

.avatar-xl {
    width: 4rem;
    height: 4rem;
}

.avatar-title {
    font-size: 1.5rem;
    font-weight: 600;
}

/* Badge improvements */
.badge {
    font-weight: 500;
    padding: 0.5rem 1rem;
    border-radius: 50px;
}

/* Transparent backgrounds for badges */
.bg-primary-transparent {
    background-color: rgba(159, 239, 0, 0.1) !important;
}

.bg-success-transparent {
    background-color: rgba(16, 185, 129, 0.1) !important;
}

.bg-info-transparent {
    background-color: rgba(59, 130, 246, 0.1) !important;
}

.bg-warning-transparent {
    background-color: rgba(245, 158, 11, 0.1) !important;
}

.bg-danger-transparent {
    background-color: rgba(239, 68, 68, 0.1) !important;
}

.bg-purple-transparent {
    background-color: rgba(139, 92, 246, 0.1) !important;
}

/* Text colors for transparent backgrounds */
.text-purple {
    color: #8b5cf6 !important;
}

/* Button improvements */
.btn-lg {
    font-size: 1rem;
    font-weight: 600;
    border-radius: 8px;
}

.btn-outline-light {
    border: 2px solid rgba(255, 255, 255, 0.3);
    color: #fff;
}

.btn-outline-light:hover {
    background-color: rgba(255, 255, 255, 0.1);
    border-color: #fff;
    color: #fff;
}

/* Card improvements */
.card {
    border-radius: 12px;
    transition: all 0.3s ease;
}

.card-body {
    padding: 1.5rem;
}

/* Section spacing */
.section {
    position: relative;
}

.py-7 {
    padding-top: 8rem !important;
    padding-bottom: 8rem !important;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .hero-section {
        padding-top: 3rem !important;
        padding-bottom: 3rem !important;
    }
    
    .py-7 {
        padding-top: 3rem !important;
        padding-bottom: 3rem !important;
    }
    
    .display-4 {
        font-size: 2rem !important;
    }
}

/* Dark mode adjustments */
.dark-mode .card {
    background-color: #1f2837;
    border-color: #374151;
}

.dark-mode .text-muted {
    color: #9ca3af !important;
}

.dark-mode .bg-light {
    background-color: #1f2837 !important;
}

/* Animations */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-in-up {
    animation: fadeInUp 0.6s ease;
}
.pb-4, .py-4 {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
}