.ps-popup-overlay {
	/* Colores tomados del tema (temas de bloques) con valores de reserva. */
	--ps-accent: var(--wp--preset--color--primary, var(--wp--preset--color--accent, var(--wp--preset--color--link, #2271b1)));
	--ps-accent-contrast: var(--wp--preset--color--base, #ffffff);
	--ps-text: var(--wp--preset--color--contrast, var(--wp--preset--color--foreground, #1e1e1e));
	--ps-bg: var(--wp--preset--color--base, var(--wp--preset--color--background, #ffffff));
	--ps-border: rgba(127, 127, 127, 0.35);
	--ps-radius: 12px;

	position: fixed;
	inset: 0;
	z-index: 99999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
	background: rgba(0, 0, 0, 0.6);
	opacity: 0;
	/* Mientras no esté visible no debe interceptar clics, aunque siga en el DOM. */
	pointer-events: none;
	transition: opacity 0.25s ease;
}

/* El atributo [hidden] debe ganar al display:flex de la clase, si no el
   overlay queda fijo tapando toda la página y bloquea todos los clics. */
.ps-popup-overlay[hidden] {
	display: none;
}

.ps-popup-overlay.ps-visible {
	opacity: 1;
	pointer-events: auto;
}

.ps-popup {
	position: relative;
	width: 100%;
	max-width: 420px;
	background: var(--ps-bg);
	color: var(--ps-text);
	font-family: inherit;
	border-radius: var(--ps-radius);
	padding: 32px 28px 28px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
	transform: translateY(12px);
	transition: transform 0.25s ease;
	box-sizing: border-box;
}

.ps-popup-overlay.ps-visible .ps-popup {
	transform: translateY(0);
}

.ps-popup-close {
	position: absolute;
	top: 8px;
	right: 12px;
	border: 0;
	background: transparent;
	font-size: 28px;
	line-height: 1;
	cursor: pointer;
	color: inherit;
	opacity: 0.6;
}

.ps-popup-close:hover {
	opacity: 1;
}

.ps-popup-title {
	margin: 0 0 8px;
	font-size: 1.4em;
	font-family: inherit;
	color: inherit;
}

.ps-popup-desc {
	margin: 0 0 20px;
	font-size: 0.95em;
	opacity: 0.8;
}

.ps-field {
	display: block;
	margin-bottom: 14px;
}

.ps-field span {
	display: block;
	margin-bottom: 4px;
	font-size: 0.85em;
	font-weight: 600;
}

.ps-field input {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--ps-border);
	border-radius: calc(var(--ps-radius) - 4px);
	font: inherit;
	font-size: 1em;
	color: inherit;
	background: transparent;
	box-sizing: border-box;
}

.ps-field input:focus {
	outline: none;
	border-color: var(--ps-accent);
	box-shadow: 0 0 0 2px color-mix(in srgb, var(--ps-accent) 25%, transparent);
}

.ps-popup-submit {
	width: 100%;
	padding: 12px 16px;
	border: 0;
	border-radius: calc(var(--ps-radius) - 4px);
	background: var(--ps-accent);
	color: var(--ps-accent-contrast);
	font: inherit;
	font-size: 1em;
	font-weight: 600;
	cursor: pointer;
	transition: filter 0.2s ease;
}

.ps-popup-submit:hover {
	filter: brightness(0.92);
}

.ps-popup-submit:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.ps-google-btn {
	display: flex;
	justify-content: center;
	margin-bottom: 12px;
}

.ps-popup-divider {
	display: flex;
	align-items: center;
	text-align: center;
	opacity: 0.6;
	font-size: 0.8em;
	margin: 4px 0 16px;
}

.ps-popup-divider::before,
.ps-popup-divider::after {
	content: "";
	flex: 1;
	border-bottom: 1px solid var(--ps-border);
}

.ps-popup-divider span {
	padding: 0 10px;
}

.ps-popup-message {
	min-height: 1.2em;
	margin: 0 0 10px;
	font-size: 0.9em;
}

.ps-popup-message.ps-error {
	color: #d63638;
}

.ps-popup-message.ps-ok {
	color: #00854a;
}
