/* klaro-theme-overrides.css
   Full-file replacement — lightweight theme overrides to match Lorner site.
   No !important used. Install after klaro.min.css.
*/

/* Map Klaro tokens to site tokens (uses site's CSS variables when available) */
.klaro {
  --dark1: var(--brand-dark, #0b2540);
  --light1: var(--card-bg, #fbfcfd);
  --dark2: var(--muted, #6b7280);
  --light2: rgba(238,243,246,1);
  --light3: rgba(160,160,160,1);
  --green1: var(--accent, #0b6fae);      /* toggle on color */
  --green2: var(--accent, #0b6fae);      /* required/opt-out color */
  --button-text-color: #ffffff;
  --border-radius: var(--card-radius, 6px);
  --border-width: 1px;
  --notice-max-width: 420px;
  --notice-right: 20px;
  --notice-bottom: 20px;
  --font-family: var(--body-font, Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);
  --font-size: 14px;
}

/* Ensure Klaro uses the site's font stack and body color */
.klaro,
.klaro button,
.klaro .cm-modal,
.klaro .cm-body,
.klaro .cookie-notice,
.klaro .context-notice {
  font-family: var(--font-family);
  font-size: var(--font-size);
  color: var(--brand-dark);
}

/* Modal surface: use site card surface and subtle shadow */
.klaro .cookie-modal .cm-modal.cm-klaro {
  background: var(--card-bg, #fbfcfd);
  color: var(--brand-dark);
  border-radius: var(--border-radius);
  border: var(--border-width) solid var(--light2);
  box-shadow: 0 12px 32px rgba(12,30,45,0.06);
}

/* Cookie notice (inline) styling */
.klaro .cookie-notice:not(.cookie-modal-notice) {
  background: var(--card-bg);
  color: var(--brand-dark);
  border-radius: var(--border-radius);
  border: var(--border-width) solid var(--light2);
  right: var(--notice-right);
  bottom: var(--notice-bottom);
  max-width: var(--notice-max-width);
}

/* Buttons: match site accent + text color */
.klaro .cm-btn,
.klaro .cm-btn.cm-btn-success,
.klaro .cm-btn.cm-btn-success-var,
.klaro .cm-btn.cm-btn-info {
  color: var(--button-text-color);
  background: var(--accent, var(--green1));
  border-radius: calc(var(--border-radius));
  border: 0;
  padding: 0.4em 0.7em;
  font-weight: 700;
  cursor: pointer;
}

/* Secondary / close buttons */
.klaro .cm-btn.cm-btn-close,
.klaro .cm-btn.cm-btn-close svg {
  color: var(--dark2);
  background: var(--light2);
}

/* Links in Klaro should use the accent color */
.klaro a,
.klaro .cm-link {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Switch / toggle accent */
.klaro .slider,
.klaro .cm-switch .slider {
  background-color: #f2f2f2;
}
.klaro .cm-list-input:checked + .cm-list-label .slider,
.klaro .cm-list-input.only-required + .cm-list-label .slider {
  background-color: var(--accent);
}

/* Reduce border radii inside lists to match site (square or subtle) */
.klaro .cm-list-label,
.klaro .cm-switch-container,
.klaro .cm-modal .cm-body ul.cm-services li,
.klaro .cm-modal .cm-body ul.cm-purposes li {
  border-radius: calc(var(--border-radius));
}

/* Make cookie notice compact and aligned with site spacing tokens */
.klaro .cookie-notice .cn-body,
.klaro .cookie-modal .cm-modal .cm-body {
  padding: 12px;
  gap: 8px;
}

/* Accessibility: preserve focus outlines in case site removes them globally;
   provide subtle visible focus for keyboard users */
.klaro button:focus,
.klaro a:focus,
.klaro input:focus {
  outline: 3px solid rgba(11,111,174,0.14);
  outline-offset: 3px;
}

/* Small screens: ensure notice fits nicely */
@media (max-width: 480px) {
  .klaro .cookie-notice:not(.cookie-modal-notice) {
    right: 12px;
    left: 12px;
    bottom: 12px;
    max-width: calc(100% - 24px);
    border-radius: calc(var(--border-radius));
  }
}