/* /assets/css/consent.css
 * DSGVO Consent Banner + Modal
 * Nutzt CSS-Variablen aus index.php (:root)
 */

#cc-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.45);
  backdrop-filter: blur(2px);
  z-index:9998;
  display:none;
}

#cc-banner{
  position:fixed;
  left:18px; right:18px; bottom:18px;
  max-width:1050px;
  margin:0 auto;
  z-index:9999;
  display:none;
}

#cc-card{
  border-radius:18px;
  border:1px solid var(--line);
  background:
    radial-gradient(700px 380px at 15% 20%, rgba(112,84,255,.18), transparent 60%),
    radial-gradient(700px 380px at 85% 20%, rgba(35,213,255,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: 0 24px 90px rgba(0,0,0,.55);
  padding:14px 14px;
}

#cc-head{
  display:flex;
  gap:12px;
  align-items:flex-start;
  justify-content:space-between;
  margin-bottom:10px;
}

#cc-title{
  font-weight:800;
  font-size:14px;
  letter-spacing:.2px;
}

#cc-text{
  color:var(--muted);
  font-size:12.5px;
  line-height:1.45;
  margin-top:4px;
  max-width:85ch;
}

#cc-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}

.cc-btn{
  appearance:none;
  border:0;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  font-weight:800;
  font-size:13px;
  letter-spacing:.2px;
  cursor:pointer;
  user-select:none;
}

.cc-primary{
  color:#081022;
  background: linear-gradient(135deg, var(--btn), var(--btn2));
  box-shadow: 0 14px 40px rgba(35,213,255,.12), 0 14px 60px rgba(112,84,255,.18);
}

.cc-ghost{
  background: rgba(255,255,255,.06);
  color:var(--text);
  border:1px solid var(--line);
  box-shadow:none;
  font-weight:700;
}

.cc-link{
  background:transparent;
  color:var(--muted);
  border:1px solid transparent;
  font-weight:700;
}

.cc-link:hover{ text-decoration:underline; }

#cc-mini{
  margin-top:10px;
  color:var(--muted);
  font-size:12px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

#cc-mini a{ color:var(--muted); text-decoration:none; }
#cc-mini a:hover{ text-decoration:underline; }

#cc-modal{
  position:fixed;
  inset:0;
  z-index:10000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
}

#cc-modal .box{
  width:min(820px, 100%);
  border-radius:22px;
  border:1px solid var(--line);
  background: rgba(15,22,45,.92);
  box-shadow: 0 24px 90px rgba(0,0,0,.60);
  padding:16px;
}

#cc-modal .row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

#cc-modal h3{
  margin:0;
  font-size:16px;
  letter-spacing:.2px;
}

#cc-modal p{
  margin:6px 0 0;
  color:var(--muted);
  font-size:12.5px;
  line-height:1.5;
}

#cc-cats{
  margin-top:14px;
  display:grid;
  gap:10px;
}

.cc-cat{
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px;
  background: rgba(255,255,255,.04);
}

.cc-cat .top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin:0;
}

.cc-cat b{ font-size:13px; }

.cc-cat small{
  color:var(--muted);
  display:block;
  margin-top:6px;
  line-height:1.4;
}

.cc-switch{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:var(--muted);
  user-select:none;
}

.cc-switch input{
  width:18px;
  height:18px;
  accent-color: var(--btn2);
}

.cc-switch input:disabled{ opacity:.6; }

.cc-modal-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}

.cc-note{
  margin-top:10px;
  font-size:12px;
  color:var(--muted);
  line-height:1.4;
}

@media (max-width:520px){
  #cc-banner{ left:12px; right:12px; bottom:12px; }
}
