/*
 * HND Tracking - Klaro custom theme.
 *
 * Design tokens are emitted exclusively as inline <style id="hnd-tracking-vars">
 * by Consent::output_inline_styles(). This file consumes those variables but
 * does not declare any defaults, to avoid duplicate :root blocks in DOM.
 *
 * If the inline block fails for some reason, Klaro will fall back to its
 * own internal styling.
 */

/* Override Klaro's own variables so the wrapper can't fight us. */
#klaro {
	--button-text-color: var(--hnd-klaro-primary-text);
}

/* ====================================================================
 * NOTICE (small banner / floating)
 * ==================================================================== */

.klaro .cookie-notice,
.klaro #klaro-cookie-notice {
	background: var(--hnd-klaro-bg);
	color: var(--hnd-klaro-text);
	font-family: var(--hnd-klaro-font);
	box-shadow: var(--hnd-klaro-shadow);
	border: 1px solid var(--hnd-klaro-border);
	border-radius: var(--hnd-klaro-radius);
	padding: 1.25rem 1.5rem;
	box-sizing: border-box;
	z-index: 9999;
	font-size: 0.9rem;
	line-height: 1.5;

	position: var(--hnd-klaro-position, fixed);
	top: var(--hnd-klaro-top, auto);
	bottom: var(--hnd-klaro-bottom, 20px);
	left: var(--hnd-klaro-left, auto);
	right: var(--hnd-klaro-right, 20px);
	transform: var(--hnd-klaro-translate, none);
	max-width: var(--hnd-klaro-max-width);
	width: calc(100vw - 40px);
}

/* When set to bar layout, override the floating styling. */
.klaro .cookie-notice.cookie-notice--bar,
.klaro[data-layout="bar"] .cookie-notice,
.klaro[data-layout="bar"] #klaro-cookie-notice {
	border-radius: 0;
	border-left: 0;
	border-right: 0;
	border-bottom: 0;
	max-width: 100%;
	width: 100%;
	left: 0;
	right: 0;
	bottom: 0;
	top: auto;
	transform: none;
}

.klaro .cookie-notice .cn-body,
.klaro #klaro-cookie-notice .cn-body {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin: 0 auto;
	max-width: 1200px;
	font-weight: 400 !important;
}

.klaro .cookie-notice .cn-body p,
.klaro #klaro-cookie-notice .cn-body p {
	margin: 0;
	color: var(--hnd-klaro-text);
}

.klaro .cookie-notice .cn-body p a,
.klaro #klaro-cookie-notice .cn-body p a {
	color: var(--hnd-klaro-primary-bg);
	text-decoration: underline;
}

.klaro .cookie-notice .cn-ok {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	align-items: center;
	justify-content: space-between;
}

.klaro .cookie-notice .cn-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.klaro .cookie-notice .cn-learn-more {
	color: var(--hnd-klaro-text);
	text-decoration: underline;
	font-size: 0.85rem;
	background: transparent;
	border: 0;
	padding: 0.4rem 0.5rem;
	cursor: pointer;
}

/* ====================================================================
 * BUTTONS (shared)
 * ==================================================================== */

.klaro .cm-btn,
.klaro .cookie-notice button,
.klaro #klaro-cookie-notice button {
	font-family: var(--hnd-klaro-font);
	font-size: 0.875rem;
	font-weight: 500;
	padding: 0.6rem 1rem;
	border: 1px solid transparent;
	border-radius: var(--hnd-klaro-radius);
	cursor: pointer;
	transition: opacity 0.15s ease, transform 0.05s ease;
	white-space: nowrap;
}

.klaro .cm-btn:hover,
.klaro .cookie-notice button:hover {
	opacity: 0.9;
}

.klaro .cm-btn:active,
.klaro .cookie-notice button:active {
	transform: translateY(1px);
}

/* Accept all (primary). */
.klaro .cm-btn-success,
.klaro .cm-btn-accept,
.klaro .cm-btn-accept-all {
	background: var(--hnd-klaro-primary-bg);
	color: var(--hnd-klaro-primary-text);
	border-color: var(--hnd-klaro-primary-bg);
}

/* Klaro's "Save selection" sometimes uses cm-btn-info class. */
.klaro .cm-btn-info {
	background: var(--hnd-klaro-secondary-bg);
	color: var(--hnd-klaro-secondary-text);
	border-color: var(--hnd-klaro-border);
}

/* Decline. */
.klaro .cm-btn-decline,
.klaro .cm-btn-danger,
.klaro .cn-decline {
	background: var(--hnd-klaro-decline-bg);
	color: var(--hnd-klaro-decline-text);
	border-color: var(--hnd-klaro-border);
}

/* ====================================================================
 * MODAL (settings / "Manage cookies" view)
 * ==================================================================== */

.klaro .cookie-modal {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	z-index: 10000;
	font-family: var(--hnd-klaro-font);
}

.klaro .cookie-modal .cm-bg {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
}

.klaro .cookie-modal .cm-modal {
	position: relative;
	background: var(--hnd-klaro-bg);
	color: var(--hnd-klaro-text);
	border-radius: var(--hnd-klaro-radius);
	max-width: 1024px;
	width: 100%;
	max-height: 90vh;
	overflow-y: auto;
	padding: 1.75rem;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
	font-weight: 400 !important;
}

