/**
 * Accessibility Widget NZ - CSS Optimisé
 * @version 2.0.0
 * @author Nicolas Zabik
 */

/* ===== VARIABLES CSS POUR LA COHÉRENCE ===== */
:root {
    --aw-primary-color: #007bff;
    --aw-primary-hover: #0069d9;
    --aw-secondary-color: #6c757d;
    --aw-success-color: #28a745;
    --aw-warning-color: #ffc107;
    --aw-danger-color: #dc3545;
    --aw-light-color: #f8f9fa;
    --aw-dark-color: #343a40;
    --aw-white: #ffffff;
    --aw-black: #000000;
    
    --aw-border-radius: 8px;
    --aw-transition: all 0.2s ease-in-out;
    --aw-shadow: 0 2px 10px rgba(0,0,0,0.1);
    --aw-shadow-hover: 0 4px 20px rgba(0,0,0,0.15);
    
    --aw-font-size-base: 14px;
    --aw-font-size-lg: 16px;
    --aw-font-size-sm: 12px;
    
    --aw-spacing-xs: 4px;
    --aw-spacing-sm: 8px;
    --aw-spacing-md: 16px;
    --aw-spacing-lg: 24px;
    --aw-spacing-xl: 32px;
}

/* ===== MASQUAGE DES FONCTIONNALITÉS DÉSACTIVÉES ===== */
.accessibility-widget .disabled-feature,
.accessibility-widget [data-enabled="false"],
.accessibility-widget button[disabled] {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    height: 0 !important;
    width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    position: absolute !important;
    z-index: -9999 !important;
    clip: rect(0, 0, 0, 0) !important;
    border: 0 !important;
}

/* ===== ISOLATION DU WIDGET ===== */
.accessibility-isolated {
    /* Reset complet pour éviter les conflits */
    all: initial;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    line-height: 1.5;
    color: var(--aw-dark-color);
    box-sizing: border-box;
}

.accessibility-isolated *,
.accessibility-isolated *::before,
.accessibility-isolated *::after {
    box-sizing: border-box;
}

/* ===== STRUCTURE PRINCIPALE DU WIDGET ===== */
.accessibility-widget {
    position: fixed;
    z-index: 999999; /* Z-index très élevé pour passer au-dessus de tout */
    font-size: var(--aw-font-size-base);
    
    /* Optimisations pour mobile */
    will-change: transform;
    transform: translateZ(0); /* Force l'accélération GPU */
}

/* Positions du widget - Spécificité plus élevée */
.accessibility-widget.position-bottom-right {
    bottom: 20px !important;
    right: 20px !important;
    top: auto !important;
    left: auto !important;
}

.accessibility-widget.position-bottom-left {
    bottom: 20px !important;
    left: 20px !important;
    top: auto !important;
    right: auto !important;
}

.accessibility-widget.position-top-right {
    top: 20px !important;
    right: 20px !important;
    bottom: auto !important;
    left: auto !important;
}

.accessibility-widget.position-top-left {
    top: 20px !important;
    left: 20px !important;
    bottom: auto !important;
    right: auto !important;
}

/* Position par défaut si aucune classe n'est appliquée */
.accessibility-widget:not([class*="position-"]) {
    bottom: 20px;
    right: 20px;
}

/* Tailles du widget */
.accessibility-widget.size-small .accessibility-toggle {
    width: 50px !important;
    height: 50px !important;
}

.accessibility-widget.size-medium .accessibility-toggle {
    width: 60px !important;
    height: 60px !important;
}

.accessibility-widget.size-large .accessibility-toggle {
    width: 70px !important;
    height: 70px !important;
}

/* Responsive - Mobile */
@media (max-width: 768px) {
    .accessibility-widget {
        bottom: 20px;
        right: 10px;
        font-size: var(--aw-font-size-sm);
    }
}

