/* =====================================================================
   COMPLIANZ COOKIE BANNER. Proud Brands custom skin.
   Scoped to .pb-cb with own tokens so the banner survives theme changes.
   Selectors use .pb-cb.cmplz-cookiebanner for high specificity, no !important.
   The plugin's own JS / show-hide logic (.cmplz-hidden, .cmplz-show,
   category visibility) is left intact.
   ===================================================================== */

.pb-cb {
	--pb-ink: #0d0d0d;
	--pb-white: #ffffff;
	--pb-off: #f5f4f0;
	--pb-flame: #f06522;
	--pb-cyan: #44c6ef;
	--pb-sans: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--pb-serif: 'Fraunces', Georgia, 'Times New Roman', serif;
	--pb-grotesk: 'Inter Tight', 'Inter', system-ui, sans-serif;
	--pb-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

/* Container. Pinned slab. Plugin handles position + show/hide logic. */
.pb-cb.cmplz-cookiebanner {
	font-family: var(--pb-sans);
	background: var(--pb-ink);
	color: var(--pb-white);
	border: 1px solid rgba(255,255,255,.08);
	border-radius: 0;
	padding: 0;
	max-width: 460px;
	width: calc(100vw - 48px);
	box-shadow: 0 24px 48px -12px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.04);
	z-index: 99999;
}

.pb-cb .pb-cb__inner { padding: 24px 26px; }

/* Header */
.pb-cb .pb-cb__head { display: grid; grid-template-columns: 1fr auto; grid-template-rows: auto auto; gap: 4px 16px; align-items: start; padding: 0 0 16px; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 18px; }
.pb-cb .pb-cb__eyebrow { grid-column: 1; grid-row: 1; margin: 0; font-family: var(--pb-mono); font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--pb-cyan); font-weight: 500; }
.pb-cb.cmplz-cookiebanner .cmplz-title.pb-cb__title { grid-column: 1; grid-row: 2; font-family: var(--pb-serif); font-weight: 800; font-size: 22px; letter-spacing: -.015em; line-height: 1.2; color: var(--pb-white); margin: 0; padding: 0; }
/* Aggressive reset. Beats the per-banner config CSS that ships its own width/height/border. */
.pb-cb.cmplz-cookiebanner .cmplz-close.pb-cb__close {
	grid-column: 2 !important;
	grid-row: 1 / span 2 !important;
	align-self: center !important;
	width: 28px !important;
	height: 28px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	background: transparent !important;
	border: 0 !important;
	outline: none !important;
	box-shadow: none !important;
	-webkit-appearance: none !important;
	appearance: none !important;
	color: rgba(255,255,255,.55) !important;
	cursor: pointer !important;
	padding: 0 !important;
	transition: color .18s ease, transform .18s ease !important;
	border-radius: 0 !important;
	font-size: 0 !important;
	line-height: 1 !important;
}
.pb-cb.cmplz-cookiebanner .cmplz-close.pb-cb__close:hover { color: var(--pb-cyan) !important; transform: rotate(90deg) !important; }
.pb-cb.cmplz-cookiebanner .cmplz-close.pb-cb__close:focus,
.pb-cb.cmplz-cookiebanner .cmplz-close.pb-cb__close:focus-visible { outline: 2px solid var(--pb-cyan) !important; outline-offset: 2px !important; }
.pb-cb.cmplz-cookiebanner .cmplz-close.pb-cb__close svg { width: 18px !important; height: 18px !important; display: block !important; }
.pb-cb.cmplz-cookiebanner .cmplz-close.pb-cb__close svg path { stroke: currentColor; fill: none; }

