/* ============================================
   MODE SOMBRE (Dark Mode)
   ============================================ */

/* Animation de rotation pour le bouton dark mode */
@keyframes rotateMoon {
    0% {
        transform: rotate(0deg) scale(1);
    }

    50% {
        transform: rotate(180deg) scale(1.05);
    }

    100% {
        transform: rotate(360deg) scale(1);
    }
}

@keyframes rotateSun {
    0% {
        transform: rotate(0deg) scale(1);
    }

    50% {
        transform: rotate(180deg) scale(1.05);
    }

    100% {
        transform: rotate(360deg) scale(1);
    }
}

/* Appliquer le mode sombre via la classe "dark-mode" */
body.dark-mode {
    --color-text: #E0E0E0;
    --color-text-light: #B0B0B0;
    --color-background: #1A1A1A;
    --color-white: #2A2A2A;
    --color-cream: #1F1F1F;
    --color-border: #404040;
    --color-shadow: rgba(0, 0, 0, 0.5);
}

body.dark-mode {
    background-color: #1A1A1A;
    color: #E0E0E0;
}

body.dark-mode a {
    color: #FF9E2C;
}

body.dark-mode button,
body.dark-mode input,
body.dark-mode textarea,
body.dark-mode select {
    background-color: #2A2A2A;
    color: #E0E0E0;
    border-color: #404040;
}

body.dark-mode button:hover {
    background-color: #333333;
}

body.dark-mode input:focus,
body.dark-mode textarea:focus,
body.dark-mode select:focus {
    border-color: #FF9E2C;
}

/* Navigation */
body.dark-mode .navbar {
    background-color: #1A1A1A;
    border-bottom-color: #404040;
}

body.dark-mode .nav-link {
    color: #008751;
}

body.dark-mode .nav-link:hover {
    color: #00A862;
}

/* En-têtes et sections */
body.dark-mode .page-header {
    background-color: #1A1A1A !important;
    background-image: none !important;
    background: #1A1A1A !important;
    color: #E0E0E0;
}

body.dark-mode .page-header h1 {
    color: #E0E0E0;
}

body.dark-mode .page-header p {
    color: #B0B0B0;
}

body.dark-mode .section {
    background-color: #1A1A1A;
}

body.dark-mode .container {
    background-color: #1A1A1A;
}

/* Page de succès */
body.dark-mode .success-container {
    background-color: #2A2A2A;
    border-color: #404040;
}

body.dark-mode .success-message {
    background-color: #2A2A2A;
}

body.dark-mode .success-icon {
    background-color: #00A762;
    color: #fff;
}

body.dark-mode .order-details {
    background-color: #1A1A1A;
    border-color: #404040;
}

body.dark-mode .order-details h3 {
    color: #E0E0E0;
}

body.dark-mode .order-details p,
body.dark-mode .order-details strong {
    color: #E0E0E0;
}

body.dark-mode .articles-list {
    background-color: #2A2A2A;
    border-color: #404040;
}

body.dark-mode .articles-list h4 {
    color: #E0E0E0;
}

body.dark-mode .article-item {
    border-color: #404040;
    color: #E0E0E0;
}

body.dark-mode .article-price {
    color: #FF9E2C;
}

/* Styles inline pour paiement_succes.php */
body.dark-mode div[style*="max-width: 800px"] {
    background-color: #2A2A2A !important;
    color: #E0E0E0 !important;
}

body.dark-mode div[style*="background: white"] {
    background-color: #2A2A2A !important;
}

body.dark-mode div[style*="background: #f8f9fa"] {
    background-color: #333333 !important;
    color: #E0E0E0 !important;
}

body.dark-mode h1[style*="color: #2c3e50"],
body.dark-mode h2[style*="color: #2c3e50"] {
    color: #E0E0E0 !important;
}

body.dark-mode p[style*="color: #6c757d"] {
    color: #B0B0B0 !important;
}

body.dark-mode p {
    color: #E0E0E0 !important;
}

body.dark-mode strong {
    color: #E0E0E0 !important;
}

/* Cartes produits */
body.dark-mode .product-card {
    background-color: #2A2A2A;
    border-color: #404040;
}

