/* ── Variables ────────────────────────────────────────────────────────────── */
:root {
	--ccc-accent:       #0094C8;
	--ccc-accent-dark:  #0079a8;
	--ccc-bg:           #1c1c1c;
	--ccc-text:         #ffffff;
	--ccc-muted:        #aaaaaa;
	--ccc-border:       rgba(255,255,255,0.12);
	--ccc-row-alt:      #252525;
	--ccc-th-bg:        #2a2a2a;
	--ccc-radius:       8px;
	--ccc-radius-lg:    12px;
	--ccc-z:            9999999;
}

/* ── Modal: light theme override ─────────────────────────────────────────── */
#ccc-modal {
	--ccc-bg:      #F5F6F8;
	--ccc-text:    #1A1D26;
	--ccc-muted:   #6B7490;
	--ccc-border:  #E2E4EC;
	--ccc-row-alt: #ECEEF3;
	--ccc-th-bg:   #ECEEF3;
}

/* Ensure hidden attribute always wins over our display overrides */
#ccc-banner[hidden],
#ccc-modal[hidden],
#ccc-revisit[hidden] {
	display: none !important;
}

/* ── Hard isolation — reset everything inside our containers ─────────────── */
#ccc-banner,
#ccc-modal,
#ccc-revisit {
	all: initial;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
	font-size: 14px !important;
	line-height: 1.5 !important;
	color: var(--ccc-text) !important;
	box-sizing: border-box !important;
}

#ccc-banner *,
#ccc-modal *,
#ccc-revisit * {
	box-sizing: border-box !important;
	font-family: inherit !important;
	-webkit-font-smoothing: antialiased;
}

/* Reset buttons hard — Elementor/theme styles override otherwise */
#ccc-banner button,
#ccc-modal button,
#ccc-revisit button,
#ccc-banner .ccc-btn,
#ccc-modal .ccc-btn {
	all: unset !important;
	cursor: pointer !important;
	box-sizing: border-box !important;
	font-family: inherit !important;
	line-height: 1 !important;
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	border: none !important;
	padding: 0 !important;
	margin: 0 !important;
	color: inherit !important;
}

/* Nuke ALL button hover/focus backgrounds — then selectively re-allow below */
#ccc-banner button:hover,
#ccc-banner button:focus,
#ccc-banner button:active,
#ccc-modal button:hover,
#ccc-modal button:focus,
#ccc-modal button:active {
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	box-shadow: none !important;
	outline: none !important;
}

#ccc-banner a,
#ccc-modal a {
	all: unset !important;
	cursor: pointer !important;
	color: var(--ccc-accent) !important;
	text-decoration: underline !important;
}
#ccc-banner a:hover,
#ccc-modal a:hover {
	text-decoration: none !important;
}

/* ── Banner ──────────────────────────────────────────────────────────────── */
#ccc-banner {
	position: fixed !important;
	left: 0 !important;
	right: 0 !important;
	background: var(--ccc-bg) !important;
	border-top: 1px solid var(--ccc-border) !important;
	box-shadow: 0 -4px 24px rgba(0,0,0,.10) !important;
	z-index: var(--ccc-z) !important;
	padding: 16px 0 !important;
	display: block !important;
}
#ccc-banner.ccc-banner--bottom { bottom: 0 !important; top: auto !important; }
#ccc-banner.ccc-banner--top    { top: 0 !important; bottom: auto !important; border-top: none !important; border-bottom: 1px solid var(--ccc-border) !important; box-shadow: 0 4px 24px rgba(0,0,0,.10) !important; }

.ccc-banner__inner {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 32px !important;
	max-width: 1280px !important;
	margin: 0 auto !important;
	padding: 0 28px !important;
}

.ccc-banner__content {
	display: flex !important;
	align-items: flex-start !important;
	gap: 14px !important;
	flex: 1 !important;
	min-width: 0 !important;
}

.ccc-banner__icon {
	font-size: 28px !important;
	line-height: 1 !important;
	flex-shrink: 0 !important;
	margin-top: 2px !important;
}

.ccc-banner__text { flex: 1 !important; min-width: 0 !important; }

