/* ===================================================
   TARTEAUCITRON CUSTOM THEME - Ben & Lou
   Style the EXISTING tarteaucitron elements
   =================================================== */

/* --- 1. FONTS & RESET --- */
html body div#tarteaucitronRoot,
html body div#tarteaucitronRoot * {
  box-sizing: border-box;
  font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  letter-spacing: -0.01em;
}

/* --- 2. BACKDROP --- */
html body #tarteaucitronBack {
  background-color: rgba(0, 0, 0, 0.6) !important;
  backdrop-filter: blur(4px) !important;
  -webkit-backdrop-filter: blur(4px) !important;
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  z-index: 2147483640 !important;
}

/* --- 3. MAIN POPUP (AlertBig - Initial Consent) --- */
html body #tarteaucitronAlertBig {
  position: fixed !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 90% !important;
  max-width: 520px !important;
  background: #FFFFFF !important;
  z-index: 2147483647 !important;
  border-radius: 24px !important;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25) !important;
  padding: 40px !important;
  margin: 0 !important;
  animation: tacPopIn 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  text-align: center !important;
  bottom: auto !important;
  right: auto !important;
}

/* --- 4. TITLE --- */
html body #tarteaucitronAlertBig #tarteaucitronDisclaimerAlert,
html body #tarteaucitronAlertBig .tarteaucitronH1 {
  font-family: 'Syne', sans-serif !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  color: #111827 !important;
  margin: 0 0 16px 0 !important;
  line-height: 1.2 !important;
  text-align: center !important;
  display: block !important;
}

/* --- 5. DESCRIPTION TEXT --- */
html body #tarteaucitronAlertBig #tarteaucitronDisclaimerAlert + span,
html body #tarteaucitronAlertBig > span:not(.tarteaucitronH1) {
  font-size: 15px !important;
  line-height: 1.6 !important;
  color: #4B5563 !important;
  display: block !important;
  margin-bottom: 28px !important;
  text-align: center !important;
}

/* --- 6. BUTTONS --- */
html body #tarteaucitronAlertBig button,
html body #tarteaucitronRoot #tarteaucitronAlertBig button {
  display: inline-block !important;
  margin: 6px !important;
  padding: 14px 28px !important;
  border-radius: 100px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  text-decoration: none !important;
  border: 2px solid transparent !important;
  opacity: 1 !important;
}

html body #tarteaucitronAlertBig #tarteaucitronPersonalize2,
html body #tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronPersonalize2,
html body #tarteaucitronAlertBig button.tarteaucitronAllow {
  background: #D9F99D !important;
  color: #111827 !important;
  border-color: #D9F99D !important;
  box-shadow: 0 4px 12px rgba(217, 249, 157, 0.4) !important;
}

html body #tarteaucitronAlertBig #tarteaucitronPersonalize2:hover,
html body #tarteaucitronAlertBig button.tarteaucitronAllow:hover {
  background: #BEF264 !important;
  border-color: #BEF264 !important;
  transform: translateY(-2px) !important;
}

html body #tarteaucitronAlertBig #tarteaucitronAllDenied2,
html body #tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronAllDenied2,
html body #tarteaucitronAlertBig button.tarteaucitronDeny {
  background: transparent !important;
  color: #111827 !important;
  border: 2px solid #E5E7EB !important;
  box-shadow: none !important;
}

html body #tarteaucitronAlertBig #tarteaucitronAllDenied2:hover,
html body #tarteaucitronAlertBig button.tarteaucitronDeny:hover {
  background: #F3F4F6 !important;
  border-color: #D1D5DB !important;
}

/* "Personnaliser" Link */
html body #tarteaucitronAlertBig #tarteaucitronCloseAlert,
html body #tarteaucitronAlertBig #tarteaucitronPrivacyUrl,
html body #tarteaucitronAlertBig a {
  color: #6B7280 !important;
  font-size: 13px !important;
  text-decoration: underline !important;
  display: inline-block !important;
  margin-top: 16px !important;
  padding: 8px !important;
  cursor: pointer !important;
  background: transparent !important;
  border: none !important;
}

