/* Cookie Consent banner — implemented to 123abc.co.uk blueprints spec.
   Theme via CSS vars to match the site (--cc-bg, --cc-ink, --cc-accent). */

:root {
  --cc-bg:     #0e1117;
  --cc-ink:    #ffffff;
  --cc-muted:  #b8bcc4;
  --cc-accent: #f7b500;
  --cc-radius: 14px;
}

.cc-banner {
  position: fixed;
  left: 50%;
  bottom: 20px;
  transform: translateX(-50%);
  width: calc(100% - 32px);
  max-width: 760px;
  background: var(--cc-bg);
  color: var(--cc-ink);
  border-radius: var(--cc-radius);
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.35), 0 0 0 1px rgba(255, 255, 255, 0.06) inset;
  z-index: 9999;
  font: 14px/1.5 -apple-system, "Segoe UI", system-ui, sans-serif;
  animation: cc-slide-in .25s ease both;
}

@keyframes cc-slide-in {
  from { opacity: 0; transform: translate(-50%, 24px); }
  to   { opacity: 1; transform: translate(-50%, 0); }
}

.cc-inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 18px;
  padding: 18px 22px;
  align-items: center;
}

.cc-message strong {
  display: block;
  font-size: 15px;
  margin-bottom: 6px;
}

.cc-message p {
  margin: 0;
  color: var(--cc-muted);
  font-size: 13px;
}

.cc-message a {
  color: var(--cc-accent);
  text-decoration: underline;
}

.cc-actions {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
}

.cc-btn {
  appearance: none;
  border: 0;
  padding: 10px 18px;
  border-radius: 999px;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  transition: transform .12s, background .12s, color .12s;
  white-space: nowrap;
}

.cc-reject {
  background: transparent;
  color: var(--cc-muted);
  border: 1px solid rgba(255, 255, 255, 0.18);
}

.cc-reject:hover {
  color: var(--cc-ink);
  border-color: rgba(255, 255, 255, 0.4);
}

.cc-accept {
  background: var(--cc-accent);
  color: #422006;
}

.cc-accept:hover {
  transform: translateY(-1px);
}

@media (max-width: 700px) {
  .cc-inner { grid-template-columns: 1fr; gap: 14px; }
  .cc-actions { width: 100%; }
  .cc-btn { flex: 1; padding: 11px 12px; font-size: 13px; }
}

/* Gated embed placeholder — shown when consent === rejected or unset */
.cc-placeholder {
  background: #f7f7f5;
  border: 1px dashed #cbd5e1;
  border-radius: 10px;
  padding: 22px;
  text-align: center;
  color: #5b6470;
  font-size: 14px;
}

.cc-placeholder p { margin: 0 0 12px; }
.cc-placeholder .cc-btn { padding: 8px 16px; font-size: 13px; }
