#topView section {
	display: flex;
	flex-direction: column;
	width: calc(50% - 8% - 30px);
	margin: 130px 0 130px 30px;
}

#topView section h2 {
	color: var(--fontColor);
	font-size: 30px;
	font-weight: 500;
	letter-spacing: 1px;
	margin-bottom: 40px;
}

#topView section p {
	color: var(--fontColor);
	font-size: 16px;
	line-height: 40px;
	margin-bottom: 30px;
}

#topView section p.btn {
	margin-top: 30px;
	margin-bottom: 0;
}

#viewArea1 {
	position: fixed;
	top: calc(130px + 5%);
	left: 8%;
	right: 50%;
	bottom: 130px;
	display: flex;
	justify-content: right;
	align-items: center;
	margin-right: 30px;
	z-index: -1;
}

#viewArea2 {
	position: relative;
	display: flex;
	justify-content: right;
	align-items: center;
	width: calc(50% - 8% - 30px);
	height: 100vh;
	margin-right: 30px;
}

#viewArea1 img,
#viewArea2 img {
	position: absolute;
	width: 100%;
}

#particleArea {
	position: relative;
	height: 100vh;
	overflow: hidden;
}

#particleAnimation {
	position: absolute;
	top: 130px;
	left: 50%;
	right: 8%;
	bottom: 130px;
	z-index: -2;
}

#topViewInner {
	display: flex;
	justify-content: center;
	align-items: center;
}

#shareNW {
	background-color: #F8F8F8;
}

#shareNW section h2 {
	color: var(--fontColor);
	font-size: 16px;
	font-weight: 500;
	margin-bottom: 10px;
}

#shareNW section p {
	color: var(--fontColor);
	font-size: 16px;
	line-height: 40px;
	margin-top: 30px;
}

#shareTopArea {
	display: flex;
	justify-content: center;
	padding: 120px 0 35px 0;
}

#shareTitle {
	position: relative;
	width: 32%;
	margin: 0 10% 0 8%;
	z-index: 3;
}

#shareTitle h1 {
	color: var(--mainColor);
	font-size: 75px;
	font-weight: 900;
	letter-spacing: 1px;
	line-height: 85px;
}

#shareTitle p {
	position: absolute;
	top: -36px;
	left: 0;
	color: var(--mainColor);
	font-size: 16px;
}

#shareTitle img {
	max-width: 100%;
	min-width: 300px;
	max-height: 350px;
	margin: 40px 0 -35px 0;
}

#shareTopArea section {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: center;
	width: 50%;
	background-color: #FFFFFF;
	padding: 60px 8% 60px 30px;
	box-sizing: border-box;
}

#shareTopArea section:before {
	content: '';
	position: absolute;
	top: 0;
	left: -45%;
	right: 100%;
	bottom: 0;
	background: linear-gradient(to top left, #FFFFFF 50%, transparent 50%);
	z-index: 1;
}

#shareTopArea section * {
	z-index: 2;
}

#shareBottomArea {
	padding: 110px 8% 90px 8%;
}

section#shareBottomArea h2 {
	margin-bottom: 40px;
}

#benefit {
	display: flex;
	justify-content: space-between;
	gap: 25px 40px;
	flex-wrap: wrap;
}

#benefit ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 25px 40px;
	width: calc(50% - 20px);
	list-style-type: none;
}

#benefit ul li {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
	width: calc(50% - 20px);
	height: 325px;
	background-color: #FFFFFF;
	text-align: center;
	padding: 45px 0;
	box-sizing: border-box;
}

#benefit ul li img {
	width: 70px;
}

#benefit ul li h3 {
	color: var(--fontColor);
	font-size: 20px;
	font-weight: 500;
	line-height: 30px;
}

#benefit ul li p {
	color: var(--fontColor);
	line-height: 30px;
	margin: 0;
}

#shareBottomArea p.btn {
	margin: 80px auto 0 auto;
}

#partners {
	display: flex;
	flex-direction: row-reverse;
	justify-content: center;
	padding: 210px 0 180px 0;
}

#partners section {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: center;
	width: 50%;
	background-color: #F8F8F8;
	padding: 60px 0 60px 8%;
	box-sizing: border-box;
}

#partners section:before {
	content: '';
	position: absolute;
	top: 0;
	left: 100%;
	right: -40%;
	bottom: 0;
	background: linear-gradient(to top right, #F8F8F8 50%, transparent 50%);
	z-index: 1;
}

#partners section * {
	z-index: 2;
}

#partners section h2 {
	display: flex;
	color: var(--fontColor);
	font-size: 16px;
	font-weight: 500;
	line-height: 30px;
	margin-bottom: 10px;
}