html body #tarteaucitronAlertBig #tarteaucitronCloseAlert:hover,
html body #tarteaucitronAlertBig a:hover {
  color: #111827 !important;
}

/* --- 7. FLOATING COOKIE BUTTON --- */
html body #tarteaucitronIcon {
  position: fixed !important;
  bottom: 24px !important;
  right: 24px !important;
  left: auto !important;
  z-index: 2147483645 !important;
  background: #D9F99D !important;
  width: 56px !important;
  height: 56px !important;
  border-radius: 50% !important;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.15) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  border: 2px solid #111827 !important;
  transition: transform 0.2s ease, opacity 0.2s ease !important;
}

html body #tarteaucitronIcon:hover {
  transform: scale(1.08) !important;
}

html body #tarteaucitronIcon button {
  background: transparent !important;
  border: none !important;
  color: #111827 !important;
  width: 100% !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  padding: 0 !important;
  font-size: 0 !important;
}

html body #tarteaucitronIcon button::before {
  content: "🍪";
  font-size: 26px !important;
}

html body #tarteaucitronIcon button span,
html body #tarteaucitronIcon button svg,
html body #tarteaucitronIcon button img {
  display: none !important;
}

/* Hide cookie button when popup is visible */
html body #tarteaucitronRoot.tarteaucitronBeforeVisible #tarteaucitronIcon {
  opacity: 0 !important;
  pointer-events: none !important;
}

/* --- 8. SERVICES PANEL (#tarteaucitron) --- */
html body #tarteaucitron,
html body div#tarteaucitron {
  position: fixed !important;
  top: 50% !important;
  right: 24px !important;
  left: auto !important;
  bottom: auto !important;
  transform: translateY(-50%) !important;
  width: 92vw !important;
  max-width: 520px !important;
  max-height: 82vh !important;
  background: #FFFFFF !important;
  z-index: 2147483647 !important;
  border-radius: 20px !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.18) !important;
  padding: 24px !important;
  margin: 0 !important;
  overflow: hidden !important;
  border: 1px solid #E5E7EB !important;
  animation: tacSlideIn 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

html body #tarteaucitron #tarteaucitronClosePanel,
html body div#tarteaucitron #tarteaucitronClosePanel {
  position: absolute !important;
  top: 16px !important;
  right: 16px !important;
  width: 36px !important;
  height: 36px !important;
  background: #F3F4F6 !important;
  border: none !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  font-size: 0 !important;
  color: transparent !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.2s ease !important;
  z-index: 10 !important;
  padding: 0 !important;
}

html body #tarteaucitron #tarteaucitronClosePanel::before {
  content: "✕" !important;
  font-size: 16px !important;
  color: #6B7280 !important;
  line-height: 1 !important;
}

html body #tarteaucitron #tarteaucitronClosePanel:hover {
  background: #E5E7EB !important;
}

html body #tarteaucitron #tarteaucitronClosePanel:hover::before {
  color: #111827 !important;
}

html body #tarteaucitron #tarteaucitronServices,
html body div#tarteaucitron #tarteaucitronServices {
  background: transparent !important;
  box-shadow: none !important;
  padding: 8px 0 24px 0 !important;
  overflow: auto !important;
  display: block !important;
  max-height: 100% !important;
}

/* Main Header Area in Panel */
html body #tarteaucitron .tarteaucitronMainLine,
html body div#tarteaucitron .tarteaucitronMainLine {
  display: block !important;
  text-align: left !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 0 20px 0 !important;
}

html body #tarteaucitron .tarteaucitronH1,
html body div#tarteaucitron .tarteaucitronH1 {
  font-family: 'Syne', sans-serif !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: #111827 !important;
  margin: 0 0 12px 0 !important;
  line-height: 1.3 !important;
  text-align: left !important;
  display: block !important;
  width: 100% !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}