/* ===== BOUTON PRINCIPAL (TOGGLE) ===== */
.accessibility-toggle {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--aw-primary-color), var(--aw-primary-hover));
    color: var(--aw-white);
    border: none;
    cursor: pointer;
    box-shadow: var(--aw-shadow);
    transition: var(--aw-transition);
    position: relative;
    
    /* Amélioration de l'accessibilité */
    outline: none;
    
    /* Optimisations GPU */
    will-change: transform, box-shadow;
    transform: translateZ(0);
}

.accessibility-toggle:hover,
.accessibility-toggle:focus {
    transform: scale(1.05) translateZ(0);
    box-shadow: var(--aw-shadow-hover);
    background: linear-gradient(135deg, var(--aw-primary-hover), var(--aw-primary-color));
}

.accessibility-toggle:focus {
    outline: 3px solid var(--aw-warning-color);
    outline-offset: 2px;
}

.accessibility-toggle:active {
    transform: scale(0.98) translateZ(0);
}

/* Animation de pulsation pour attirer l'attention */
@keyframes accessibility-pulse {
    0% { box-shadow: 0 0 0 0 rgba(0, 123, 255, 0.7); }
    70% { box-shadow: 0 0 0 10px rgba(0, 123, 255, 0); }
    100% { box-shadow: 0 0 0 0 rgba(0, 123, 255, 0); }
}

.accessibility-toggle:hover {
    animation: accessibility-pulse 2s infinite;
}

/* ===== PANNEAU PRINCIPAL ===== */
.accessibility-panel {
    display: none;
    position: absolute;
    bottom: 70px;
    right: 0;
    width: min(400px, 90vw); /* Responsive width */
    max-height: 80vh;
    background: var(--aw-white);
    border-radius: var(--aw-border-radius);
    box-shadow: var(--aw-shadow-hover);
    padding: var(--aw-spacing-lg);
    overflow-x: hidden;
    overflow-y: auto;
    border: 1px solid rgba(0,0,0,0.1);
    
    /* Optimisations de performance */
    will-change: opacity, transform;
    transform: translateZ(0);
    
    /* Scroll personnalisé */
    scrollbar-width: thin;
    scrollbar-color: var(--aw-secondary-color) var(--aw-light-color);
}

/* Ajustements pour les positions en haut */
.accessibility-widget.position-top-right .accessibility-panel,
.accessibility-widget.position-top-left .accessibility-panel {
    bottom: auto;
    top: 70px;
}

/* Ajustements pour les positions à gauche */
.accessibility-widget.position-bottom-left .accessibility-panel,
.accessibility-widget.position-top-left .accessibility-panel {
    right: auto;
    left: 0;
}

.accessibility-panel::-webkit-scrollbar {
    width: 8px;
}

.accessibility-panel::-webkit-scrollbar-thumb {
    background: var(--aw-secondary-color);
    border-radius: 4px;
}

.accessibility-panel::-webkit-scrollbar-track {
    background: var(--aw-light-color);
}

/* Animation d'ouverture/fermeture */
.accessibility-widget.open .accessibility-panel {
    display: block;
    animation: accessibility-fadeInUp 0.3s ease-out;
}

@keyframes accessibility-fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px) translateZ(0);
    }
    to {
        opacity: 1;
        transform: translateY(0) translateZ(0);
    }
}

/* ===== TITRE DU PANNEAU ===== */
.accessibility-panel h3 {
    font-size: var(--aw-font-size-lg) !important;
    font-weight: 600 !important;
    margin: 0 0 var(--aw-spacing-lg) 0 !important;
    padding-bottom: var(--aw-spacing-md) !important;
    text-align: center;
    border-bottom: 2px solid var(--aw-light-color);
    color: var(--aw-dark-color) !important;
}

/* ===== GROUPES D'OPTIONS ===== */
.option {
    display: flex !important;
    flex-direction: column !important;
    margin-bottom: var(--aw-spacing-lg) !important;
    border: none !important;
    padding: 0 !important;
}

