/* ==========================================
   COOKIECONSENT - MINIMALISTE & ARIA
   Pharmacie Nord Montargis
   Contrastes WCAG 2.1 AA conformes
   ========================================== */

/* Reset de base */
#cc-main * {
    box-sizing: border-box;
}

/* ==========================================
   BANNIÈRE PRINCIPALE
   ========================================== */

#cc-main .cm {
    position: fixed !important;
    bottom: 20px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    max-width: 500px !important;
    width: calc(100% - 40px) !important;
    padding: 20px !important;
    background: #FFFFFF !important;
    border: 1px solid #CCCCCC !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif !important;
    z-index: 9999 !important;
}

/* Titre */
#cc-main .cm__title {
    font-size: 18px !important;
    font-weight: 700 !important;
    margin: 0 0 12px 0 !important;
    color: #000000 !important;
}

/* Description */
#cc-main .cm__desc {
    font-size: 14px !important;
    line-height: 1.5 !important;
    margin: 0 0 16px 0 !important;
    color: #333333 !important;
}

/* Footer */
#cc-main .cm__footer {
    margin-top: 16px !important;
    padding-top: 16px !important;
    border-top: 1px solid #CCCCCC !important;
}

#cc-main .cm__footer a {
    color: #0066CC !important;
    text-decoration: underline !important;
    font-size: 14px !important;
}

/* ==========================================
   BOUTONS
   ========================================== */

#cc-main .cm__btns,
#cc-main .pm__btns {
    display: flex !important;
    gap: 10px !important;
    margin-top: 16px !important;
    flex-wrap: wrap !important;
}

#cc-main button {
    flex: 1 !important;
    min-width: 100px !important;
    padding: 10px 16px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    font-family: inherit !important;
    border: 2px solid #000000 !important;
}

/* Bouton principal (Tout accepter) */
#cc-main .cm__btn--primary,
#cc-main .pm__btn--primary {
    background: #0066CC !important;
    color: #FFFFFF !important;
    border-color: #0066CC !important;
}

#cc-main .cm__btn--primary:hover,
#cc-main .pm__btn--primary:hover {
    background: #0052A3 !important;
    border-color: #0052A3 !important;
}

/* Bouton secondaire (Tout refuser) */
#cc-main .cm__btn--secondary,
#cc-main .pm__btn--secondary {
    background: #F5F5F5 !important;
    color: #333333 !important;
    border-color: #333333 !important;
}

#cc-main .cm__btn--secondary:hover,
#cc-main .pm__btn--secondary:hover {
    background: #E0E0E0 !important;
}

/* Bouton tertiaire (Gérer) */
#cc-main button[data-role="show-settings"],
#cc-main .pm__btn {
    background: #FFFFFF !important;
    color: #0066CC !important;
    border-color: #0066CC !important;
}

#cc-main button[data-role="show-settings"]:hover,
#cc-main .pm__btn:hover {
    background: #F0F8FF !important;
}

/* ==========================================
   MODAL DE PRÉFÉRENCES
   ========================================== */

/* Masquer la bannière quand le modal est ouvert */
#cc-main.show--settings .cm,
#cc-main .cm.cm--hidden,
body.show--consent #cc-main .cm {
    display: none !important;
    visibility: hidden !important;
}

#cc-main .pm {
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    max-width: 600px !important;
    width: calc(100% - 40px) !important;
    max-height: 85vh !important;
    padding: 24px !important;
    background: #FFFFFF !important;
    border: 1px solid #CCCCCC !important;
    overflow-y: auto !important;
    z-index: 10000 !important;
}

/* Titre du modal */
#cc-main .pm__title {
    font-size: 20px !important;
    font-weight: 700 !important;
    margin: 0 0 20px 0 !important;
    color: #000000 !important;
}

/* Bouton fermer */
#cc-main .pm__close-btn {
    position: absolute !important;
    top: 16px !important;
    right: 16px !important;
    background: #FFFFFF !important;
    border: 1px solid #CCCCCC !important;
    font-size: 20px !important;
    color: #333333 !important;
    cursor: pointer !important;
    padding: 4px 8px !important;
    line-height: 1 !important;
    min-width: auto !important;
}