#partners section h2 p {
	margin-top: 0;
}

#partners section p {
	color: var(--fontColor);
	font-size: 16px;
	line-height: 40px;
	margin-top: 30px;
}

#partners section p.btn {
	margin-top: 80px;
}

#partnersTitle {
	position: relative;
	width: 32%;
	text-align: right;
	margin: 0 8% 0 10%;
	clear: both;
	z-index: 3;
}

#partnersTitle h1 {
	position: absolute;
	right: 0;
	color: var(--mainColor);
	font-size: 75px;
	font-weight: 900;
	letter-spacing: 1px;
	line-height: 85px;
}

#partnersTitle p {
	position: absolute;
	top: -36px;
	right: 0;
	color: var(--mainColor);
	font-size: 16px;
}

#partnersTitle img {
	display: block;
	max-width: 100%;
	min-width: 300px;
	max-height: 450px;
	margin: 130px 0 -20px 0;
	float: right;
}

#recruit {
	position: relative;
	height: 326px;
	text-align: center;
	overflow: hidden;
}

#recruit:after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url(../images/Top_recruit.jpg) no-repeat center center;
	background-size: cover;
	transition: all .3s ease-out;
	z-index: -1;
}

#recruit:hover:after {
	transform: scale(1.1);
}

#recruit a {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	color: var(--whiteFontColor);
	text-decoration: none;
}

#recruit a h1 {
	font-size: 30px;
	font-weight: 500;
	letter-spacing: 1px;
	line-height: 40px;
	margin-bottom: 5px;
}

#recruit a p {
	font-size: 16px;
	font-weight: 500;
	line-height: 23px;
}

.hideImg {
	opacity: 0.0;
}

.hideAnim {
	opacity: 0.0;
	transition: opacity 300ms;
}

.hyphen:after {
	content: '';
	display: inline-block;
	width: 25px;
	height: 1px;
	background-color: var(--fontColor);
	margin: 0 20px;
	vertical-align: middle;
}

@media only screen and (max-width: 1279px) {
	#topView section h2 {
		font-size: 25px;
	}

	#topView section p {
		font-size: 15px;
		line-height: 35px;
	}

	#shareNW section h2 {
		font-size: 15px;
	}

	#shareNW section p {
		font-size: 15px;
		line-height: 35px;
	}

	#shareTitle h1 {
		font-size: 50px;
		line-height: 60px;
	}

	#shareTitle p {
		top: -30px;
		font-size: 15px;
	}

	#benefit {
		display: flex;
		justify-content: space-between;
		gap: 25px 20px;
		flex-wrap: wrap;
	}

	#benefit ul {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		gap: 25px 20px;
		width: calc(50% - 10px);
		list-style-type: none;
	}

	#benefit ul li {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		align-items: center;
		width: calc(50% - 10px);
		height: 260px;
		background-color: #FFFFFF;
		text-align: center;
		padding: 25px 0;
		box-sizing: border-box;
	}

	#benefit ul li h3 {
		font-size: 15px;
		line-height: 25px;
	}

	#benefit ul li p {
		line-height: 25px;
	}

	#partnersTitle h1 {
		font-size: 50px;
		line-height: 60px;
	}

	#partnersTitle p {
		top: -30px;
		font-size: 15px;
	}

	#partners section h2 {
		font-size: 15px;
	}

	#partners section p {
		font-size: 15px;
		line-height: 35px;
	}

	#recruit a h1 {
		font-size: 25px;
		line-height: 33px;
	}

	#recruit a p {
		font-size: 15px;
		line-height: 20px;
	}
}

@media only screen and (max-width: 1023px) {
	#benefit {
		display: flex;
		justify-content: space-between;
		gap: 25px 0;
		flex-wrap: wrap;
	}

	#benefit ul {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		gap: 25px 20px;
		width: 100%;
		list-style-type: none;
	}

	#benefit ul li {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		align-items: center;
		width: calc(50% - 10px);
		max-width: 260px;
		min-width: 190px;
		height: 260px;
		background-color: #FFFFFF;
		text-align: center;
		padding: 25px 0;
		box-sizing: border-box;
	}
}