.option label {
    font-size: var(--aw-font-size-base) !important;
    font-weight: 600 !important;
    color: var(--aw-dark-color) !important;
    margin-bottom: var(--aw-spacing-sm) !important;
    padding: 0 !important;
    border: none !important;
    display: block !important;
    width: 100% !important;
    text-align: center !important;
}

.option .buttons-group {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--aw-spacing-sm) !important;
}

.option legend {
    width: 100% !important;
    text-align: center !important;
    font-size: var(--aw-font-size-base) !important;
    font-weight: 600 !important;
    color: var(--aw-secondary-color) !important;
    margin-bottom: var(--aw-spacing-md) !important;
    padding: 0 !important;
    border: none !important;
}

/* ===== BOUTONS D'ACTION ===== */
.btn-small {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 80px !important;
    min-width: 80px !important;
    flex: 1 1 auto !important;
    max-width: calc(50% - var(--aw-spacing-sm)) !important;
    margin: 0 !important;
    padding: var(--aw-spacing-sm) !important;
    background: var(--aw-light-color);
    border: 1px solid transparent;
    border-radius: var(--aw-border-radius);
    cursor: pointer;
    transition: var(--aw-transition);
    font-size: var(--aw-font-size-sm) !important;
    line-height: 1.2 !important;
    text-align: center !important;
    position: relative !important;
    overflow: hidden;
    
    /* Optimisations GPU */
    will-change: transform, background-color;
    transform: translateZ(0);
}

.btn-small:hover {
    background: var(--aw-primary-color) !important;
    color: var(--aw-white) !important;
    transform: translateY(-2px) translateZ(0) !important;
    box-shadow: var(--aw-shadow) !important;
}

.accessibility-widget .btn-small,
.accessibility-widget .btn-small span,
.accessibility-widget .btn-small img,
.accessibility-widget .btn-small .accessibility-btn-icon {
    color: #222 !important;
    fill: #222 !important;
}

.accessibility-widget .btn-small img,
.accessibility-widget .btn-small .accessibility-btn-icon img {
    filter: none !important;
}

.btn-small:focus {
    outline: 2px solid var(--aw-warning-color);
    outline-offset: 2px;
}

.btn-small:active {
    transform: translateY(0) translateZ(0);
}

.btn-small.active {
    background: var(--aw-primary-color) !important;
    color: var(--aw-white) !important;
    border-color: var(--aw-primary-color) !important;
    box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.25) !important;
    transform: none !important;
}

.btn-small.active:hover {
    background: var(--aw-primary-hover) !important;
    color: var(--aw-white) !important;
    transform: translateY(-1px) translateZ(0) !important;
}

/* ===== ICÔNES DES BOUTONS ===== */
.accessibility-btn-icon {
    display: block !important;
    font-size: 24px !important;
    height: 36px !important;
    margin: 0 auto var(--aw-spacing-sm) auto !important;
    line-height: 36px !important;
    text-align: center !important;
    filter: none !important; /* Toujours visible */
}

/* ===== MODES D'ACCESSIBILITÉ ===== */

/* Mode Contraste Élevé */
html.high-contrast-mode *:not(.accessibility-isolated):not(.accessibility-isolated *) {
    background-color: var(--aw-white) !important;
    color: var(--aw-black) !important;
    border-color: var(--aw-black) !important;
    text-shadow: none !important;
    box-shadow: none !important;
}

html.high-contrast-mode a:not(.accessibility-isolated):not(.accessibility-isolated *) {
    color: var(--aw-black) !important;
    text-decoration: underline !important;
}

/* Mode Sombre */
html.dark-mode *:not(.accessibility-isolated):not(.accessibility-isolated *) {
    background-color: var(--aw-dark-color) !important;
    color: var(--aw-light-color) !important;
    border-color: #555 !important;
}

