.login-page {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	background:
		radial-gradient(circle at top, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0) 38%),
		linear-gradient(180deg, #f8fafc 0%, #f6f8fa 100%);
}

.login-shell {
	width: 100%;
	max-width: 480px;
}

.login-brand {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin-bottom: 14px;
}

.login-brand__title {
	margin: 0;
	font-size: 30px;
	font-weight: 800;
	line-height: 1;
	color: #2f3a4a;
}

.login-brand__badge {
	padding: 5px 11px 4px;
	border-radius: 8px;
	background: linear-gradient(180deg, #79ba49 0%, #5aa32c 100%);
	box-shadow: 0 8px 16px rgba(90, 163, 44, 0.2);
	color: #fff;
	font-size: 26px;
	font-weight: 800;
	line-height: 1;
}

.login-card {
	border: 1px solid #e3eaf1;
	border-radius: 14px;
	box-shadow: 0 10px 24px rgba(47, 58, 74, 0.08);
	background: rgba(255, 255, 255, 0.96);
}

.login-card__body {
	padding: 24px 24px 16px;
}

.login-card__title {
	margin-bottom: 24px;
	text-align: center;
	font-size: 18px;
	font-weight: 700;
	color: #2f3a4a;
}

.login-form .el-form-item {
	margin-bottom: 16px;
}

.login-input {
	--el-input-height: 44px;
}

.login-input .el-input__wrapper {
	border-radius: 10px;
	box-shadow: none;
}

.login-input__toggle {
	color: #7a8191;
	font-size: 15px;
	padding: 0;
}

.login-actions {
	margin-top: 14px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
}

.login-actions .el-checkbox {
	color: #5f6779;
}

.login-actions__right {
	display: flex;
	align-items: center;
	gap: 12px;
}

.login-link {
	font-size: 12px;
	color: #6f7686;
}

.login-submit {
	min-width: 76px;
	height: 42px;
	border-radius: 10px;
	font-size: 16px;
	font-weight: 700;
	--el-button-bg-color: #5aa32c;
	--el-button-border-color: #5aa32c;
	--el-button-hover-bg-color: #6ab53a;
	--el-button-hover-border-color: #6ab53a;
	--el-button-active-bg-color: #4d8f24;
	--el-button-active-border-color: #4d8f24;
	--el-button-outline-color: rgba(90, 163, 44, 0.22);
}
