/* ===== MIGLIORAMENTI CONTRASTO MODALITÀ GIORNO MOBILE - CHARLIE RACCONTA ===== */

/* ===== VARIABILI COLORE MIGLIORATE ===== */
:root {
    --primary-contrast: #1e40af; /* Blu più scuro per miglior contrasto */
    --primary-hover-contrast: #1d4ed8;
    --text-primary-contrast: #1f2937; /* Testo più scuro */
    --text-secondary-contrast: #374151;
    --text-muted-contrast: #4b5563;
    --border-contrast: #d1d5db;
    --background-contrast: #ffffff;
    --background-secondary-contrast: #f9fafb;
}

/* ===== FIX CONTRASTO TESTI ===== */
body:not(.dark-mode) .text-gray-600 {
    color: var(--text-secondary-contrast) !important;
}

body:not(.dark-mode) .text-gray-700 {
    color: var(--text-primary-contrast) !important;
}

body:not(.dark-mode) .text-gray-800 {
    color: #111827 !important;
}

body:not(.dark-mode) .text-gray-900 {
    color: #000000 !important;
}

/* ===== FIX CONTRASTO PULSANTI ===== */
body:not(.dark-mode) .btn-primary,
body:not(.dark-mode) .bg-blue-600,
body:not(.dark-mode) button.bg-blue-600 {
    background-color: var(--primary-contrast) !important;
    color: #ffffff !important;
    border: 2px solid var(--primary-contrast) !important;
    font-weight: 600 !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1) !important;
}

body:not(.dark-mode) .btn-primary:hover,
body:not(.dark-mode) .bg-blue-600:hover {
    background-color: var(--primary-hover-contrast) !important;
    border-color: var(--primary-hover-contrast) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(30, 64, 175, 0.4) !important;
}

/* ===== FIX CONTRASTO LINK ===== */
body:not(.dark-mode) a {
    color: var(--primary-contrast) !important;
    text-decoration: underline !important;
    text-decoration-color: var(--primary-contrast) !important;
    text-underline-offset: 2px !important;
}

body:not(.dark-mode) a:hover {
    color: var(--primary-hover-contrast) !important;
    text-decoration-color: var(--primary-hover-contrast) !important;
}

/* ===== FIX CONTRASTO INPUT E FORM ===== */
body:not(.dark-mode) input,
body:not(.dark-mode) textarea,
body:not(.dark-mode) select {
    border: 2px solid var(--border-contrast) !important;
    color: var(--text-primary-contrast) !important;
    background-color: var(--background-contrast) !important;
}

body:not(.dark-mode) input:focus,
body:not(.dark-mode) textarea:focus,
body:not(.dark-mode) select:focus {
    border-color: var(--primary-contrast) !important;
    box-shadow: 0 0 0 3px rgba(30, 64, 175, 0.1) !important;
    outline: none !important;
}

