#cc-banner{position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--warm-white);border-top:1px solid var(--border);box-shadow:0 -4px 32px #0b1d3a12;padding:1.125rem 3rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;transform:translateY(100%);transition:transform .4s cubic-bezier(.16,1,.3,1)}#cc-banner.cc-visible{transform:translateY(0)}.cc-banner-text{display:flex;flex-direction:column;gap:.25rem;min-width:0;flex:1}.cc-label{font-family:var(--font-body);font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);line-height:1;margin-bottom:.125rem}.cc-banner-text p{font-family:var(--font-body);font-size:.875rem;color:var(--muted);line-height:1.5;margin:0}.cc-banner-text a{color:var(--navy);text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--border);transition:text-decoration-color .2s}.cc-banner-text a:hover{text-decoration-color:var(--navy)}.cc-banner-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0;flex-wrap:wrap}.cc-btn{font-family:var(--font-body);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;white-space:nowrap;min-height:44px;display:inline-flex;align-items:center;justify-content:center;padding:0 1.375rem;border-radius:var(--radius-full)}.cc-btn:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.cc-btn-primary{background:var(--accent);color:#fff}.cc-btn-primary:hover{background:var(--accent-light);transform:translateY(-1px)}.cc-btn-ghost{background:transparent;color:var(--navy);border:1.5px solid var(--border);border-color:#0b1d3a33}.cc-btn-ghost:hover{border-color:var(--navy);background:#0b1d3a0a}.cc-btn-text{background:transparent;color:var(--muted);padding:0 .5rem;font-weight:500;text-decoration:underline;text-underline-offset:2px;text-decoration-color:transparent;transition:color .2s,text-decoration-color .2s}.cc-btn-text:hover{color:var(--navy);text-decoration-color:var(--navy)}.cc-btn-save{background:var(--navy);color:var(--warm-white);width:100%;font-size:.9375rem;padding:0 2rem;min-height:48px;border-radius:var(--radius-full)}.cc-btn-save:hover{background:var(--navy-light);transform:translateY(-1px)}#cc-modal-overlay{position:fixed;inset:0;z-index:300;background:#0b1d3a8c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:1rem}#cc-modal-overlay[hidden]{display:none}#cc-modal{background:var(--warm-white);border-radius:var(--radius-lg);max-width:520px;width:100%;box-shadow:var(--shadow-xl),0 0 0 1px var(--border);max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;outline:none}.cc-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.75rem 1.125rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--warm-white);z-index:1;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.cc-modal-header h2{font-family:var(--font-display);font-size:1.25rem;font-weight:400;color:var(--navy);margin:0;letter-spacing:-.01em}.cc-close-btn{width:36px;height:36px;min-height:unset;border-radius:var(--radius-full);background:transparent;border:1.5px solid var(--border);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;padding:0}.cc-close-btn:hover{background:#0b1d3a0d;border-color:#0b1d3a33;color:var(--navy)}.cc-close-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.cc-modal-body{padding:1.375rem 1.75rem;display:flex;flex-direction:column;gap:0}.cc-modal-intro{font-family:var(--font-body);font-size:.875rem;color:var(--muted);line-height:1.6;margin:0 0 1.25rem}.cc-category-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;padding:1rem 0}.cc-category-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.375rem}.cc-category-name-row{display:flex;align-items:center;gap:.625rem;flex-wrap:wrap}.cc-category-name{font-family:var(--font-body);font-size:.9375rem;font-weight:600;color:var(--navy);line-height:1.3}.cc-category-desc{font-family:var(--font-body);font-size:.8125rem;color:var(--muted);line-height:1.55;margin:0}.cc-divider{height:1px;background:var(--border)}.cc-always-on-badge{display:inline-flex;align-items:center;padding:.2em .65em;background:#2a7d6e1f;color:var(--teal);border-radius:var(--radius-full);font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-family:var(--font-body);white-space:nowrap}.cc-toggle-locked{width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:var(--teal);flex-shrink:0;opacity:.7}.cc-toggle{position:relative;width:44px;height:26px;border-radius:100px;border:none;cursor:pointer;background:#0b1d3a26;transition:background .25s ease;flex-shrink:0;padding:0;min-height:unset;margin-top:2px}.cc-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.cc-toggle[aria-checked=true]{background:var(--teal)}.cc-toggle-thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #0b1d3a33;transition:transform .25s cubic-bezier(.34,1.56,.64,1);pointer-events:none}.cc-toggle[aria-checked=true] .cc-toggle-thumb{transform:translate(18px)}.cc-modal-footer{padding:1.125rem 1.75rem 1.5rem;border-top:1px solid var(--border);background:var(--warm-white);border-radius:0 0 var(--radius-lg) var(--radius-lg);position:sticky;bottom:0}#cc-dns-link{color:var(--accent)!important}#cc-dns-link:hover{text-decoration:underline;text-underline-offset:2px}@media(max-width:768px){#cc-banner{flex-direction:column;align-items:flex-start;padding:1.25rem 1.25rem 1.5rem;gap:1rem}.cc-banner-actions{flex-direction:column;width:100%;gap:.625rem}.cc-btn-primary,.cc-btn-ghost{width:100%}.cc-btn-text{align-self:center}#cc-modal-overlay{align-items:flex-end;padding:0}#cc-modal{max-width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:88vh}.cc-modal-header{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.cc-modal-footer{border-radius:0}}@media(max-width:480px){#cc-banner{padding:1.125rem 1rem 1.375rem}.cc-modal-body{padding:1.125rem 1.25rem}.cc-modal-header{padding:1.25rem 1.25rem 1rem}.cc-modal-footer{padding:1rem 1.25rem 1.375rem}}
