/* ==========================================================
   QRacked Klaro Overrides
   Light & dark theme alignment 
   ========================================================== */

:root {
  --klaro-bg: #f6f8ff;
  --klaro-surface: #ffffff;
  --klaro-text: #0f172a;
  --klaro-strong-text: #253479;
  --klaro-muted: #4c5774;
  --klaro-border: rgba(15, 23, 42, 0.08);
  --klaro-shadow: 0 18px 40px rgba(15, 23, 42, 0.15);
  --klaro-radius: 18px;
  --klaro-accent: #4c6aff;
  --klaro-accent-solid: #4c6aff;
  --klaro-accent-hover: #3c5ce5;
  --klaro-accent-muted: rgba(76, 106, 255, 0.12);
}

.dark {
  --klaro-bg: #050b16;
  --klaro-surface: #0c1426;
  --klaro-text: #e5edff;
  --klaro-strong-text: #cbd5ff;
  --klaro-muted: #9fb5d8;
  --klaro-border: rgba(148, 163, 184, 0.2);
  --klaro-shadow: 0 20px 45px rgba(3, 4, 15, 0.75);
  --klaro-accent-solid: #7c7bff;
  --klaro-accent-hover: #9f6dff;
  --klaro-accent-muted: rgba(124, 123, 255, 0.18);
}

.klaro {
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--klaro-text);
}

/* Banner ------------------------------------------------ */
.klaro .cookie-notice:not(.cookie-modal-notice),
.klaro .cm-dialog.cm-dialog-type-notice {
  position: fixed !important;
  bottom: 2.5rem !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  max-width: 560px !important;
  width: calc(100% - 2rem);
  background: radial-gradient(circle at top left, rgba(76, 106, 255, 0.08), transparent 70%), var(--klaro-surface) !important;
  color: var(--klaro-text) !important;
  border: 1px solid var(--klaro-border) !important;
  border-radius: var(--klaro-radius) !important;
  box-shadow: var(--klaro-shadow) !important;
  z-index: 9999;
  text-align: left;
  padding: 1.25rem 1.5rem;
  backdrop-filter: blur(6px);
}

.klaro .cookie-notice h1,
.klaro .cookie-notice h2,
.klaro .cookie-notice p,
.klaro strong {
  color: var(--klaro-text) !important;
}
.klaro strong {
  color: var(--klaro-strong-text) !important;
  font-weight: 700;
}

.klaro .cookie-notice a,
.klaro .cm-link {
  color: var(--klaro-accent-solid) !important;
  font-weight: 600;
  text-decoration: none;
}
.klaro .cookie-notice a:hover {
  text-decoration: underline;
}

/* Buttons ----------------------------------------------- */
.klaro .cookie-notice .cn-ok,
.klaro .cookie-notice .cn-buttons {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.klaro .cm-btn.cm-btn-success,
.klaro .cookie-notice .cm-btn.cm-btn-success {
  background: var(--klaro-accent-solid) !important;
  color: #fff !important;
  border-radius: 999px !important;
  border: none !important;
  padding: 0.55rem 1.5rem !important;
  font-weight: 600;
  box-shadow: 0 10px 25px rgba(92, 108, 255, 0.35);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.klaro .cm-btn.cm-btn-success:hover {
  transform: translateY(-1px);
  box-shadow: 0 15px 30px rgba(92, 108, 255, 0.45);
}

.klaro .cm-btn.cm-btn-close,
.klaro .cm-btn.cm-btn-decl {
  background: var(--klaro-accent-muted) !important;
  color: var(--klaro-text) !important;
  border-radius: 999px !important;
  border: 1px solid transparent !important;
  padding: 0.55rem 1.35rem !important;
  font-weight: 500;
  transition: border-color 0.25s ease, color 0.25s ease;
}
.klaro .cm-btn.cm-btn-close:hover,
.klaro .cm-btn.cm-btn-decl:hover {
  border-color: var(--klaro-accent-solid) !important;
  color: var(--klaro-accent-solid) !important;
}

/* Switches ---------------------------------------------- */
.klaro .cm-list-input:checked + .cm-list-label .slider,
.klaro .cm-switch-container .cm-list-input:checked + .cm-list-label .slider {
  background: var(--klaro-accent-solid) !important;
}

.klaro .cm-list-input:checked + .cm-list-label .slider::before {
  background-color: #fff !important;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);
}

.klaro .cm-switch-container .cm-list-label:hover .slider {
  background: var(--klaro-accent-hover) !important;
  transition: background-color 0.3s ease;
}

.klaro .cm-switch-container a,
.klaro .cookie-modal a {
  color: var(--klaro-accent-solid) !important;
}

.klaro .cm-switch input:focus + .slider,
.klaro .cm-btn:focus {
  outline: 2px solid var(--klaro-accent-hover) !important;
  outline-offset: 2px;
}

/* Modal ------------------------------------------------- */
.klaro .cookie-modal .cm-modal.cm-klaro {
  background: radial-gradient(circle at top left, rgba(76, 106, 255, 0.08), transparent 70%), var(--klaro-surface) !important;
  color: var(--klaro-text) !important;
  border: 1px solid var(--klaro-border) !important;
  border-radius: var(--klaro-radius) !important;
  box-shadow: var(--klaro-shadow) !important;
  padding: 1.75rem !important;
  max-width: 720px !important;
}
.klaro .cookie-modal .cm-header h1 {
  color: var(--klaro-text) !important;
}
.klaro .cookie-modal .cm-body p,
.klaro .cookie-modal .cm-body span {
  color: var(--klaro-muted) !important;
}

/* Table & service rows --------------------------------- */
.klaro .services,
.klaro .accordion,
.klaro .context-notice {
  background: var(--klaro-bg) !important;
  border-radius: var(--klaro-radius) !important;
  border: 1px solid var(--klaro-border) !important;
}
.klaro .services li,
.klaro .cm-switch-container {
  background: transparent !important;
  border-bottom: 1px solid var(--klaro-border) !important;
}
.klaro .services li:last-child,
.klaro .cm-switch-container:last-child {
  border-bottom: none !important;
}

/* Utility ------------------------------------------------ */
.klaro .cm-modal .cm-footer,
.klaro .cm-modal .cm-body {
  background: transparent !important;
}
.klaro .cookie-notice .cm-footer {
  border-top: 1px solid var(--klaro-border) !important;
  padding-top: 1rem !important;
}



