/*
 * Sonnenhof-Theme für Klaro Cookie Consent.
 * Wichtig: das ACSS-Setup setzt root font-size auf 62.5% (1rem = 10px).
 * Klaro-Default-CSS rechnet mit normalen Größen. Daher fixieren wir auf .klaro
 * eine eigene font-size, sodass alle inneren em/rem-Berechnungen lesbar bleiben.
 * Alle Kontraste sind gegen WCAG 2.1 AA (4.5:1 für Text, 3:1 für Large Text) geprüft.
 */

.klaro {
  /* Brand-Tokens */
  --sn-primary: #1e1e1e;
  --sn-secondary: #da7925;
  --sn-secondary-hover: #e08d46;
  --sn-cta: #a45a17;            /* dunkleres Orange für 4.7:1 Kontrast auf weiß-Text */
  --sn-cta-hover: #b56419;
  --sn-link: #8a4a13;            /* noch dunkler für Text-Links: 6.7:1 auf weiß */
  --sn-base-ultra-light: #f7f2ee;
  --sn-base-light: #e6d8cc;
  --sn-base-dark: #553e2a;
  --sn-white: #ffffff;
  --sn-radius: 12px;
  --sn-radius-pill: 999px;
  --sn-space-s: 12px;
  --sn-space-m: 20px;
  --sn-space-l: 28px;
  --sn-font: "Urbanist", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* Absolutwerte, damit ACSS 62.5%-Root nicht alles auf 9.5px schrumpft */
  font-family: var(--sn-font);
  font-size: 16px;
  line-height: 1.55;
  color: var(--sn-primary);
}

/* === Notice (kompaktes Banner unten rechts) === */
.klaro .cookie-notice:not(.cookie-modal-notice) {
  background: var(--sn-base-ultra-light);
  color: var(--sn-primary);
  border-radius: var(--sn-radius);
  box-shadow: 0 12px 48px -8px rgba(34, 25, 17, 0.32), 0 4px 12px -4px rgba(34, 25, 17, 0.12);
  border: 1px solid var(--sn-base-light);
  padding: var(--sn-space-m);
  max-width: 460px;
  margin: 20px;
  font-family: var(--sn-font);
  font-size: 16px;
  line-height: 1.55;
}

.klaro .cookie-notice .cn-body {
  margin: 0;
  padding: 0;
}

.klaro .cookie-notice .cn-body h1,
.klaro .cookie-notice .cn-body h2 {
  font-family: var(--sn-font);
  font-weight: 700;
  font-size: 20px;
  color: var(--sn-primary);
  margin: 0 0 var(--sn-space-s) 0;
  letter-spacing: -0.01em;
  line-height: 1.3;
}

.klaro .cookie-notice .cn-body p {
  margin: 0 0 var(--sn-space-s) 0;
  color: var(--sn-primary);
  font-size: 16px;
  line-height: 1.55;
}

.klaro .cookie-notice .cn-body p.cn-changes {
  display: none;
}

.klaro .cookie-notice .cn-body p a {
  color: var(--sn-link);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  font-weight: 600;
}

.klaro .cookie-notice .cn-body p a:hover,
.klaro .cookie-notice .cn-body p a:focus-visible {
  color: var(--sn-primary);
}

/* === Buttons === */
.klaro .cookie-notice .cn-ok,
.klaro .cn-buttons,
.klaro .cookie-modal .cm-btn-success-wrapper,
.klaro .cookie-modal .cm-footer-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: var(--sn-space-m);
}

.klaro .cn-buttons .cm-btn,
.klaro .cookie-modal .cm-btn {
  font-family: var(--sn-font);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.02em;
  text-transform: none;
  padding: 12px 22px;
  border-radius: var(--sn-radius-pill);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
  line-height: 1.2;
  white-space: nowrap;
}

.klaro .cn-buttons .cm-btn:focus-visible,
.klaro .cookie-modal .cm-btn:focus-visible {
  outline: 2px solid var(--sn-cta);
  outline-offset: 3px;
}

/* Accept-Button: dunkleres Orange für WCAG-AA Kontrast 4.7:1 weiß auf #a45a17 */
.klaro .cn-buttons .cm-btn.cm-btn-success,
.klaro .cn-buttons .cm-btn.cm-btn-accept-all,
.klaro .cookie-modal .cm-btn.cm-btn-success,
.klaro .cookie-modal .cm-btn.cm-btn-accept-all {
  background: var(--sn-cta);
  color: var(--sn-white);
  border-color: var(--sn-cta);
}