body.dark-mode .product-card:hover {
    background-color: #333333;
    box-shadow: 0 4px 16px rgba(255, 158, 44, 0.2);
}

/* Panier */
body.dark-mode .cart-item {
    background-color: #2A2A2A;
    border-color: #404040;
}

body.dark-mode .cart-summary {
    background-color: #2A2A2A;
    border-color: #404040;
}

body.dark-mode .cart-summary-line {
    border-bottom-color: #404040;
}

body.dark-mode .cart-qty-input {
    background-color: #404040;
    color: #FF9E2C;
    border-color: #505050;
    font-weight: 600;
}

body.dark-mode .qty-btn {
    background-color: #404040;
    color: #E0E0E0;
    border-color: #505050;
}

body.dark-mode .qty-btn:hover {
    background-color: #505050;
    border-color: #FF9E2C;
    color: #FF9E2C;
}

/* Modales et overlays */
body.dark-mode .modal {
    background-color: #2A2A2A;
    color: #E0E0E0;
}

body.dark-mode .modal-header {
    border-bottom-color: #404040;
}

body.dark-mode .modal-close {
    color: #E0E0E0;
}

/* Formulaires */
body.dark-mode .form-group label {
    color: #E0E0E0;
}

body.dark-mode .form-control {
    background-color: #2A2A2A;
    border-color: #404040;
    color: #E0E0E0;
}

body.dark-mode .form-control:focus {
    background-color: #333333;
    border-color: #FF9E2C;
    box-shadow: 0 0 0 3px rgba(255, 158, 44, 0.1);
}

/* Barre de recherche */
body.dark-mode .search-container {
    background-color: #2A2A2A;
}

body.dark-mode .search-bar {
    background-color: #2A2A2A;
}

body.dark-mode .search-input {
    background-color: #333333;
    border-color: #404040;
    color: #E0E0E0;
}

body.dark-mode .search-input::placeholder {
    color: #808080;
}

body.dark-mode .search-input:focus {
    background-color: #3A3A3A;
    border-color: #FF9E2C;
}

body.dark-mode .search-btn {
    background-color: #FF9E2C;
    color: #1A1A1A;
    border-color: #FF9E2C;
}

body.dark-mode .search-btn:hover {
    background-color: #FFB850;
    border-color: #FFB850;
}

body.dark-mode .sort-container {
    background-color: #2A2A2A;
}

body.dark-mode select {
    background-color: #333333;
    border-color: #404040;
    color: #E0E0E0;
}

/* Badges et tags */
body.dark-mode .badge {
    background-color: #FF9E2C;
    color: #1A1A1A;
}

body.dark-mode .tag {
    background-color: #333333;
    color: #FF9E2C;
    border-color: #FF9E2C;
}

/* Code promo */
body.dark-mode .promo-section {
    background-color: #2A2A2A;
    border-color: #404040;
}

body.dark-mode .promo-input {
    background-color: #1A1A1A;
    border-color: #404040;
    color: #E0E0E0;
}

body.dark-mode .btn-promo {
    background-color: #FF9E2C;
    color: #1A1A1A;
}

body.dark-mode .btn-promo:hover {
    background-color: #FFB850;
}

/* Boutons */
body.dark-mode .btn {
    background-color: #FF9E2C;
    color: #1A1A1A;
}

body.dark-mode .btn:hover {
    background-color: #FFB850;
}

body.dark-mode .btn-secondary {
    background-color: #404040;
    color: #E0E0E0;
    border-color: #505050;
}

body.dark-mode .btn-secondary:hover {
    background-color: #505050;
    border-color: #FF9E2C;
}

/* Tables */
body.dark-mode table {
    background-color: #2A2A2A;
    border-color: #404040;
}

body.dark-mode th {
    background-color: #1A1A1A;
    color: #FF9E2C;
    border-color: #404040;
}

body.dark-mode td {
    border-color: #404040;
    color: #E0E0E0;
}

body.dark-mode tr:hover {
    background-color: #333333;
}

/* Alertes et notifications */
body.dark-mode .alert {
    background-color: #2A2A2A;
    border-color: #404040;
    color: #E0E0E0;
}

