/* ==========================================================================
   setupERP - Single floating WhatsApp widget
   ========================================================================== */

.sp-wa {
	--sp-wa-green: #25d366;
	--sp-wa-green-dark: #1da851;
	--sp-wa-z: 99990;

	position: fixed;
	right: max(16px, env(safe-area-inset-right, 0px));
	bottom: max(16px, env(safe-area-inset-bottom, 0px));
	z-index: var(--sp-wa-z);
	width: min(340px, calc(100vw - 32px));
	font-family: var(--sp-font);
	pointer-events: none;
}

.sp-wa > * {
	pointer-events: auto;
}

/* ── Main card ── */

.sp-wa__card {
	position: relative;
	border: 1px solid rgba(34, 197, 94, 0.2);
	border-radius: 14px;
	background: #fff;
	box-shadow:
		0 16px 40px rgba(15, 23, 42, 0.14),
		0 4px 12px rgba(15, 23, 42, 0.06);
	animation: spWaSlideIn 0.4s var(--sp-ease-out) both;
	transition:
		opacity 0.25s ease,
		transform 0.25s var(--sp-ease-out),
		visibility 0.25s;
	overflow: visible;
}

.sp-wa.is-minimized .sp-wa__card {
	visibility: hidden;
	opacity: 0;
	transform: translateY(8px) scale(0.96);
	pointer-events: none;
}

.sp-wa__link {
	display: flex;
	align-items: center;
	gap: 14px;
	min-width: 0;
	padding: 14px 16px;
	color: var(--sp-text);
	text-decoration: none;
	transition: background 0.2s ease;
	border-radius: 14px;
}

.sp-wa__link:hover {
	background: var(--sp-bg-soft);
	color: var(--sp-text);
}

.sp-wa__link:focus-visible,
.sp-wa__close:focus-visible,
.sp-wa__compact:focus-visible {
	outline: 3px solid var(--sp-primary);
	outline-offset: 2px;
}

.sp-wa__icon {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--sp-wa-green);
	color: #fff;
}

.sp-wa.is-agent-online .sp-wa__icon::after {
	content: '';
	position: absolute;
	right: 0;
	bottom: 0;
	width: 11px;
	height: 11px;
	border: 2px solid #fff;
	border-radius: 50%;
	background: var(--sp-accent);
}

.sp-wa__copy {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.sp-wa__title {
	font-size: 14px;
	font-weight: 600;
	line-height: 1.35;
	color: var(--sp-text);
}

.sp-wa__text {
	font-size: 12.5px;
	line-height: 1.45;
	color: var(--sp-text-muted);
}

.sp-wa__number {
	margin-top: 2px;
	font-size: 12px;
	font-weight: 600;
	color: var(--sp-wa-green-dark);
	letter-spacing: 0.02em;
}

/* ── Close badge — corner, bulletproof against theme button reset ── */

.sp-wa__close,
.setuperp-landing .sp-wa__close {
	position: absolute !important;
	top: -10px !important;
	right: -10px !important;
	z-index: 5 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 30px !important;
	height: 30px !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 1px solid var(--sp-border) !important;
	border-radius: 50% !important;
	background: #ffffff !important;
	color: #0f172a !important;
	cursor: pointer;
	box-shadow: 0 2px 10px rgba(15, 23, 42, 0.2) !important;
	touch-action: manipulation;
	-webkit-tap-highlight-color: transparent;
	transition: background 0.2s ease, transform 0.15s ease;
}

.sp-wa__close:hover,
.sp-wa__close:active,
.setuperp-landing .sp-wa__close:hover,
.setuperp-landing .sp-wa__close:focus,
.setuperp-landing .sp-wa__close:active {
	background: #f1f5f4 !important;
	border-color: var(--sp-border) !important;
	box-shadow: 0 2px 10px rgba(15, 23, 42, 0.2) !important;
	transform: scale(1.05);
}

.sp-wa__close-icon {
	display: block;
	font-size: 22px;
	font-weight: 400;
	line-height: 1;
	color: #0f172a;
	pointer-events: none;
}

/* ── Minimized icon (shown only after dismiss) ── */

.sp-wa__compact {
	position: fixed;
	right: max(16px, env(safe-area-inset-right, 0px));
	bottom: max(16px, env(safe-area-inset-bottom, 0px));
	display: none;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background: var(--sp-wa-green);
	color: #fff;
	text-decoration: none;
	box-shadow: 0 8px 24px rgba(37, 211, 102, 0.35);
	transition: transform 0.2s var(--sp-ease-spring);
}

.sp-wa.is-minimized .sp-wa__compact {
	display: flex;
}

.sp-wa__compact:hover {
	color: #fff;
	transform: scale(1.06);
}

@keyframes spWaSlideIn {
	from {
		opacity: 0;
		transform: translateY(12px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* ── Tablet ── */

@media (max-width: 768px) {
	.sp-wa {
		right: max(12px, env(safe-area-inset-right, 0px));
		bottom: max(12px, env(safe-area-inset-bottom, 0px));
		width: min(320px, calc(100vw - 24px));
	}

	.sp-wa__compact {
		right: max(12px, env(safe-area-inset-right, 0px));
		bottom: max(12px, env(safe-area-inset-bottom, 0px));
	}
}

/* ── Mobile ── */

@media (max-width: 480px) {
	.sp-wa {
		left: max(12px, env(safe-area-inset-left, 0px));
		right: max(12px, env(safe-area-inset-right, 0px));
		width: auto;
	}

	.sp-wa__link {
		padding: 14px;
		gap: 12px;
	}

	.sp-wa__close,
	.setuperp-landing .sp-wa__close {
		top: -12px !important;
		right: -8px !important;
		width: 36px !important;
		height: 36px !important;
	}

	.sp-wa__close-icon {
		font-size: 26px;
	}

	.sp-wa__icon {
		width: 40px;
		height: 40px;
	}

	.sp-wa__title {
		font-size: 13.5px;
	}

	.sp-wa__text {
		font-size: 12px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.sp-wa__card,
	.sp-wa__compact {
		animation: none;
		transition: none;
	}
}