.klaro .cn-buttons .cm-btn.cm-btn-success:hover,
.klaro .cn-buttons .cm-btn.cm-btn-accept-all:hover,
.klaro .cookie-modal .cm-btn.cm-btn-success:hover,
.klaro .cookie-modal .cm-btn.cm-btn-accept-all:hover {
  background: var(--sn-cta-hover);
  border-color: var(--sn-cta-hover);
}

/* Decline-Button: Outline, dark primary on white */
.klaro .cn-buttons .cm-btn.cn-decline,
.klaro .cn-buttons .cm-btn.cm-btn-decline,
.klaro .cookie-modal .cm-btn.cm-btn-decline {
  background: var(--sn-white);
  color: var(--sn-primary);
  border-color: var(--sn-primary);
}

.klaro .cn-buttons .cm-btn.cn-decline:hover,
.klaro .cn-buttons .cm-btn.cm-btn-decline:hover,
.klaro .cookie-modal .cm-btn.cm-btn-decline:hover {
  background: var(--sn-primary);
  color: var(--sn-white);
  border-color: var(--sn-primary);
}

/* Learn-More link */
.klaro .cookie-notice .cn-learn-more,
.klaro .cn-buttons .cm-btn.cn-learn-more {
  background: transparent;
  color: var(--sn-link);
  border: none;
  padding: 12px 4px;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1px;
  font-weight: 600;
  font-size: 15px;
}

.klaro .cookie-notice .cn-learn-more:hover,
.klaro .cookie-notice .cn-learn-more:focus-visible {
  color: var(--sn-primary);
}

/* === Modal (Detail-Ansicht) === */
.klaro .cookie-modal .cm-bg {
  background: rgba(34, 25, 17, 0.55);
  backdrop-filter: blur(2px);
}

.klaro .cookie-modal .cm-modal {
  background: var(--sn-white);
  color: var(--sn-primary);
  border-radius: var(--sn-radius);
  font-family: var(--sn-font);
  font-size: 16px;
  padding: 0;
  max-width: 720px;
  border: 1px solid var(--sn-base-light);
  box-shadow: 0 24px 64px -12px rgba(34, 25, 17, 0.4);
}

.klaro .cookie-modal .cm-header {
  background: var(--sn-base-ultra-light);
  padding: var(--sn-space-m) var(--sn-space-l);
  border-bottom: 1px solid var(--sn-base-light);
  border-radius: var(--sn-radius) var(--sn-radius) 0 0;
}

.klaro .cookie-modal .cm-header h1 {
  font-family: var(--sn-font);
  font-weight: 700;
  font-size: 24px;
  color: var(--sn-primary);
  margin: 0;
  line-height: 1.2;
}

.klaro .cookie-modal .cm-body {
  padding: var(--sn-space-l);
}

.klaro .cookie-modal .cm-body p,
.klaro .cookie-modal .cm-header p,
.klaro .cookie-modal .cm-header p span {
  color: var(--sn-primary) !important;
  font-size: 16px;
  line-height: 1.55;
  margin: 0 0 var(--sn-space-s) 0;
}

/* Alle Inline-Links im Modal (Datenschutz-Link im Header, sonstige Verweise) */
.klaro .cookie-modal a,
.klaro .cookie-modal .cm-header a,
.klaro .cookie-modal .cm-body a {
  color: var(--sn-link) !important;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  font-weight: 600;
}

.klaro .cookie-modal a:hover,
.klaro .cookie-modal a:focus-visible {
  color: var(--sn-primary) !important;
}

/* Caret-Toggle: separater Selektor unten überschreibt nur Button-Style */
.klaro .cookie-modal .cm-caret > a {
  text-decoration: none;
}

/* Service- und Purpose-Titel + Beschreibungen */
.klaro .cookie-modal .cm-list-title,
.klaro .cookie-modal .cm-list-description,
.klaro .cookie-modal .cm-services li.cm-service .cm-list-title,
.klaro .cookie-modal .cm-services li.cm-service .cm-list-description,
.klaro .cookie-modal .cm-purpose .cm-list-title,
.klaro .cookie-modal .cm-purpose .cm-list-description {
  color: var(--sn-primary) !important;
}

