/* ============================================================
   STRIVERA · COOKIE-CONSENT BANNER
   Rechtskonform: gleichwertige Buttons (VG Hannover 2025),
   keine Pre-Checks (EuGH Planet49), granulare Kategorien.
   ============================================================ */

.sv-consent{
  --c-bg:rgba(11,18,32,0.96);
  --c-bg-card:#0F1A2E;
  --c-border:rgba(230,238,250,0.14);
  --c-border-strong:rgba(230,238,250,0.22);
  --c-text:#E6EEFA;
  --c-text-mute:rgba(230,238,250,0.68);
  --c-accent:#4F8CFF;
  --c-accent-hover:#3B72E0;
  --c-mint:#A6F0D6;
  --c-font-d:"Inter Tight",-apple-system,BlinkMacSystemFont,sans-serif;
  --c-font-m:"JetBrains Mono",ui-monospace,monospace;
}

/* === Banner unten === */
.sv-consent__banner{
  position:fixed;
  left:clamp(12px,2vw,24px);
  right:clamp(12px,2vw,24px);
  bottom:clamp(12px,2vw,24px);
  max-width:560px;
  margin-left:auto;
  margin-right:auto;
  background:var(--c-bg);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border:1px solid var(--c-border-strong);
  border-radius:18px;
  padding:22px 24px;
  color:var(--c-text);
  font-family:var(--c-font-d);
  font-size:14px;
  line-height:1.55;
  box-shadow:0 24px 60px -16px rgba(0,0,0,0.7), 0 0 0 1px rgba(255,255,255,0.04) inset;
  z-index:9999;
  display:none;
  animation:sv-c-up 0.45s cubic-bezier(.2,.7,.2,1);
}
.sv-consent--open .sv-consent__banner{display:block}

