/* ═══════════════════════════════════════════
   Cookie Settings Popup – FiRelax
   Modal-Overlay für schnellen Zugriff aus dem Footer
   ═══════════════════════════════════════════ */

/* ── Custom Properties (scoped) ── */
.cke-overlay {
  --cke-accent:       #f59e0b;
  --cke-accent-light: #fef3c7;
  --cke-accent-dark:  #b45309;
  --cke-accent-text:  #78350f;
  --cke-text:         #1e293b;
  --cke-text-mid:     #475569;
  --cke-text-light:   #64748b;
  --cke-bg:           #ffffff;
  --cke-bg-page:      #f8fafc;
  --cke-bg-alt:       #f1f5f9;
  --cke-border:       #e2e8f0;
  --cke-border-light: #f1f5f9;
  --cke-radius:       12px;
  --cke-radius-sm:    8px;
  --cke-shadow-sm:    0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --cke-shadow-md:    0 4px 16px rgba(0,0,0,0.06), 0 2px 4px rgba(0,0,0,0.04);
  --cke-shadow-lg:    0 8px 30px rgba(0,0,0,0.08);
  --cke-focus-ring:   0 0 0 3px rgba(245,158,11,0.45);
  --cke-transition:   0.2s ease;
  --cke-content-max:  720px;
  --cke-green:        #16a34a;
  --cke-green-light:  #dcfce7;
  --cke-green-dark:   #15803d;
  --cke-red:          #dc2626;
  --cke-red-light:    #fee2e2;
}

/* ═══════════════════════════════════════════
   1. Overlay / Backdrop
   ═══════════════════════════════════════════ */
.cke-overlay {
  position: fixed;
  inset: 0;
  z-index: 2147483647; /* Maximaler 32-bit Integer – höchste Priorität */
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.55);
  /* backdrop-filter entfernt: verursacht pointer-events Bugs auf iOS Safari */
  padding: 24px 16px;
  opacity: 0;
  transition: opacity 0.3s ease;
  /* Touch-Events explizit erlauben wenn sichtbar */
  touch-action: auto;
  -webkit-tap-highlight-color: transparent;
}

.cke-overlay.open {
  display: flex;
  opacity: 1;
}

.cke-overlay.closing {
  opacity: 0;
}

/* ═══════════════════════════════════════════
   2. Container (Modal Card)
   ═══════════════════════════════════════════ */
.cke-overlay .cke-container {
  width: 100%;
  max-width: var(--cke-content-max);
  max-height: 85vh;
  background: var(--cke-bg);
  border: 1px solid var(--cke-border);
  border-radius: var(--cke-radius);
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.25);
  overflow-y: auto;
  overflow-x: hidden;
  transform: translateY(30px) scale(0.97);
  transition: transform 0.3s ease;
  scrollbar-width: thin;
  scrollbar-color: var(--cke-border) transparent;
  /* Touch-Scrolling Fix für iOS */
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
  pointer-events: auto;
  position: relative;
}

.cke-overlay.open .cke-container {
  transform: translateY(0) scale(1);
}

.cke-overlay.closing .cke-container {
  transform: translateY(30px) scale(0.97);
}

.cke-overlay .cke-container::-webkit-scrollbar {
  width: 6px;
}
.cke-overlay .cke-container::-webkit-scrollbar-track {
  background: transparent;
}
.cke-overlay .cke-container::-webkit-scrollbar-thumb {
  background: var(--cke-border);
  border-radius: 3px;
}

/* ═══════════════════════════════════════════
   3. Close Button
   ═══════════════════════════════════════════ */
.cke-popup-close {
  position: absolute;
  top: 16px;
  right: 16px;
  /* KRITISCH: Min. 48x48px Touch-Target (Apple/Google HIG, WCAG) */
  width: 48px;
  height: 48px;
  min-width: 48px;
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--cke-bg-alt);
  border: 1px solid var(--cke-border);
  border-radius: 50%;
  cursor: pointer;
  color: var(--cke-text-mid);
  font-size: 1.25rem;
  transition: all var(--cke-transition);
  z-index: 10;
  /* Touch-Event-Fixes */
  pointer-events: auto;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

