/**
 * Tarteaucitron.js - Personnalisation pour Dernière Chance
 * Bannière : bandeau bas | Panneau : modal centré
 */

/* ============================================
   FIX FLASH BANNIÈRE AU CHARGEMENT
   ============================================ */
/* Cacher la bannière par défaut pour éviter le flash de 0.1s */
#tarteaucitronRoot #tarteaucitronAlertBig {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transition: opacity 0.3s ease, visibility 0s 0.3s !important;
}

/* Afficher uniquement si Tarteaucitron décide de la montrer (display:block ajouté par le JS) */
#tarteaucitronRoot #tarteaucitronAlertBig[style*="display: block"],
#tarteaucitronRoot #tarteaucitronAlertBig[style*="display:block"] {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transition: opacity 0.3s ease !important;
}

/* ============================================
   VARIABLES COULEURS
   ============================================ */
:root {
  --dc-violet: #5B21B6;
  --dc-violet-dark: #4C1D95;
  --dc-violet-light: #7C3AED;
  --dc-pink-pastel: #F9A8D4;
  --dc-pink-hover: #F472B6;
}

/* ============================================
   BANNIÈRE — CARTE BAS GAUCHE (desktop)
   ============================================ */
#tarteaucitronRoot #tarteaucitronAlertBig {
  position: fixed !important;
  bottom: 16px !important;
  left: 16px !important;
  right: auto !important;
  top: auto !important;
  transform: none !important;
  max-width: 340px !important;
  width: calc(100vw - 32px) !important;
  border-radius: 14px !important;
  border: 1px solid rgba(91, 33, 182, 0.4) !important;
  background: rgba(10, 10, 22, 0.98) !important;
  /* backdrop-filter retiré — cause un décalage des coordonnées touch sur iOS Safari */
  padding: 16px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 10px !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5) !important;
  z-index: 2147483647 !important;
}

/* Texte de la bannière */
#tarteaucitronRoot #tarteaucitronDisclaimerAlert {
  color: rgba(255, 255, 255, 0.75) !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  flex: 1 !important;
  min-width: 200px !important;
  margin: 0 !important;
}

/* ============================================
   BACKDROP (overlay)
   Tarteaucitron gère display via JS — on style seulement
   ============================================ */
#tarteaucitronRoot #tarteaucitronBack {
  background: rgba(0, 0, 0, 0.65) !important;
  /* backdrop-filter retiré — cause un décalage des coordonnées touch sur iOS Safari */
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 100% !important;
  z-index: 2147483646 !important;
}

/* ============================================
   PANNEAU DE GESTION — MODAL CENTRÉ
   ============================================ */
#tarteaucitronRoot #tarteaucitron {
  /* On laisse le JS gérer la position (sidebar droite) */
  width: 400px !important;
  max-width: 90vw !important;
  height: 100% !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  left: auto !important;
  transform: none !important;
  margin: 0 !important;
  border-radius: 16px 0 0 16px !important;
  background: #12112a !important;
  background-color: #12112a !important;
  border: none !important;
  border-left: 1px solid rgba(91, 33, 182, 0.35) !important;
  box-shadow: -8px 0 40px rgba(0, 0, 0, 0.5) !important;
  padding: 0 !important;
  z-index: 2147483648 !important;
  opacity: 1 !important;
}

/* Scrollbar discrète dans le panneau */
#tarteaucitronRoot #tarteaucitron #tarteaucitronScrollbarLong {
  scrollbar-width: thin !important;
  scrollbar-color: var(--dc-violet) transparent !important;
}

#tarteaucitronRoot #tarteaucitron #tarteaucitronScrollbarLong::-webkit-scrollbar {
  width: 4px !important;
}

#tarteaucitronRoot #tarteaucitron #tarteaucitronScrollbarLong::-webkit-scrollbar-track {
  background: transparent !important;
}

#tarteaucitronRoot #tarteaucitron #tarteaucitronScrollbarLong::-webkit-scrollbar-thumb {
  background: var(--dc-violet) !important;
  border-radius: 10px !important;
}

