/**
 * Popup Frontend Styles
 *
 * BEM block: pwmisc-popup
 */

/* ==========================================================================
   Base Container
   ========================================================================== */

.pwmisc-popup {
	position: fixed;
	inset: 0;
	display: none;
	z-index: 999998;
	padding: 20px;
	pointer-events: none;
}

.pwmisc-popup--active {
	display: flex;
}

/* ==========================================================================
   Overlay
   ========================================================================== */

.pwmisc-popup__overlay {
	position: fixed;
	inset: 0;
	z-index: 999998;
	pointer-events: auto;
}

/* ==========================================================================
   Inner Popup
   ========================================================================== */

.pwmisc-popup__inner {
	position: relative;
	z-index: 999999;
	background: #fff;
	border-radius: 8px;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.15);
	max-height: 90vh;
	height: fit-content;
	overflow-y: auto;
	padding: 0;
	pointer-events: auto;
}

.pwmisc-popup--no-radius .pwmisc-popup__inner {
	border-radius: 0;
}

/* ==========================================================================
   Close Button
   ========================================================================== */

.pwmisc-popup__close {
	position: absolute;
	top: 12px;
	right: 12px;
	background: transparent;
	border: none;
	cursor: pointer;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1;
	color: #666;
	transition: background-color 0.2s, color 0.2s;
}

.pwmisc-popup__close:hover {
	background-color: #f0f0f0;
	color: #333;
}

/* ==========================================================================
   Content
   ========================================================================== */

.pwmisc-popup__content > *:first-child {
	margin-top: 0;
}

.pwmisc-popup__content > *:last-child {
	margin-bottom: 0;
}

/* ==========================================================================
   Desktop Position Modifiers (≥769px)
   ========================================================================== */

.pwmisc-popup--pos-center {
	align-items: center;
	justify-content: center;
}

.pwmisc-popup--pos-top-left {
	align-items: flex-start;
	justify-content: flex-start;
}

.pwmisc-popup--pos-top-center {
	align-items: flex-start;
	justify-content: center;
}

.pwmisc-popup--pos-top-right {
	align-items: flex-start;
	justify-content: flex-end;
}

.pwmisc-popup--pos-middle-left {
	align-items: center;
	justify-content: flex-start;
}

.pwmisc-popup--pos-middle-center {
	align-items: center;
	justify-content: center;
}

.pwmisc-popup--pos-middle-right {
	align-items: center;
	justify-content: flex-end;
}

.pwmisc-popup--pos-bottom-left {
	align-items: flex-end;
	justify-content: flex-start;
}

.pwmisc-popup--pos-bottom-center {
	align-items: flex-end;
	justify-content: center;
}

.pwmisc-popup--pos-bottom-right {
	align-items: flex-end;
	justify-content: flex-end;
}

/* ==========================================================================
   Mobile (≤768px)
   ========================================================================== */

@media (max-width: 768px) {
	.pwmisc-popup {
		padding: 0;
	}

	.pwmisc-popup__inner {
		width: 100%;
		max-width: 100% !important;
		max-height: 80vh;
		padding: 0;
	}

	/* Mobile position modifiers */
	.pwmisc-popup--mobile-top {
		align-items: flex-start;
		justify-content: center;
	}

	.pwmisc-popup--mobile-middle {
		align-items: center;
		justify-content: center;
	}

	.pwmisc-popup--mobile-bottom {
		align-items: flex-end;
		justify-content: center;
	}

	/* Border-radius adjustments per mobile position */
	.pwmisc-popup--mobile-top .pwmisc-popup__inner {
		border-radius: 0 0 8px 8px;
	}

	.pwmisc-popup--mobile-middle .pwmisc-popup__inner {
		border-radius: 8px;
	}

	.pwmisc-popup--mobile-bottom .pwmisc-popup__inner {
		border-radius: 8px 8px 0 0;
	}
}
