/* ===== Klaro Cookie Consent Overrides ===== */

.klaro {
  font-family: var(--font-family-sans) !important;
}

/* Hide branding + purpose labels */
.klaro .cm-powered-by,
.klaro .cm-purposes,
.klaro .cookie-modal .cm-purpose .cm-purposes,
.klaro .cookie-modal .cm-service .cm-purposes {
  display: none !important;
}

/* Backdrop */
.klaro .cookie-notice .cm-bg,
.klaro .cookie-modal .cm-bg {
  background-color: rgba(0, 0, 0, 0.4) !important;
  backdrop-filter: blur(4px) !important;
}

/* Shared Button Style – DSGVO: alle Buttons gleich */
.klaro .cm-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 9999px !important;
  padding: 0.625rem 1.25rem !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  transition: all 0.15s ease !important;
  cursor: pointer !important;
  text-decoration: none !important;
  background-color: var(--color-cedar) !important;
  color: #ffffff !important;
  border: none !important;
}

.klaro .cm-btn:hover {
  background-color: var(--color-rifle-green) !important;
}

/* "Einstellungen" Link → auch als Button */
.klaro .cm-link.cn-learn-more,
.klaro .ccn-modal-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 9999px !important;
  padding: 0.625rem 1.25rem !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  transition: all 0.15s ease !important;
  cursor: pointer !important;
  text-decoration: none !important;
  background-color: var(--color-cedar) !important;
  color: #ffffff !important;
  border: none !important;
}

.klaro .cm-link.cn-learn-more:hover,
.klaro .ccn-modal-link:hover {
  background-color: var(--color-rifle-green) !important;
  text-decoration: none !important;
}

/* === COOKIE NOTICE (zentriert) === */

.klaro .cookie-notice:not(.cookie-modal-notice) {
  position: fixed !important;
  bottom: auto !important;
  right: auto !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  z-index: 999 !important;
}

.klaro .cookie-notice {
  background-color: #ffffff !important;
  border-radius: 1.25rem !important;
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.15) !important;
  border: 1px solid var(--color-kangaroo) !important;
  padding: 2rem 2rem !important;
  max-width: 620px !important;
  width: calc(100vw - 2rem) !important;
  text-align: center !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

/* Logo oben */
.klaro .cookie-notice::before {
  content: '' !important;
  display: block !important;
  width: 48px !important;
  height: 48px !important;
  margin: 0 auto 0.5rem !important;
  background: url('/images/Baum-Gruenanlagenpflege-Ritter-Logo.webp') no-repeat center / contain !important;
  order: 0 !important;
}

.klaro .cookie-notice .cn-body,
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body {
  padding: 0 !important;
  margin: 0 0 1.25rem 0 !important;
  order: 1 !important;
  width: 100% !important;
}

.klaro .cookie-notice .cn-body p {
  color: var(--color-cedar) !important;
  font-size: 0.875rem !important;
  line-height: 1.6 !important;
  margin: 0 0 1.25rem 0 !important;
  text-align: center !important;
}

/* Button-Container */
.klaro .cookie-notice .cn-ok,
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-ok {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.5rem !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  flex-wrap: nowrap !important;
}

@media (min-width: 640px) {
  .klaro .cookie-notice .cn-ok,
  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-ok {
    flex-direction: row !important;
  }
}

.klaro .cookie-notice .cn-buttons,
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons {
  display: contents !important;
}

/* Reihenfolge: Alle akzeptieren → Einstellungen → Nur notwendige */
.klaro .cookie-notice .cm-btn.cm-btn-success { order: 1 !important; }
.klaro .cookie-notice .cm-link.cn-learn-more { order: 2 !important; }
.klaro .cookie-notice .cm-btn.cm-btn-danger,
.klaro .cookie-notice .cn-decline { order: 3 !important; }

/* Alle Buttons gleich breit */
.klaro .cookie-notice .cn-ok > *,
.klaro .cookie-notice .cn-ok .cn-buttons > * {
  flex: 1 1 0% !important;
  min-width: 0 !important;
  width: 100% !important;
  box-sizing: border-box !important;
  text-align: center !important;
  white-space: nowrap !important;
  margin: 0 !important;
  padding: 0.625rem 0.5rem !important;
}

/* Datenschutz-Link unten */
.klaro .cookie-notice .cn-privacy-link {
  display: block !important;
  margin-top: 1rem !important;
  font-size: 0.8125rem !important;
  color: var(--color-oyster) !important;
  text-decoration: underline !important;
  text-align: center !important;
  order: 10 !important;
  background: none !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 0 !important;
}

.klaro .cookie-notice .cn-privacy-link:hover {
  color: var(--color-cedar) !important;
  background: none !important;
}

/* === CONSENT MODAL (Detail) === */

.klaro .cookie-modal .cm-modal.cm-klaro {
  background-color: #ffffff !important;
  border-radius: 1.25rem !important;
  color: var(--color-cedar) !important;
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.15) !important;
  border: 1px solid var(--color-kangaroo) !important;
  max-width: 640px !important;
  overflow: hidden !important;
  max-height: 90vh !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Header */
.klaro .cookie-modal .cm-header {
  padding: 1rem 1.5rem 0.75rem !important;
  border-bottom: 1px solid var(--color-kangaroo) !important;
  background: transparent !important;
  text-align: center !important;
  flex-shrink: 0 !important;
}

