:root{
  --font-size: 14px;
  --border-radius: 0;
  --btn-primary-bg: #333; /* navy dark */
  --btn-primary-color: #fff;
  --btn-secondary-bg: #f9f7f4 ;; /* grey */
  --btn-secondary-color: #333;
  --surface-bg: #f9f7f4 ; /* dark surface */
  --surface-fg: #333;
  --surface-shadow: 0 10px 20px rgba(50,50,50,0.3);
  --surface-radius: 0;
  --link-green: #333;
}

/* Buttons */
.klaro .cm-btn,
.klaro .cm-btn-accept-all,
.klaro .cm-btn-accept,
.klaro .cm-btn-decline,
.klaro .cm-btn-success,
.klaro .cm-btn-danger{
  border-radius: var(--border-radius) !important;
  padding: 10px 18px !important;
  font-weight: 600 !important;
}

.klaro .cm-btn-accept-all,
.klaro .cm-btn-success{
  background: var(--btn-primary-bg) !important;
  color: var(--btn-primary-color) !important;
  border: none !important;
}

.klaro .cm-btn-decline,
.klaro .cm-btn-secondary,
.klaro .cm-btn-danger{
  background: var(--btn-secondary-bg) !important;
  color: var(--btn-secondary-color) !important;
  border: 1.5px solid var(--btn-secondary-color) !important;
}

/* Modal */
.klaro .cm-modal{
  border-radius: var(--surface-radius) !important;
  background: var(--surface-bg) !important;
  box-shadow: var(--surface-shadow) !important;
  color: var(--surface-fg) !important;
}

.klaro,
.klaro .cookie-notice,
.klaro .context-notice {
  z-index: 10000 !important;
}

.klaro .cookie-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 10000 !important;
}

.klaro .cookie-modal .cm-modal {
  position: relative !important;
  z-index: 10001 !important;
}

.klaro .cm-modal .cm-purposes,
.klaro .cm-modal .cm-list{
  margin-top: 8px !important;
}

.klaro .cm-modal .cm-purpose .cm-purpose-title{
  font-weight: 700 !important;
}

/* Notice (bottom bar) */
.klaro .context-notice,
.klaro .cookie-notice {
  border-radius: var(--surface-radius) !important;
  background: var(--surface-bg) !important;
  box-shadow: var(--surface-shadow) !important;
  padding: 14px 16px !important;
  color: var(--surface-fg) !important;
}

.klaro .cookie-modal p, .klaro .cookie-modal strong, .klaro .cookie-modal h1, .klaro .cookie-modal h2, .klaro .cookie-modal ul, .klaro .cookie-modal li, .klaro .context-notice p, .klaro .context-notice strong, .klaro .context-notice h1, .klaro .context-notice h2, .klaro .context-notice ul, .klaro .context-notice li, .klaro .cookie-notice p, .klaro .cookie-notice strong, .klaro .cookie-notice h1, .klaro .cookie-notice h2, .klaro .cookie-notice ul, .klaro .cookie-notice li {
    
    color: var(--surface-fg) !important;
}

/* Notice (bottom bar) */
#id-cookie-notice {
  color: var(--surface-fg) !important;
}
.klaro .cm-powered-by {
    color: var(--surface-bg) !important;
}

/* Make the primary button slightly larger prominence */
.klaro .cm-btn-accept-all{
  padding: 12px 20px !important;
}




