/**
 * Key AI — Cookiebot consent UI
 * Compact · .key-cb-details-open · .key-cb-expanded (About only)
 */

/* ── Shell (override Cookiebot min-width: 100vw) ── */
#CybotCookiebotDialog,
#CybotCookiebotDialog.CybotEdge,
#CybotCookiebotDialog.CybotMultilevel,
#CybotCookiebotDialog.CybotCookiebotDialogActive {
  font-family: 'Inter Variable', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
  color: #0a0a0a !important;
  background: #ffffff !important;
  border: 1px solid #e0e0de !important;
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.14),
    0 0 0 1px rgba(255, 255, 255, 0.85) inset !important;
  -webkit-font-smoothing: antialiased !important;
  box-sizing: border-box !important;
  height: fit-content !important;
  min-height: 0 !important;
  min-width: 0 !important;
  z-index: 2147483646 !important;
  position: fixed !important;
  left: 50% !important;
  right: auto !important;
  top: auto !important;
  transform: translateX(-50%) !important;
  margin: 0 !important;
  bottom: max(12px, env(safe-area-inset-bottom, 0px)) !important;
  width: min(920px, calc(100vw - 32px)) !important;
  max-width: min(920px, calc(100vw - 32px)) !important;
}

#CybotCookiebotDialogHeader,
#CybotCookiebotDialogHeaderLogosWrapper,
#CybotCookiebotDialogPoweredbyCybot,
#CybotCookiebotDialogPoweredbyLink,
#CybotCookiebotDialog #CybotCookiebotDialogPoweredbyImage {
  display: none !important;
}

/* ═══════════════════════════════════════
   COMPACT — one layout, no grid overlap
   Structure (JS): TabContent | .key-cb-aside
     .key-cb-aside: .key-cb-actions + .key-cb-details-row
   ═══════════════════════════════════════ */
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) {
  border-radius: 24px !important;
}

#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .CybotCookiebotDialogContentWrapper {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 0 !important;
  padding: 16px 22px 14px !important;
  width: 100% !important;
  height: auto !important;
}

@media (min-width: 720px) {
  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .CybotCookiebotDialogContentWrapper {
    flex-direction: row !important;
    align-items: flex-start !important;
    gap: 28px !important;
    padding: 18px 24px 16px !important;
  }
}

#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogTabContent {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  width: 100% !important;
  order: 1 !important;
}

#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-aside {
  flex: 0 0 auto !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 8px !important;
  order: 2 !important;
  width: 100% !important;
}

@media (min-width: 720px) {
  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-aside {
    align-items: flex-end !important;
    width: auto !important;
    min-width: 220px !important;
    margin-top: 2px !important;
  }
}

/* Hide non-consent chrome */
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogNav,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogDetailPanel,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .CybotCookiebotDialogDetailBody,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBodyLevelWrapper,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBodyLevelButtonsTable,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .CybotCookiebotDialogBodyLevelButtonsSelectPane,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .CybotCookiebotDialogBodyLevelButtonWrapper.CybotCookiebotDialogBodyContentControlsWrapper,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBody .CybotCookiebotDialogBodyBottomWrapper,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) [class*='LevelOptinPrivacy'],
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .CybotCookiebotDialogBodyLevelButtonLevelOptinPrivacy,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBodyContent > *:not(#CybotCookiebotDialogBodyContentTitle):not(#CybotCookiebotDialogBodyContentText),
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBodyLevelButtonLevelOptinAllowallSelection {
  display: none !important;
}

#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBody {
  padding: 0 !important;
  margin: 0 !important;
}

#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBodyContentTitle,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBodyContentTitle h2 {
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.3 !important;
  margin: 0 0 6px !important;
  color: #0a0a0a !important;
}

#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBodyContentText,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBodyContentText p {
  font-size: 13px !important;
  line-height: 1.5 !important;
  color: #525252 !important;
  margin: 0 !important;
  max-width: 100% !important;
}

/* Message: no clamp on desktop so copy isn't crushed beside actions */
@media (min-width: 720px) {
  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBodyContentText,
  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBodyContentText p {
    display: block !important;
    overflow: visible !important;
    -webkit-line-clamp: unset !important;
  }
}