html.dark-mode input:not(.accessibility-isolated):not(.accessibility-isolated *),
html.dark-mode textarea:not(.accessibility-isolated):not(.accessibility-isolated *) {
    background-color: #2c2c2c !important;
    color: var(--aw-light-color) !important;
}

/* Préserver l'apparence du widget en mode sombre */
html.dark-mode .accessibility-panel {
    background: var(--aw-white) !important;
    color: var(--aw-dark-color) !important;
}

/* ===== MODES DALTONISME ===== */
html.deuteranopia-mode {
    filter: 
        url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><defs><filter id="deuteranopia"><feColorMatrix type="matrix" values="0.625 0.375 0 0 0 0.7 0.3 0 0 0 0 0.3 0.7 0 0 0 0 0 1 0"/></filter></defs></svg>#deuteranopia');
}

html.protanopia-mode {
    filter: 
        url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><defs><filter id="protanopia"><feColorMatrix type="matrix" values="0.567 0.433 0 0 0 0.558 0.442 0 0 0 0 0.242 0.758 0 0 0 0 0 1 0"/></filter></defs></svg>#protanopia');
}

html.tritanopia-mode {
    filter: 
        url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><defs><filter id="tritanopia"><feColorMatrix type="matrix" values="0.95 0.05 0 0 0 0 0.433 0.567 0 0 0 0.475 0.525 0 0 0 0 0 1 0"/></filter></defs></svg>#tritanopia');
}

/* ===== ESPACEMENT DU TEXTE ===== */
body.wide-text-spacing *:not(.accessibility-isolated):not(.accessibility-isolated *) {
    line-height: 1.8 !important;
    letter-spacing: 0.12em !important;
    word-spacing: 0.16em !important;
}

body.wide-text-spacing p:not(.accessibility-isolated):not(.accessibility-isolated *),
body.wide-text-spacing li:not(.accessibility-isolated):not(.accessibility-isolated *) {
    margin-bottom: 1.5em !important;
}

/* ===== POLICE LISIBLE ===== */
body.readable-font *:not(.fas):not(.fab):not(.far):not(.fa):not([class*="fa-"]):not(.accessibility-isolated):not(.accessibility-isolated *) {
    font-family: "Verdana", "Tahoma", "DejaVu Sans", sans-serif !important;
    font-weight: normal !important;
    text-transform: none !important;
}

/* ===== SURLIGNAGE DES LIENS ===== */
body.highlight-links a:not(.accessibility-isolated):not(.accessibility-isolated *),
body.highlight-links button:not(.accessibility-isolated):not(.accessibility-isolated *),
body.highlight-links input[type="button"]:not(.accessibility-isolated):not(.accessibility-isolated *),
body.highlight-links input[type="submit"]:not(.accessibility-isolated):not(.accessibility-isolated *),
body.highlight-links .btn:not(.accessibility-isolated):not(.accessibility-isolated *) {
    position: relative !important;
    background-color: rgba(255, 235, 59, 0.3) !important;
    outline: 2px solid var(--aw-warning-color) !important;
    outline-offset: 1px !important;
    z-index: 1 !important;
}

body.highlight-links a:hover:not(.accessibility-isolated):not(.accessibility-isolated *),
body.highlight-links button:hover:not(.accessibility-isolated):not(.accessibility-isolated *) {
    background-color: rgba(255, 235, 59, 0.5) !important;
    outline-width: 3px !important;
}

/* ===== GRAND CURSEUR ===== */
body.large-cursor,
body.large-cursor * {
    cursor: none !important;
}

.custom-cursor {
    position: fixed;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255,255,255,0.8) 0%, rgba(0,123,255,0.6) 100%);
    border: 3px solid var(--aw-primary-color);
    pointer-events: none;
    z-index: 999999;
    transform: translate(-50%, -50%) translateZ(0);
    transition: transform 0.1s ease-out, width 0.2s, height 0.2s;
    will-change: transform;
}

