/* ============================================================
   Klaro CMP — G&M Finance brand overrides
   Editorial · Bg #FAFAF7 · Ink #1C1D33 · Terracotta #C2562B · Satoshi
   ============================================================ */

.klaro {
  font-family: var(--font-body, 'Satoshi', system-ui, sans-serif) !important;
  color: var(--ink, #1C1D33) !important;
}

.klaro .cookie-notice,
.klaro .cookie-modal .cm-modal {
  background: var(--bg-card, #FFFFFF) !important;
  color: var(--ink, #1C1D33) !important;
  border-radius: var(--radius-md, 6px) !important;
  border: 1px solid var(--line, rgba(28, 29, 51, 0.08)) !important;
  box-shadow: 0 12px 40px rgba(28, 29, 51, 0.12), 0 2px 8px rgba(28, 29, 51, 0.04) !important;
  font-family: var(--font-body, 'Satoshi', system-ui, sans-serif) !important;
}

/* Bottom notice — compact card */
.klaro .cookie-notice {
  max-width: 520px !important;
  left: 24px !important;
  right: auto !important;
  bottom: 24px !important;
  padding: 24px !important;
}

@media (max-width: 600px) {
  .klaro .cookie-notice {
    left: 12px !important;
    right: 12px !important;
    bottom: 12px !important;
    max-width: none !important;
    padding: 20px !important;
  }
}

/* Heading inside notice */
.klaro .cookie-notice .cn-body h2,
.klaro .cookie-notice .cn-body h1 {
  font-family: var(--font-display, 'Satoshi', sans-serif) !important;
  font-size: 18px !important;
  letter-spacing: -0.015em !important;
  color: var(--ink, #1C1D33) !important;
  margin: 0 0 12px 0 !important;
  font-weight: 600 !important;
  line-height: 1.25 !important;
}

.klaro .cookie-notice .cn-body p,
.klaro .cookie-modal p {
  color: var(--ink-soft, #2C2D43) !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  margin: 0 0 16px 0 !important;
}

.klaro .cookie-notice .cn-body p:last-of-type {
  margin-bottom: 20px !important;
}

/* Links — terracotta with subtle underline */
.klaro .cookie-notice a,
.klaro .cookie-modal a,
.klaro .cm-link {
  color: var(--accent, #C2562B) !important;
  text-decoration: none !important;
  border-bottom: 1px solid currentColor !important;
  transition: color 200ms var(--ease-out, ease) !important;
}

.klaro .cookie-notice a:hover,
.klaro .cookie-modal a:hover,
.klaro .cm-link:hover {
  color: var(--accent-hover, #A2451F) !important;
}

/* Buttons row */
.klaro .cookie-notice .cn-buttons,
.klaro .cookie-modal .cm-footer-buttons {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  align-items: center !important;
}

/* Base button reset */
.klaro .cm-btn {
  padding: 11px 20px !important;
  font-family: var(--font-body, 'Satoshi', system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  letter-spacing: -0.005em !important;
  border-radius: var(--radius-sm, 2px) !important;
  border: 1px solid transparent !important;
  cursor: pointer !important;
  transition: background 200ms var(--ease-out, ease), border-color 200ms var(--ease-out, ease), color 200ms var(--ease-out, ease) !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1.2 !important;
}

/* Accept-all — terracotta */
.klaro .cm-btn.cm-btn-success,
.klaro .cm-btn.cn-ok {
  background: var(--accent, #C2562B) !important;
  color: #FFFFFF !important;
  border-color: var(--accent, #C2562B) !important;
}

.klaro .cm-btn.cm-btn-success:hover,
.klaro .cm-btn.cn-ok:hover {
  background: var(--accent-hover, #A2451F) !important;
  border-color: var(--accent-hover, #A2451F) !important;
}

/* Decline — ghost with ink border */
.klaro .cm-btn.cm-btn-danger,
.klaro .cm-btn.cm-btn-decline {
  background: transparent !important;
  color: var(--ink, #1C1D33) !important;
  border-color: var(--line-strong, rgba(28, 29, 51, 0.16)) !important;
}

.klaro .cm-btn.cm-btn-danger:hover,
.klaro .cm-btn.cm-btn-decline:hover {
  background: var(--bg-alt, #F4EFE8) !important;
  border-color: var(--ink, #1C1D33) !important;
}

/* Info / Learn more / Save selection — quiet tertiary */
.klaro .cm-btn.cm-btn-info,
.klaro .cm-btn.cm-btn-success-var {
  background: transparent !important;
  color: var(--muted, #475569) !important;
  border: none !important;
  padding: 11px 8px !important;
  text-decoration: underline !important;
  text-underline-offset: 4px !important;
  text-decoration-thickness: 1px !important;
}

.klaro .cm-btn.cm-btn-info:hover,
.klaro .cm-btn.cm-btn-success-var:hover {
  color: var(--ink, #1C1D33) !important;
  background: transparent !important;
}

/* Modal */
.klaro .cookie-modal .cm-bg {
  background: rgba(28, 29, 51, 0.55) !important;
  backdrop-filter: blur(2px) !important;
}

.klaro .cookie-modal .cm-modal {
  background: var(--bg, #FAFAF7) !important;
  max-width: 720px !important;
  width: calc(100vw - 32px) !important;
}

.klaro .cookie-modal .cm-modal .cm-header {
  padding: 28px 32px 16px !important;
  border-bottom: 1px solid var(--line, rgba(28, 29, 51, 0.08)) !important;
}

.klaro .cookie-modal .cm-modal .cm-header h1,
.klaro .cookie-modal .cm-modal .cm-header h1.title {
  font-family: var(--font-display, 'Satoshi', sans-serif) !important;
  font-size: 22px !important;
  letter-spacing: -0.02em !important;
  color: var(--ink, #1C1D33) !important;
  font-weight: 600 !important;
  margin: 0 !important;
  line-height: 1.2 !important;
}

.klaro .cookie-modal .cm-modal .cm-body {
  padding: 20px 32px !important;
}

.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Purpose & nested-service rows — remove Klaro's default left-padding-for-switch
   and re-anchor the switch inside the label (small box), so it stays next to the title
   even when the service-detail block below expands. */
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-purpose,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-purpose .cm-services li.cm-service {
  position: static !important;
  padding-left: 0 !important;
  min-height: 0 !important;
}

.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-purpose {
  border-top: 1px solid var(--line, rgba(28, 29, 51, 0.08)) !important;
  padding: 20px 0 !important;
}

.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-purpose:first-child {
  border-top: none !important;
  padding-top: 8px !important;
}

.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-purpose .cm-services li.cm-service,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service {
  padding: 12px 0 !important;
  border-top: 1px dashed var(--line, rgba(28, 29, 51, 0.08)) !important;
  margin-top: 8px !important;
}

/* Label = switch-anchor. Title sits right of switch in same row. */
.klaro .cookie-modal .cm-list-label,
.klaro .cookie-notice .cm-list-label {
  display: block !important;
  position: relative !important;
  padding-left: 60px !important;
  min-height: 28px !important;
  cursor: pointer !important;
}

.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-purpose span.cm-list-title,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service span.cm-list-title {
  font-family: var(--font-body, 'Satoshi', sans-serif) !important;
  font-weight: 600 !important;
  color: var(--ink, #1C1D33) !important;
  font-size: 15px !important;
  display: inline-block !important;
  line-height: 1.4 !important;
  padding-top: 2px !important;
}

/* Description + purposes-meta sit below the label, indented to align with title */
.klaro .cookie-modal .cm-modal .cm-body span.cm-list-description,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-purpose > p,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service > p,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-purpose p.purposes,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service p.purposes {
  color: var(--muted, #475569) !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  margin-top: 6px !important;
  margin-left: 60px !important;
  padding-left: 0 !important;
}

/* Caret link — "↓ 1 Dienst" */
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-purpose .cm-services .cm-caret a {
  color: var(--accent, #C2562B) !important;
  font-size: 13px !important;
  margin-left: 60px !important;
  margin-top: 10px !important;
  display: inline-block !important;
  border-bottom: none !important;
}

/* Switch anchored to the label, not the li — stays put when content below expands */
.klaro .cookie-modal .cm-list-label .cm-switch,
.klaro .cookie-notice .cm-list-label .cm-switch {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  transform: none !important;
  width: 44px !important;
  height: 24px !important;
}

.klaro .cookie-modal .cm-list-label .slider,
.klaro .cookie-notice .cm-list-label .slider {
  background: var(--line-strong, rgba(28, 29, 51, 0.16)) !important;
  width: 44px !important;
  height: 24px !important;
  box-shadow: none !important;
  border-radius: 999px !important;
  transition: background 200ms var(--ease-out, ease) !important;
}

.klaro .cookie-modal .cm-list-label .slider::before,
.klaro .cookie-notice .cm-list-label .slider::before {
  background: #FFFFFF !important;
  width: 18px !important;
  height: 18px !important;
  left: 3px !important;
  bottom: 3px !important;
  border-radius: 50% !important;
  box-shadow: 0 1px 3px rgba(28, 29, 51, 0.2) !important;
  transition: transform 200ms var(--ease-out, ease) !important;
}

.klaro .cookie-modal .cm-list-input:checked + .cm-list-label .slider,
.klaro .cookie-notice .cm-list-input:checked + .cm-list-label .slider {
  background: var(--accent, #C2562B) !important;
}

.klaro .cookie-modal .cm-list-input:checked + .cm-list-label .slider::before,
.klaro .cookie-notice .cm-list-input:checked + .cm-list-label .slider::before {
  transform: translateX(20px) !important;
}

.klaro .cookie-modal .cm-list-input:focus + .cm-list-label .slider,
.klaro .cookie-notice .cm-list-input:focus + .cm-list-label .slider {
  box-shadow: 0 0 0 3px var(--accent-soft, #F1E0D5) !important;
}

/* Footer (modal) */
.klaro .cookie-modal .cm-modal .cm-footer {
  padding: 20px 32px !important;
  border-top: 1px solid var(--line, rgba(28, 29, 51, 0.08)) !important;
  background: var(--bg-alt, #F4EFE8) !important;
}

/* Hide "powered by Klaro" branding */
.klaro .cookie-modal .cm-modal .cm-footer .cm-powered-by,
.klaro .cm-powered-by {
  display: none !important;
}

/* Close icon */
.klaro .cookie-modal .cm-modal .hide,
.klaro .cm-btn-close {
  color: var(--muted, #475569) !important;
  opacity: 0.7 !important;
  transition: opacity 200ms var(--ease-out, ease) !important;
}

.klaro .cookie-modal .cm-modal .hide:hover,
.klaro .cm-btn-close:hover {
  opacity: 1 !important;
  color: var(--ink, #1C1D33) !important;
}

.klaro .cookie-modal .cm-modal .hide svg {
  stroke: currentColor !important;
}

/* Required-tag */
.klaro .cm-required,
.klaro .cm-opt-out {
  font-family: var(--font-body, 'Satoshi', sans-serif) !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  color: var(--muted, #475569) !important;
  letter-spacing: 0.02em !important;
  text-transform: uppercase !important;
  background: var(--bg-alt, #F4EFE8) !important;
  border-radius: 2px !important;
  padding: 2px 6px !important;
  margin-left: 8px !important;
}