@keyframes sv-c-up{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

.sv-consent__h{
  font-family:var(--c-font-d);
  font-size:15px;
  font-weight:700;
  letter-spacing:-0.01em;
  margin:0 0 8px 0;
  color:var(--c-text);
}

.sv-consent__txt{
  color:var(--c-text-mute);
  font-size:13.5px;
  line-height:1.55;
  margin:0 0 16px 0;
}
.sv-consent__txt a{
  color:var(--c-accent);
  text-decoration:underline;
  text-underline-offset:3px;
}
.sv-consent__txt a:hover{color:var(--c-accent-hover)}

.sv-consent__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.sv-consent__btn{
  font-family:var(--c-font-d);
  font-size:13.5px;
  font-weight:700;
  letter-spacing:-0.005em;
  padding:11px 18px;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  transition:all 0.2s;
  flex:1 1 auto;
  min-width:120px;
  text-align:center;
  line-height:1.2;
}
.sv-consent__btn:focus-visible{
  outline:2px solid var(--c-mint);
  outline-offset:2px;
}

/* Gleichwertige Buttons: Accept und Reject = gleiches Styling-Gewicht */
.sv-consent__btn--accept{
  background:var(--c-accent);
  color:#fff;
  border-color:var(--c-accent);
}
.sv-consent__btn--accept:hover{
  background:var(--c-accent-hover);
  border-color:var(--c-accent-hover);
}

.sv-consent__btn--reject{
  background:rgba(230,238,250,0.08);
  color:var(--c-text);
  border-color:var(--c-border-strong);
}
.sv-consent__btn--reject:hover{
  background:rgba(230,238,250,0.14);
  border-color:rgba(230,238,250,0.36);
}

.sv-consent__btn--settings{
  background:transparent;
  color:var(--c-text-mute);
  border-color:var(--c-border);
  flex:0 0 auto;
  min-width:auto;
  padding:11px 16px;
  font-weight:600;
}
.sv-consent__btn--settings:hover{
  color:var(--c-text);
  border-color:var(--c-border-strong);
}

/* === Modal === */
.sv-consent__modal-bg{
  position:fixed;
  inset:0;
  background:rgba(6,11,20,0.78);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  z-index:10000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  animation:sv-c-fade 0.25s ease;
}
.sv-consent--modal-open .sv-consent__modal-bg{display:flex}

@keyframes sv-c-fade{
  from{opacity:0}
  to{opacity:1}
}

.sv-consent__modal{
  background:var(--c-bg-card);
  border:1px solid var(--c-border-strong);
  border-radius:20px;
  max-width:540px;
  width:100%;
  max-height:calc(100vh - 48px);
  overflow-y:auto;
  padding:32px;
  color:var(--c-text);
  font-family:var(--c-font-d);
  box-shadow:0 32px 80px -20px rgba(0,0,0,0.8);
  animation:sv-c-pop 0.35s cubic-bezier(.2,.7,.2,1);
}

@keyframes sv-c-pop{
  from{opacity:0;transform:translateY(16px) scale(0.97)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

.sv-consent__modal-h{
  font-family:var(--c-font-d);
  font-size:22px;
  font-weight:800;
  letter-spacing:-0.02em;
  line-height:1.2;
  margin:0 0 12px 0;
}
.sv-consent__modal-lead{
  color:var(--c-text-mute);
  font-size:14px;
  line-height:1.55;
  margin:0 0 24px 0;
}
.sv-consent__modal-lead a{color:var(--c-accent);text-decoration:underline;text-underline-offset:3px}

.sv-consent__cat{
  border:1px solid var(--c-border);
  border-radius:14px;
  padding:18px 20px;
  margin-bottom:12px;
  transition:border-color 0.2s;
}
.sv-consent__cat:hover{border-color:var(--c-border-strong)}

.sv-consent__cat-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:6px;
}
.sv-consent__cat-name{
  font-family:var(--c-font-d);
  font-size:15px;
  font-weight:700;
  letter-spacing:-0.005em;
}
.sv-consent__cat-desc{
  font-size:13px;
  color:var(--c-text-mute);
  line-height:1.5;
}

/* === Toggle Switch === */
.sv-consent__toggle{
  position:relative;
  width:42px;
  height:24px;
  flex-shrink:0;
}
.sv-consent__toggle input{
  position:absolute;
  inset:0;
  opacity:0;
  margin:0;
  cursor:pointer;
}
.sv-consent__toggle-slider{
  position:absolute;
  inset:0;
  background:rgba(230,238,250,0.16);
  border-radius:999px;
  transition:background 0.2s;
  pointer-events:none;
}
.sv-consent__toggle-slider::before{
  content:"";
  position:absolute;
  top:3px;left:3px;
  width:18px;height:18px;
  background:#fff;
  border-radius:50%;
  transition:transform 0.2s cubic-bezier(.2,.7,.2,1);
  box-shadow:0 1px 4px rgba(0,0,0,0.4);
}
.sv-consent__toggle input:checked + .sv-consent__toggle-slider{
  background:var(--c-accent);
}
.sv-consent__toggle input:checked + .sv-consent__toggle-slider::before{
  transform:translateX(18px);
}
.sv-consent__toggle input:disabled + .sv-consent__toggle-slider{
  opacity:0.6;
  cursor:not-allowed;
}
.sv-consent__toggle input:focus-visible + .sv-consent__toggle-slider{
  box-shadow:0 0 0 3px rgba(166,240,214,0.45);
}

.sv-consent__cat--locked .sv-consent__cat-name{color:var(--c-text-mute)}
.sv-consent__cat--locked .sv-consent__cat-name::after{
  content:"immer aktiv";
  display:inline-block;
  margin-left:8px;
  padding:2px 8px;
  background:rgba(166,240,214,0.14);
  color:var(--c-mint);
  font-family:var(--c-font-m);
  font-size:10px;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  border-radius:999px;
  vertical-align:middle;
}

.sv-consent__modal-actions{
  display:flex;
  gap:10px;
  margin-top:22px;
  flex-wrap:wrap;
}
.sv-consent__modal-actions .sv-consent__btn{
  flex:1 1 0;
  min-width:120px;
}

/* === Mobile === */
@media (max-width:520px){
  .sv-consent__banner{
    left:8px;right:8px;bottom:8px;
    padding:18px 20px;
  }
  .sv-consent__actions{flex-direction:column}
  .sv-consent__actions .sv-consent__btn{width:100%}
  .sv-consent__modal{padding:24px;border-radius:16px}
  .sv-consent__modal-h{font-size:19px}
}

/* === Reduced motion === */
@media (prefers-reduced-motion: reduce){
  .sv-consent__banner,
  .sv-consent__modal-bg,
  .sv-consent__modal{animation:none}
  .sv-consent__toggle-slider::before{transition:none}
}