html body #tarteaucitron #tarteaucitronInfo,
html body div#tarteaucitron #tarteaucitronInfo {
  font-size: 13px !important;
  line-height: 1.5 !important;
  color: #6B7280 !important;
  margin: 0 0 16px 0 !important;
}

/* Global Allow/Deny Buttons in Panel */
html body #tarteaucitron .tarteaucitronMainLine .tarteaucitronAsk,
html body div#tarteaucitron .tarteaucitronMainLine .tarteaucitronAsk {
  display: flex !important;
  flex-direction: row !important;
  justify-content: flex-start !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
}

html body #tarteaucitron .tarteaucitronMainLine .tarteaucitronAsk button,
html body #tarteaucitron #tarteaucitronAllAllowed,
html body #tarteaucitron #tarteaucitronAllDenied {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 10px 18px !important;
  border-radius: 100px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  text-decoration: none !important;
  margin: 0 !important;
  opacity: 1 !important;
}

html body #tarteaucitron #tarteaucitronAllAllowed,
html body div#tarteaucitron #tarteaucitronAllAllowed {
  background: #D9F99D !important;
  color: #111827 !important;
  border: 2px solid #D9F99D !important;
  box-shadow: 0 4px 12px rgba(217, 249, 157, 0.4) !important;
}

html body #tarteaucitron #tarteaucitronAllAllowed:hover {
  background: #BEF264 !important;
  border-color: #BEF264 !important;
  transform: translateY(-1px) !important;
}

html body #tarteaucitron #tarteaucitronAllDenied,
html body div#tarteaucitron #tarteaucitronAllDenied {
  background: transparent !important;
  color: #111827 !important;
  border: 2px solid #E5E7EB !important;
  box-shadow: none !important;
}

html body #tarteaucitron #tarteaucitronAllDenied:hover {
  background: #F3F4F6 !important;
  border-color: #D1D5DB !important;
}

html body #tarteaucitron .tarteaucitronBorder,
html body div#tarteaucitron .tarteaucitronBorder {
  display: block !important;
  margin-top: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
}

html body #tarteaucitron .tarteaucitronBorder > ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

html body #tarteaucitron [id^="tarteaucitronServicesTitle_"] {
  list-style: none !important;
  margin: 0 0 12px 0 !important;
  padding: 0 !important;
}

html body #tarteaucitron [id^="tarteaucitronServicesTitle_"] > ul > li.tarteaucitronLine {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 14px 16px !important;
  margin: 0 !important;
  background: #F3F4F6 !important;
  border-radius: 14px !important;
  border: 1px solid #E5E7EB !important;
  gap: 12px !important;
}

html body #tarteaucitron [id^="tarteaucitronServicesTitle_"] .tarteaucitronName {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  flex: 1 !important;
  width: 100% !important;
}

html body #tarteaucitron [id^="tarteaucitronServicesTitle_"] .tarteaucitronH3 {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #111827 !important;
}

html body #tarteaucitron [id^="tarteaucitronServicesTitle_"] .tarteaucitronName > span:not(.tarteaucitronH3) {
  font-size: 12px !important;
  color: #6B7280 !important;
  line-height: 1.4 !important;
}

html body #tarteaucitron [id^="tarteaucitronServicesTitle_"] > ul > li.tarteaucitronLine .tarteaucitronName > span:not(.tarteaucitronH3) {
  display: none !important;
}

html body #tarteaucitron .tarteaucitronName > span + span.tarteaucitronH3 {
  display: block !important;
  order: -1 !important;
}

html body #tarteaucitron button.tarteaucitron-toggle-group,
html body #tarteaucitron .tarteaucitron-toggle-group + span,
html body #tarteaucitron .tarteaucitronName > span:not(.tarteaucitronH3) + button {
  font-size: 12px !important;
}

html body #tarteaucitron button.tarteaucitron-toggle-group {
  background: transparent !important;
  border: none !important;
  color: #111827 !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  padding: 0 !important;
  margin-top: 4px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  cursor: pointer !important;
}

html body #tarteaucitron .tarteaucitron-toggle-group,
html body #tarteaucitron .tarteaucitron-toggle-group * {
  text-decoration: none !important;
}

