.main_visual .swiper-slide{
	width:100% !important;
	height:100vh;
	position:relative;
}
.main_visual .swiper-slide .item {
	position:relative;
	width:100%;
	height:100%;
	overflow:hidden;
	background-size:cover !important;
}
.main_visual .swiper-slide .item > .txt_box {
	position:absolute;
	left:50%;
	top:50%;
	width:100%;
	transform:translateX(-50%);
	text-align:center;
	color:#fff;
	z-index:10;
	opacity:0;
	transition:all 2s ease;
}
.main_visual .swiper-slide .item > .txt_box > p {
	font-size:2.8rem;
	font-weight:300;
}
.main_visual .swiper-slide .item > .txt_box > h3 {
	font-size:6.8rem;
	font-weight:800;
	margin-top:1rem;
}
.main_visual .swiper-slide.swiper-slide-active > .item > .txt_box {
	opacity:1;
	top:45%;
}
.main_visual .swiper-slide .item > .visual_bg {
	position:absolute;
	left:0;
	top:0;
	width:100%;
	height:100%;
	transition:all 5s ease-in-out;
	transform:scale(1,1);
}
.main_visual .swiper-slide.swiper-slide-active .item > .visual_bg {
	transform:scale(1.05,1.05);
}
.main_visual .swiper-container .visual-button-next,
.main_visual .swiper-container .visual-button-prev {
	position:absolute;
	color:#fff;
	width:6rem;
	height:6rem;
	text-align:center;
	line-height:6rem;
	box-sizing:border-box;
	border:1px solid rgba(255,255,255,0.5);
	font-size:2.2rem;
	top:55%;
	transform:translateY(-55%);
	z-index:10;
}
.main_visual .swiper-container .visual-button-prev {
	left:3rem;
}
.main_visual .swiper-container .visual-button-next {
	right:3rem;
}
.main_visual .swiper-container .visual-pagination {
	display:none;
	bottom:3rem !important;
}
.main_visual .swiper-container .visual-pagination .swiper-pagination-bullet {
	opacity:1;
	background:rgba(255,255,255,0.5);
}
.main_visual .swiper-container .visual-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
	background:rgba(255,255,255,1);
}
@media (max-width: 1199.98px) {
	.main_visual .swiper-slide{
		height:80vh;
	}
	.main_visual .swiper-slide .item > .txt_box {
		top:60%;
	}
	.main_visual .swiper-slide.swiper-slide-active > .item > .txt_box {
		top:55%;
	}
	.main_visual .swiper-container .visual-button-next,
	.main_visual .swiper-container .visual-button-prev {
		top:63%;
	}
}
@media (max-width: 991.98px) {
	.main_visual .swiper-slide{
		height:60vh;
	}
	.main_visual .swiper-slide .item > .txt_box > p {
		font-size:2.2rem;
	}
	.main_visual .swiper-slide .item > .txt_box > h3 {
		font-size:4.8rem;
		margin-top:0;
	}
	.main_visual .swiper-container .visual-button-next,
	.main_visual .swiper-container .visual-button-prev {
		width:4rem;
		height:4rem;
		line-height:4rem;
		font-size:2rem;
	}
	.main_visual .swiper-container .visual-button-prev {
		left:2rem;
	}
	.main_visual .swiper-container .visual-button-next {
		right:2rem;
	}
}
@media (max-width: 575.98px) {
	.main_visual .swiper-slide{
		height:40vh;
	}
	.main_visual .swiper-slide .item > .txt_box {
		top:53%;
	}
	.main_visual .swiper-slide .item > .txt_box > p {
		font-size:1.8rem;
	}
	.main_visual .swiper-slide .item > .txt_box > h3 {
		font-size:3.6rem;
		margin-top:0.5rem;
	}
	.main_visual .swiper-slide.swiper-slide-active > .item > .txt_box {
		top:48%;
	}
	.main_visual .swiper-container .visual-button-next,
	.main_visual .swiper-container .visual-button-prev {
		display:none;
	}
	.main_visual .swiper-container .visual-pagination {
		display:block;
	}
}