/* Body */
.pb-cb .pb-cb__body { padding: 0; }
.pb-cb.cmplz-cookiebanner .cmplz-message.pb-cb__msg { font-size: 14px; line-height: 1.6; color: rgba(255,255,255,.78); margin: 0 0 18px; }
.pb-cb.cmplz-cookiebanner .cmplz-message.pb-cb__msg a { color: var(--pb-cyan); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.pb-cb.cmplz-cookiebanner .cmplz-message.pb-cb__msg a:hover { color: var(--pb-white); }

/* Categories */
.pb-cb.cmplz-cookiebanner .cmplz-categories.pb-cb__cats { display: block; margin: 0 0 18px; padding: 0; border: none; }
.pb-cb.cmplz-cookiebanner .cmplz-category.pb-cb__cat { background: transparent; border: 1px solid rgba(255,255,255,.08); border-bottom: none; margin: 0; padding: 0; }
.pb-cb.cmplz-cookiebanner .cmplz-category.pb-cb__cat:last-child { border-bottom: 1px solid rgba(255,255,255,.08); }
.pb-cb.cmplz-cookiebanner .cmplz-category.pb-cb__cat summary { list-style: none; cursor: pointer; padding: 12px 14px; display: grid; grid-template-columns: 1fr auto auto; gap: 14px; align-items: center; user-select: none; transition: background .18s ease; }
.pb-cb.cmplz-cookiebanner .cmplz-category.pb-cb__cat summary::-webkit-details-marker { display: none; }
.pb-cb.cmplz-cookiebanner .cmplz-category.pb-cb__cat summary:hover { background: rgba(255,255,255,.03); }
.pb-cb .pb-cb__cat-title { font-family: var(--pb-grotesk); font-weight: 700; font-size: 12px; letter-spacing: .06em; text-transform: uppercase; color: var(--pb-white); }
.pb-cb .pb-cb__cat-state { display: inline-flex; align-items: center; }
.pb-cb .pb-cb__pill { display: inline-flex; align-items: center; padding: 4px 10px; font-family: var(--pb-mono); font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: var(--pb-cyan); background: rgba(68,198,239,.08); border: 1px solid rgba(68,198,239,.25); }
.pb-cb .pb-cb__caret { width: 22px; height: 22px; display: inline-flex; align-items: center; justify-content: center; color: rgba(255,255,255,.7); transition: transform .18s ease, color .18s ease; }
.pb-cb.cmplz-cookiebanner .cmplz-category.pb-cb__cat[open] .pb-cb__caret { transform: rotate(180deg); color: var(--pb-cyan); }
.pb-cb .pb-cb__caret svg { width: 16px; height: 16px; display: block; }
.pb-cb .pb-cb__caret svg path { stroke: currentColor; }
.pb-cb.cmplz-cookiebanner .cmplz-description.pb-cb__cat-desc { padding: 0 14px 14px; font-size: 12px; line-height: 1.55; color: rgba(255,255,255,.6); border-top: 1px dashed rgba(255,255,255,.08); margin-top: -1px; padding-top: 12px; }

/* Pill switch toggle.
   Complianz config CSS draws the slider with .cmplz-label::before (track)
   + .cmplz-label::after (bullet). We override those pseudo-elements with
   brand colours and dimensions, rather than fighting them with our own
   element. !important is required to beat the per-banner config CSS file
   served from /wp-content/uploads/complianz/css/banner-{id}-{type}.css. */
.pb-cb .pb-cb__cat-toggle { position: relative; display: inline-flex; align-items: center; padding: 0 4px; }

.pb-cb.cmplz-cookiebanner .cmplz-banner-checkbox.pb-cb__cat-toggle input.cmplz-consent-checkbox {
	position: absolute !important;
	opacity: 0 !important;
	width: 40px !important;
	height: 22px !important;
	margin: 0 !important;
	top: 0 !important;
	left: 0 !important;
	cursor: pointer !important;
	z-index: 2 !important;
}

.pb-cb.cmplz-cookiebanner .cmplz-banner-checkbox.pb-cb__cat-toggle .cmplz-label {
	position: relative !important;
	display: inline-block !important;
	width: 40px !important;
	height: 22px !important;
	padding: 0 !important;
	margin: 0 !important;
	cursor: pointer !important;
}

/* Track */
.pb-cb.cmplz-cookiebanner .cmplz-banner-checkbox.pb-cb__cat-toggle .cmplz-label::before {
	content: '' !important;
	display: block !important;
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	width: 40px !important;
	height: 22px !important;
	background: rgba(255,255,255,.18) !important;
	border: 1px solid rgba(255,255,255,.25) !important;
	border-radius: 999px !important;
	padding: 0 !important;
	transition: background-color .2s ease, border-color .2s ease !important;
	font-size: 0 !important;
	line-height: 1 !important;
	box-sizing: border-box !important;
	font-family: inherit !important;
	color: transparent !important;
}

/* Bullet */
.pb-cb.cmplz-cookiebanner .cmplz-banner-checkbox.pb-cb__cat-toggle .cmplz-label::after {
	content: '' !important;
	display: block !important;
	position: absolute !important;
	top: 3px !important;
	left: 3px !important;
	width: 14px !important;
	height: 14px !important;
	background: var(--pb-white) !important;
	border-radius: 50% !important;
	transition: left .2s ease, background-color .2s ease !important;
	box-shadow: 0 1px 2px rgba(0,0,0,.25) !important;
	letter-spacing: 0 !important;
}

/* Checked state */
.pb-cb.cmplz-cookiebanner .cmplz-banner-checkbox.pb-cb__cat-toggle input.cmplz-consent-checkbox:checked + .cmplz-label::before {
	background: var(--pb-cyan) !important;
	border-color: var(--pb-cyan) !important;
}
.pb-cb.cmplz-cookiebanner .cmplz-banner-checkbox.pb-cb__cat-toggle input.cmplz-consent-checkbox:checked + .cmplz-label::after {
	left: 21px !important;
	background: var(--pb-ink) !important;
}

/* Focus ring on the track when input is focused */
.pb-cb.cmplz-cookiebanner .cmplz-banner-checkbox.pb-cb__cat-toggle input.cmplz-consent-checkbox:focus-visible + .cmplz-label::before {
	outline: 2px solid var(--pb-cyan) !important;
	outline-offset: 2px !important;
}

/* Information links row */
.pb-cb.cmplz-cookiebanner .cmplz-links.pb-cb__links { padding: 0; margin: 0 0 16px; }
.pb-cb.cmplz-cookiebanner .cmplz-links.pb-cb__links ul { display: flex; flex-wrap: wrap; gap: 16px; padding: 0; margin: 0; list-style: none; }
.pb-cb.cmplz-cookiebanner .cmplz-links.pb-cb__links li { padding: 0; margin: 0; }
.pb-cb.cmplz-cookiebanner .cmplz-links.pb-cb__links a { font-family: var(--pb-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.6); text-decoration: none; padding-bottom: 2px; border-bottom: 1px dotted rgba(255,255,255,.25); transition: color .18s ease, border-color .18s ease; }
.pb-cb.cmplz-cookiebanner .cmplz-links.pb-cb__links a:hover { color: var(--pb-cyan); border-bottom-color: var(--pb-cyan); }

/* Buttons */
.pb-cb.cmplz-cookiebanner .cmplz-buttons.pb-cb__btns { display: flex; flex-wrap: wrap; gap: 10px; padding: 0; margin: 0; border: none; }
.pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn { font-family: var(--pb-grotesk); font-weight: 700; font-size: 12px; letter-spacing: .06em; text-transform: uppercase; padding: 12px 18px; border: 1px solid transparent; cursor: pointer; transition: background .18s ease, color .18s ease, border-color .18s ease; line-height: 1; border-radius: 0; box-shadow: none; min-height: 0; min-width: 0; }
.pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--primary { background: var(--pb-flame); color: var(--pb-white); border-color: var(--pb-flame); }
.pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--primary:hover { background: var(--pb-white); color: var(--pb-ink); border-color: var(--pb-white); }
.pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--ghost { background: transparent; color: var(--pb-white); border-color: rgba(255,255,255,.25); }
.pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--ghost:hover { border-color: var(--pb-white); background: rgba(255,255,255,.06); }
.pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--text { background: transparent; color: rgba(255,255,255,.65); border: none; padding-left: 0; padding-right: 0; }
.pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--text:hover { color: var(--pb-cyan); }

/* Document links foot */
.pb-cb.cmplz-cookiebanner .cmplz-documents.pb-cb__docs { margin-top: 18px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,.08); }
.pb-cb.cmplz-cookiebanner .cmplz-documents.pb-cb__docs ul { display: flex; flex-wrap: wrap; gap: 14px; padding: 0; margin: 0; list-style: none; }
.pb-cb.cmplz-cookiebanner .cmplz-documents.pb-cb__docs a { font-family: var(--pb-mono); font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.45); text-decoration: none; }
.pb-cb.cmplz-cookiebanner .cmplz-documents.pb-cb__docs a:hover { color: var(--pb-cyan); }

