:root{
  --ex180-brand:#0EA5E9;
  --ex180-accent:#111827;
  --ex180-text:#111827;
  --ex180-bg:#ffffff;
}

#ex180-consent-root{position:fixed;left:0;right:0;z-index:99999;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ex180-text);}
#ex180-consent-root[data-position="bottom"]{bottom:0}
#ex180-consent-root[data-position="top"]{top:0}
#ex180-consent-root .ex180-consent-banner{
  margin:12px auto;
  max-width:960px;
  background:var(--ex180-bg);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 10px 40px rgba(0,0,0,.12);
  border-radius:16px;
  padding:16px;
  display:flex;gap:16px;align-items:center;justify-content:space-between;
}
#ex180-consent-root .ex180-consent-text{margin:0;font-size:14px;line-height:1.4}
#ex180-consent-root .ex180-consent-actions{display:flex;gap:8px;flex-wrap:wrap}
#ex180-consent-root .ex180-btn{
  cursor:pointer;border:none;border-radius:12px;padding:10px 14px;font-weight:600;
}
#ex180-consent-root .ex180-btn-accept{background:var(--ex180-brand);color:#fff}
#ex180-consent-root .ex180-btn-reject{background:#e5e7eb;color:#111827}
#ex180-consent-root .ex180-btn-manage{background:transparent;color:var(--ex180-accent);text-decoration:underline}

#ex180-consent-root .ex180-consent-modal{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;padding:20px;}
#ex180-consent-root .ex180-modal-card{background:#fff;border-radius:16px;max-width:720px;width:100%;padding:20px;box-shadow:0 10px 40px rgba(0,0,0,.2)}
#ex180-consent-root .ex180-modal-card h3{margin:0 0 12px}
#ex180-consent-root .ex180-cats{display:flex;flex-direction:column;gap:12px;margin:12px 0}
#ex180-consent-root .ex180-cat{display:flex;justify-content:space-between;gap:12px;align-items:center;border:1px solid #e5e7eb;border-radius:12px;padding:12px}
#ex180-consent-root .ex180-modal-actions{display:flex;justify-content:flex-end;gap:8px}
#ex180-consent-root .ex180-btn-primary{background:var(--ex180-brand);color:#fff}
#ex180-consent-root .ex180-btn-secondary{background:#e5e7eb;color:#111827}

.ex180-switch{position:relative;display:inline-block;width:46px;height:26px}
.ex180-switch input{opacity:0;width:0;height:0}
.ex180-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#d1d5db;transition:.2s;border-radius:999px}
.ex180-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;top:3px;background:white;transition:.2s;border-radius:50%}
.ex180-switch input:checked + .ex180-slider{background:var(--ex180-brand)}
.ex180-switch input:checked + .ex180-slider:before{transform:translateX(20px)}

#ex180-consent-root .ex180-badge{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:999px;background:#eef2ff;color:#1f2937;font-weight:600;font-size:11px}
#ex180-consent-root .ex180-badge.alt{background:#ecfdf5;color:#065f46}

@media (max-width:640px){
  #ex180-consent-root .ex180-consent-banner{flex-direction:column;align-items:flex-start}
}