#main_container section {
	position:relative;
	box-sizing:border-box;
	overflow:hidden;
}
#main_container .sec01 {
	padding:16rem 0;
}
#main_container .sec01:before {
	content:"";
	position:absolute;
	width:100%;
	height:50%;
	background:#f5f5f5;
	left:0;
	bottom:0;
	z-index:-1;
}
#main_container .sec01 .title {
	text-align:center;
}
#main_container .sec01 .title h2 {
	font-size:6rem;
	font-weight:700;
	color:#222;
	display:inline-block;
	position:relative;
}
#main_container .sec01 .title h2:before {
	content:"";
	position:absolute;
	width:100%;
	height:2rem;
	background:var(--main-color);
	opacity:0.6;
	left:0;
	bottom:0.5rem;
}
#main_container .sec01 .title p {
	margin-top:3rem;
	font-size:2rem;
}
#main_container .sec01 .row {
	width:100%;
	max-width:124rem;
	margin:10rem auto 0;
}
#main_container .sec01 .row > div[class^='col-'] {
	position:relative;
}
#main_container .sec01 .row > div[class^='col-'] > a {
	display:block;
	position:relative;
	padding-bottom:160%;
	background-repeat:no-repeat;
	background-position:center center;
	background-size:cover;
	transition:all 0.3s;
	color:#fff;
	font-size:2.2rem;
	text-align:center;
}
#main_container .sec01 .row > div[class^='col-'] > a > .inner {
	position:absolute;
	left:0;
	top:0;
	display:flex;
	align-items:center;
	justify-content:center;
	width:100%;
	height:100%;
}
#main_container .sec01 .row > div[class^='col-'] > a > .inner .icon {
	margin-bottom:1rem;
}
#main_container .sec01 .row > div[class^='col-'] > a > .btn {
	position:absolute;
	left:50%;
	transform:translateX(-50%);
	bottom:6rem;
	width:60%;
	font-size:1.6rem;
	font-weight:300;
	color:#fff;
	text-align:center;
	box-sizing:border-box;
	padding:1.2rem;
	border:1px solid rgba(255,255,255,0.5);
	z-index:5;
	opacity:0;
}
#main_container .sec01 .row > div[class^='col-'] > a:hover {
	transform:scale(1.1);
	z-index:20;
	box-shadow:10px 0 20px rgba(0,0,0,0.3);
}
#main_container .sec01 .row > div[class^='col-'] > a:hover > .btn {
	opacity:1;
}
#main_container .sec01 .row > div[class^='col-'] > a:hover > .btn:hover {
	background:#fff;
	color:#222;
	font-weight:400;
}
@media (max-width: 991.98px) {
	#main_container .sec01 {
		padding:6rem 0;
	}
	#main_container .sec01 .title h2 {
		font-size:4rem;
	}
	#main_container .sec01 .title h2:before {
		height:1rem;
	}
	#main_container .sec01 .title p {
		margin-top:2rem;
		font-size:1.8rem;
	}
	#main_container .sec01 .row {
		margin:4rem auto 0;
	}
	#main_container .sec01 .row > div[class^='col-'] > a {
		padding-bottom:140%;
		font-size:2rem;
	}
}
@media (max-width: 767.98px) {
	#main_container .sec01 .title h2 {
		font-size:3rem;
	}
	#main_container .sec01 .row > div[class^='col-'] > a {
		transition:all 0s;
	}
	#main_container .sec01 .row > div[class^='col-'] > a:hover {
		transform:scale(1);
		box-shadow:10px 0 20px rgba(0,0,0,0);
	}
	#main_container .sec01 .row > div[class^='col-'] > a .icon > img {
		max-width:5rem;
	}
	#main_container .sec01 .row > div[class^='col-'] > a > .btn {
		bottom:2rem;
		width:80%;
		opacity:1;
		padding:1rem;
	}
}


#main_container .sec02 {
	padding-bottom:28%;
	background:url('../_img/sub/main_sec02_img.jpg') no-repeat center top / cover;
	background-attachment: fixed;
}
#main_container .sec02:before {
	content:"";
	position:absolute;
	width:100%;
	height:100%;
	left:0;
	top:0;
	background:rgba(0,0,0,0.4);
}
#main_container .sec02 .inner {
	position:absolute;
	width:100%;
	height:100%;
	left:0;
	top:0;
	z-index:20;
	display:flex;
	align-items:center;
	justify-content:center;
}
#main_container .sec02 .inner .txt {
	text-align:center;
	font-size:4rem;
	color:#fff;
	line-height:1.2;
	box-sizing:border-box;
	padding:0 2rem;
}
@media (max-width: 991.98px) {
	#main_container .sec02 {
		padding-bottom:34%;
	}
	#main_container .sec02 .inner .txt {
		font-size:3rem;
	}
}
@media (max-width: 767.98px) {
	#main_container .sec02 {
		padding-bottom:40%;
		background-position:center center;
		background-attachment: unset;
	}
	#main_container .sec02 .inner .txt {
		font-size:2.4rem;
	}
}


