: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 .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;
}

/* ── Make the consent notice scrollable on mobile ── */
@media (max-width: 767px) {
  .klaro .cookie-notice,
  .klaro .context-notice {
    max-height: 100dvh !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
  }

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