.custom-cursor.clickable-target {
    width: 50px;
    height: 50px;
    background: radial-gradient(circle, rgba(0,123,255,0.3) 0%, rgba(0,123,255,0.1) 100%);
    border-color: var(--aw-success-color);
}

.custom-cursor.clicking {
    transform: translate(-50%, -50%) scale(0.8) translateZ(0);
    background: radial-gradient(circle, rgba(0,123,255,0.6) 0%, rgba(0,123,255,0.3) 100%);
    border-width: 4px;
}

/* ===== GUIDE DE LECTURE ===== */
body.reading-guide {
    position: relative;
}

body.reading-guide::before,
body.reading-guide::after {
    content: "";
    position: fixed;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.75);
    pointer-events: none;
    z-index: 99998;
    transition: height 0.1s ease;
    will-change: height;
}

body.reading-guide::before {
    top: 0;
    height: calc(var(--guide-position, 50vh) - 25px);
    border-bottom: 3px solid var(--aw-warning-color);
}

body.reading-guide::after {
    bottom: 0;
    height: calc(100vh - var(--guide-position, 50vh) - 25px);
    border-top: 3px solid var(--aw-warning-color);
}

.reading-highlight-borders {
    position: fixed;
    left: 0;
    right: 0;
    height: 50px;
    z-index: 99999;
    pointer-events: none;
    will-change: transform;
    opacity: 0;
}

/* ===== MODE SANS ANIMATIONS ===== */
body.no-animations *,
body.no-animations *::before,
body.no-animations *::after {
    animation-duration: 0s !important;
    animation-delay: 0s !important;
    transition-duration: 0s !important;
    transition-delay: 0s !important;
    scroll-behavior: auto !important;
}

/* ===== MODE SANS IMAGES ===== */
body.no-images img:not(.accessibility-isolated img) {
    opacity: 0 !important;
    position: relative !important;
}

body.no-images img:not(.accessibility-isolated img)::after {
    content: attr(alt) " (Image masquée)" !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: var(--aw-light-color) !important;
    border: 2px dashed var(--aw-secondary-color) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: var(--aw-spacing-sm) !important;
    font-size: var(--aw-font-size-sm) !important;
    text-align: center !important;
    opacity: 1 !important;
    box-sizing: border-box !important;
}

html.no-background-images *:not(.accessibility-widget *) {
    background-image: none !important;
}

/* ===== LECTURE AU SURVOL ===== */
body.hover-reading-mode {
    cursor: help !important;
}

body.hover-reading-mode *:hover {
    outline: 2px dashed var(--aw-danger-color) !important;
    outline-offset: 1px !important;
}

/* ===== COPYRIGHT ===== */
.copyright-nz {
    text-align: center;
    font-size: var(--aw-font-size-sm) !important;
    color: var(--aw-secondary-color) !important;
    margin-top: var(--aw-spacing-lg) !important;
    padding-top: var(--aw-spacing-md) !important;
    border-top: 1px solid var(--aw-light-color);
}

/* ===== CLASSE UTILITAIRE POUR LECTEURS D'ÉCRAN ===== */
.sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* ===== OPTIMISATIONS POUR LES MOUVEMENTS RÉDUITS ===== */
@media (prefers-reduced-motion: reduce) {
    .accessibility-toggle,
    .btn-small,
    .accessibility-panel {
        animation: none !important;
        transition: none !important;
    }
    
    .accessibility-toggle:hover {
        transform: none !important;
        animation: none !important;
    }
}

/* ===== MODE HIGH-DPI / RETINA ===== */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .accessibility-toggle {
        box-shadow: var(--aw-shadow), inset 0 1px 0 rgba(255,255,255,0.1);
    }
    
    .accessibility-panel {
        box-shadow: var(--aw-shadow-hover), inset 0 1px 0 rgba(255,255,255,0.1);
    }
}

/* ===== AMÉLIORATIONS POUR L'IMPRESSION ===== */
@media print {
    .accessibility-widget {
        display: none !important;
    }
}

