/* Banner */
.cc-banner{ position:fixed; z-index:9999; inset:auto 1rem 1rem 1rem; max-width:720px; margin-left:auto;
  background:#fff; border:1px solid #e8eaf0; border-radius:14px; box-shadow:0 12px 40px rgba(15,28,45,.18);
  padding:18px 18px 14px; font:16px/1.45 system-ui,-apple-system,Segoe UI,Roboto,Arial; color:#203551; }
.cc-banner h3{ margin:0 0 8px; font-weight:800; font-size:20px; }
.cc-banner p{ margin:0 0 12px; color:#55627a; }
.cc-actions{ display:flex; gap:.6rem; flex-wrap:wrap; }
.cc-btn{ padding:.55rem .9rem; border-radius:12px; border:1px solid #d8dde6; background:#fff; cursor:pointer; }
.cc-btn:hover{ background:#f7f9fc; }
.cc-btn--reject{ border-color:#cfd6e3; }
.cc-btn--accept{ background:#35b26f; border-color:#35b26f; color:#fff; }
.cc-btn--accept:hover{ filter:brightness(.96); }

/* Modal préférences */
.cc-modal{ position:fixed; inset:0; background:rgba(0,0,0,.45); display:none; align-items:center; justify-content:center; z-index:10000; }
.cc-modal .cc-card{ background:#fff; width:min(680px,92vw); border-radius:14px; box-shadow:0 18px 50px rgba(15,28,45,.2); padding:18px; }
.cc-row{ display:flex; align-items:center; justify-content:space-between; padding:10px 0; border-bottom:1px solid #eef2f7; }
.cc-row:last-child{ border-bottom:0; }
.cc-switch{ appearance:none; width:44px; height:26px; background:#e1e6ef; border-radius:999px; position:relative; outline:none; cursor:pointer; }
.cc-switch:before{ content:""; position:absolute; top:3px; left:3px; width:20px; height:20px; border-radius:50%; background:#fff; transition:.2s; }
.cc-switch:checked{ background:#35b26f; }
.cc-switch:checked:before{ transform:translateX(18px); }
.cc-footer{ display:flex; gap:.6rem; justify-content:flex-end; margin-top:12px; }
@media (max-width:768px){ .cc-banner{ inset:auto .5rem .5rem .5rem; } }
