/*
 * Klaro Brand-Override — The Podcast Summit 2026 (Schwarz-Rot, Poppins).
 * Überschreibt die Klaro-CSS-Variablen. Wird NACH klaro.css geladen.
 * Klaro nutzt historisch "green*"-Variablennamen als Akzentfarbe → mit Brand-Rot belegen.
 */
.klaro {
  --font-family: 'Poppins', system-ui, sans-serif;

  /* Akzent / Buttons (Brand-Rot) */
  --green1: #C8102E;
  --green2: #E11936;
  --button-text-color: #fff;

  /* Flächen */
  --dark1: #0E0D0C;
  --dark2: #1A1815;
  --dark3: #2A2622;
  --light1: #F5F1EA;
  --light2: #E7E0D5;
  --light3: #cdc6ba;

  /* Texte auf dunklem Grund */
  --text-color: #ffffff;

  /* Toggles */
  --gray1: #3a3631;
  --gray2: #4a453f;
  --gray5: #6b655d;
}

.klaro .cookie-modal,
.klaro .cookie-notice {
  color: #fff;
  font-family: var(--font-family);
}

/* =====================================================================
   Zentriertes, prominentes Consent-Modal (mustConsent)
   ===================================================================== */

/* Wrapper: Karte mittig zentrieren */
.klaro .cookie-modal {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

/* Backdrop: dunkel + leichter Blur. Seite dahinter nicht scrollbar. */
.klaro .cookie-modal .cm-bg {
  background: rgba(8, 8, 12, 0.85);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
}
html:has(.klaro .cm-modal) { overflow: hidden; }

/* Karte: dunkel, Markenoptik, max ~480px, mittig, abgerundet, Schatten */
.klaro .cookie-modal .cm-modal {
  position: relative;
  top: auto; left: auto; right: auto; bottom: auto;
  transform: none;
  margin: 0;
  width: 100%;
  max-width: 480px !important;
  min-width: 0 !important;
  max-height: calc(100vh - 40px);
  overflow-y: auto;
  background: var(--dark1);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 20px;
  box-shadow: 0 40px 100px -20px rgba(0, 0, 0, 0.8);
}

/* Kopf / Text */
.klaro .cookie-modal .cm-modal .cm-header { border-bottom: 0; padding: 28px 28px 6px; }
.klaro .cookie-modal .cm-modal .cm-header h1 { font-size: 22px !important; font-weight: 700; letter-spacing: -0.02em; line-height: 1.2; }
.klaro .cookie-modal .cm-modal .cm-body { padding: 6px 28px 2px; }
.klaro .cookie-modal .cm-modal .cm-body p { font-size: 14px; line-height: 1.6; color: rgba(255, 255, 255, 0.82); }
.klaro .cookie-modal .cm-modal a { color: var(--green2); }

/* Granulare Dienste-Liste: vorhanden, aber dezent (zwei Buttons bleiben Fokus) */
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes { margin-top: 14px; font-size: 13px; }
.klaro .cookie-modal .cm-modal .cm-body .cm-purpose p,
.klaro .cookie-modal .cm-modal .cm-body .cm-purpose .cm-services { color: rgba(255, 255, 255, 0.6); }

/* Fuß: keine Trennlinie, "powered by" dezent */
.klaro .cookie-modal .cm-modal .cm-footer { border-top: 0; padding: 18px 28px 24px; }
.klaro .cookie-modal .cm-modal .cm-footer .cm-powered-by,
.klaro .cookie-modal .cm-modal .cm-footer .cm-powered { opacity: 0.35; font-size: 10px; }

/* Button-Reihe → vertikal gestapelt, volle Breite (Klaro-Default ist row → überschreiben) */
.klaro .cookie-modal .cm-modal .cm-footer .cm-footer-buttons,
.klaro .cookie-modal .cm-modal .cm-footer-buttons,
.klaro .cookie-modal .cm-modal .cm-footer .cm-buttons {
  display: flex !important;
  flex-direction: column !important;
  flex-flow: column !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
  gap: 10px;
}

/* Basis-Button */
.klaro .cm-btn { border-radius: 999px; font-weight: 600; letter-spacing: -0.01em; transition: transform .15s ease, background .2s ease, opacity .15s ease; }
.klaro .cookie-modal .cm-modal .cm-footer .cm-btn {
  width: 100% !important;
  box-sizing: border-box;
  margin: 0 !important;
  padding: 13px 20px;
  font-size: 15px;
}
.klaro .cm-btn:hover { transform: translateY(-1px); }

/* "Ja, lecker Cookies" (Accept all): prominenter Primary, Akzent-Rot, oben */
.klaro .cookie-modal .cm-modal .cm-btn.cm-btn-accept-all {
  order: 1;
  background: var(--green1) !important;
  color: #fff !important;
  box-shadow: 0 10px 26px -10px rgba(200, 16, 46, 0.75);
}
.klaro .cookie-modal .cm-modal .cm-btn.cm-btn-accept-all:hover { background: var(--green2) !important; }

/* "Nein, nur notwendige" (Decline): gleichwertig, klar sichtbar, ruhiger (Outline) */
.klaro .cookie-modal .cm-modal .cm-btn.cm-btn-decline,
.klaro .cookie-modal .cm-modal .cm-btn.cn-decline {
  order: 2;
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.32) !important;
  color: #fff !important;
}
.klaro .cookie-modal .cm-modal .cm-btn.cm-btn-decline:hover,
.klaro .cookie-modal .cm-modal .cm-btn.cn-decline:hover { background: rgba(255, 255, 255, 0.13) !important; }

/* "Auswahl speichern" (Accept selected): dezent, unten */
.klaro .cookie-modal .cm-modal .cm-btn.cm-btn-accept {
  order: 3;
  background: transparent !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  color: rgba(255, 255, 255, 0.7) !important;
  font-weight: 500;
  font-size: 13px;
  padding: 10px 18px;
}
.klaro .cookie-modal .cm-modal .cm-btn.cm-btn-accept:hover { color: #fff !important; border-color: rgba(255, 255, 255, 0.3) !important; }

/* Toggle "an" = Brand-Rot */
.klaro .cm-list-input:checked + .cm-list-label .slider { background-color: var(--green1); }
.klaro .cm-list-input.half-checked + .cm-list-label .slider,
.klaro .cm-list-input.required:checked + .cm-list-label .slider { background-color: var(--green2); opacity: .7; }

/* ---- Fallback: Notice-Banner (falls mustConsent je deaktiviert wird) ---- */
.klaro .cookie-notice:not(.cookie-modal-notice) {
  background: var(--dark1);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 16px;
  box-shadow: 0 30px 80px -20px rgba(0, 0, 0, 0.7);
  max-width: 100%;
}
.klaro .cookie-notice a { color: var(--green2); }

/* Mobil: komfortabel tappbar, beide Optionen ohne Scrollen */
@media (max-width: 480px) {
  .klaro .cookie-modal { padding: 12px; align-items: flex-end; }
  .klaro .cookie-modal .cm-modal { max-width: 100%; border-radius: 18px; }
  .klaro .cm-btn { padding: 14px 20px; }
}

@media (prefers-reduced-motion: reduce) {
  .klaro .cm-btn { transition: none; }
  .klaro .cm-btn:hover { transform: none; }
}