html body #tarteaucitron button.tarteaucitron-toggle-group::after {
  content: "▾" !important;
  font-size: 12px !important;
  transition: transform 0.2s ease !important;
}

html body #tarteaucitron [id^="tarteaucitronServicesTitle_"].tarteaucitronIsExpanded button.tarteaucitron-toggle-group::after {
  transform: rotate(180deg) !important;
}

html body #tarteaucitron [id^="tarteaucitronServices_"] {
  list-style: none !important;
  margin: 10px 0 0 12px !important;
  padding: 0 0 0 12px !important;
  border-left: 2px solid #E5E7EB !important;
}

html body #tarteaucitron [id^="tarteaucitronServices_"] > li.tarteaucitronLine {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 12px 14px !important;
  margin: 8px 0 !important;
  background: #FFFFFF !important;
  border-radius: 12px !important;
  border: 1px solid #E5E7EB !important;
  gap: 12px !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.02) !important;
}

html body #tarteaucitron [id^="tarteaucitronServices_"] .tarteaucitronName {
  display: block !important;
  flex: 1 !important;
  min-width: 0 !important;
}

html body #tarteaucitron [id^="tarteaucitronServices_"] .tarteaucitronName > span,
html body #tarteaucitron [id^="tarteaucitronServices_"] .tarteaucitronName > a {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #111827 !important;
  text-decoration: none !important;
  display: block !important;
}

html body #tarteaucitron #tarteaucitronSave {
  position: sticky !important;
  bottom: 0 !important;
  background: #FFFFFF !important;
  padding: 12px 0 4px 0 !important;
  margin-top: 16px !important;
  text-align: right !important;
  box-shadow: 0 -10px 20px rgba(255, 255, 255, 0.9) !important;
}

html body #tarteaucitron ul,
html body #tarteaucitron li {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

html body #tarteaucitron .tarteaucitronDetails,
html body #tarteaucitron .tarteaucitronHidden {
  display: none !important;
}

html body #tarteaucitron [id^="tarteaucitronServicesTitle_"] {
  display: none !important;
}

html body #tarteaucitron [id^="tarteaucitronServicesTitle_"]:has([id^="tarteaucitronServices_"] li.tarteaucitronLine) {
  display: block !important;
}

html body #tarteaucitron .tarteaucitronLine .tarteaucitronListCookies {
  font-size: 11px !important;
  color: #9CA3AF !important;
  margin-top: 4px !important;
}

/* Service Buttons */
html body #tarteaucitron .tarteaucitronLine .tarteaucitronAsk {
  flex-shrink: 0 !important;
  gap: 8px !important;
  display: flex !important;
}

html body #tarteaucitron .tarteaucitronLine .tarteaucitronAsk button {
  padding: 6px 14px !important;
  font-size: 12px !important;
  min-width: auto !important;
  border-radius: 100px !important;
  font-weight: 600 !important;
}

html body #tarteaucitron .tarteaucitronLine .tarteaucitronAllow {
  background: #D9F99D !important;
  color: #111827 !important;
  border: 1px solid #D9F99D !important;
}

html body #tarteaucitron .tarteaucitronLine .tarteaucitronDeny {
  background: transparent !important;
  color: #6B7280 !important;
  border: 1px solid #E5E7EB !important;
}

html body #tarteaucitron .tarteaucitronLine .tarteaucitronAllow:hover {
  background: #BEF264 !important;
}

html body #tarteaucitron .tarteaucitronLine .tarteaucitronDeny:hover {
  background: #F3F4F6 !important;
  color: #111827 !important;
}

/* --- 9. HIDE UNNECESSARY ELEMENTS --- */
html body #tarteaucitronPremium,
html body #tarteaucitronPercentage,
html body #tarteaucitronScrollbarChild,
html body span#tarteaucitronDisclaimerAlert,
html body #tarteaucitron #tarteaucitronPrivacyUrlDialog {
  display: none !important;
}

