/* Popup Promo — floating panel styles */

.popup-promo-widget {
	position: fixed;
	z-index: 999999;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

/* Corner positions */
.popup-promo-widget.popup-promo-pos-bottom-right { bottom: 20px; right: 20px; }
.popup-promo-widget.popup-promo-pos-bottom-left  { bottom: 20px; left:  20px; }
.popup-promo-widget.popup-promo-pos-top-right    { top:    20px; right: 20px; }
.popup-promo-widget.popup-promo-pos-top-left     { top:    20px; left:  20px; }

/* -------------------------------------------------------------------
 * Panel
 * ----------------------------------------------------------------- */
.popup-promo-panel {
	position: relative;
	width: 320px;
	max-width: calc(100vw - 40px);
	border-radius: 14px;
	padding: 22px 22px 20px;
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.18);
	box-sizing: border-box;
	opacity: 0;
	pointer-events: none;
	transform: translateY(8px) scale(0.98);
	transition: opacity 0.25s ease, transform 0.25s ease;
}

.popup-promo-pos-bottom-right .popup-promo-panel { transform-origin: bottom right; }
.popup-promo-pos-bottom-left  .popup-promo-panel { transform-origin: bottom left; }
.popup-promo-pos-top-right    .popup-promo-panel { transform-origin: top right; }
.popup-promo-pos-top-left     .popup-promo-panel { transform-origin: top left; }

.popup-promo-widget[data-state="open"] .popup-promo-panel {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0) scale(1);
}

/* Bare mode: strip the panel chrome so user's HTML is the only visible thing */
.popup-promo-panel--bare {
	background: transparent !important;
	color: inherit !important;
	padding: 0 !important;
	box-shadow: none !important;
	border-radius: 0 !important;
	width: auto !important;
	max-width: calc(100vw - 40px);
}

/* In bare mode, move the close button to overlap the user's card corner */
.popup-promo-panel--bare > .popup-promo-close {
	top: -8px;
	right: -8px;
	width: 26px;
	height: 26px;
	background: #1a1a1a;
	color: #fff;
	border-radius: 50%;
	font-size: 18px;
	line-height: 1;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0.9;
	box-shadow: 0 2px 6px rgba(0,0,0,0.25);
}

/* Bare mode kills the default-centering rules — user's HTML controls alignment */
.popup-promo-panel--bare .popup-promo-body,
.popup-promo-panel--bare .popup-promo-body h1,
.popup-promo-panel--bare .popup-promo-body h2,
.popup-promo-panel--bare .popup-promo-body h3,
.popup-promo-panel--bare .popup-promo-body h4,
.popup-promo-panel--bare .popup-promo-body h5,
.popup-promo-panel--bare .popup-promo-body h6,
.popup-promo-panel--bare .popup-promo-body p {
	text-align: initial;
	margin: 0;
}

.popup-promo-panel--bare .popup-promo-body {
	font-size: inherit;
	line-height: inherit;
}

.popup-promo-close {
	position: absolute;
	top: 6px;
	right: 10px;
	background: transparent;
	border: 0;
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
	color: inherit;
	opacity: 0.6;
	padding: 4px 8px;
}

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

#popup-promo-panel .popup-promo-body,
#popup-promo-panel .popup-promo-body h1,
#popup-promo-panel .popup-promo-body h2,
#popup-promo-panel .popup-promo-body h3,
#popup-promo-panel .popup-promo-body h4,
#popup-promo-panel .popup-promo-body h5,
#popup-promo-panel .popup-promo-body h6,
#popup-promo-panel .popup-promo-body p {
	text-align: center;
}

.popup-promo-body {
	margin: 0 0 14px;
	font-size: 14px;
	line-height: 1.5;
}

.popup-promo-body :last-child {
	margin-bottom: 0;
}

.popup-promo-body h1, .popup-promo-body h2, .popup-promo-body h3,
.popup-promo-body h4, .popup-promo-body h5, .popup-promo-body h6 {
	margin: 0 0 10px;
	line-height: 1.25;
}

.popup-promo-body p {
	margin: 0 0 8px;
}

.popup-promo-form-wrap {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.popup-promo-email {
	width: 100%;
	padding: 11px 13px;
	border: 1px solid #d0d0d0;
	border-radius: 8px;
	font-size: 14px;
	box-sizing: border-box;
	background: #fff;
	color: #1a1a1a;
}

.popup-promo-submit,
.popup-promo-cta {
	display: block;
	width: 100%;
	padding: 11px 18px;
	border: 0;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	text-align: center;
	box-sizing: border-box;
	transition: filter 0.15s ease;
}

.popup-promo-submit:hover,
.popup-promo-cta:hover {
	filter: brightness(0.92);
}

.popup-promo-submit:disabled {
	opacity: 0.6;
	cursor: wait;
}

.popup-promo-feedback {
	margin: 10px 0 0;
	font-size: 13px;
	min-height: 1.2em;
}

.popup-promo-feedback.is-error   { color: #c0392b; }
.popup-promo-feedback.is-success { color: #1e8449; }

/* Tiny-screen tweak — make the panel feel less squeezed */
@media (max-width: 380px) {
	.popup-promo-widget {
		bottom: 12px !important;
		right:  12px !important;
		left:   auto !important;
		top:    auto !important;
	}
	.popup-promo-panel {
		width: calc(100vw - 24px);
		right: 0 !important;
		left:  auto !important;
	}
}
