.cmp-banner{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:10000;background:#fff;color:#1a1a1a;border-radius:.75rem;box-shadow:0 10px 40px rgba(0,0,0,.25);max-width:780px;margin:0 auto;font-family:inherit;line-height:1.5}
.cmp-banner[hidden]{display:none}
.cmp-inner{padding:1.25rem 1.5rem}
.cmp-title{font-size:1.05rem;margin:0 0 .5rem;font-weight:600}
.cmp-text{font-size:.875rem;margin:0 0 1rem;color:#333}
.cmp-text a{color:#0a58ca;text-decoration:underline}
.cmp-actions{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}
.cmp-btn{font:inherit;font-size:.85rem;padding:.55rem 1.1rem;border-radius:.4rem;border:1px solid transparent;cursor:pointer;transition:opacity .15s}
.cmp-btn:hover{opacity:.85}
.cmp-btn-primary{background:#1a1a1a;color:#fff;border-color:#1a1a1a}
.cmp-btn-ghost{background:transparent;color:#1a1a1a;border-color:#cfcfcf}
.cmp-settings{padding:0 1.5rem 1.25rem;border-top:1px solid #eee;margin-top:.25rem}
.cmp-settings[hidden]{display:none}
.cmp-cats{list-style:none;padding:0;margin:1rem 0}
.cmp-cat{padding:.75rem 0;border-bottom:1px solid #f0f0f0}
.cmp-cat:last-child{border-bottom:0}
.cmp-cat-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}
.cmp-cat p{font-size:.8rem;color:#555;margin:0}
.cmp-locked{font-size:.75rem;color:#888;text-transform:uppercase;letter-spacing:.05em}
.cmp-switch{position:relative;display:inline-block;width:38px;height:22px}
.cmp-switch input{opacity:0;width:0;height:0}
.cmp-slider{position:absolute;cursor:pointer;inset:0;background:#ccc;border-radius:22px;transition:.2s}
.cmp-slider::before{content:"";position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}
.cmp-switch input:checked+.cmp-slider{background:#1a1a1a}
.cmp-switch input:checked+.cmp-slider::before{transform:translateX(16px)}
.cmp-floating{position:fixed;left:1rem;bottom:1rem;z-index:9999;width:40px;height:40px;border-radius:50%;border:none;background:#1a1a1a;color:#fff;cursor:pointer;box-shadow:0 4px 14px rgba(0,0,0,.25);display:none;align-items:center;justify-content:center}
.cmp-floating.is-visible{display:inline-flex}
.cmp-floating:hover{opacity:.9}
@media (max-width:540px){
    .cmp-actions{justify-content:stretch}
    .cmp-btn{flex:1 1 auto}
}