.cke-popup-close:hover {
  background: var(--cke-red-light);
  color: var(--cke-red);
  border-color: var(--cke-red);
}

.cke-popup-close:focus-visible {
  outline: none;
  box-shadow: var(--cke-focus-ring);
}

/* ═══════════════════════════════════════════
   4. Header
   ═══════════════════════════════════════════ */
.cke-overlay .cke-header {
  padding: 28px 32px 20px;
  border-bottom: 2px solid var(--cke-accent);
  position: relative;
}

.cke-overlay .cke-header h2 {
  font-size: clamp(1.15rem, 2vw + 0.4rem, 1.4rem);
  font-weight: 800;
  color: var(--cke-text);
  letter-spacing: -0.02em;
  line-height: 1.3;
  margin-bottom: 12px;
  padding-right: 40px;
}

.cke-overlay .cke-header p {
  font-size: 0.88rem;
  line-height: 1.7;
  color: var(--cke-text-mid);
  margin: 0;
}

.cke-overlay .cke-header p a {
  color: var(--cke-accent-dark);
  text-decoration: underline;
  text-decoration-color: rgba(180,83,9,0.3);
  text-underline-offset: 3px;
}

.cke-overlay .cke-header p a:hover {
  text-decoration-color: var(--cke-accent-dark);
}

/* ═══════════════════════════════════════════
   5. Cookie Categories
   ═══════════════════════════════════════════ */
.cke-overlay .cke-categories {
  padding: 20px 32px 8px;
}

.cke-overlay .cke-categories-label {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--cke-text-mid);
  margin-bottom: 14px;
}

.cke-overlay .cke-category {
  border: 1px solid var(--cke-border);
  border-radius: var(--cke-radius);
  margin-bottom: 10px;
  overflow: hidden;
  transition: box-shadow var(--cke-transition), border-color var(--cke-transition);
}

.cke-overlay .cke-category:hover {
  box-shadow: var(--cke-shadow-sm);
}

.cke-overlay .cke-category.active {
  border-color: var(--cke-accent);
}

.cke-overlay .cke-category-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: var(--cke-bg);
  cursor: default;
}

/* ── Toggle Switch ── */
.cke-overlay .toggle-wrapper {
  flex-shrink: 0;
  position: relative;
}

.cke-overlay .toggle-input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.cke-overlay .toggle-slider {
  display: block;
  width: 44px;
  height: 24px;
  background: var(--cke-border);
  border-radius: 12px;
  position: relative;
  cursor: pointer;
  transition: background 0.25s ease;
}

.cke-overlay .toggle-slider::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  background: var(--cke-bg);
  border-radius: 50%;
  box-shadow: 0 1px 3px rgba(0,0,0,0.15);
  transition: transform 0.25s ease;
}

.cke-overlay .toggle-input:checked + .toggle-slider {
  background: var(--cke-green);
}

.cke-overlay .toggle-input:checked + .toggle-slider::after {
  transform: translateX(20px);
}

.cke-overlay .toggle-input:focus-visible + .toggle-slider {
  box-shadow: var(--cke-focus-ring);
}

.cke-overlay .toggle-input:disabled + .toggle-slider {
  opacity: 0.6;
  cursor: not-allowed;
}

.cke-overlay .toggle-input:disabled:checked + .toggle-slider {
  background: var(--cke-green);
  opacity: 0.7;
}

/* Category info */
.cke-overlay .cke-category-info {
  flex: 1;
  min-width: 0;
}

.cke-overlay .cke-category-name {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--cke-text);
  line-height: 1.3;
}

.cke-overlay .cke-category-desc {
  font-size: 0.8rem;
  color: var(--cke-text-light);
  line-height: 1.5;
  margin-top: 1px;
}

/* Required badge */
.cke-overlay .cke-required {
  flex-shrink: 0;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--cke-text-light);
  background: var(--cke-bg-alt);
  padding: 3px 9px;
  border-radius: 20px;
  border: 1px solid var(--cke-border);
  white-space: nowrap;
}

/* Status badge */
.cke-overlay .cke-status {
  flex-shrink: 0;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 3px 9px;
  border-radius: 20px;
  white-space: nowrap;
  transition: all 0.25s ease;
}