/* Actions row: Deny then Allow all */
#CybotCookiebotDialog .key-cb-actions {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-actions #CybotCookiebotDialogFooter,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-actions #CybotCookiebotDialogBodyLevelButtons {
  display: flex !important;
  flex: 0 0 auto !important;
  flex-direction: row !important;
  align-items: center !important;
  position: static !important;
  inset: auto !important;
  width: auto !important;
  min-width: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: none !important;
}

#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-actions #CybotCookiebotDialogFooter .CybotCookiebotScrollArea,
#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-actions #CybotCookiebotDialogBodyButtons {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

#CybotCookiebotDialogBodyButtonDecline,
#CybotCookiebotDialogBodyLevelButtonLevelOptinDeclineAll {
  order: 1 !important;
}

#CybotCookiebotDialogBodyLevelButtonLevelOptinAllowAll,
#CybotCookiebotDialogBodyButtonAccept {
  order: 2 !important;
}

/* Show details — under buttons, right-aligned on desktop */
#CybotCookiebotDialog .key-cb-details-row {
  display: flex !important;
  justify-content: center !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

@media (min-width: 720px) {
  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-details-row {
    justify-content: flex-end !important;
    width: auto !important;
  }
}

#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-details-row a {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #525252 !important;
  text-decoration: none !important;
}

#CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-details-row a:hover {
  color: #0a0a0a !important;
}

#CybotCookiebotDialog.key-cb-details-open .key-cb-aside,
#CybotCookiebotDialog.key-cb-expanded .key-cb-aside,
#CybotCookiebotDialog.key-cb-details-open .key-cb-details-row,
#CybotCookiebotDialog.key-cb-expanded .key-cb-details-row {
  display: none !important;
}

/* ═══════════════════════════════════════
   DETAILS OPEN
   ═══════════════════════════════════════ */
#CybotCookiebotDialog.key-cb-details-open:not(.key-cb-expanded) {
  border-radius: 20px !important;
  width: min(640px, calc(100vw - 24px)) !important;
  max-width: min(640px, calc(100vw - 24px)) !important;
  max-height: min(52vh, 420px) !important;
  overflow: hidden !important;
}

#CybotCookiebotDialog.key-cb-details-open .CybotCookiebotDialogContentWrapper {
  display: flex !important;
  flex-direction: column !important;
  padding: 0 !important;
  max-height: min(52vh, 420px) !important;
  overflow: hidden !important;
}

#CybotCookiebotDialog.key-cb-details-open #CybotCookiebotDialogNav {
  display: none !important;
}

#CybotCookiebotDialog.key-cb-details-open #CybotCookiebotDialogBodyContentTitle,
#CybotCookiebotDialog.key-cb-details-open #CybotCookiebotDialogBodyContentText {
  display: none !important;
}

#CybotCookiebotDialog.key-cb-details-open #CybotCookiebotDialogTabContent {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow-y: auto !important;
}

#CybotCookiebotDialog.key-cb-details-open #CybotCookiebotDialogFooter {
  position: relative !important;
  padding: 10px 14px 12px !important;
  border-top: 1px solid #e0e0de !important;
  background: #fff !important;
  width: 100% !important;
}

#CybotCookiebotDialog.key-cb-details-open #CybotCookiebotDialogFooter .CybotCookiebotScrollArea,
#CybotCookiebotDialog.key-cb-details-open #CybotCookiebotDialogBodyButtons,
#CybotCookiebotDialog.key-cb-details-open #CybotCookiebotDialogBodyLevelButtons,
#CybotCookiebotDialog.key-cb-details-open #CybotCookiebotDialogBodyLevelButtonsWrapper {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  width: 100% !important;
}

#CybotCookiebotDialog.key-cb-details-open #CybotCookiebotDialogBodyLevelButtonLevelOptinAllowallSelection {
  display: inline-flex !important;
}

#CybotCookiebotDialog.key-cb-details-open .CybotCookiebotDialogBodyContentControlsWrapper {
  flex: 1 1 100% !important;
  order: -1 !important;
}

/* ═══════════════════════════════════════
   EXPANDED (About)
   ═══════════════════════════════════════ */