body.dark-mode .alert-success {
    background-color: rgba(0, 167, 98, 0.2);
    border-color: #00A762;
    color: #00FF7F;
}

body.dark-mode .alert-error {
    background-color: rgba(220, 20, 60, 0.2);
    border-color: #DC143C;
    color: #FF6B6B;
}

/* Footer */
body.dark-mode footer {
    background-color: #1A1A1A;
    border-top-color: #404040;
    color: #FF9E2C;
}

body.dark-mode footer a {
    color: #FF9E2C;
}

body.dark-mode footer a:hover {
    color: #008751;
}

body.dark-mode .footer {
    background-color: #1A1A1A !important;
}

body.dark-mode .footer-section {
    color: #FF9E2C;
}

body.dark-mode .footer-section h3,
body.dark-mode .footer-section h4 {
    color: #FF9E2C;
}

body.dark-mode .footer-section p {
    color: #FF9E2C !important;
}

body.dark-mode .footer-section .footer-description {
    color: #FF9E2C !important;
}

/* ============================================
   PAGE CONTACT - MODE SOMBRE
   ============================================ */
body.dark-mode .contact-layout {
    background-color: transparent;
}

body.dark-mode .contact-info {
    background-color: #1A1A1A;
}

body.dark-mode .contact-info h2 {
    color: #FF9E2C;
}

body.dark-mode .contact-info-item {
    background-color: #1A1A1A;
    border: none;
}

body.dark-mode .contact-info-item h4 {
    color: #E0E0E0;
}

body.dark-mode .contact-info-item p {
    color: #B0B0B0 !important;
}

body.dark-mode .contact-icon {
    color: #FF9E2C;
}

body.dark-mode .contact-social h4 {
    color: #E0E0E0;
}

body.dark-mode .social-icons a {
    background-color: #404040;
    color: #FF9E2C;
    border: 1px solid #505050;
}

body.dark-mode .social-icons a:hover {
    background-color: #FF9E2C;
    color: #1A1A1A;
}

body.dark-mode .contact-form-wrapper {
    background-color: transparent;
}

body.dark-mode .contact-form-wrapper h2 {
    color: #FF9E2C;
}

body.dark-mode .form-group label {
    color: #E0E0E0;
}

body.dark-mode .form-control {
    background-color: #2A2A2A;
    border-color: #404040;
    color: #E0E0E0;
}

body.dark-mode .form-control:focus {
    border-color: #FF9E2C;
    box-shadow: 0 0 0 2px rgba(255, 158, 44, 0.2);
}

body.dark-mode .form-control::placeholder {
    color: #808080;
}

body.dark-mode .alert-success {
    background-color: rgba(0, 135, 81, 0.2);
    color: #00A862;
    border-color: #008751;
}

body.dark-mode .alert-error {
    background-color: rgba(231, 76, 60, 0.2);
    color: #e74c3c;
    border-color: #c0392b;
}

body.dark-mode .footer-links a,
body.dark-mode .footer-contact {
    color: #FF9E2C;
}

body.dark-mode .footer-links a:hover {
    color: #008751;
    transition: color 0.3s ease;
}

body.dark-mode .footer-contact li {
    color: #FF9E2C;
}

body.dark-mode .footer-contact i {
    color: #FF9E2C;
}

body.dark-mode .footer-bottom {
    color: #FF9E2C;
    border-top-color: #404040;
}

body.dark-mode .footer-bottom p {
    color: #FF9E2C;
}

/* Slider */
body.dark-mode .slider {
    background-color: #2A2A2A;
}

body.dark-mode .slide {
    background-color: #1A1A1A;
}

