/* ===============================
   Cookie Manager (scoped)
   =============================== */

#ck-root{
  /* Theme */
  --ck-bg:#ffffff;
  --ck-text:#0b0d10;
  --ck-muted:#556070;
  --ck-border:#e5e7eb;
  --ck-accent:#3aa6a0;        /* Gecko-Grün */
  --ck-accent-ink:#ffffff;
  --ck-shadow:0 20px 60px rgba(0,0,0,.18);
  --ck-radius:6px;
  --ck-z:2147483000;          /* sehr hoch, über Panels/Modals */
  position: relative;
}

/* Nur innerhalb des Widgets verbergen */
#ck-root [hidden]{ display:none !important; }

/* -------------------------------
   Floating-Button (unten links)
   ------------------------------- */
#ck-root .ck-fab{
  position: absolute;
  left: 16px;
  bottom: 16px;
  width: 48px;
  height: 48px;
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  cursor: pointer;
}
#ck-root .ck-fab img { 
  width: 45px; 
  height: 45px; 
  display: block;
  filter: grayscale(1) brightness(1.6);
}

#ck-title {
  font-weight: 300;
  text-align: center;
}

#ck-desc {
  font-size: .9rem;
  font-weight: 200;
  line-height: 1.45;
}

#ck-btn {
  border-radius: 8px !important;
  padding: 8px 12px;
  font-size: .85rem;
}

/* -------------------------------
   Abdunkelung
   ------------------------------- */
#ck-root .ck-overlay{
  display:none !important;
}

/* -------------------------------
   Banner (Erstbesuch)
   ------------------------------- */
#ck-root .ck-banner{
  position: fixed;
  left: 50%;
  bottom: 20px;
  top: auto;
  transform: translateX(-50%);
  width: 90vw;
  background:var(--ck-bg); color:var(--ck-text);
  border:1px solid #49a5a2; 
  border-radius:var(--ck-radius);
  box-shadow:var(--ck-shadow);
  padding:16px 18px;
  z-index:var(--ck-z);
}
#ck-root .ck-head{ display:flex; align-items:center; gap:12px; margin-bottom:6px;
font-weight: 300; font-size: 1rem; }
#ck-root .ck-logo{ width:60px; height:60px }
#ck-root .ck-desc{ color:var(--ck-muted); margin:.2rem 0 1rem; font-size: .9rem; line-height: 1.45; }
#ck-root .ck-actions{ display:flex; gap:12px; flex-wrap:wrap }

#ck-root .ck-btn{
  appearance:none; cursor:pointer;
  border-radius:8px !important; padding:8px 12px;
  border:1px solid var(--ck-border);
  background:#f8fafc; color:var(--ck-text);
  font-weight:600;
  font-size: .85rem;
}
#ck-root .ck-btn:hover{ filter:brightness(1.02) }
#ck-root .ck-btn.ck-accept{
  background:var(--ck-accent);
  border-color:var(--ck-accent);
  color:var(--ck-accent-ink);
}

/* -------------------------------
   Einstellungen (Modal)
   ------------------------------- */
#ck-root .ck-modal{
  position:fixed; left:50%; top:50%; transform:translate(-50%,-50%);
  width:min(92vw,640px);
  max-height: 80vh;
  overflow-y: auto;
  z-index:var(--ck-z);
}
#ck-root .ckm-card{
  background:var(--ck-bg); color:var(--ck-text);
  border:1px solid var(--ck-border); border-radius:var(--ck-radius);
  box-shadow:var(--ck-shadow);
  overflow:hidden;
}
#ck-root .ckm-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 16px; border-bottom:1px solid var(--ck-border);
  font-size: 1rem;
}
#ck-root .ckm-x{
  border:none; background:transparent; font-size:20px; cursor:pointer; line-height:1;
}
#ck-root .ckm-body{ padding:8px 18px 4px }
#ck-root .ckm-desc{ color:var(--ck-muted); margin:.2rem 0 1rem; font-size: .95rem; }

#ck-root .ckm-list{ list-style:none; margin:0; padding:0 }
#ck-root .ckm-row{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:10px 14px;
}
#ck-root .ckm-row:hover{ background:#f6f7f9 }
#ck-root .ckm-row.is-locked{ opacity:.7 }
#ck-root .ckm-row p{ color:var(--ck-muted); margin:.2rem 0 0; font-size: .9rem; }

#ck-root .ckm-actions{
  display:flex; gap:10px; flex-wrap:wrap;
  padding:12px 16px; border-top:1px solid var(--ck-border);
}

/* Switch */
#ck-root .ckm-switch{ position:relative; width:46px; height:28px; display:inline-block; flex:0 0 auto }
#ck-root .ckm-switch input{ opacity:0; width:0; height:0 }
#ck-root .ckm-switch span{
  position:absolute; inset:0; background:#d1d5db; border-radius:999px; transition:.2s;
}
#ck-root .ckm-switch span::after{
  content:""; position:absolute; height:22px; width:22px; left:3px; top:3px;
  background:#fff; border-radius:50%; transition:.2s; box-shadow:0 1px 3px rgba(0,0,0,.25);
}
#ck-root .ckm-switch input:checked + span{ background:var(--ck-accent) }
#ck-root .ckm-switch input:checked + span::after{ transform:translateX(18px) }