.ccc-banner__title {
	font-size: 15px !important;
	font-weight: 700 !important;
	margin: 0 0 4px !important;
	color: var(--ccc-text) !important;
	display: block !important;
}

.ccc-banner__desc {
	font-size: 13px !important;
	color: var(--ccc-muted) !important;
	margin: 0 !important;
	line-height: 1.5 !important;
	display: block !important;
}

.ccc-banner__actions {
	display: flex !important;
	align-items: center !important;
	gap: 10px !important;
	flex-shrink: 0 !important;
}

/* ── Buttons — ID-prefixed to beat #ccc-banner/modal button{all:unset} (1,0,1) ── */
#ccc-banner .ccc-btn,
#ccc-modal .ccc-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	border-radius: var(--ccc-radius) !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	padding: 9px 20px !important;
	transition: background .15s, color .15s, border-color .15s, opacity .15s !important;
	white-space: nowrap !important;
	border: 2px solid transparent !important;
	line-height: 1.4 !important;
	cursor: pointer !important;
	text-decoration: none !important;
	box-sizing: border-box !important;
}

/* Primary */
#ccc-banner .ccc-btn--primary,
#ccc-modal .ccc-btn--primary {
	background: var(--ccc-accent) !important;
	background-color: var(--ccc-accent) !important;
	color: #fff !important;
	border: 2px solid var(--ccc-accent) !important;
}
#ccc-banner .ccc-btn--primary:hover,
#ccc-banner .ccc-btn--primary:focus,
#ccc-modal .ccc-btn--primary:hover,
#ccc-modal .ccc-btn--primary:focus {
	background: var(--ccc-accent-dark) !important;
	background-color: var(--ccc-accent-dark) !important;
	border-color: var(--ccc-accent-dark) !important;
	color: #fff !important;
}

/* Outline */
#ccc-banner .ccc-btn--outline,
#ccc-modal .ccc-btn--outline {
	background: transparent !important;
	background-color: transparent !important;
	color: var(--ccc-text) !important;
	border: 2px solid rgba(255,255,255,0.35) !important;
}
#ccc-banner .ccc-btn--outline:hover,
#ccc-banner .ccc-btn--outline:focus,
#ccc-modal .ccc-btn--outline:hover,
#ccc-modal .ccc-btn--outline:focus {
	border-color: rgba(255,255,255,0.7) !important;
	background: transparent !important;
	background-color: transparent !important;
	color: var(--ccc-text) !important;
}

/* Ghost */
#ccc-banner .ccc-btn--ghost,
#ccc-modal .ccc-btn--ghost {
	background: transparent !important;
	background-color: transparent !important;
	color: var(--ccc-muted) !important;
	border: 2px solid transparent !important;
	font-size: 13px !important;
	text-decoration: underline !important;
	padding: 9px 8px !important;
}
#ccc-banner .ccc-btn--ghost:hover,
#ccc-modal .ccc-btn--ghost:hover {
	color: var(--ccc-text) !important;
	background: transparent !important;
	background-color: transparent !important;
}

/* ── Modal overlay ───────────────────────────────────────────────────────── */
#ccc-modal {
	position: fixed !important;
	inset: 0 !important;
	z-index: calc(var(--ccc-z) + 1) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

.ccc-modal__overlay {
	position: absolute !important;
	inset: 0 !important;
	background: rgba(17,24,39,.55) !important;
	z-index: 0 !important;
}

.ccc-modal__dialog {
	position: relative !important;
	z-index: 1 !important;
	background: var(--ccc-bg) !important;
	border-radius: var(--ccc-radius-lg) !important;
	box-shadow: 0 20px 60px rgba(0,0,0,.20) !important;
	width: min(560px, calc(100vw - 32px)) !important;
	max-height: calc(100vh - 64px) !important;
	display: flex !important;
	flex-direction: column !important;
	overflow: hidden !important;
}

.ccc-modal__header {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	padding: 20px 24px !important;
	border-bottom: 1px solid var(--ccc-border) !important;
	flex-shrink: 0 !important;
}

