/* 提示框的样式 */
.alert {
	position: fixed;
	top: 20px;
	left: 50%;
	transform: translateX(-50%);
	background-color: #f44336;
	color: white;
	padding: 15px;
	border-radius: 5px;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
	z-index: 9999999;
	font-size: 16px;
	transition: opacity 1s ease-in-out;
	/* 渐变效果 */
	animation: shake 0.5s;
	/* 抖动效果 */
}

/* 隐藏提示框的样式 */
.alert.fade-out {
	opacity: 0;
}

/* 抖动效果的关键帧动画 */
@keyframes shake {
	0% {
		transform: translateX(-50%) translateY(0);
	}

	25% {
		transform: translateX(-50%) translateY(-5px);
	}

	50% {
		transform: translateX(-50%) translateY(5px);
	}

	75% {
		transform: translateX(-50%) translateY(-5px);
	}

	100% {
		transform: translateX(-50%) translateY(0);
	}
}