/* Header du panneau */
#tarteaucitronRoot #tarteaucitron .tarteaucitronBorder {
  background: rgba(91, 33, 182, 0.12) !important;
  border-bottom: 1px solid rgba(91, 33, 182, 0.3) !important;
  padding: 18px 20px !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  border-radius: 16px 16px 0 0 !important;
}

/* Liste des services — on conserve le margin-top natif qui crée l'espace sous le bouton Fermer */
#tarteaucitronRoot #tarteaucitronServices {
  color: #ffffff !important;
  font-size: 16px !important;
  font-weight: 700 !important;
}

/* Bouton Fermer au-dessus de tout */
#tarteaucitronRoot #tarteaucitronClosePanel {
  z-index: 10 !important;
}

/* Bouton de fermeture */
#tarteaucitronRoot #tarteaucitronClosePanel {
  background: rgba(255, 255, 255, 0.08) !important;
  color: rgba(255, 255, 255, 0.7) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  border-radius: 8px !important;
  padding: 6px 14px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
}

#tarteaucitronRoot #tarteaucitronClosePanel:hover {
  background: var(--dc-violet) !important;
  border-color: var(--dc-violet) !important;
  color: #ffffff !important;
}

/* Contenu principal du panneau */
#tarteaucitronRoot #tarteaucitron #tarteaucitronScrollbarLong {
  padding: 16px 20px !important;
}

/* Titres des catégories */
#tarteaucitronRoot .tarteaucitronTitle {
  background: rgba(91, 33, 182, 0.2) !important;
  color: #ffffff !important;
  border-radius: 8px !important;
  padding: 10px 14px !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  margin: 12px 0 6px !important;
  border-left: 3px solid var(--dc-violet) !important;
}

/* Lignes de services */
#tarteaucitronRoot .tarteaucitronLine {
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 8px !important;
  color: #ffffff !important;
  padding: 12px 14px !important;
  margin: 6px 0 !important;
  transition: background 0.2s ease !important;
}

#tarteaucitronRoot .tarteaucitronLine:hover {
  background: rgba(91, 33, 182, 0.15) !important;
}

/* Noms des services */
#tarteaucitronRoot .tarteaucitronName {
  color: #ffffff !important;
  font-weight: 600 !important;
  font-size: 14px !important;
}

/* Descriptions des services */
#tarteaucitronRoot .tarteaucitronName b {
  color: rgba(255, 255, 255, 0.6) !important;
  font-weight: 400 !important;
  font-size: 12px !important;
}

/* Boutons Allow/Deny dans le panneau */
#tarteaucitronRoot .tarteaucitronLine .tarteaucitronAllow {
  background: var(--dc-violet) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 6px !important;
  font-size: 12px !important;
  padding: 5px 12px !important;
  cursor: pointer !important;
  transition: background 0.2s ease !important;
}

#tarteaucitronRoot .tarteaucitronLine .tarteaucitronAllow:hover {
  background: var(--dc-violet-light) !important;
}

#tarteaucitronRoot .tarteaucitronLine .tarteaucitronDeny {
  background: transparent !important;
  color: rgba(255, 255, 255, 0.55) !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  border-radius: 6px !important;
  font-size: 12px !important;
  padding: 5px 12px !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
}

#tarteaucitronRoot .tarteaucitronLine .tarteaucitronDeny:hover {
  color: #ffffff !important;
  border-color: rgba(255, 255, 255, 0.4) !important;
}

/* Détails des services */
#tarteaucitronRoot .tarteaucitronHidden,
#tarteaucitronRoot .tarteaucitronDetails {
  background: rgba(0, 0, 0, 0.2) !important;
  padding: 10px 12px !important;
  margin: 6px 0 !important;
  border-radius: 6px !important;
  border-left: 2px solid var(--dc-violet) !important;
  color: rgba(255, 255, 255, 0.8) !important;
  font-size: 12px !important;
  line-height: 1.6 !important;
}

/* ============================================
   BOUTONS BANNIÈRE
   ============================================ */

/* Tout accepter */
#tarteaucitronRoot .tarteaucitronAllow,
#tarteaucitronRoot #tarteaucitronPersonalize2 {
  background: var(--dc-violet) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 8px 18px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background 0.2s ease !important;
  white-space: nowrap !important;
}

#tarteaucitronRoot .tarteaucitronAllow:hover,
#tarteaucitronRoot #tarteaucitronPersonalize2:hover {
  background: var(--dc-violet-light) !important;
}