#CybotCookiebotDialog.key-cb-expanded {
  border-radius: 20px !important;
  width: min(640px, calc(100vw - 24px)) !important;
  max-width: min(640px, calc(100vw - 24px)) !important;
  max-height: min(60vh, 480px) !important;
  overflow: hidden !important;
}

#CybotCookiebotDialog.key-cb-expanded .CybotCookiebotDialogContentWrapper {
  display: flex !important;
  flex-direction: column !important;
  padding: 0 !important;
  max-height: min(60vh, 480px) !important;
  overflow-y: auto !important;
}

#CybotCookiebotDialog.key-cb-expanded #CybotCookiebotDialogNav {
  display: flex !important;
  padding: 8px 12px 0 !important;
  border-bottom: 1px solid #e0e0de !important;
}

#CybotCookiebotDialog.key-cb-expanded #CybotCookiebotDialogFooter {
  position: relative !important;
  padding: 10px 14px 12px !important;
  border-top: 1px solid #e0e0de !important;
  width: 100% !important;
}

/* ── Buttons ── */
#CybotCookiebotDialog button,
#CybotCookiebotDialog input[type='button'] {
  font-family: inherit !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  border-radius: 100px !important;
  padding: 8px 20px !important;
  min-height: 36px !important;
  margin: 0 !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  flex: 0 0 auto !important;
}

#CybotCookiebotDialogBodyLevelButtonLevelOptinAllowAll,
#CybotCookiebotDialogBodyButtonAccept {
  background: #0a0a0a !important;
  color: #fff !important;
  border: none !important;
}

#CybotCookiebotDialogBodyLevelButtonLevelOptinDeclineAll,
#CybotCookiebotDialogBodyButtonDecline {
  background: #fff !important;
  color: #525252 !important;
  border: 1px solid #cacac8 !important;
}

#CybotCookiebotDialogBodyLevelButtonLevelOptinAllowallSelection {
  background: #f4f4f2 !important;
  color: #0a0a0a !important;
  border: 1px solid #e0e0de !important;
}

#CybotCookiebotDialog .CybotCookiebotDialogBodyLevelButtonSlider {
  background-color: #e0e0de !important;
}

#CybotCookiebotDialog input:checked + .CybotCookiebotDialogBodyLevelButtonSlider {
  background-color: #0a0a0a !important;
}

#CybotCookiebotDialogBodyContentText a {
  color: #0a0a0a !important;
  font-weight: 600 !important;
}

#CybotCookiebotDialogBodyUnderlay {
  background: rgba(10, 10, 10, 0.28) !important;
  backdrop-filter: blur(4px) !important;
}

/* ── Mobile compact ── */
@media (max-width: 719px) {
  #CybotCookiebotDialog,
  #CybotCookiebotDialog.CybotEdge {
    width: calc(100vw - 16px) !important;
    max-width: calc(100vw - 16px) !important;
  }

  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) {
    border-radius: 20px !important;
  }

  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .CybotCookiebotDialogContentWrapper {
    padding: 14px 16px 12px !important;
  }

  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBodyContentText,
  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) #CybotCookiebotDialogBodyContentText p {
    display: block !important;
    overflow: visible !important;
    -webkit-line-clamp: unset !important;
  }

  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-aside {
    align-items: stretch !important;
    gap: 6px !important;
  }

  /* Full-width Deny | Allow row (flatten Cookiebot wrappers) */
  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-actions {
    justify-content: stretch !important;
    margin-top: 12px !important;
    padding-top: 12px !important;
    border-top: 1px solid #e0e0de !important;
  }

  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-actions #CybotCookiebotDialogFooter,
  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-actions #CybotCookiebotDialogBodyLevelButtons,
  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-actions #CybotCookiebotDialogFooter .CybotCookiebotScrollArea,
  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-actions #CybotCookiebotDialogBodyButtons {
    display: contents !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-actions button {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    min-height: 44px !important;
  }

  #CybotCookiebotDialog:not(.key-cb-details-open):not(.key-cb-expanded) .key-cb-details-row {
    justify-content: center !important;
    margin-top: 2px !important;
  }

  #CybotCookiebotDialog.key-cb-details-open:not(.key-cb-expanded),
  #CybotCookiebotDialog.key-cb-expanded {
    width: calc(100vw - 12px) !important;
    max-width: calc(100vw - 12px) !important;
  }
}