/* ===== FIX CONTRASTO CARD E CONTAINER ===== */
body:not(.dark-mode) .card,
body:not(.dark-mode) .bg-white {
    background-color: var(--background-contrast) !important;
    border: 1px solid var(--border-contrast) !important;
    color: var(--text-primary-contrast) !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

/* ===== FIX CONTRASTO HEADER ===== */
body:not(.dark-mode) .charlie-header,
body:not(.dark-mode) header {
    background-color: var(--background-contrast) !important;
    border-bottom: 2px solid var(--border-contrast) !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

body:not(.dark-mode) .charlie-header button,
body:not(.dark-mode) header button {
    color: var(--text-primary-contrast) !important;
    background-color: transparent !important;
}

body:not(.dark-mode) .charlie-header button:hover,
body:not(.dark-mode) header button:hover {
    background-color: var(--background-secondary-contrast) !important;
    color: var(--primary-contrast) !important;
}

/* ===== FIX CONTRASTO NAVIGAZIONE ===== */
body:not(.dark-mode) .nav-link {
    color: var(--text-primary-contrast) !important;
    font-weight: 500 !important;
}

body:not(.dark-mode) .nav-link:hover {
    color: var(--primary-contrast) !important;
    background-color: var(--background-secondary-contrast) !important;
}

body:not(.dark-mode) .nav-link.active {
    color: #ffffff !important;
    background-color: var(--primary-contrast) !important;
}

/* ===== FIX CONTRASTO MOBILE SPECIFICO ===== */
@media (max-width: 768px) {
    /* Testo più grande per miglior leggibilità */
    body:not(.dark-mode) {
        font-size: 16px !important;
        line-height: 1.6 !important;
    }
    
    /* Pulsanti più grandi per touch */
    body:not(.dark-mode) button,
    body:not(.dark-mode) .btn {
        min-height: 44px !important;
        padding: 12px 20px !important;
        font-size: 16px !important;
        font-weight: 600 !important;
    }
    
    /* Link più grandi per touch */
    body:not(.dark-mode) a {
        min-height: 44px !important;
        display: inline-flex !important;
        align-items: center !important;
        padding: 8px 12px !important;
    }
    
    /* Input più grandi per touch */
    body:not(.dark-mode) input,
    body:not(.dark-mode) textarea,
    body:not(.dark-mode) select {
        min-height: 44px !important;
        padding: 12px 16px !important;
        font-size: 16px !important;
    }
    
    /* Card con bordi più spessi */
    body:not(.dark-mode) .card,
    body:not(.dark-mode) .bg-white {
        border: 2px solid var(--border-contrast) !important;
        border-radius: 12px !important;
        margin: 8px !important;
        padding: 16px !important;
    }
}

/* ===== FIX CONTRASTO ELEMENTI SPECIFICI ===== */
body:not(.dark-mode) .text-blue-600 {
    color: var(--primary-contrast) !important;
}

body:not(.dark-mode) .text-green-600 {
    color: #047857 !important;
}

body:not(.dark-mode) .text-red-600 {
    color: #dc2626 !important;
}

body:not(.dark-mode) .text-yellow-600 {
    color: #d97706 !important;
}

/* ===== FIX CONTRASTO BADGE E STATUS ===== */
body:not(.dark-mode) .badge,
body:not(.dark-mode) .status {
    font-weight: 600 !important;
    padding: 4px 8px !important;
    border-radius: 6px !important;
    font-size: 12px !important;
}

body:not(.dark-mode) .badge-success,
body:not(.dark-mode) .status-available {
    background-color: #047857 !important;
    color: #ffffff !important;
}

body:not(.dark-mode) .badge-error,
body:not(.dark-mode) .status-unavailable {
    background-color: #dc2626 !important;
    color: #ffffff !important;
}

body:not(.dark-mode) .badge-warning {
    background-color: #d97706 !important;
    color: #ffffff !important;
}

/* ===== FIX CONTRASTO DROPDOWN ===== */
body:not(.dark-mode) .dropdown,
body:not(.dark-mode) #accountDropdown,
body:not(.dark-mode) #cart-dropdown {
    background-color: var(--background-contrast) !important;
    border: 2px solid var(--border-contrast) !important;
    color: var(--text-primary-contrast) !important;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1) !important;
}

/* ===== FIX CONTRASTO MODAL ===== */
body:not(.dark-mode) .modal-content {
    background-color: var(--background-contrast) !important;
    border: 2px solid var(--border-contrast) !important;
    color: var(--text-primary-contrast) !important;
}

/* ===== FIX CONTRASTO HERO SECTION ===== */
body:not(.dark-mode) .hero-section {
    background: linear-gradient(135deg, #ffffff 0%, #f9fafb 100%) !important;
    color: var(--text-primary-contrast) !important;
}

body:not(.dark-mode) .hero-title {
    color: var(--text-primary-contrast) !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

body:not(.dark-mode) .hero-subtitle {
    color: var(--text-secondary-contrast) !important;
}

/* ===== FIX CONTRASTO RATING ===== */
body:not(.dark-mode) .rating,
body:not(.dark-mode) .stars {
    color: #f59e0b !important;
}

/* ===== FIX CONTRASTO FOOTER ===== */
body:not(.dark-mode) .footer {
    background-color: var(--text-primary-contrast) !important;
    color: #ffffff !important;
}

body:not(.dark-mode) .footer a {
    color: #d1d5db !important;
}

body:not(.dark-mode) .footer a:hover {
    color: #ffffff !important;
}

/* Enforce high-contrast footer on pages without .footer class */
body:not(.dark-mode) footer a {
    color: #ffffff !important;
    text-decoration: underline !important;
    text-decoration-color: #ffffff !important;
}

body:not(.dark-mode) footer ul {
    list-style: none !important;
    padding-left: 0 !important;
}

body:not(.dark-mode) footer li::before {
    display: none !important;
    content: none !important;
}

/* ===== FIX CONTRASTO ALTO CONTRASTO (ACCESSIBILITÀ) ===== */
@media (prefers-contrast: high) {
    :root {
        --primary-contrast: #000080;
        --text-primary-contrast: #000000;
        --text-secondary-contrast: #000000;
        --border-contrast: #000000;
    }
    
    body:not(.dark-mode) * {
        border-color: #000000 !important;
    }
    
    body:not(.dark-mode) button,
    body:not(.dark-mode) .btn {
        border: 2px solid #000000 !important;
    }
}