.ccc-modal__title {
	font-size: 16px !important;
	font-weight: 700 !important;
	color: var(--ccc-text) !important;
	margin: 0 !important;
	display: block !important;
}

/* Max specificity: html body + ID + element+ID — beats any theme rule */
html body #ccc-modal button#ccc-modal-close,
html body #ccc-modal button#ccc-modal-close:link,
html body #ccc-modal button#ccc-modal-close:visited {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 32px !important;
	height: 32px !important;
	border-radius: 50% !important;
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	border: none !important;
	box-shadow: none !important;
	outline: none !important;
	color: var(--ccc-muted) !important;
	font-size: 22px !important;
	line-height: 1 !important;
	padding: 0 !important;
	margin: 0 !important;
	transition: background .15s, color .15s !important;
	flex-shrink: 0 !important;
}
html body #ccc-modal button#ccc-modal-close:hover,
html body #ccc-modal button#ccc-modal-close:focus,
html body #ccc-modal button#ccc-modal-close:active {
	background: var(--ccc-border) !important;
	background-color: var(--ccc-border) !important;
	background-image: none !important;
	border: none !important;
	box-shadow: none !important;
	outline: none !important;
	color: var(--ccc-text) !important;
}

.ccc-modal__body {
	flex: 1 !important;
	overflow-y: auto !important;
}

.ccc-modal__footer {
	display: flex !important;
	align-items: center !important;
	justify-content: flex-end !important;
	gap: 10px !important;
	padding: 16px 24px !important;
	border-top: 1px solid var(--ccc-border) !important;
	flex-shrink: 0 !important;
	flex-wrap: wrap !important;
}

/* ── Category rows ───────────────────────────────────────────────────────── */
.ccc-cat {
	border-bottom: 1px solid var(--ccc-border) !important;
}
.ccc-cat:last-child { border-bottom: none !important; }

.ccc-cat__row {
	display: flex !important;
	align-items: flex-start !important;
	justify-content: space-between !important;
	gap: 16px !important;
	padding: 18px 24px !important;
}

.ccc-cat__meta { flex: 1 !important; min-width: 0 !important; }

/* Expander button — full reset then our styles */
html body #ccc-modal button.ccc-cat__expander,
html body #ccc-modal button.ccc-cat__expander:hover,
html body #ccc-modal button.ccc-cat__expander:focus,
html body #ccc-modal button.ccc-cat__expander:active,
html body #ccc-modal button.ccc-cat__expander:visited {
	display: flex !important;
	align-items: center !important;
	gap: 8px !important;
	background: none !important;
	background-color: transparent !important;
	background-image: none !important;
	border: none !important;
	box-shadow: none !important;
	outline: none !important;
	padding: 0 !important;
	margin: 0 !important;
	text-align: left !important;
	color: var(--ccc-text) !important;
	width: 100% !important;
	text-decoration: none !important;
}

.ccc-cat__name {
	font-size: 14px !important;
	font-weight: 600 !important;
	color: var(--ccc-text) !important;
}

/* Chevron arrow — inline SVG, rotate on expand */
.ccc-cat__arrow {
	display: block !important;
	width: 16px !important;
	height: 16px !important;
	flex-shrink: 0 !important;
	color: var(--ccc-text) !important;
	transition: transform .2s !important;
	overflow: visible !important;
}
.ccc-cat__expander--open .ccc-cat__arrow {
	transform: rotate(180deg) !important;
}

.ccc-cat__desc {
	font-size: 13px !important;
	color: var(--ccc-muted) !important;
	margin: 5px 0 0 !important;
	line-height: 1.55 !important;
	display: block !important;
}

.ccc-cat__control {
	flex-shrink: 0 !important;
	display: flex !important;
	align-items: center !important;
	padding-top: 1px !important;
}

.ccc-always-on {
	font-size: 12px !important;
	color: var(--ccc-muted) !important;
	font-style: italic !important;
	white-space: nowrap !important;
}