/* Light theme overrides. Driven by html[data-theme="light"], same hook the theme uses */
html[data-theme="light"] .pb-cb.cmplz-cookiebanner { background: var(--pb-off); color: var(--pb-ink); border-color: rgba(13,13,13,.1); box-shadow: 0 24px 48px -12px rgba(13,13,13,.18), 0 0 0 1px rgba(13,13,13,.04); }
html[data-theme="light"] .pb-cb .pb-cb__head { border-bottom-color: rgba(13,13,13,.1); }
html[data-theme="light"] .pb-cb .pb-cb__eyebrow { color: var(--pb-flame); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-title.pb-cb__title { color: var(--pb-ink); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-close.pb-cb__close { color: rgba(13,13,13,.55); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-close.pb-cb__close:hover { color: var(--pb-flame); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-message.pb-cb__msg { color: rgba(13,13,13,.75); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-message.pb-cb__msg a { color: var(--pb-flame); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-message.pb-cb__msg a:hover { color: var(--pb-ink); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-category.pb-cb__cat { border-color: rgba(13,13,13,.1); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-category.pb-cb__cat:last-child { border-bottom-color: rgba(13,13,13,.1); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-category.pb-cb__cat summary:hover { background: rgba(13,13,13,.03); }
html[data-theme="light"] .pb-cb .pb-cb__cat-title { color: var(--pb-ink); }
html[data-theme="light"] .pb-cb .pb-cb__pill { color: var(--pb-flame); background: rgba(240,101,34,.08); border-color: rgba(240,101,34,.25); }
html[data-theme="light"] .pb-cb .pb-cb__caret { color: rgba(13,13,13,.65); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-category.pb-cb__cat[open] .pb-cb__caret { color: var(--pb-flame); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-description.pb-cb__cat-desc { color: rgba(13,13,13,.6); border-top-color: rgba(13,13,13,.1); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-banner-checkbox.pb-cb__cat-toggle .cmplz-label::before { background: rgba(13,13,13,.18) !important; border-color: rgba(13,13,13,.25) !important; }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-banner-checkbox.pb-cb__cat-toggle .cmplz-label::after { background: var(--pb-white) !important; box-shadow: 0 1px 2px rgba(0,0,0,.15) !important; }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-banner-checkbox.pb-cb__cat-toggle input.cmplz-consent-checkbox:checked + .cmplz-label::before { background: var(--pb-flame) !important; border-color: var(--pb-flame) !important; }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-banner-checkbox.pb-cb__cat-toggle input.cmplz-consent-checkbox:checked + .cmplz-label::after { background: var(--pb-white) !important; }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-links.pb-cb__links a { color: rgba(13,13,13,.6); border-bottom-color: rgba(13,13,13,.25); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-links.pb-cb__links a:hover { color: var(--pb-flame); border-bottom-color: var(--pb-flame); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--primary { background: var(--pb-flame); color: var(--pb-white); border-color: var(--pb-flame); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--primary:hover { background: var(--pb-ink); color: var(--pb-white); border-color: var(--pb-ink); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--ghost { color: var(--pb-ink); border-color: rgba(13,13,13,.25); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--ghost:hover { border-color: var(--pb-ink); background: rgba(13,13,13,.04); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--text { color: rgba(13,13,13,.65); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--text:hover { color: var(--pb-flame); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-documents.pb-cb__docs { border-top-color: rgba(13,13,13,.1); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-documents.pb-cb__docs a { color: rgba(13,13,13,.5); }
html[data-theme="light"] .pb-cb.cmplz-cookiebanner .cmplz-documents.pb-cb__docs a:hover { color: var(--pb-flame); }

/* Mobile. Full-width slab */
@media (max-width: 640px) {
	.pb-cb.cmplz-cookiebanner { max-width: none; width: calc(100vw - 24px); }
	.pb-cb .pb-cb__inner { padding: 18px 18px; }
	.pb-cb.cmplz-cookiebanner .cmplz-buttons.pb-cb__btns { flex-direction: column; gap: 8px; }
	.pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn { width: 100%; }
	.pb-cb.cmplz-cookiebanner .cmplz-btn.pb-cb__btn--text { width: auto; align-self: center; padding-top: 4px; }
}
