/**
 * Klaro Cookie Consent — Design System Overrides
 * Überschreibt Klaro-Default-Styles mit MarktLinse Design Tokens
 *
 * Klaro vendor CSS nutzt `.klaro .cookie-notice:not(.cookie-modal-notice)`
 * → Overrides müssen gleiche oder höhere Spezifität haben.
 *
 * @version 1.1.0
 * @date 2026-03-11
 */

/* ============================================
   NOTICE BAR (Bottom Banner)
   ============================================ */
.klaro .cookie-notice:not(.cookie-modal-notice) {
  background: var(--bg-primary);
  border: 1px solid var(--overlay-8);
  box-shadow: var(--shadow-xl);
  font-family: var(--font-body);
  color: var(--text-primary);
  padding: var(--spacing-5) var(--spacing-6);
  border-radius: var(--radius-lg);
}

@media (min-width: 1024px) {
  .klaro .cookie-notice:not(.cookie-modal-notice) {
    max-width: 420px;
    right: var(--spacing-6);
    bottom: var(--spacing-6);
  }
}

@media (max-width: 1023px) {
  .klaro .cookie-notice:not(.cookie-modal-notice) {
    border-radius: 0;
    border-left: none;
    border-right: none;
    border-bottom: none;
  }
}

/* Body */
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body {
  padding: 0;
}

.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body p {
  font-size: var(--font-size-sm);
  line-height: 1.5;
  color: var(--text-secondary);
  margin: 0 0 var(--spacing-4);
}

.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body p a {
  color: var(--color-primary);
  text-decoration: none;
  font-weight: 500;
}
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body p a:hover {
  text-decoration: underline;
}

/* ============================================
   OK SECTION (Buttons + Learn More)
   ============================================ */
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-ok {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
  margin-top: 0;
  align-items: stretch;
}

/* ============================================
   BUTTONS
   ============================================ */
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons {
  display: flex;
  gap: var(--spacing-2);
  margin-top: 0;
}

.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons button.cm-btn {
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  font-weight: 600;
  border: none;
  border-radius: var(--radius-btn);
  padding: var(--spacing-2) var(--spacing-4);
  cursor: pointer;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
  line-height: 1.4;
  flex: 1;
  margin-top: 0;
}

/* "Akzeptieren" */
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons button.cm-btn.cm-btn-success {
  background: var(--gradient-primary);
  color: var(--color-white);
  box-shadow: var(--shadow-primary);
}
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons button.cm-btn.cm-btn-success:hover {
  transform: translateY(-1px);
}

/* "Ablehnen" */
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons button.cm-btn.cm-btn-danger {
  background: var(--overlay-5);
  color: var(--text-primary);
  border: 1px solid var(--overlay-10);
}
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons button.cm-btn.cm-btn-danger:hover {
  background: var(--overlay-8);
}

/* "Einstellungen" Link */
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-ok a.cn-learn-more {
  font-size: var(--font-size-2xs);
  color: var(--text-tertiary);
  text-decoration: none;
  cursor: pointer;
  background: none;
  border: none;
  font-family: var(--font-body);
  text-align: center;
  margin-top: 0;
}
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-ok a.cn-learn-more:hover {
  color: var(--text-secondary);
  text-decoration: underline;
}

/* ============================================
   MODAL (Einstellungen)
   ============================================ */
.klaro .cookie-modal {
  z-index: var(--z-modal);
}

.klaro .cookie-modal .cm-modal.cm-klaro {
  background: var(--bg-primary);
  color: var(--text-primary);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--overlay-8);
  font-family: var(--font-body);
}

@media (min-width: 660px) {
  .klaro .cookie-modal .cm-modal.cm-klaro {
    max-width: 560px;
    border-radius: var(--radius-xl);
  }
}

.klaro .cookie-modal .cm-modal .cm-header {
  padding: var(--spacing-6) var(--spacing-6) var(--spacing-4);
  border-bottom-color: var(--overlay-6);
}

.klaro .cookie-modal .cm-modal .cm-header h1 {
  font-family: var(--font-headline);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text-primary);
}

.klaro .cookie-modal .cm-modal .cm-header p {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  line-height: 1.5;
}

.klaro .cookie-modal .cm-modal .cm-header p a {
  color: var(--color-primary);
  text-decoration: none;
}

.klaro .cookie-modal .cm-modal .cm-body {
  padding: var(--spacing-4) var(--spacing-6);
}

.klaro .cookie-modal .cm-modal .cm-footer {
  padding: var(--spacing-4) var(--spacing-6);
  border-top-color: var(--overlay-6);
}

.klaro .cookie-modal .cm-modal .hide svg {
  stroke: var(--text-tertiary);
}

/* ============================================
   SERVICE LIST (im Modal)
   ============================================ */
.klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service .cm-switch-container,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-purpose .cm-switch-container {
  border-bottom-color: var(--overlay-4);
}

.klaro .cookie-modal .cm-modal .cm-body .cm-service-title,
.klaro .cookie-modal .cm-modal .cm-body .cm-purpose-title {
  font-weight: 600;
  font-size: var(--font-size-sm);
  color: var(--text-primary);
}

.klaro .cookie-modal .cm-modal .cm-body .cm-service-description,
.klaro .cookie-modal .cm-modal .cm-body .cm-purpose-description {
  font-size: var(--font-size-2xs);
  color: var(--text-tertiary);
  line-height: 1.4;
}

/* ============================================
   TOGGLE SWITCH
   ============================================ */
.klaro .cookie-modal .cm-list-input:checked + .cm-list-label .slider,
.klaro .cookie-notice .cm-list-input:checked + .cm-list-label .slider {
  background-color: var(--color-primary);
}

/* ============================================
   MODAL BUTTONS
   ============================================ */
.klaro .cookie-modal .cm-modal .cm-footer .cm-footer-buttons button.cm-btn {
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  font-weight: 600;
  border: none;
  border-radius: var(--radius-btn);
  padding: var(--spacing-2) var(--spacing-4);
  cursor: pointer;
  transition: transform var(--transition-fast), background var(--transition-fast);
}

.klaro .cookie-modal .cm-modal .cm-footer .cm-footer-buttons button.cm-btn-success {
  background: var(--gradient-primary);
  color: var(--color-white);
  box-shadow: var(--shadow-primary);
}
.klaro .cookie-modal .cm-modal .cm-footer .cm-footer-buttons button.cm-btn-success:hover {
  transform: translateY(-1px);
}

.klaro .cookie-modal .cm-modal .cm-footer .cm-footer-buttons button.cm-btn-info {
  background: var(--overlay-5);
  color: var(--text-primary);
  border: 1px solid var(--overlay-10);
}
.klaro .cookie-modal .cm-modal .cm-footer .cm-footer-buttons button.cm-btn-info:hover {
  background: var(--overlay-8);
}

/* ============================================
   OVERLAY
   ============================================ */
.klaro .cookie-modal .cm-bg {
  background: var(--overlay-45);
  backdrop-filter: var(--glass-blur-xs);
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 384px) {
  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons {
    flex-direction: column;
  }
  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons button.cm-btn {
    width: 100%;
    text-align: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  .klaro .cn-buttons .cm-btn,
  .klaro .cm-switch .slider,
  .klaro .cm-switch .slider::before {
    transition-duration: 0.01ms;
  }
}