/* -------------------------------
   Responsiveness & Print
   ------------------------------- */
@media (max-width: 480px){
  #ck-root .ck-actions{ flex-direction:column; align-items:stretch }
}
@media print{
  #ck-root{ display:none !important; }
}

/* ===============================
   Cookie-Details (scrollbarer Bereich, 2 Spalten)
   =============================== */
#ck-root .ckm-details{
  max-height: 38vh;            /* nur der Detailbereich scrollt, Footer bleibt sichtbar */
  overflow: auto;
  padding: 8px 18px 16px;
  border-top: 1px solid var(--ck-border, #e5e7eb);
  background: #fff;
}

#ck-root .ckm-details h4{
  margin: 12px 0 6px;
  font-size: 1.05rem;
  font-weight: 700;
}

#ck-root .ckd-intro,
#ck-root .ckd-note{
  color: var(--ck-muted, #6b7280);
  font-size: .95rem;
  line-height: 1.55;
  margin: 6px 0 12px;
}

/* Accordion-Blöcke */
#ck-root .ckd-block{
  border: 1px solid var(--ck-border, #e5e7eb);
  border-radius: 10px;
  margin: 10px 0 12px;
  background: #fafbfc;
}

#ck-root .ckd-block > summary{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  cursor: pointer;
  list-style: none;
}

#ck-root .ckd-block > summary::-webkit-details-marker{ display:none; }
#ck-root .ckd-block[open] > summary{ background:#f6f7f9; }

#ck-root .ckd-hint{
  color: var(--ck-muted, #6b7280);
  font-size: .92rem;
}

/* Kategorien-Badges */
#ck-root .ckd-cat{
  display:inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 700;
  font-size: .9rem;
  background:#e9f8f5;
  color:#0d6a63;
  border:1px solid rgba(58,166,160,.35);
}
#ck-root .ckd-cat--stats{ background:#eef6ff; color:#0b4ea2; border-color:#cfe3ff; }
#ck-root .ckd-cat--marketing{ background:#fff3e8; color:#8a4b00; border-color:#ffd3a8; }

/* Zweispaltiges Layout pro Cookie-Eintrag */
#ck-root .ckd-grid{
  display: grid;
  grid-template-columns: 1.2fr 1fr;  /* links Daten, rechts Beschreibung */
  gap: 14px;
  padding: 12px 14px 14px;
  border-top: 1px dashed var(--ck-border, #e5e7eb);
}

#ck-root .ckd-grid:first-of-type{ border-top: 1px solid var(--ck-border, #e5e7eb) }

#ck-root .ckd-left div{ 
  margin: 3px 0; 
  line-height: 1.45;
}
#ck-root .ckd-left code{
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  font-size: .92em;
  background: #fff;
  padding: 1px 6px;
  border: 1px solid var(--ck-border, #e5e7eb);
  border-radius: 6px;
}

#ck-root .ckd-right{
  color: var(--ck-muted, #6b7280);
  line-height: 1.55;
}

/* Body-Bereich im Einstellungsdialog optional separat scrollen lassen */
#ck-root .ckm-body .ckm-scroll{
  max-height: 40vh;
  overflow: auto;
  padding-right: 4px; /* kleiner „Gutter“ neben Scrollbar */
}

/* Footer */

#ck-root .ckm-foot {
  text-align: center;
  padding: 10px 18px 14px;
  font-size: 0.85rem;
  color: var(--ck-muted);
  border-top: 1px solid var(--ck-border);
}

#ck-root .ckm-foot a {
  color: var(--ck-text);
  text-decoration: underline;
}

#ck-root .ckm-foot a:hover {
  text-decoration: none;
}



/* Eingangs-Popup (Banner) – schmaler & luftiger */
#ck-root .ck-banner{
  width: min(92vw, 540px);     /* vorher breiter – jetzt schlanker */
  padding: 20px 22px 16px;     /* etwas mehr Innenabstand */
}

#ck-root .ck-head h2{
  margin: 0;
  font-size: 1.2rem;
  line-height: 1.2;
}

#ck-root .ck-desc{
  font-size: .9rem;
  line-height: 1.45;
  color: var(--ck-muted);
  margin: .4rem 0 1rem;
}

#ck-root .ck-actions{
  gap: 12px;
  flex-wrap: wrap;
}

/* Buttons leicht größer & klarer */
#ck-root .ck-btn{
  padding: 8px 12px;
  border-radius: 8px;
  font-weight: 700;
  font-size: .85rem;
}
#ck-root .ck-btn.ck-decline{
  background: #fff;
  border: 1px solid var(--ck-border);
}
#ck-root .ck-btn.ck-accept{
  background: var(--ck-accent);
  border-color: var(--ck-accent);
  color: var(--ck-accent-ink);
}