/* =============================
   Leukequizzen — cookie banner
   ============================= */

/* Kritisch: ondanks dat de modal display:flex heeft, MOET het hidden-attribute
 * winnen — anders blijft de onzichtbare modal over het hele scherm liggen en
 * vangt het alle klikken op. */
.lq-cookie-banner[hidden],
.lq-cookie-modal[hidden] { display: none !important; }

/* Voorkomt scrollen op de achtergrond zolang de modal open staat. */
html.lq-no-scroll, html.lq-no-scroll body { overflow: hidden; }

/* ---------- Banner ---------- */
.lq-cookie-banner {
	position: fixed;
	left: 16px; right: 16px; bottom: 16px;
	z-index: 200;
	background: #fff;
	color: var(--color-dark, #1A1A2E);
	border-radius: 18px;
	box-shadow: 0 18px 50px rgba(26, 26, 46, 0.22), 0 2px 8px rgba(26,26,46,0.08);
	padding: 18px 22px;
	max-width: 980px;
	margin: 0 auto;
	transform: translateY(calc(100% + 32px));
	transition: transform .3s cubic-bezier(.2, .8, .2, 1), opacity .3s ease;
	opacity: 0;
}
.lq-cookie-banner[data-visible="1"] {
	transform: translateY(0);
	opacity: 1;
}

.lq-cookie-banner__inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 18px;
	align-items: center;
}
.lq-cookie-banner__icon {
	font-size: 1.8rem;
	line-height: 1;
	background: var(--color-cream, #FFF8E7);
	width: 48px; height: 48px;
	border-radius: 14px;
	display: flex; align-items: center; justify-content: center;
}
.lq-cookie-banner__text strong {
	display: block;
	font-family: var(--font-heading, 'Fraunces', Georgia, serif);
	font-size: 1.05rem;
	font-weight: 800;
	margin-bottom: 2px;
}
.lq-cookie-banner__text p {
	margin: 0;
	font-size: 0.95rem;
	color: var(--color-text, #2D2D3F);
	line-height: 1.5;
}
.lq-cookie-banner__actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	justify-content: flex-end;
}
.lq-cookie-banner__actions .lq-button { font-size: 0.9rem; padding: 10px 16px; }

@media (max-width: 820px) {
	.lq-cookie-banner {
		left: 12px; right: 12px; bottom: 12px;
		padding: 16px;
		border-radius: 16px;
	}
	.lq-cookie-banner__inner {
		grid-template-columns: 1fr;
		gap: 12px;
	}
	.lq-cookie-banner__icon { display: none; }
	.lq-cookie-banner__actions {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 8px;
	}
	.lq-cookie-banner__actions .lq-button { width: 100%; padding: 12px 14px; }
	.lq-cookie-banner__actions .lq-button:last-child {
		grid-column: 1 / -1;
	}
}

/* ---------- Modal ---------- */
.lq-cookie-modal {
	position: fixed;
	inset: 0;
	z-index: 300;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	opacity: 0;
	transition: opacity .2s ease;
}
.lq-cookie-modal[data-visible="1"] { opacity: 1; }

.lq-cookie-modal__backdrop {
	position: absolute; inset: 0;
	background: rgba(26, 26, 46, 0.55);
	cursor: pointer;
}

.lq-cookie-modal__panel {
	position: relative;
	width: 100%;
	max-width: 540px;
	max-height: calc(100vh - 40px);
	overflow: auto;
	background: #fff;
	border-radius: 22px;
	padding: 32px 32px 24px;
	box-shadow: 0 30px 80px rgba(0, 0, 0, 0.35);
	transform: translateY(20px) scale(0.97);
	transition: transform .3s cubic-bezier(.2, .8, .2, 1);
}
.lq-cookie-modal[data-visible="1"] .lq-cookie-modal__panel {
	transform: translateY(0) scale(1);
}
.lq-cookie-modal__panel:focus { outline: none; }

.lq-cookie-modal__close {
	position: absolute;
	top: 14px; right: 14px;
	background: var(--color-cream, #FFF8E7);
	border: 0;
	width: 36px; height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--color-dark, #1A1A2E);
	cursor: pointer;
	border-radius: 10px;
	transition: background-color .15s ease, transform .15s ease;
}
.lq-cookie-modal__close:hover {
	background: var(--color-primary, #FFD23F);
	transform: rotate(90deg);
}

.lq-cookie-modal__head {
	text-align: center;
	margin-bottom: 16px;
}
.lq-cookie-modal__icon {
	display: inline-flex;
	align-items: center; justify-content: center;
	width: 56px; height: 56px;
	border-radius: 16px;
	background: var(--color-cream, #FFF8E7);
	font-size: 2rem;
	margin-bottom: 8px;
}
.lq-cookie-modal h2 {
	margin: 0 0 8px;
	font-size: 1.5rem;
}
.lq-cookie-modal__head p {
	margin: 0;
	color: var(--color-muted, #6B6B7B);
	font-size: 0.95rem;
}

.lq-cookie-modal__row {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 16px;
	align-items: center;
	padding: 16px 0;
	border-top: 1px solid var(--color-border, #E8E4D8);
}
.lq-cookie-modal__row:first-of-type { border-top: 1px solid var(--color-border, #E8E4D8); margin-top: 4px; }
.lq-cookie-modal__row-text strong { display: block; font-size: 1rem; margin-bottom: 2px; }
.lq-cookie-modal__row-text p {
	margin: 0;
	color: var(--color-muted, #6B6B7B);
	font-size: 0.9rem;
	line-height: 1.5;
}

.lq-cookie-modal__footer {
	display: flex;
	justify-content: flex-end;
	gap: 8px;
	margin-top: 18px;
	padding-top: 18px;
	border-top: 1px solid var(--color-border, #E8E4D8);
}
@media (max-width: 520px) {
	.lq-cookie-modal__panel { padding: 26px 22px 20px; border-radius: 18px; }
	.lq-cookie-modal__footer { flex-direction: column-reverse; }
	.lq-cookie-modal__footer .lq-button { width: 100%; }
}

/* ---------- Switch ---------- */
.lq-switch {
	position: relative;
	display: inline-block;
	width: 50px; height: 28px;
	flex-shrink: 0;
}
.lq-switch input {
	position: absolute;
	opacity: 0;
	width: 100%; height: 100%;
	margin: 0;
	cursor: pointer;
}
.lq-switch__track {
	position: absolute;
	inset: 0;
	background: #cfcfd4;
	border-radius: 999px;
	transition: background .2s ease;
	pointer-events: none;
}
.lq-switch__thumb {
	position: absolute;
	top: 3px; left: 3px;
	width: 22px; height: 22px;
	background: #fff;
	border-radius: 50%;
	box-shadow: 0 1px 3px rgba(0,0,0,0.2);
	transition: transform .2s cubic-bezier(.2, .8, .2, 1);
}
.lq-switch input:checked + .lq-switch__track {
	background: var(--color-success, #2BAA6F);
}
.lq-switch input:checked + .lq-switch__track .lq-switch__thumb {
	transform: translateX(22px);
}
.lq-switch input:focus-visible + .lq-switch__track {
	outline: 3px solid var(--color-dark, #1A1A2E);
	outline-offset: 3px;
	border-radius: 999px;
}
.lq-switch--disabled .lq-switch__track {
	background: color-mix(in srgb, var(--color-success, #2BAA6F) 50%, #ccc);
	cursor: not-allowed;
}
.lq-switch--disabled .lq-switch__thumb { transform: translateX(22px); }
.lq-switch--disabled input { cursor: not-allowed; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.lq-cookie-banner, .lq-cookie-modal, .lq-cookie-modal__panel,
	.lq-switch__thumb, .lq-cookie-modal__close { transition: none; }
}