.klaro .cookie-modal .cm-header::before {
  content: '' !important;
  display: block !important;
  width: 36px !important;
  height: 36px !important;
  margin: 0 auto 0.5rem !important;
  background: url('/images/Baum-Gruenanlagenpflege-Ritter-Logo.webp') no-repeat center / contain !important;
}

@media (max-height: 700px) {
  .klaro .cookie-modal .cm-header::before {
    display: none !important;
  }
}

.klaro .cookie-modal .cm-header h1,
.klaro .cookie-modal .cm-header h1.title {
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  color: var(--color-cedar) !important;
  margin: 0 !important;
  line-height: 1.3 !important;
  text-align: center !important;
  font-family: var(--font-family-sans) !important;
}

.klaro .cookie-modal .cm-header .hide {
  color: var(--color-oyster) !important;
  font-size: 1.25rem !important;
}

.klaro .cookie-modal .cm-header .hide:hover {
  color: var(--color-cedar) !important;
}

/* Body */
.klaro .cookie-modal .cm-body {
  padding: 1rem 1.5rem !important;
  overflow-y: auto !important;
  flex: 1 !important;
  min-height: 0 !important;
}

.klaro .cookie-modal .cm-body p,
.klaro .cookie-modal .cm-body .cm-content p {
  color: var(--color-oyster) !important;
  font-size: 0.875rem !important;
  line-height: 1.6 !important;
  margin-bottom: 0.75rem !important;
  text-align: center !important;
}

/* Services */
.klaro .cookie-modal .cm-services,
.klaro .cookie-modal .cm-purpose {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}

.klaro .cookie-modal .cm-service {
  padding: 0.625rem 0 !important;
  border-bottom: 1px solid var(--color-kangaroo) !important;
  overflow: visible !important;
}

.klaro .cookie-modal .cm-service:last-child {
  border-bottom: none !important;
}

.klaro .cookie-modal .cm-service .cm-list-label {
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.75rem !important;
  padding-left: 0 !important;
  margin-left: 0 !important;
  overflow: visible !important;
}

.klaro .cookie-modal .cm-switch {
  flex-shrink: 0 !important;
  width: 40px !important;
  min-width: 40px !important;
  position: relative !important;
}

.klaro .cookie-modal .cm-service .cm-list-label > span:not(.cm-switch) {
  flex: 1 !important;
  min-width: 0 !important;
}

.klaro .cookie-modal .cm-list-title {
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  color: var(--color-cedar) !important;
  display: inline !important;
}

.klaro .cookie-modal .cm-required {
  font-size: 0.75rem !important;
  color: var(--color-oyster) !important;
  font-weight: 400 !important;
}

.klaro .cookie-modal .cm-list-description {
  font-size: 0.8125rem !important;
  color: var(--color-oyster) !important;
  line-height: 1.5 !important;
  margin-top: 0.25rem !important;
  display: block !important;
}

/* Toggle: Aus → Grau */
.klaro .cookie-modal .cm-list-label .slider,
.klaro .cookie-modal .cm-list-label .slider.round.active {
  background-color: #d1d5db !important;
}

/* Toggle: An → Oyster */
.klaro .cookie-modal .cm-list-input:checked + .cm-list-label .slider {
  background-color: var(--color-oyster) !important;
}

/* Toggle: Required + An */
.klaro .cookie-modal .cm-list-input.required:checked + .cm-list-label .slider {
  background-color: var(--color-oyster) !important;
  opacity: 0.8 !important;
  cursor: not-allowed !important;
}

/* Toggle-Labels */
.klaro .cookie-modal .cm-list-label .slider::after {
  content: 'Aus' !important;
  position: absolute !important;
  right: 5px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 0.625rem !important;
  font-weight: 600 !important;
  color: #6b7280 !important;
  line-height: 1 !important;
  pointer-events: none !important;
}

.klaro .cookie-modal .cm-list-input:checked + .cm-list-label .slider::after {
  content: 'An' !important;
  left: 7px !important;
  right: auto !important;
  color: #ffffff !important;
}

/* Expand links */
.klaro .cookie-modal .cm-caret a {
  color: var(--color-oyster) !important;
  font-size: 0.8125rem !important;
}

/* Toggle all */
.klaro .cookie-modal .cm-toggle-all {
  border-top: 1px solid var(--color-kangaroo) !important;
  padding-top: 0.75rem !important;
  margin-top: 0.5rem !important;
}

/* Footer */
.klaro .cookie-modal .cm-footer {
  padding: 0.75rem 1.5rem !important;
  border-top: 1px solid var(--color-kangaroo) !important;
  background-color: var(--color-merino) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  flex-shrink: 0 !important;
}

.klaro .cookie-modal .cm-footer-buttons {
  display: flex !important;
  gap: 0.5rem !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  width: 100% !important;
}

/* Button-Reihenfolge Modal */
.klaro .cookie-modal .cm-btn-accept-all { order: 1 !important; }
.klaro .cookie-modal .cm-btn-accept { order: 2 !important; }
.klaro .cookie-modal .cm-btn-decline { order: 3 !important; }

/* Datenschutz-Link im Modal */
.klaro .cookie-modal .cm-footer .cm-privacy-link {
  display: block !important;
  margin-top: 0.75rem !important;
  font-size: 0.8125rem !important;
  color: var(--color-oyster) !important;
  text-decoration: underline !important;
  text-align: center !important;
  background: none !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 0 !important;
}

.klaro .cookie-modal .cm-footer .cm-privacy-link:hover {
  color: var(--color-cedar) !important;
  background: none !important;
}