/* ── Toggle switch ───────────────────────────────────────────────────────── */
.ccc-toggle {
	position: relative !important;
	display: inline-flex !important;
	cursor: pointer !important;
}
.ccc-toggle__input {
	position: absolute !important;
	opacity: 0 !important;
	width: 0 !important;
	height: 0 !important;
	pointer-events: none !important;
}
.ccc-toggle__track {
	display: inline-block !important;
	width: 44px !important;
	height: 24px !important;
	background: #d1d5db !important;
	border-radius: 12px !important;
	transition: background .2s !important;
	position: relative !important;
	cursor: pointer !important;
}
.ccc-toggle__thumb {
	position: absolute !important;
	top: 3px !important;
	left: 3px !important;
	width: 18px !important;
	height: 18px !important;
	background: #fff !important;
	border-radius: 50% !important;
	box-shadow: 0 1px 4px rgba(0,0,0,.25) !important;
	transition: transform .2s !important;
}
.ccc-toggle__input:checked ~ .ccc-toggle__track {
	background: var(--ccc-accent) !important;
}
.ccc-toggle__input:checked ~ .ccc-toggle__track .ccc-toggle__thumb {
	transform: translateX(20px) !important;
}

/* ── Cookie table ────────────────────────────────────────────────────────── */
.ccc-cat__cookies {
	padding: 0 24px 18px !important;
}

.ccc-table-wrap {
	width: 100% !important;
	overflow: hidden !important;
	border: 1px solid var(--ccc-border) !important;
	border-radius: 6px !important;
}

.ccc-table {
	width: 100% !important;
	border-collapse: separate !important;
	border-spacing: 0 !important;
	font-size: 12px !important;
	color: var(--ccc-text) !important;
	margin: 0 !important;
}
.ccc-table th {
	text-align: left !important;
	font-weight: 600 !important;
	color: var(--ccc-text) !important;
	background: var(--ccc-th-bg) !important;
	padding: 8px 12px !important;
	border-top: none !important;
	border-right: none !important;
	border-left: none !important;
	border-bottom: 1px solid var(--ccc-border) !important;
	white-space: nowrap !important;
	font-size: 11px !important;
	text-transform: uppercase !important;
	letter-spacing: .04em !important;
}
.ccc-table td {
	padding: 8px 12px !important;
	border-top: none !important;
	border-right: none !important;
	border-left: none !important;
	border-bottom: 1px solid var(--ccc-border) !important;
	vertical-align: top !important;
	color: var(--ccc-text) !important;
	font-size: 12px !important;
}
.ccc-table tr:last-child td { border-bottom: none !important; }
.ccc-table tr:nth-child(even) td { background: var(--ccc-row-alt) !important; }
.ccc-table code {
	font-size: 11px !important;
	background: #f1f5f9 !important;
	border: 1px solid #e2e8f0 !important;
	border-radius: 3px !important;
	padding: 1px 5px !important;
	font-family: 'SFMono-Regular', Consolas, monospace !important;
}

/* ── Revisit button ──────────────────────────────────────────────────────── */
#ccc-revisit {
	position: fixed !important;
	bottom: 24px !important;
	left: 24px !important;
	width: 40px !important;
	height: 40px !important;
	border-radius: 50% !important;
	background: #0F1117 !important;
	color: #fff !important;
	border: none !important;
	cursor: pointer !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	z-index: var(--ccc-z) !important;
	box-shadow: none !important;
	transition: transform .15s !important;
	padding: 0 !important;
}
#ccc-revisit:hover {
	transform: scale(1.08) !important;
	box-shadow: none !important;
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 700px) {
	.ccc-banner__inner {
		flex-direction: column !important;
		align-items: stretch !important;
		gap: 14px !important;
	}
	.ccc-banner__actions {
		flex-wrap: wrap !important;
		gap: 8px !important;
	}
	#ccc-banner .ccc-btn { flex: 1 1 auto !important; justify-content: center !important; }
	#ccc-banner .ccc-btn--ghost { flex: none !important; }

	.ccc-modal__footer {
		flex-direction: column !important;
	}
	#ccc-modal .ccc-modal__footer .ccc-btn { width: 100% !important; justify-content: center !important; }

	.ccc-cat__row { padding: 14px 16px !important; }
	.ccc-cat__cookies { padding: 0 16px 14px !important; }
}
