/* woogency Popup – frontend
*********************************************************/
dialog.woogency-popup {
	--_primary-color: var(--popup-primary-color);
	--_backdrop-color: var(--popup-backdrop-color, #000000);
	--_backdrop-opacity: var(--popup-backdrop-opacity, 0.7);
	--_backdrop-blur: var(--popup-backdrop-blur, 5px);
	--_close-button-clr: var(--popup-close-button-color, currentColor);
	--_header-headline-color: var(--popup-headline-color, inherit);

	--_overlay-color: var(--popup-overlay-color, transparent);
	--_overlay-opacity: var(--popup-overlay-opacity, 0);

	--_border-width: var(--popup-border-width, 0);
	--_border-color: var(--popup-border-color, transparent);
	--_border-radius: var(--popup-border-radius, 0);

	--_close-button-size: var(--popup-close-button-size, 30px);

	--duration: 0.4s;

	position: fixed;
	inset: 0;
	margin: auto;
	max-width: 65ch;
	width: calc(100% - 2rem);
	padding: 0;
	border: var(--_border-width) solid var(--_border-color);
	border-radius: var(--_border-radius);
	overflow-y: auto;
	background-color: var(--neutral-100, #ffffff);
	box-shadow: var(--popup-shadow, 0 10px 40px rgba(0, 0, 0, 0.15));
	display: none;
	opacity: 0;
	transition: opacity var(--duration), display var(--duration), overlay var(--duration);
	transition-behavior: allow-discrete;
	z-index: 9999;
}

dialog.woogency-popup .close-button {
	position: absolute;
	inset-block-start: 1rem;
	inset-inline-end: 1rem;
	margin: 0;
	padding: 0;
	width: var(--_close-button-size);
	height: var(--_close-button-size);
	outline: none;
	background: transparent;
	border: none;
	cursor: pointer;
	z-index: 1;
	color: var(--_close-button-clr);
}

dialog.woogency-popup .close-button > svg {
	fill: currentColor;
	width: 100%;
	height: 100%;
	display: block;
}

dialog.woogency-popup .sr-only {
	position: absolute;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	white-space: nowrap;
	border: 0;
}

dialog.woogency-popup .popup-header {
	display: grid;
	grid-template-areas: 'image-wrapper';
	place-items: center;
	text-align: center;
	position: relative;
	isolation: isolate;
}

dialog.woogency-popup .popup-header::after {
	content: '';
	position: absolute;
	inset: 0;
	background: var(--_overlay-color);
	opacity: var(--_overlay-opacity);
	pointer-events: none;
}

dialog.woogency-popup .popup-header img,
dialog.woogency-popup .popup-header .popup-headline {
	grid-area: image-wrapper;
}

dialog.woogency-popup .popup-header img {
	aspect-ratio: 16 / 9;
	object-fit: cover;
	width: 100%;
}

dialog.woogency-popup .popup-headline {
	color: var(--_header-headline-color);
	margin: 1rem;
	z-index: 1;
}

dialog.woogency-popup .popup-body {
	padding: 1rem;
}

dialog.woogency-popup .popup-body p {
	margin-block-end: 0;
}

/* Defensive text wrap: themes with fluid-type scales (--step-*) can blow
   headings beyond the 65ch container. We do not override the font-size —
   that is the theme's call — but we make sure long words/headlines wrap. */
dialog.woogency-popup :is(h1, h2, h3, h4, h5, h6, p) {
	max-width: 100%;
	overflow-wrap: break-word;
	hyphens: auto;
}

dialog.woogency-popup .popup-body a.button {
	margin: 0;
}

dialog.woogency-popup::backdrop {
	background-color: hsl(from var(--_backdrop-color, #000) h s l / var(--_backdrop-opacity));
	backdrop-filter: blur(var(--_backdrop-blur));
	display: none;
	opacity: 0;
	transition: opacity var(--duration), display var(--duration), overlay var(--duration);
	transition-behavior: allow-discrete;
}

dialog.woogency-popup[open] {
	display: block;
	opacity: 1;
	transition-delay: var(--duration);
}

@starting-style {
	dialog.woogency-popup[open] {
		display: block;
		opacity: 0;
	}
}

dialog.woogency-popup[open]::backdrop {
	display: block;
	opacity: var(--_backdrop-opacity);
}

@starting-style {
	dialog.woogency-popup[open]::backdrop {
		display: block;
		opacity: 0;
	}
}

dialog.woogency-popup.popup-no-image .popup-headline {
	margin-top: 1.5rem;
	text-align: center;
}

@media (prefers-reduced-motion: reduce) {
	dialog.woogency-popup,
	dialog.woogency-popup::backdrop { transition: none; }
}