/* ===== RÈGLES DE CONTRASTE POUR WCAG AAA ===== */
@media (prefers-contrast: high) {
    :root {
        --aw-primary-color: #0056b3;
        --aw-primary-hover: #004085;
    }
    
    .accessibility-toggle {
        border: 2px solid var(--aw-white);
    }
    
    .btn-small {
        border: 1px solid var(--aw-secondary-color);
    }
}

/* ===== MODES D'ACCESSIBILITÉ ===== */
/* Mode sombre */
html.dark-mode *:not(.accessibility-isolated):not(.accessibility-isolated *) {
    background-color: #222 !important;
    color: #f5f5f5 !important;
    border-color: #555 !important;
}

html.dark-mode .accessibility-panel h3 {
    color: #333 !important;
    background-color: white !important;
    border-bottom-color: #eee !important;
}

html.dark-mode input, 
html.dark-mode textarea {
    background-color: #333 !important;
}

/* Mode contraste élevé */
html.high-contrast-mode *:not(.accessibility-isolated):not(.accessibility-isolated *) {
    background-color: white !important;
    color: black !important;
    border-color: black !important;
}

/* Mode daltonisme */
html.deuteranopia-mode {
    filter: grayscale(0.5) sepia(0.2) !important;
}

html.protanopia-mode {
    filter: hue-rotate(-30deg) saturate(0.8) !important;
}

html.tritanopia-mode {
    filter: hue-rotate(90deg) saturate(0.8) !important;
}

/* Mode texte large */
body.wide-text-spacing *:not(.accessibility-isolated):not(.accessibility-isolated *) {
    line-height: 1.8 !important;
    letter-spacing: 0.12em !important;
    word-spacing: 0.16em !important;
}

body.wide-text-spacing p, 
body.wide-text-spacing li:not(.accessibility-isolated):not(.accessibility-isolated *) {
    margin-bottom: 1.5em !important;
}

/* Police lisible */
body.readable-font *:not(.fas):not(.fab):not(.far):not(.fa):not([class*="fa-"]):not(.accessibility-isolated):not(.accessibility-isolated *) {
    font-family: Verdana, sans-serif !important;
    text-transform: none !important;
}

/* Combinaison Police lisible + espacement large */
body.wide-text-spacing.readable-font *:not(.fas):not(.fab):not(.far):not(.fa):not([class*="fa-"]):not(.accessibility-isolated):not(.accessibility-isolated *) {
    font-family: Verdana, sans-serif !important;
    line-height: 1.8 !important;
    letter-spacing: 0.12em !important;
    word-spacing: 0.16em !important;
}

/* Gestion des liens surlignés */
body.highlight-links a,
body.highlight-links button,
body.highlight-links input[type="button"],
body.highlight-links input[type="submit"],
body.highlight-links .btn {
    position: relative !important;
    background-color: #ffeb3ba1 !important;
    box-shadow: 0 0 0 2px #ff6b6b !important;
    z-index: 1 !important;
}

body.highlight-links a::after,
body.highlight-links button::after,
body.highlight-links input[type="button"]::after,
body.highlight-links input[type="submit"]::after,
body.highlight-links .btn::after {
    content: "" !important;
    position: absolute !important;
    top: -2px !important;
    left: -2px !important;
    right: -2px !important;
    bottom: -2px !important;
    background-color: #ffeb3ba1 !important;
    border: 1px solid #ff6b6b !important;
    border-radius: inherit !important;
    z-index: -1 !important;
    pointer-events: none !important;
}

body.highlight-links a:hover,
body.highlight-links button:hover,
body.highlight-links input[type="button"]:hover,
body.highlight-links input[type="submit"]:hover,
body.highlight-links .btn:hover {
    background-color: #ffeb3ba1 !important;
    box-shadow: 0 0 0 3px rgba(255, 107, 107, 0.5) !important;
}

