/*
 * StickyCTA Frontend Styles
 * High specificity + z-index isolation to avoid theme interference.
 */

#stickycta-btn-wrap,
#stickycta-btn-wrap *,
#stickycta-btn-wrap *::before,
#stickycta-btn-wrap *::after {
	box-sizing: border-box !important;
	margin: 0;
	padding: 0;
}

#stickycta-btn-wrap {
	/* Isolation layer */
	all: initial;
	display: block !important;
	position: fixed !important;
	z-index: 2147483647 !important; /* Max z-index */
	pointer-events: auto !important;
	overflow: visible !important;
	width: var(--stickycta-size, 56px) !important;
	height: var(--stickycta-size, 56px) !important;
}

/* Position classes set top/left/right/bottom inline – transform handled inline too */

.stickycta-link {
	all: initial;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: var(--stickycta-size, 56px) !important;
	height: var(--stickycta-size, 56px) !important;
	text-decoration: none !important;
	cursor: pointer !important;
	position: relative !important;
	z-index: 1 !important;
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.30) !important;
	transition: transform var(--stickycta-hover-dur, 200ms) ease,
	            box-shadow var(--stickycta-hover-dur, 200ms) ease !important;
	/* Shape applied via modifier classes */
}

.stickycta-link:hover,
.stickycta-link:focus {
	transform: scale(var(--stickycta-hover-scale, 1.10)) !important;
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.36) !important;
}

/* Hover animation disabled */
.stickycta-no-hover .stickycta-link {
	transition: none !important;
}

.stickycta-no-hover .stickycta-link:hover,
.stickycta-no-hover .stickycta-link:focus {
	transform: none !important;
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.30) !important;
}

/* Shape modifiers */
.stickycta-shape-circle .stickycta-link {
	border-radius: 50% !important;
}

.stickycta-shape-square .stickycta-link {
	border-radius: 8px !important;
}

/* Icon */
.stickycta-icon {
	all: initial;
	display: inline-block !important;
	font-family: dashicons !important;
	font-size: var(--stickycta-icon-size, 26px) !important;
	line-height: 1 !important;
	width: var(--stickycta-icon-size, 26px) !important;
	height: var(--stickycta-icon-size, 26px) !important;
	cursor: pointer !important;
	speak: never;
	font-weight: normal !important;
	font-variant: normal !important;
	text-transform: none !important;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* Entrance animation */
@keyframes stickycta-pop-in {
	0%   { transform: scale(0); opacity: 0; }
	70%  { transform: scale(1.12); opacity: 1; }
	100% { transform: scale(1); opacity: 1; }
}

#stickycta-btn-wrap {
	animation: stickycta-pop-in 0.35s cubic-bezier(0.34, 1.56, 0.64, 1) both !important;
}

/* ── Halo background circle ──────────────────────────────────────────── */
.stickycta-halo {
	all: initial;
	display: block !important;
	position: absolute !important;
	top: 50% !important;
	left: 50% !important;
	transform: translate(-50%, -50%) !important;
	width: var(--stickycta-halo-size, 57px) !important;
	height: var(--stickycta-halo-size, 57px) !important;
	border-radius: 50% !important;
	background-color: var(--stickycta-halo-color, #0073aa) !important;
	opacity: var(--stickycta-halo-opacity, 0.4) !important;
	z-index: 0 !important;
	pointer-events: none !important;
	transition: transform var(--stickycta-halo-dur, 300ms) ease,
	            opacity var(--stickycta-halo-dur, 300ms) ease !important;
}

/* Halo grows on hover/focus */
#stickycta-btn-wrap:hover .stickycta-halo,
#stickycta-btn-wrap:focus-within .stickycta-halo {
	transform: translate(-50%, -50%) scale(var(--stickycta-halo-scale, 1.30)) !important;
}

/* Halo animation disabled – freeze transform */
#stickycta-btn-wrap.stickycta-no-halo-anim .stickycta-halo {
	transition: none !important;
}

#stickycta-btn-wrap.stickycta-no-halo-anim:hover .stickycta-halo,
#stickycta-btn-wrap.stickycta-no-halo-anim:focus-within .stickycta-halo {
	transform: translate(-50%, -50%) !important;
}