#main_container .sec03 {
	padding:16rem 0;
}
#main_container .sec03 .row > div[class^='col-'] > a {
	display:block;
	color:#222;
}
#main_container .sec03 .row > div[class^='col-'] > a > h3 {
	font-size:4.8rem;
	font-weight:700;
	margin-bottom:1rem;
}
#main_container .sec03 .row > div[class^='col-'] > a > p {
	font-size:2rem;
}
#main_container .sec03 .row > div[class^='col-'] > a > .icon {
	margin:2rem 0 5rem;
}
@media (max-width: 991.98px) {
	#main_container .sec03 {
		padding:6rem 0;
	}
	#main_container .sec03 .row > div[class^='col-'] {
		margin-bottom:4rem;
	}
	#main_container .sec03 .row > div[class^='col-']:last-child {
		margin-bottom:0;
	}
	#main_container .sec03 .row > div[class^='col-'] > a > h3 {
		font-size:3rem;
		margin-bottom:1rem;
	}
	#main_container .sec03 .row > div[class^='col-'] > a > p {
		font-size:1.8rem;
	}
	#main_container .sec03 .row > div[class^='col-'] > a > .icon {
		margin:1rem 0 3rem;
	}
}
@media (max-width: 767.98px) {
	#main_container .sec03 .row > div[class^='col-'] {
		margin-bottom:2rem;
	}
	#main_container .sec03 .row > div[class^='col-'] > a > h3 {
		font-size:2.4rem;
		margin-bottom:.5rem;
	}
	#main_container .sec03 .row > div[class^='col-'] > a > .icon {
		margin:1rem 0 2rem;
	}
	#main_container .sec03 .row > div[class^='col-'] > a > .icon > img {
		max-width:5rem;
	}
}


#main_container .sec04 {
	padding:0 0 16rem;
}
#main_container .sec04 .flex {
	display:flex;
	flex-wrap:wrap;
	-ms-flex-wrap:wrap;
}
#main_container .sec04 .flex > div {
	display:block;
	position:relative;
	height:100%;
}
#main_container .sec04 .flex > .fl {
	width:20rem;
	height:46rem;
}
#main_container .sec04 .flex > .fr {
	width:calc(100% - 20rem);
}
#main_container .sec04 .flex > .fl > a {
	display:block;
	height:100%;
	color:#222;
}
#main_container .sec04 .flex > .fl > a h2 {
	font-size:8rem;
	font-weight:700;
	transform:rotate(90deg);
	transform-origin: 3.5rem 3.5rem;
	line-height:1;
}
#main_container .sec04 .flex > .fl > a .icon {
	position:absolute;
	left:0;
	bottom:0;
}
#main_container .sec04 .flex > .fr > .list {
	list-style:none;
	padding-left:0;
}
#main_container .sec04 .flex > .fr > .list > div {
	box-sizing:border-box;
	padding:3rem 3rem;
	position:relative;
	border-bottom:1px solid #eee;
}
#main_container .sec04 .flex > .fr > .list > div:first-child {
	padding-top:0;
}
#main_container .sec04 .flex > .fr > .list > div > a {
	display:block;
	position:relative;
	font-size:2.4rem;
	font-weight:600;
	color:#222;
}
#main_container .sec04 .flex > .fr > .list > div > a:before {
	content: "\e907";
	font-family:"xeicon";
	position:absolute;
	right:0;
	top:50%;
	transform:translateY(-50%);
	font-size:2.4rem;
	color:#7f7f7f;
}
#main_container .sec04 .flex > .fr > .list > div > a > p {
	display:block;
	box-sizing:border-box;
	padding-right:5rem;
	white-space:nowrap;
	overflow:hidden;
	text-overflow:ellipsis;
}
#main_container .sec04 .flex > .fr > .list > div > a > span {
	display:block;
	font-size:1.6rem;
	font-weight:300;
	color:#999;
}
#main_container .sec04 .flex > .fr > .list > div.noData {
	height:46rem;
	border-top:1px solid #eee;
	display:flex;
	align-items:center;
	justify-content:center;
}
@media (max-width: 991.98px) {
	#main_container .sec04 {
		padding:0 0 6rem;
	}
	#main_container .sec04 .flex {
		display:block;
	}
	#main_container .sec04 .flex > .fl {
		width:100%;
		height:auto;
	}
	#main_container .sec04 .flex > .fr {
		width:100%;
	}
	#main_container .sec04 .flex > .fl > a h2 {
		font-size:4rem;
		font-weight:700;
		transform:rotate(0);
		transform-origin: 0 0;
		line-height:1;
	}
	#main_container .sec04 .flex > .fl > a .icon {
		left:auto;
		right:0;
	}
	#main_container .sec04 .flex > .fr > .list {
		list-style:none;
		padding-left:0;
		margin-top:2rem;
	}
	#main_container .sec04 .flex > .fr > .list > div {
		padding:2rem 2rem;
	}
	#main_container .sec04 .flex > .fr > .list > div:first-child {
		padding-top:2rem;
		border-top:1px solid #eee;
	}
	#main_container .sec04 .flex > .fr > .list > div > a {
		font-size:2rem;
	}
	#main_container .sec04 .flex > .fr > .list > div > a:before {
		font-size:2rem;
	}
	#main_container .sec04 .flex > .fr > .list > div.noData {
		height:24rem;
	}
}
@media (max-width: 767.98px) {
	#main_container .sec04 .flex > .fl > a h2 {
		font-size:3rem;
	}
	#main_container .sec04 .flex > .fl > a .icon > img {
		max-width:5rem;
	}
	#main_container .sec04 .flex > .fr > .list > div {
		padding:2rem 1.5rem;
	}
}