.klaro .cookie-modal .cm-body ul.cm-services,
.klaro .cookie-modal .cm-body ul.cm-purposes,
.klaro .cookie-modal .cm-body ul.cm-content {
  padding: 0;
  margin: var(--sn-space-m) 0;
  list-style: none;
}

.klaro .cookie-modal .cm-services li.cm-service,
.klaro .cookie-modal .cm-purposes li.cm-purpose {
  background: var(--sn-white);
  border: 1px solid var(--sn-base-light);
  border-radius: 8px;
  padding: var(--sn-space-s) var(--sn-space-m);
  margin-bottom: 10px;
  color: var(--sn-primary);
}

/* Nested cm-services (Service-Liste unter einem Purpose) */
.klaro .cookie-modal .cm-purpose .cm-services {
  background: var(--sn-base-ultra-light);
  border-radius: 8px;
  padding: var(--sn-space-s);
  margin-top: var(--sn-space-s);
}

.klaro .cookie-modal .cm-purpose .cm-services .cm-service {
  background: var(--sn-white);
}

/* Caret-Toggle "1 Dienst ↓" Link */
.klaro .cookie-modal .cm-caret > a {
  color: var(--sn-link) !important;
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 0;
}

.klaro .cookie-modal .cm-caret > a:hover,
.klaro .cookie-modal .cm-caret > a:focus-visible {
  color: var(--sn-primary) !important;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.klaro .cookie-modal .cm-caret > a span {
  color: inherit !important;
  display: inline-block;
  transition: transform 0.2s ease;
}

.klaro .cookie-modal .cm-caret > a[aria-expanded="true"] span {
  transform: rotate(180deg);
}

.klaro .cookie-modal .cm-services li.cm-service .cm-content {
  margin: 0;
}

.klaro .cookie-modal .cm-services li.cm-service p.purposes,
.klaro .cookie-modal .cm-service .purposes,
.klaro .cookie-modal p.purposes {
  color: var(--sn-base-dark) !important;
  font-size: 14px;
  margin-top: 6px;
  margin-bottom: 0;
}

.klaro .cookie-modal .cm-services li.cm-service .cm-list-title {
  font-weight: 600;
  font-size: 16px;
  color: var(--sn-primary);
}

.klaro .cookie-modal .cm-services li.cm-service .cm-list-description {
  font-size: 14px;
  color: var(--sn-primary);
  margin-top: 6px;
}

.klaro .cookie-modal .cm-footer {
  padding: var(--sn-space-m) var(--sn-space-l);
  border-top: 1px solid var(--sn-base-light);
  background: var(--sn-base-ultra-light);
  border-radius: 0 0 var(--sn-radius) var(--sn-radius);
}

.klaro .cookie-modal .cm-footer .cm-powered-by {
  display: none;
}

/* === Switches === */
.klaro .cm-list-input + .cm-list-label .slider {
  background: var(--sn-base-light);
}

.klaro .cm-list-input:checked + .cm-list-label .slider {
  background: var(--sn-cta);
}

.klaro .cm-list-input:focus-visible + .cm-list-label .slider {
  outline: 2px solid var(--sn-cta);
  outline-offset: 2px;
}

.klaro .cm-list-title .cm-required {
  color: var(--sn-base-dark);
  font-size: 12px;
  font-weight: 600;
  margin-left: 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* === Mobile === */
@media (max-width: 640px) {
  .klaro .cookie-notice:not(.cookie-modal-notice) {
    margin: 10px;
    padding: var(--sn-space-m);
    max-width: none;
  }
  .klaro .cookie-notice .cn-body h1,
  .klaro .cookie-notice .cn-body h2 {
    font-size: 18px;
  }
  .klaro .cn-buttons .cm-btn,
  .klaro .cookie-modal .cm-btn {
    flex: 1 1 auto;
    padding: 14px 20px;
    font-size: 15px;
  }
  .klaro .cookie-modal .cm-modal {
    margin: 12px;
    max-width: calc(100vw - 24px);
  }
  .klaro .cookie-modal .cm-body,
  .klaro .cookie-modal .cm-header,
  .klaro .cookie-modal .cm-footer {
    padding: var(--sn-space-m);
  }
}