/* Tout refuser */
#tarteaucitronRoot .tarteaucitronDeny,
#tarteaucitronRoot #tarteaucitronCloseAlert {
  background: transparent !important;
  color: rgba(255, 255, 255, 0.6) !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  border-radius: 8px !important;
  padding: 8px 18px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  white-space: nowrap !important;
}

#tarteaucitronRoot .tarteaucitronDeny:hover,
#tarteaucitronRoot #tarteaucitronCloseAlert:hover {
  color: #ffffff !important;
  border-color: rgba(255, 255, 255, 0.4) !important;
}

/* Personnaliser */
#tarteaucitronRoot #tarteaucitronPersonalize {
  background: transparent !important;
  color: rgba(249, 168, 212, 0.7) !important;
  border: none !important;
  text-decoration: underline !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  cursor: pointer !important;
  transition: color 0.2s ease !important;
  white-space: nowrap !important;
  padding: 0 !important;
}

#tarteaucitronRoot #tarteaucitronPersonalize:hover {
  color: var(--dc-pink-pastel) !important;
}

/* ============================================
   LIENS
   ============================================ */
#tarteaucitronRoot a {
  color: var(--dc-pink-pastel) !important;
  text-decoration: underline !important;
}

#tarteaucitronRoot a:hover {
  color: var(--dc-pink-hover) !important;
}

/* ============================================
   ANIMATIONS
   ============================================ */
@keyframes slideUpBar {
  from { transform: translateY(calc(100% + 16px)); opacity: 0; }
  to   { transform: translateY(0);                 opacity: 1; }
}

@keyframes slideInRight {
  from { transform: translateX(100%); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}

#tarteaucitronRoot #tarteaucitronAlertBig {
  animation: slideUpBar 0.3s ease-out !important;
}

#tarteaucitronRoot #tarteaucitron {
  animation: slideInRight 0.25s ease-out !important;
}

/* ============================================
   RESPONSIVE MOBILE
   ============================================ */
@media (max-width: 768px) {

  /* Bannière mobile : barre ultra-compacte en bas, texte masqué */
  #tarteaucitronRoot #tarteaucitronAlertBig {
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
    border-radius: 0 !important;
    border: none !important;
    border-top: 1px solid rgba(91, 33, 182, 0.35) !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex-wrap: nowrap !important;
    padding: 10px 16px !important;
    gap: 8px !important;
  }

  /* Masquer le texte descriptif sur mobile */
  #tarteaucitronRoot #tarteaucitronDisclaimerAlert {
    display: none !important;
  }

  /* Boutons côte à côte, compacts */
  #tarteaucitronRoot .tarteaucitronAllow,
  #tarteaucitronRoot .tarteaucitronDeny,
  #tarteaucitronRoot #tarteaucitronPersonalize2 {
    width: auto !important;
    flex: 1 !important;
    text-align: center !important;
    padding: 10px 12px !important;
    font-size: 13px !important;
  }

  /* Lien "Personnaliser" compact sur mobile */
  #tarteaucitronRoot #tarteaucitronPersonalize {
    font-size: 11px !important;
  }

  /* Animations désactivées sur mobile — évite le décalage de zone de clic (bug webkit transform) */
  #tarteaucitronRoot #tarteaucitronAlertBig,
  #tarteaucitronRoot #tarteaucitron {
    animation: none !important;
  }

  /* Sidebar : pleine largeur sur mobile */
  #tarteaucitronRoot #tarteaucitron {
    width: 100vw !important;
    max-width: 100vw !important;
    border-radius: 0 !important;
    border-left: none !important;
    border-top: 1px solid rgba(91, 33, 182, 0.35) !important;
  }

  #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder {
    padding: 14px 16px !important;
  }

  #tarteaucitronRoot #tarteaucitronServices {
    font-size: 14px !important;
  }

  /* Bouton "Fermer" — touch target minimum 44×44px (WCAG) */
  #tarteaucitronRoot #tarteaucitronClosePanel {
    min-height: 44px !important;
    min-width: 88px !important;
    padding: 10px 20px !important;
    font-size: 15px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 10px !important;
  }
}
