.consent-root{z-index:9999;position:relative}.consent-banner{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172a73;padding:1rem;position:fixed;inset:auto 0 0}.consent-banner-inner{background:#fff;border:1px solid #e2e8f0;border-radius:1rem;gap:1rem;max-width:56rem;margin:0 auto;padding:1.25rem 1.5rem;display:grid;box-shadow:0 20px 50px #0f172a2e}@media (width>=768px){.consent-banner-inner{grid-template-columns:1fr auto;align-items:center}}.consent-title{color:#0f172a;font-size:1rem;font-weight:700}.consent-text{color:#64748b;margin-top:.35rem;font-size:.875rem;line-height:1.5}.consent-actions{flex-wrap:wrap;gap:.5rem;display:flex}.consent-btn{cursor:pointer;border:1px solid #0000;border-radius:.75rem;justify-content:center;align-items:center;min-height:2.5rem;padding:0 1rem;font-size:.875rem;font-weight:600;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.consent-btn-primary{background:var(--brand);color:#fff}.consent-btn-primary:hover{background:var(--brand-hover)}.consent-btn-secondary{color:#0f172a;background:#fff;border-color:#cbd5e1}.consent-btn-secondary:hover{background:#f8fafc}.consent-btn-ghost{color:#475569;background:0 0}.consent-btn-ghost:hover{color:var(--brand)}.consent-modal{z-index:10000;justify-content:center;align-items:flex-end;padding:1rem;display:flex;position:fixed;inset:0}.consent-modal[hidden],.consent-banner[hidden]{display:none!important}body.consent-modal-open{overflow:hidden}@media (width>=640px){.consent-modal{align-items:center}}.consent-modal-backdrop{background:#0f172a80;position:absolute;inset:0}.consent-modal-panel{background:#fff;border-radius:1.25rem;flex-direction:column;width:min(100%,32rem);max-height:min(85vh,40rem);display:flex;position:relative;overflow:hidden;box-shadow:0 25px 60px #0f172a40}.consent-modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.consent-modal-header h2{color:#0f172a;font-size:1rem;font-weight:700}.consent-modal-close{color:#475569;cursor:pointer;background:#f1f5f9;border:none;border-radius:999px;justify-content:center;align-items:center;width:2rem;height:2rem;display:inline-flex}.consent-modal-body{gap:.75rem;padding:1rem 1.25rem;display:grid;overflow-y:auto}.consent-category{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.875rem;padding:.875rem 1rem}.consent-category-head{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.consent-category h3{color:#0f172a;font-size:.875rem;font-weight:600}.consent-category p{color:#64748b;margin-top:.25rem;font-size:.75rem;line-height:1.45}.consent-badge{color:#475569;text-transform:uppercase;letter-spacing:.04em;background:#e2e8f0;border-radius:999px;flex-shrink:0;padding:.2rem .5rem;font-size:.6875rem;font-weight:600}.consent-switch{flex-shrink:0;display:inline-flex;position:relative}.consent-switch input{opacity:0;width:0;height:0;position:absolute}.consent-switch-ui{background:#cbd5e1;border-radius:999px;width:2.75rem;height:1.5rem;transition:background .15s}.consent-switch-ui:after{content:"";background:#fff;border-radius:999px;width:1.25rem;height:1.25rem;transition:transform .15s;position:absolute;top:.125rem;left:.125rem;box-shadow:0 1px 3px #0f172a33}.consent-switch input:checked+.consent-switch-ui{background:var(--brand)}.consent-switch input:checked+.consent-switch-ui:after{transform:translate(1.25rem)}.consent-modal-footer{background:#fff;border-top:1px solid #e2e8f0;flex-wrap:wrap;justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;display:flex}