#cc-main .pm__close-btn:hover {
    background: #F5F5F5 !important;
}

/* ==========================================
   SECTIONS - TOUJOURS OUVERTES
   ========================================== */

#cc-main .pm__section {
    margin-bottom: 20px !important;
    padding: 16px !important;
    background: #F5F5F5 !important;
    border: 1px solid #CCCCCC !important;
}

/* Titre de section - SANS FLÈCHE */
#cc-main .pm__section-title {
    font-size: 16px !important;
    font-weight: 600 !important;
    margin: 0 0 8px 0 !important;
    color: #000000 !important;
    display: block !important;
    cursor: default !important;
    padding: 0 !important;
}

/* SUPPRIMER TOUTES LES FLÈCHES */
#cc-main .pm__section-title::before,
#cc-main .pm__section-title::after,
#cc-main .pm__section-arrow,
#cc-main [class*="arrow"],
#cc-main [class*="chevron"],
#cc-main .pm__section-toggle-icon {
    display: none !important;
    content: none !important;
}

/* Description de section */
#cc-main .pm__section-desc {
    font-size: 14px !important;
    line-height: 1.5 !important;
    margin: 0 0 12px 0 !important;
    color: #333333 !important;
}

/* Contenu de section - TOUJOURS VISIBLE */
#cc-main .pm__section-body {
    display: block !important;
    max-height: none !important;
    overflow: visible !important;
    opacity: 1 !important;
    margin-top: 12px !important;
}

/* ==========================================
   TOGGLE (interrupteur)
   ========================================== */

#cc-main .section__toggle {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-top: 12px !important;
}

#cc-main .toggle {
    position: relative !important;
    width: 44px !important;
    height: 24px !important;
    background: #CCCCCC !important;
    border: 1px solid #999999 !important;
    cursor: pointer !important;
}

#cc-main .toggle::after {
    content: '' !important;
    position: absolute !important;
    top: 2px !important;
    left: 2px !important;
    width: 18px !important;
    height: 18px !important;
    background: #FFFFFF !important;
    border: 1px solid #999999 !important;
}

/* Toggle activé */
#cc-main input[type="checkbox"]:checked + .toggle {
    background: #0066CC !important;
    border-color: #0066CC !important;
}

#cc-main input[type="checkbox"]:checked + .toggle::after {
    transform: translateX(20px) !important;
}

/* Toggle désactivé (read-only) */
#cc-main input[type="checkbox"]:disabled + .toggle {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
}

/* Input caché */
#cc-main input[type="checkbox"] {
    position: absolute !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* Label du toggle */
#cc-main .toggle__label {
    font-size: 14px !important;
    color: #333333 !important;
    font-weight: 600 !important;
}

/* ==========================================
   OVERLAY (fond sombre)
   ========================================== */

#cc-main .pm__overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(0, 0, 0, 0.5) !important;
    z-index: 9998 !important;
}

/* ==========================================
   RESPONSIVE MOBILE
   ========================================== */

@media (max-width: 640px) {
    #cc-main .cm {
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        transform: none !important;
        width: 100% !important;
        max-width: 100% !important;
        padding: 16px !important;
    }
    
    #cc-main .pm {
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        transform: none !important;
        width: 100% !important;
        max-width: 100% !important;
        max-height: 100% !important;
        padding: 16px !important;
    }
    
    #cc-main button {
        min-width: 80px !important;
        font-size: 14px !important;
        padding: 10px 12px !important;
    }
    
    #cc-main .pm__section {
        padding: 12px !important;
    }
}

/* ==========================================
   ACCESSIBILITÉ (Focus visible)
   ========================================== */

#cc-main button:focus-visible {
    outline: 3px solid #0066CC !important;
    outline-offset: 2px !important;
}

#cc-main a:focus-visible {
    outline: 2px solid #0066CC !important;
    outline-offset: 2px !important;
}