.klaro .cookie-modal .cm-header {
	margin-bottom: 1rem;
}

.klaro .cookie-modal .cm-header .hide {
	position: absolute;
	top: 1rem;
	right: 1rem;
	background: transparent;
	border: 0;
	cursor: pointer;
	color: var(--hnd-klaro-muted);
	padding: 0.5rem;
}

.klaro .cookie-modal .cm-header .hide svg {
	stroke: currentColor;
}

.klaro .cookie-modal .cm-header .title,
.klaro .cookie-modal .cm-header h1,
.klaro .cookie-modal .cm-header h2 {
	margin: 0 0 0.5rem;
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--hnd-klaro-heading);
}

.klaro .cookie-modal .cm-header p {
	margin: 0;
	font-size: 0.9rem;
	color: var(--hnd-klaro-text);
}

.klaro .cookie-modal .cm-header p a {
	color: var(--hnd-klaro-primary-bg);
	text-decoration: underline;
}

.klaro .cookie-modal .cm-body {
	margin: 1rem 0;
}

.klaro .cookie-modal .cm-purposes {
	list-style: none;
	margin: 0;
	padding: 0;
}

p.purposes {
	display: none !important;
}

.klaro .cookie-modal .cm-purpose {
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--hnd-klaro-border);
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.5rem;
}

.klaro .cookie-modal .cm-purpose:last-child {
	border-bottom: 0;
}

.klaro .cookie-modal .cm-purpose .cm-list-label {
	display: flex;
	align-items: center;
	justify-content: space-between;
	cursor: pointer;
}

.klaro .cookie-modal .cm-list-title {
	font-weight: 600;
	color: var(--hnd-klaro-heading);
}

.klaro .cookie-modal .cm-list-description {
	margin: 0;
	font-size: 0.85rem;
	color: var(--hnd-klaro-muted);
}

.klaro .cookie-modal .cm-services {
	margin-top: 0.5rem;
	padding-left: 1rem;
}

.klaro .cookie-modal .cm-caret {
	font-size: 0.8rem;
	color: var(--hnd-klaro-muted);
}

.klaro .cookie-modal .cm-caret a {
	color: var(--hnd-klaro-muted);
	text-decoration: none;
}

.klaro .cookie-modal .cm-content {
	list-style: none;
	margin: 0.5rem 0 0;
	padding: 0;
}

.klaro .cookie-modal .cm-service {
	padding: 0.5rem 0;
}

.klaro .cookie-modal .cm-service .cm-list-label {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.klaro .cookie-modal .cm-service .purposes {
	font-size: 0.75rem;
	color: var(--hnd-klaro-muted);
	margin: 0.2rem 0 0;
}

/* Switches — Klaro builds them as label.cm-list-label > .slider */
.klaro .cm-list-input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.klaro .cm-switch {
	display: inline-block;
	width: 36px;
	height: 20px;
	position: relative;
	margin-left: 0.75rem;
	flex-shrink: 0;
}

.klaro .slider {
	position: absolute;
	cursor: pointer;
	inset: 0;
	background: #cbd5e1;
	border-radius: 999px;
	transition: background 0.18s ease;
}

.klaro .slider::before {
	content: '';
	position: absolute;
	height: 14px;
	width: 14px;
	left: 3px;
	top: 3px;
	background: #fff;
	border-radius: 50%;
	transition: transform 0.18s ease;
}

.klaro .cm-list-input:checked + .cm-list-label .slider,
.klaro .cm-list-input.required + .cm-list-label .slider {
	background: var(--hnd-klaro-primary-bg);
}

.klaro .cm-list-input:checked + .cm-list-label .slider::before {
	transform: translateX(16px);
}

.klaro .cm-list-input.half-checked + .cm-list-label .slider {
	background: var(--hnd-klaro-primary-bg);
	opacity: 0.6;
}

.klaro .cm-list-input.half-checked + .cm-list-label .slider::before {
	transform: translateX(8px);
}

.klaro .cm-list-input:disabled + .cm-list-label .slider,
.klaro .cm-list-input.required + .cm-list-label .slider {
	cursor: not-allowed;
}

/* Footer */
.klaro .cookie-modal .cm-footer {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	justify-content: flex-end;
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid var(--hnd-klaro-border);
}

.klaro .cookie-modal .cm-footer-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.klaro .cookie-modal .cm-powered-by {
	flex-basis: 100%;
	font-size: 0.7rem;
	color: var(--hnd-klaro-muted);
	text-align: left;
	margin: 0.5rem 0 0;
}

.klaro .cookie-modal .cm-powered-by a {
	color: var(--hnd-klaro-muted);
}

.klaro .cookie-modal .cm-powered-by:empty {
	display: none;
}

/* ====================================================================
 * MOBILE
 * ==================================================================== */

@media (max-width: 640px) {
	.klaro .cookie-notice,
	.klaro #klaro-cookie-notice {
		left: 10px !important;
		right: 10px !important;
		bottom: 10px !important;
		top: auto !important;
		transform: none !important;
		max-width: calc(100vw - 20px) !important;
		padding: 1rem;
	}

	.klaro .cookie-notice .cn-buttons {
		width: 100%;
		justify-content: stretch;
	}

	.klaro .cookie-notice .cn-buttons button {
		flex: 1;
	}

	.klaro .cookie-modal .cm-modal {
		padding: 1.25rem;
	}
}