.cke-overlay .cke-status.on {
  color: var(--cke-green-dark);
  background: var(--cke-green-light);
  border: 1px solid rgba(22,163,74,0.25);
}

.cke-overlay .cke-status.off {
  color: var(--cke-text-light);
  background: var(--cke-bg-alt);
  border: 1px solid var(--cke-border);
}

/* Details toggle */
.cke-overlay .cke-details-toggle {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 1px solid var(--cke-border);
  background: var(--cke-bg);
  color: var(--cke-text-mid);
  cursor: pointer;
  transition: all var(--cke-transition);
  font-size: 0;
}

.cke-overlay .cke-details-toggle:hover {
  background: var(--cke-bg-alt);
  color: var(--cke-text);
}

.cke-overlay .cke-details-toggle:focus-visible {
  outline: none;
  box-shadow: var(--cke-focus-ring);
}

.cke-overlay .cke-details-toggle svg {
  width: 13px;
  height: 13px;
  fill: currentColor;
  transition: transform 0.25s ease;
}

.cke-overlay .cke-details-toggle[aria-expanded="true"] svg {
  transform: rotate(180deg);
}

/* Details panel */
.cke-overlay .cke-details {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
  border-top: 0 solid var(--cke-border-light);
}

.cke-overlay .cke-details.open {
  border-top-width: 1px;
}

.cke-overlay .cke-details-inner {
  padding: 14px 18px 16px;
  background: var(--cke-bg-alt);
}

.cke-overlay .cke-details-inner p {
  font-size: 0.83rem;
  line-height: 1.6;
  color: var(--cke-text-mid);
  margin-bottom: 10px;
}

.cke-overlay .cke-details-inner p:last-child {
  margin-bottom: 0;
}

.cke-overlay .cke-details-inner strong {
  color: var(--cke-text);
  font-weight: 650;
}

/* Cookie table */
.cke-overlay .cke-cookie-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8rem;
  line-height: 1.5;
  margin-top: 6px;
}

.cke-overlay .cke-cookie-table thead th {
  background: var(--cke-bg);
  color: var(--cke-text);
  font-weight: 700;
  font-size: 0.73rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 7px 10px;
  text-align: left;
  border-bottom: 2px solid var(--cke-border);
  white-space: nowrap;
}

.cke-overlay .cke-cookie-table tbody td {
  padding: 7px 10px;
  border-bottom: 1px solid var(--cke-border-light);
  color: var(--cke-text);
  vertical-align: top;
}

.cke-overlay .cke-cookie-table tbody tr:last-child td {
  border-bottom: none;
}

.cke-overlay .cke-cookie-table code {
  font-family: 'SF Mono', 'Cascadia Code', 'Fira Code', ui-monospace, monospace;
  font-size: 0.76rem;
  background: var(--cke-bg);
  padding: 1px 5px;
  border-radius: 4px;
  color: var(--cke-accent-dark);
}

/* ═══════════════════════════════════════════
   6. Action Buttons
   ═══════════════════════════════════════════ */
.cke-overlay .cke-actions {
  display: flex;
  gap: 10px;
  padding: 18px 32px 24px;
  flex-wrap: wrap;
}