.klaro .cm-switch .slider{
  border-radius: 50px !important;
  
    background-color: var(--surface-fg, #333);
    opacity: .8;
}
.klaro .cm-switch .slider:before{
  border-radius: 50px !important;
}

.klaro .cookie-modal .cm-list-input:checked+.cm-list-label .slider, .klaro .context-notice .cm-list-input:checked+.cm-list-label .slider, .klaro .cookie-notice .cm-list-input:checked+.cm-list-label .slider {
    background-color: var(--surface-fg, #333)!important ;

}

/* Link in notice/modal ("Lassen Sie mich wählen") */
.klaro .cookie-notice a,
.klaro .context-notice a,
.klaro .cm-modal a{
  color: var(--link-green) !important;
  font-weight: 600 !important;
}

/* ── Mobile scroll-lock: prevent page scroll while banner/modal is open ── */
body.klaro-open {
  overflow: hidden !important;
  position: fixed !important;
  width: 100% !important;
  touch-action: none !important;
}

/* ── Compact mobile bottom sheet: keep shop and choice buttons visible ── */
@media (max-width: 767px) {
  .klaro .cookie-notice,
  .klaro .context-notice {
    --klaro-mobile-content-width: min(320px, calc(100vw - 40px));
  }

  body.klaro-open::before {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9990;
    pointer-events: none;
  }

  .klaro .cookie-notice,
  .klaro .context-notice {
    position: fixed !important;
    top: auto !important;
    right: 0 !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 100vw !important;
    min-width: 0 !important;
    max-width: 100vw !important;
    max-height: min(68dvh, calc(100dvh - 96px)) !important;
    box-sizing: border-box !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
    border-radius: 14px 14px 0 0 !important;
    padding: 26px 20px calc(18px + env(safe-area-inset-bottom)) !important;
    z-index: 9999 !important;
  }

  .klaro .cookie-notice *,
  .klaro .context-notice * {
    box-sizing: border-box !important;
    max-width: 100% !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
  }

  .klaro .cookie-notice .cn-body,
  .klaro .context-notice .cn-body {
    margin: 0 !important;
    width: var(--klaro-mobile-content-width) !important;
    min-width: 0 !important;
    max-width: var(--klaro-mobile-content-width) !important;
  }

  .klaro .cookie-notice p,
  .klaro .context-notice p {
    font-size: 17px !important;
    line-height: 1.45 !important;
    margin: 0 !important;
    width: var(--klaro-mobile-content-width) !important;
    max-width: var(--klaro-mobile-content-width) !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
  }

  .klaro .cookie-notice #id-cookie-notice > span,
  .klaro .context-notice #id-cookie-notice > span {
    display: block !important;
    width: var(--klaro-mobile-content-width) !important;
    max-width: var(--klaro-mobile-content-width) !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
  }

  .klaro .cookie-notice strong,
  .klaro .context-notice strong {
    display: block !important;
    font-size: 20px !important;
    line-height: 1.2 !important;
    margin-bottom: 16px !important;
  }

  .klaro .cookie-notice a,
  .klaro .context-notice a {
    display: inline-block !important;
    margin-top: 8px !important;
    font-weight: 600 !important;
    text-decoration: underline !important;
  }

  .klaro .cookie-notice .cn-ok,
  .klaro .context-notice .cn-ok {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    margin-top: 22px !important;
    width: var(--klaro-mobile-content-width) !important;
    max-width: var(--klaro-mobile-content-width) !important;
  }

  .klaro .cookie-notice .cn-buttons,
  .klaro .context-notice .cn-buttons {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    width: var(--klaro-mobile-content-width) !important;
    max-width: var(--klaro-mobile-content-width) !important;
  }

  .klaro .cookie-notice .cm-btn,
  .klaro .context-notice .cm-btn {
    width: var(--klaro-mobile-content-width) !important;
    max-width: var(--klaro-mobile-content-width) !important;
    min-height: 48px !important;
    margin: 0 !important;
    font-size: 17px !important;
  }

  .klaro .cookie-notice .cm-btn-accept-all,
  .klaro .cookie-notice .cm-btn-success,
  .klaro .context-notice .cm-btn-accept-all,
  .klaro .context-notice .cm-btn-success {
    order: 1 !important;
  }

  .klaro .cookie-notice .cm-btn-info,
  .klaro .cookie-notice .cn-learn-more,
  .klaro .cookie-notice .cm-link,
  .klaro .context-notice .cm-btn-info,
  .klaro .context-notice .cn-learn-more,
  .klaro .context-notice .cm-link {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: var(--klaro-mobile-content-width) !important;
    max-width: var(--klaro-mobile-content-width) !important;
    min-height: 48px !important;
    margin: 0 !important;
    padding: 10px 18px !important;
    order: 2 !important;
    background: #eeeeee !important;
    color: #555 !important;
    border: none !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
  }

  .klaro .cookie-notice .cm-btn-decline,
  .klaro .cookie-notice .cm-btn-danger,
  .klaro .context-notice .cm-btn-decline,
  .klaro .context-notice .cm-btn-danger {
    order: 3 !important;
  }

  .klaro .cookie-modal .cm-modal {
    max-height: 90dvh !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
  }
}