/* Toggle dark mode button */
.dark-mode-toggle {
    background-color: transparent;
    border: none;
    cursor: pointer;
    font-size: 1.5rem;
    padding: 0.5rem;
    color: #FF9E2C;
    transition: color 0.3s ease;
    margin-right: 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    outline: none !important;
    box-shadow: none !important;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.dark-mode-toggle:hover {
    outline: none !important;
    box-shadow: none !important;
    background-color: transparent;
}

.dark-mode-toggle:focus {
    outline: none !important;
    box-shadow: none !important;
    background-color: transparent;
}

.dark-mode-toggle:active {
    outline: none !important;
    box-shadow: none !important;
    background-color: transparent;
}

.dark-mode-toggle:focus-visible {
    outline: none !important;
    background-color: transparent;
}

/* En mode sombre */
body.dark-mode .dark-mode-toggle {
    background-color: transparent;
    color: #FFD700;
}

body.dark-mode .dark-mode-toggle:hover {
    outline: none !important;
    box-shadow: none !important;
    background-color: transparent;
}

.dark-mode-toggle.rotating {
    animation: rotateMoon 0.5s ease-out;
}

body.dark-mode .dark-mode-toggle {
    color: #FFD700;
    background-color: transparent;
}

body.dark-mode .dark-mode-toggle.rotating {
    animation: rotateSun 0.5s ease-out;
}

/* Placeholder text */
body.dark-mode ::placeholder {
    color: #808080;
}

/* Scrollbar */
body.dark-mode ::-webkit-scrollbar {
    width: 10px;
}

body.dark-mode ::-webkit-scrollbar-track {
    background: #1A1A1A;
}

body.dark-mode ::-webkit-scrollbar-thumb {
    background: #404040;
    border-radius: 5px;
}

body.dark-mode ::-webkit-scrollbar-thumb:hover {
    background: #505050;
}

/* ============================================
   BOUTON SCROLL EN HAUT
   ============================================ */
#scrollTopBtn {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 50px;
    height: 50px;
    background-color: #008751;
    color: white;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    font-size: 24px;
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    box-shadow: 0 4px 12px rgba(0, 135, 81, 0.3);
    transition: all 0.3s ease;
}

#scrollTopBtn.show {
    display: flex;
    animation: slideUp 0.4s ease;
}

#scrollTopBtn:hover {
    background-color: #006d3f;
    box-shadow: 0 6px 16px rgba(0, 135, 81, 0.5);
    transform: translateY(-3px);
}

#scrollTopBtn:active {
    transform: translateY(-1px);
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Mode sombre - style du bouton scroll */
body.dark-mode #scrollTopBtn {
    background-color: #008751;
    box-shadow: 0 4px 12px rgba(0, 135, 81, 0.5);
}

body.dark-mode #scrollTopBtn:hover {
    background-color: #00A862;
    box-shadow: 0 6px 16px rgba(0, 162, 98, 0.6);
}

/* ============================================
   SLIDER FADE - DARK MODE
   ============================================ */
body.dark-mode .fade-slider {
    background: #2a2a2a;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4);
}

body.dark-mode .slider-dots .dot {
    background: rgba(255, 255, 255, 0.3);
}

body.dark-mode .slider-dots .dot:hover {
    background: rgba(255, 255, 255, 0.6);
}

body.dark-mode .slider-dots .dot.active {
    background: #F77F00;
}

/* ============================================
   GOOGLE MAPS - DARK MODE
   ============================================ */
body.dark-mode .contact-map h4,
body.dark-mode .map-title {
    color: #F7F7F7;
}

body.dark-mode .map-container {
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
}

/* Mode sombre - Styles spécifiques panier */
body.dark-mode .cart-qty-input {
    background-color: #2A2A2A !important;
    color: #FF9E2C !important;
    border-color: #404040 !important;
}

body.dark-mode .cart-item-quantity .qty-btn {
    background-color: #2A2A2A !important;
    color: #E0E0E0 !important;
    border-color: #404040 !important;
}

body.dark-mode .cart-item-quantity .qty-btn:hover {
    background-color: #333333 !important;
    border-color: #FF9E2C !important;
    color: #FF9E2C !important;
}

/* Mode sombre - Badges catégories */
body.dark-mode .badge-category {
    background: rgba(0, 0, 0, 0.7) !important;
    color: #FF9E2C !important;
    /* Orange */
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4) !important;
}

/* Mode sombre - Badge Populaire transparent */
body.dark-mode .badge-popular {
    background: rgba(247, 127, 0, 0.8) !important;
    backdrop-filter: blur(4px);
    color: #FFFFFF !important;
    /* Texte blanc pour contraste sur orange */
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.5) !important;
}