
/* Consent widgets (fallback) */
.ctn-consent-banner{
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 9999;
  background: var(--card); color: var(--text);
  border-top: 1px solid var(--border);
  box-shadow: 0 -8px 24px rgba(0,0,0,0.12);
  padding: 16px;
  display: none;
}
.ctn-consent-wrap{ max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: center; }
.ctn-consent-text{ font-size: 14px; color: var(--muted); }
.ctn-consent-actions{ display: flex; gap: 8px; }
.ctn-btn{ height: 40px; padding: 0 14px; border-radius: 10px; border: 1px solid var(--border); background: var(--card); cursor: pointer; }
.ctn-btn.primary{ background: var(--accent); color: var(--accent-contrast); border-color: var(--accent); }
.ctn-btn.link{ background: transparent; color: var(--accent); border-color: var(--accent); }

/* Preferences modal */
.ctn-modal{
  position: fixed; inset: 0; z-index: 10000; display: none;
  background: rgba(0,0,0,0.4);
}
.ctn-modal-panel{
  background: var(--card); color: var(--text);
  width: min(560px, 92%); margin: 8vh auto; border-radius: 14px; padding: 16px;
  box-shadow: var(--shadow);
}
.ctn-options{ display: grid; gap: 12px; margin: 12px 0; }
.ctn-opt{ display:flex; align-items: center; justify-content: space-between; border:1px solid var(--border); border-radius:12px; padding: 10px 12px; }
.ctn-opt label{ display:block; font-weight:600; }
.ctn-opt small{ color: var(--muted); display:block; margin-top: 4px; }
.ctn-switch input{ width: 48px; height: 24px; }
.ctn-modal-foot{ display:flex; gap:8px; justify-content:flex-end; margin-top: 12px; }
@media (max-width: 720px){
  .ctn-consent-wrap{ grid-template-columns: 1fr; }
  .ctn-consent-actions{ justify-content: flex-end; }
}