/* ===== GESTION DES ICÔNES EN MODE SOMBRE ===== */
/* Masquer/afficher les icônes adaptées au mode sombre */
img[src$="cart-shopping-white.svg"],
img[src$="user-alt-white.svg"] {
    display: none !important;
}

html.dark-mode img[src$="cart-shopping-svgrepo-com.svg"],
html.dark-mode img[src$="user-alt-1-svgrepo-com.svg"] {
    display: none !important;
}

html.dark-mode img[src$="cart-shopping-white.svg"],
html.dark-mode img[src$="user-alt-white.svg"] {
    display: inline-block !important;
}

/* Effets hover pour les icônes */
html.dark-mode img[src$="cart-shopping-white.svg"]:hover,
html.dark-mode img[src$="user-alt-white.svg"]:hover,
html.dark-mode img[src$="cart-shopping-svgrepo-com.svg"]:hover,
html.dark-mode img[src$="user-alt-1-svgrepo-com.svg"]:hover {
    opacity: 0.8;
    transform: scale(1.05);
}

/* ===== NAVBAR EN MODE SOMBRE ===== */
html.dark-mode .navbar-toggler {
    border-color: rgba(255, 255, 255, 0.5) !important;
    background-color: rgba(255, 255, 255, 0.1) !important;
}

html.dark-mode .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

html.dark-mode .navbar-toggler:hover {
    background-color: rgba(255, 255, 255, 0.2) !important;
}

/* ===== GRAND CURSEUR PERSONNALISÉ ===== */
body.large-cursor,
body.large-cursor a,
body.large-cursor button,
body.large-cursor input,
body.large-cursor textarea,
body.large-cursor select,
body.large-cursor [role="button"],
body.large-cursor [tabindex],
body.large-cursor label,
body.large-cursor .btn,
body.large-cursor .clickable,
body.large-cursor *[onclick] {
    cursor: none !important;
}

.custom-cursor {
    position: fixed;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: rgba(255,255,255,0.5);
    border: 2px solid #000;
    pointer-events: none;
    z-index: 9999;
    transform: translate(-50%, -50%);
    transition: transform 0.1s ease-out, width 0.2s, height 0.2s;
}

body.large-cursor:active .custom-cursor {
    transform: translate(-50%, -50%) scale(0.8);
    background-color: rgba(0,123,255,0.3);
    border-color: #0069d9;
}

body.large-cursor a:hover ~ .custom-cursor,
body.large-cursor button:hover ~ .custom-cursor,
body.large-cursor input:hover ~ .custom-cursor {
    width: 45px;
    height: 45px;
    border-color: #007bff;
}

.custom-cursor.clickable-target {
    background-color: rgba(0,123,255,0.2);
    border-color: #007bff;
    width: 45px;
    height: 45px;
}

.custom-cursor.clicking {
    transform: translate(-50%, -50%) scale(0.8);
    background-color: rgba(0,123,255,0.4);
    border-width: 3px;
}

/* ===== MODE LECTURE AU SURVOL ===== */
body.hover-reading-mode {
    cursor: help !important;
}

body.hover-reading-mode *:hover {
    outline: 2px dashed #ff6b6b !important;
}

/* ===== STYLES SPÉCIFIQUES POUR LES BOUTONS DE MODE ===== */
[data-action="high-contrast"].active {
    background-color: #000 !important;
    color: white !important;
}

[data-action="dark-mode"].active {
    background-color: #343a40 !important;
    color: #f8f9fa !important;
}

[data-action="highlight-links"].active {
    border-left: 3px solid #ff6b6b !important;
}

[data-action="readable-font"].active {
    font-family: Arial, sans-serif !important;
}

/* Mode sans animation */
body.no-animations * {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
}

/* Guide de lecture */
body.reading-guide {
    position: relative;
}

/* Masque supérieur avec bordure inférieure */
body.reading-guide::before {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: calc(var(--guide-position, 50vh) - 25px); 
    background-color: rgba(0, 0, 0, 0.7) !important;
    border-bottom: 2px solid #ffeb3b !important; /* Bordure inférieure */
    pointer-events: none;
    z-index: 9998;
    transition: height 0.1s ease;
}

