.ccg-banner {
	position: fixed;
	bottom: 1.25rem;
	z-index: 99999;
	box-sizing: border-box;
	max-width: 420px;
	width: calc(100% - 2.5rem);
	padding: 1.25rem;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.25);
	/*font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;*/
	font-size: 1rem;
	line-height: 1.5;
	animation: ccg-slide-up 0.35s ease-out;
}

.ccg-banner--bottom-left {
	left: 1.25rem;
}

.ccg-banner--bottom-center {
	left: 50%;
	transform: translateX(-50%);
}

.ccg-banner--bottom-right {
	right: 1.25rem;
}

.ccg-banner__heading {
	display: block;
	font-size: 1rem;
	margin-bottom: 0.5rem;
}

.ccg-banner__body {
	margin: 0 0 1rem;
	opacity: 0.9;
}

.ccg-banner__actions {
	display: flex;
	gap: 0.5rem;
}

.ccg-banner__btn {
	flex: 1;
	padding: 0.5rem 1rem;
	border: none;
	font-size: 0.875rem;
	font-weight: 600;
	cursor: pointer;
	transition: opacity 0.15s ease;
}

.ccg-banner__btn:hover {
	opacity: 0.85;
}

@keyframes ccg-slide-up {
	from {
		opacity: 0;
		transform: translateY(1rem);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.ccg-banner--bottom-center {
	animation: ccg-slide-up-center 0.35s ease-out;
}

@keyframes ccg-slide-up-center {
	from {
		opacity: 0;
		transform: translateX(-50%) translateY(1rem);
	}
	to {
		opacity: 1;
		transform: translateX(-50%) translateY(0);
	}
}

@media (max-width: 480px) {
	.ccg-banner {
		bottom: 0;
		left: 0;
		right: 0;
		width: 100%;
		max-width: none;
		border-radius: 0 !important;
		animation: ccg-slide-up-mobile 0.35s ease-out;
	}

	.ccg-banner--bottom-center {
		transform: none;
		animation: ccg-slide-up-mobile 0.35s ease-out;
	}

	@keyframes ccg-slide-up-mobile {
		from {
			opacity: 0;
			transform: translateY(100%);
		}
		to {
			opacity: 1;
			transform: translateY(0);
		}
	}
}