.cke-overlay .cke-btn {
  flex: 1 1 0;
  min-width: 140px;
  /* KRITISCH: 48px Min-Höhe für Touch-Targets */
  min-height: 48px;
  padding: 12px 18px;
  border-radius: var(--cke-radius-sm);
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
  transition: all var(--cke-transition);
  text-align: center;
  line-height: 1.3;
  border: 2px solid transparent;
  /* Touch-Event-Fixes */
  pointer-events: auto;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

.cke-overlay .cke-btn:focus-visible {
  outline: none;
  box-shadow: var(--cke-focus-ring);
}

.cke-overlay .cke-btn--reject {
  background: var(--cke-bg);
  color: var(--cke-text);
  border-color: var(--cke-border);
}

.cke-overlay .cke-btn--reject:hover {
  background: var(--cke-bg-alt);
  border-color: var(--cke-text-mid);
}

.cke-overlay .cke-btn--confirm {
  background: var(--cke-bg);
  color: var(--cke-text);
  border-color: var(--cke-text);
}

.cke-overlay .cke-btn--confirm:hover {
  background: var(--cke-text);
  color: var(--cke-bg);
}

.cke-overlay .cke-btn--accept {
  background: var(--cke-text);
  color: var(--cke-bg);
  border-color: var(--cke-text);
}

.cke-overlay .cke-btn--accept:hover {
  background: var(--cke-text-mid);
  border-color: var(--cke-text-mid);
}

/* ═══════════════════════════════════════════
   7. Footer Links
   ═══════════════════════════════════════════ */
.cke-overlay .cke-footer {
  display: flex;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
  padding: 0 32px 20px;
  border-top: 1px solid var(--cke-border);
  padding-top: 14px;
}

.cke-overlay .cke-footer a {
  font-size: 0.8rem;
  color: var(--cke-text-light);
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 3px;
  transition: all var(--cke-transition);
}

.cke-overlay .cke-footer a:hover {
  color: var(--cke-accent-dark);
  text-decoration-color: var(--cke-accent-dark);
}

/* ═══════════════════════════════════════════
   8. Toast (inside popup context)
   ═══════════════════════════════════════════ */
.cke-overlay .cke-toast {
  position: fixed;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%) translateY(120%);
  background: var(--cke-text);
  color: #fff;
  padding: 14px 28px;
  border-radius: var(--cke-radius);
  font-size: 0.9rem;
  font-weight: 600;
  box-shadow: var(--cke-shadow-lg);
  z-index: 2147483647; /* Gleicher Max-Wert wie Overlay */
  opacity: 0;
  transition: transform 0.35s ease, opacity 0.35s ease;
  pointer-events: none;
  white-space: nowrap;
}

.cke-overlay .cke-toast.visible {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}

.cke-overlay .cke-toast .toast-icon {
  margin-right: 8px;
}

/* ═══════════════════════════════════════════
   9. Prevent body scroll when open
   ═══════════════════════════════════════════ */
body.cke-popup-open {
  overflow: hidden;
  /* Robustes Scroll-Lock für Mobile (iOS Safari) */
  touch-action: none;
  -webkit-overflow-scrolling: auto;
}

/* ═══════════════════════════════════════════
   9b. Toggle/Label Touch-Target Fixes
   ═══════════════════════════════════════════ */
.cke-overlay .toggle-slider {
  pointer-events: auto;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  min-width: 44px;
  min-height: 24px;
  cursor: pointer;
}

.cke-overlay .cke-details-toggle {
  pointer-events: auto;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  min-width: 44px;
  min-height: 44px;
}

.cke-overlay .cke-category-header {
  pointer-events: auto;
}

/* ═══════════════════════════════════════════
   10. Responsive – Mobile (≤ 640px)
   ═══════════════════════════════════════════ */
@media (max-width: 640px) {
  .cke-overlay {
    padding: 12px 8px;
  }

  .cke-overlay .cke-container {
    max-height: 90vh;
  }

  .cke-overlay .cke-header {
    padding: 20px 18px 16px;
  }

  .cke-overlay .cke-header h2 {
    font-size: 1.1rem;
    padding-right: 36px;
  }

  .cke-overlay .cke-categories {
    padding: 16px 18px 4px;
  }

  .cke-overlay .cke-category-header {
    padding: 12px 14px;
    gap: 8px;
    flex-wrap: wrap;
  }

  .cke-overlay .cke-category-name {
    font-size: 0.86rem;
  }

  .cke-overlay .cke-details-inner {
    padding: 12px 14px 14px;
  }

  .cke-overlay .cke-actions {
    padding: 14px 18px 20px;
    flex-direction: column;
    gap: 8px;
  }

  .cke-overlay .cke-btn {
    min-width: unset;
  }

  .cke-overlay .cke-footer {
    padding: 0 18px 16px;
    padding-top: 12px;
    gap: 14px;
  }

  .cke-popup-close {
    top: 12px;
    right: 12px;
    /* 48x48px Touch-Target bleibt auch auf Mobile */
    width: 48px;
    height: 48px;
    min-width: 48px;
    min-height: 48px;
    font-size: 1.25rem;
  }
}

/* ═══════════════════════════════════════════
   11. Reduced Motion
   ═══════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  .cke-overlay,
  .cke-overlay .cke-container {
    transition-duration: 0.01ms !important;
  }
}