@media only screen and (max-width: 599px) {
	#viewArea1 {
		left: 30px;
		right: 30px;
		justify-content: left;
	}

	#viewArea2 {
		justify-content: left;
		align-items: center;
		width: auto;
		height: auto;
		margin: 0 40px 65px 0;
	}

	#viewArea2 img.secondView {
		position: relative;
	}

	#particleAnimation {
		left: 0;
		right: 0;
	}

	#topViewInner {
		display: block;
		margin: 0 30px;
	}

	#topView section {
		width: 100%;
		margin: 0 0 160px 0;
	}

	#topView section h2 {
		font-size: 25px;
	}

	#topView section p {
		font-size: 15px;
	}

	#shareNW section h2 {
		font-size: 15px;
	}

	#shareNW section p {
		font-size: 15px;
		margin-top: 35px;
	}

	#shareTopArea {
		display: block;
		padding: 120px 0 0 0;
	}

	#shareTitle {
		width: 100%;
		padding: 0 30px;
		margin: 0;
		box-sizing: border-box;
	}

	#shareTitle h1 {
		font-size: 50px;
		line-height: 60px;
	}

	#shareTitle p {
		top: -30px;
		left: 30px;
		font-size: 15px;
	}

	#shareTitle img {
		display: block;
		max-width: 100%;
		max-height: 305px;
		margin: 45px auto;
	}

	#shareTopArea section {
		width: 100%;
		background-color: transparent;
		padding: 45px 30px;
	}

	#shareTopArea section:before {
		left: 30px;
		right: 70%;
		background: linear-gradient(to top left, transparent 50% , #F8F8F8 50%);
	}

	#shareTopArea section:after {
		content: '';
		position: absolute;
		top: 0;
		left: 30px;
		right: 0;
		bottom: 0;
		background-color: #FFFFFF;
	}

	#shareBottomArea {
		padding: 90px 30px 125px 30px;
	}

	#benefit ul {
		gap: 25px 20px;
		width: 100%;
	}

	#benefit ul li {
		width: calc(50% - 10px);
		height: 260px;
		padding: 25px 0;
	}

	#benefit ul li h3 {
		font-size: 15px;
		line-height: 25px;
	}

	#benefit ul li p {
		line-height: 25px;
	}

	#shareBottomArea p.btn {
		margin: 65px auto 0 auto;
	}

	#partners {
		display: block;
		padding: 155px 0 160px 0;
	}

	#partnersTitle {
		width: 100%;
		text-align: left;
		padding: 0 30px;
		margin: 0;
		box-sizing: border-box;
	}

	#partnersTitle h1 {
		position: relative;
		font-size: 50px;
		line-height: 60px;
	}

	#partnersTitle p {
		top: -30px;
		left: 30px;
		right: auto;
		font-size: 15px;
	}

	#partnersTitle img {
		max-width: 100%;
		max-height: 395px;
		margin: 45px auto;
		float: none;
	}

	#partners section {
		position: relative;
		width: 100%;
		background-color: transparent;
		padding: 45px 30px;
		box-sizing: border-box;
	}

	#partners section:before {
		left: 0;
		right: 30px;
		background-color: #F8F8F8;
	}

	#partners section:after {
		content: '';
		position: absolute;
		top: 0;
		left: 70%;
		right: 30px;
		bottom: 0;
		background: linear-gradient(to top right, #F8F8F8 50%, #FFFFFF 50%);
		z-index: 1;
	}

	#partners section h2 {
		font-size: 15px;
	}

	#partners section p {
		font-size: 15px;
		margin-top: 35px;
	}

	#partners section p.btn {
		margin-top: 65px;
	}

	#recruit {
		height: 252px;
	}

	#recruit a h1 {
		font-size: 25px;
		line-height: 33px;
	}

	#recruit a p {
		font-size: 15px;
		line-height: 20px;
	}
}

@media only screen and (max-width: 479px) {
	#topView section h2 {
		font-size: 20px;
	}

	#topView section p {
		font-size: 14px;
	}

	#shareNW section h2 {
		font-size: 14px;
	}

	#shareNW section p {
		font-size: 14px;
	}

	#shareTitle h1 {
		font-size: 45px;
	}

	#shareTitle p {
		top: -24px;
		font-size: 14px;
	}

	#benefit ul {
		justify-content: center;
		min-width: 200px;
	}

	#benefit ul li {
		min-width: 200px;
	}

	#benefit ul li h3 {
		font-size: 14px;
	}

	#partnersTitle h1 {
		font-size: 45px;
	}

	#partnersTitle p {
		top: -24px;
		font-size: 14px;
	}

	#partners section h2 {
		font-size: 14px;
	}

	#partners section p {
		font-size: 14px;
	}

	#recruit a p {
		font-size: 14px;
	}
}

.particles-canvas {
	animation: 60s linear infinite rotation;
}

@keyframes rotation{
	0%{ transform: rotate(0); }
	100%{ transform: rotate(360deg); }
}