/* --- 10. ANIMATION --- */
@keyframes tacPopIn {
  from { opacity: 0; transform: translate(-50%, -48%) scale(0.96); }
  to { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}

@keyframes tacSlideIn {
  from { transform: translateX(40px); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}

/* --- 11. MOBILE --- */
@media (max-width: 640px) {
  html body #tarteaucitronAlertBig {
    width: 95% !important;
    padding: 32px 24px !important;
    border-radius: 20px !important;
  }
  
  html body #tarteaucitronAlertBig #tarteaucitronDisclaimerAlert,
  html body #tarteaucitronAlertBig .tarteaucitronH1 {
    font-size: 22px !important;
  }
  
  html body #tarteaucitronAlertBig button {
    display: block !important;
    width: 100% !important;
    margin: 8px 0 !important;
  }
  
  html body #tarteaucitron,
  html body div#tarteaucitron {
    top: auto !important;
    right: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    max-height: 90vh !important;
    border-radius: 20px 20px 0 0 !important;
    padding: 20px !important;
  }
  
  html body #tarteaucitron .tarteaucitronH1 {
    font-size: 20px !important;
  }
  
  html body #tarteaucitron .tarteaucitronMainLine .tarteaucitronAsk {
    flex-direction: column !important;
    gap: 10px !important;
    align-items: stretch !important;
  }
  
  html body #tarteaucitron .tarteaucitronMainLine .tarteaucitronAsk button,
  html body #tarteaucitron #tarteaucitronAllAllowed,
  html body #tarteaucitron #tarteaucitronAllDenied {
    width: 100% !important;
  }

  html body #tarteaucitron [id^="tarteaucitronServicesTitle_"] > ul > li.tarteaucitronLine {
    display: block !important;
    padding: 14px 16px !important;
  }

  html body #tarteaucitron [id^="tarteaucitronServicesTitle_"] > ul > li.tarteaucitronLine .tarteaucitronName {
    display: block !important;
    margin-bottom: 12px !important;
  }

  html body #tarteaucitron [id^="tarteaucitronServicesTitle_"] > ul > li.tarteaucitronLine .tarteaucitronAsk {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    width: 100% !important;
  }

  html body #tarteaucitron [id^="tarteaucitronServicesTitle_"] > ul > li.tarteaucitronLine .tarteaucitronAsk button {
    width: 100% !important;
    text-align: center !important;
    justify-content: center !important;
  }

  html body #tarteaucitron button.tarteaucitron-toggle-group,
  html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder button.tarteaucitron-toggle-group {
    position: static !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    font-size: 12px !important;
    white-space: nowrap !important;
    width: auto !important;
    padding: 4px 0 !important;
    margin-top: 4px !important;
    top: auto !important;
    right: auto !important;
  }

  html body #tarteaucitronRoot #tarteaucitron .tarteaucitronBorder button.tarteaucitron-toggle-group::before {
    content: none !important;
  }

  html body #tarteaucitron [id^="tarteaucitronServices_"] {
    margin: 8px 0 0 8px !important;
    padding: 0 0 0 10px !important;
  }

  html body #tarteaucitron [id^="tarteaucitronServices_"] > li.tarteaucitronLine {
    display: block !important;
    padding: 12px 14px !important;
  }

  html body #tarteaucitron [id^="tarteaucitronServices_"] > li.tarteaucitronLine .tarteaucitronName {
    margin-bottom: 10px !important;
  }

  html body #tarteaucitron [id^="tarteaucitronServices_"] > li.tarteaucitronLine .tarteaucitronAsk {
    display: flex !important;
    gap: 8px !important;
    width: 100% !important;
  }

  html body #tarteaucitron [id^="tarteaucitronServices_"] > li.tarteaucitronLine .tarteaucitronAsk button {
    flex: 1 !important;
    text-align: center !important;
  }
  
  html body #tarteaucitronIcon {
    bottom: 16px !important;
    right: 16px !important;
    width: 48px !important;
    height: 48px !important;
  }
  
  html body #tarteaucitronIcon button::before {
    font-size: 22px !important;
  }
}