/* Masque inférieur avec bordure supérieure */
body.reading-guide::after {
    content: "";
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: calc(100vh - var(--guide-position, 50vh) - 25px);
    background-color: rgba(0, 0, 0, 0.7) !important;
    border-top: 2px solid #ffeb3b !important; /* Bordure supérieure */
    pointer-events: none;
    z-index: 9998;
    transition: height 0.1s ease;
}

/* Amélioration des performances */
.reading-highlight-borders {
    will-change: transform;
    position: fixed;
    left: 0;
    right: 0;
    height: 50px;
    z-index: 9999;
    pointer-events: none;
}

/* Règles spécifiques pour le mode contraste élevé */
html.high-contrast-mode body.reading-guide::before {
    background-color: rgba(0, 0, 0, 0.8) !important;
    border-bottom: 3px solid #ffeb3b !important; /* Bordure plus visible en contraste élevé */
}

html.high-contrast-mode body.reading-guide::after {
    background-color: rgba(0, 0, 0, 0.8) !important;
    border-top: 3px solid #ffeb3b !important; /* Bordure plus visible en contraste élevé */
}

/* Règles spécifiques pour le mode sombre */
html.dark-mode body.reading-guide::before {
    background-color: rgba(0, 0, 0, 0.8) !important;
    border-bottom: 2px solid #ffeb3b !important;
}

html.dark-mode body.reading-guide::after {
    background-color: rgba(0, 0, 0, 0.8) !important;
    border-top: 2px solid #ffeb3b !important;
}

/* Garantir que l'élément reading-highlight-borders reste transparent */
html.high-contrast-mode body.reading-guide .reading-highlight-borders,
html.dark-mode body.reading-guide .reading-highlight-borders {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    border-top: none !important;
    border-bottom: none !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    opacity: 0 !important;
}

/* Animation au survol du bouton d'accessibilité */
.accessibility-toggle {
    transition: transform 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease !important;
}

.accessibility-toggle:hover {
    transform: scale(1.1) !important;
    box-shadow: 0 4px 15px rgba(0, 123, 255, 0.4) !important;
    background-color: #0069d9 !important;
    animation: pulse 2s infinite !important;
}

@keyframes pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(0, 123, 255, 0.7);
    }
    70% {
        box-shadow: 0 0 0 10px rgba(0, 123, 255, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(0, 123, 255, 0);
    }
}

/* Assurer que l'animation fonctionne en mode sombre et contraste élevé */
html.dark-mode .accessibility-toggle:hover,
html.high-contrast-mode .accessibility-toggle:hover {
    animation: pulse 2s infinite !important;
}

/* Désactiver l'animation si l'utilisateur préfère réduire les mouvements */
@media (prefers-reduced-motion: reduce) {
    .accessibility-toggle:hover {
        transform: scale(1.05) !important;
        animation: none !important;
    }
}

.copyrightNZ {
    color: #000000;
}

/* Mode sans images */
html.no-background-images *:not(.accessibility-widget *) {
    background-image: none !important;
}

img.disabled-image {
    border: 1px dashed #999 !important;
    background-color: #f0f0f0 !important;
    padding: 8px !important;
    box-sizing: border-box !important;
    min-width: 24px !important;
    min-height: 24px !important;
    position: relative !important;
}

/* Pour compatibilité avec le mode sombre */
html.dark-mode img.disabled-image {
    background-color: #333 !important;
    border-color: #666 !important;
}

html.dark-mode,
html.dark-mode body {
    background-color: #121212 !important;
    color: #e6eef8 !important;
    background-image: none !important;
}
html.high-contrast-mode,
html.high-contrast-mode body {
    background-color: #ffffff !important;
    color: #000000 !important;
    background-image: none !important;
}