#main_visual_mo{
	display: none;
}
.main_visual .swiper-slide{
	height:970px;
	position:relative;
}
.main_visual .swiper-slide > .txt_box{
	position:absolute;
	left:0;
	width:100%;
	top:50%;
	transform:translateY(-51%);
	text-align:center;
	color:#fff;
	padding-top:90px;
}
.main_visual .swiper-slide > .txt_box h3{
	font-size:7.2rem;
	font-weight:600;
}
.main_visual .swiper-slide > .txt_box h3 span{
	font-weight: 300;
}
.main_visual .swiper-slide > .txt_box p{
	letter-spacing: 2rem;
	font-size:2.4rem;
	font-weight:300;
	margin-top:2rem;
}
/* 컨트롤러 */
.main_visual .controller{
	position:absolute;
	left:0;
	bottom:0;
	z-index:10;
	color:#fff;
	display:flex;
	align-items: center;
	padding:3rem 5rem;
}
.main_visual .controller .mv_pagination{
	display:flex;
	align-items: center;
}
.main_visual .swiper-pagination-bullet {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	width: auto;
	height: auto;
	margin: 0 10px;
	background-color: transparent;
	border-radius: 50%;
	cursor: pointer;
	transition: 0.3s;
	outline: none;
	opacity:1;
}
.main_visual .swiper-pagination-bullet-active::before{
	content:"";
	position:absolute;
	left:0;
	top:0;
	width:100%;
	height:100%;
	border:2px solid rgba(255,255,255,.3);
	border-radius:100%;
}
.main_visual .swiper-pagination-bullet::after{
	content:"";
	position:absolute;
	width:10px;
	height:10px;
	background:#fff;
	border-radius:100%;
}
.main_visual .swiper-pagination-bullet-active::after{
	background:#cc0000;
}
.main_visual .progress_circle {
	transform: rotate(-90deg);
	opacity:.6;
}
.main_visual .circle-origin {
	fill: transparent;
	stroke: rgb(255, 255, 255);
	stroke-width: 2;
	stroke-linecap: round;
	stroke-dasharray: 97px;
	stroke-dashoffset: 97px;
}
/* 스크롤 다운 */
.main_visual .scroll_down{
	position:absolute;
	right:6rem;
	bottom:3rem;
	z-index:3;
}
.main_visual .scroll_down button{
	display:block;
	border:none;
	background:none;
	outline: none;
	color:#fff;
}
.main_visual .scroll_down button .mouse{
	display:block;
	border:2px solid #fff;
	height:2.5rem;
	width:1.5rem;
	margin:0 auto;
	margin-bottom:.5rem;
	border-radius:5rem;
	position:relative;
}
.main_visual .scroll_down button .mouse::after{
	content:"";
	position:absolute;
	left:50%;
	transform:translateX(-50%);
	width:2px;
	height:8px;
	background:#fff;
	border-radius:5rem;
	top:6px;
	animation: mouse .6s infinite alternate;
}

@keyframes mouse{
	0%{top:6px;}
	100%{top:12px; height:6px;}
}

@media(max-width:991.98px){
	#main_visual_pc{
		display: none;
	}
	#main_visual_mo{
		display: block;
		padding-top: 6.75rem;
	}
	.main_visual .swiper-slide {
		position: relative;
 	}
	 .main_visual .controller {
    left: 50%;
		transform: translateX(-50%);
	}
	.main_visual .swiper-slide > .txt_box{
		padding-top: 0;
	}
	 .main_visual .swiper-slide > .txt_box h3{
		font-size:5rem;
	}
	.main_visual .swiper-slide > .txt_box p{
		letter-spacing: 2rem;
		font-size:2.2rem;
		margin-top:2rem;
	}
}
@media(max-width:767.98px){
	.main_visual .swiper-slide {
		max-height: 750px;
	}
	 .main_visual .controller {
		padding-bottom: 5rem;
	}
	.main_visual .scroll_down {
		display: none;
	}
	.main_visual .swiper-slide > .txt_box p{
		letter-spacing: 1.5rem;
		font-size:2rem;
		margin-top:1rem;
	}
}
@media(max-width:575.98px){
	.main_visual .swiper-slide {
		max-height: 500px;
	}
	.main_visual .controller {
		padding-bottom: 1rem;
	}
}
@media(max-width:450px){
	.main_visual .swiper-slide {
		max-height: 400px;
	}
}
@media(max-width:360px){
	.main_visual .swiper-slide {
		max-height: 350px;
	}
}





/* section title */
#main_container {
	overflow-x: hidden;
}
#main_container > section h4.main_title{
	text-transform: uppercase;
	font-family: 'Poppins';
	font-size: 6rem;
	font-weight: 500;
}
@media (max-width:991.98px) {
	#main_container > section h4.main_title{
		font-size: 5rem;
	}
}
@media (max-width:767.98px) {
	#main_container > section h4.main_title{
		font-size: 4rem;
	}
}
@media (max-width:575.98px) {
	#main_container > section h4.main_title{
		font-size: 3rem;
	}
}

/*sec01*/
#main_container > .sec01{
	padding-top: 11rem;
	padding-bottom: 11rem;
}
#main_container > .sec01 .txt,
#main_container > .sec01 .txt h4,
#main_container > .sec01 .txt a{
	display: flex;
}
#main_container > .sec01 .txt{
	margin-bottom: 8rem;
	justify-content: space-between;
}
#main_container > .sec01 .txt a{
	align-items: center;
	justify-content: center;
	width: 18rem;
	height: 5rem;
	color: #fff;
	background: #333;
	border-radius: 2.5rem;
}
#main_container > .sec01 .img{
	position: relative;
	height: 48rem;
	background: url(../_img/main/sec01_img.jpg) no-repeat center center / cover;
}
#main_container > .sec01 .img p{
	position: absolute;
	top: 50%; left: 50%;
	transform: translate(-50%,-50%);
}

@media (max-width:1199.98px) {
	#main_container > .sec01 .txt h4{
		display: block;
	}
}
@media (max-width:991.98px) {
	#main_container > .sec01{
		padding-top: 8rem;
		padding-bottom: 8rem;
	}
	#main_container > .sec01 .img{
		height: 40rem;
	}
}
@media (max-width:767.98px) {
	#main_container > .sec01{
		padding-top: 6rem;
		padding-bottom: 6rem;
	}
	#main_container > .sec01 .txt{
		display: block;
	}
	#main_container > .sec01 .img{
		height: 35rem;
	}
	#main_container > .sec01 .img img{
		max-width: 150px;
	}
}
@media (max-width:575.98px) {
	#main_container > .sec01 .img{
		height: 30rem;
	}
	#main_container > .sec01 .img img{
		max-width: 110px;
	}
}




/*sec02*/
#main_container > .sec02{
	position: relative;
	padding-top: 9rem;
	padding-bottom: 13.5rem;
	background: #f8f8f8;
}
#main_container > .sec02::after{
	content: '';
	position: absolute;
	top: 0; right: 0;
	width: 25%;
	height: 100%;
	background: url(../_img/main/sec02_bg.jpg) no-repeat center center / cover;
}
#main_container > .sec02 > div{
	position: relative;
	z-index: 1;
}
#main_container > .sec02 h4 p{
	color: #303030;
}
#main_container > .sec02 .list{
	display: flex;
}
#main_container > .sec02 .list a{
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-left: 7rem;
	width: 50%;
	height: 52rem;
	color: #fff;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
#main_container > .sec02 .list a:first-child{
	box-shadow: 0 1rem 2rem rgba(0,0,0,.3);
}
#main_container > .sec02 .list p img{
	margin-left: 1rem;
}

@media (max-width:991.98px) {
	#main_container > .sec02{
		padding-top: 8rem;
		padding-bottom: 10.5rem;
	}
	#main_container > .sec02::after {
    width: 18%;
	}
	#main_container > .sec02 .list a {
    padding: 4rem;
    width: 50%;
    height: 45rem;
	}
}
@media (max-width:767.98px) {
	#main_container > .sec02{
		padding-top: 6rem;
		padding-bottom: 6rem;
	}
	#main_container > .sec02::after{
		display: none;
	}
	#main_container > .sec02 .list {
    flex-wrap: wrap;
	}
	#main_container > .sec02 .list a {
    width: 100%;
    height: 35rem;
		box-shadow: 0 1rem 2rem rgba(0,0,0,.3);
	}
}
@media (max-width:575.98px) {
	#main_container > .sec02 .list a {
    height: 30rem;
	}
}




/*sec03*/
#main_container > .sec03{
	z-index: 1;
	position: relative;
	padding-top: 10rem;
	padding-bottom: 18rem;
}
#main_container > .sec03::after{
	content:"";
	position:absolute;
	left:50%;
	right:50%;
	margin-left:-50vw;
	margin-right:-50vw;
	height:72%;
	bottom:0;
	background:#f0f0f0;
	z-index:-1;
}
#main_container > .sec03 .txt{
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
}
#main_container > .sec03 .txt .tab span{
	cursor: pointer;
	display: inline-block;
	margin-left: 5rem;
	padding-bottom: 5px;
	border-bottom: 3px solid rgba(0,0,0,0);
}
#main_container > .sec03 .txt .tab span.active{
	border-color: #cc0000;
}
#main_container > .sec03 ul{
	display: flex;
	flex-wrap: wrap;
	gap: 4rem;
}
#main_container > .sec03 ul li{
	width: calc(33.3% - 2.7rem);
}
#main_container > .sec03 ul li a{
	position: relative;
	display: block;
	width: 100%;
}
#main_container > .sec03 ul li a::before{
	content: '';
	z-index: 1;
	position: absolute;
	width: 100%;
	height: 100%;
	border: 3px solid #000;
	opacity: 0;
	transition: all .3s;
}
#main_container > .sec03 ul li .img{
	position: relative;
} 
#main_container > .sec03 ul li .img::before,
#main_container > .sec03 ul li .img::after{
	content: '';
	position: absolute;
	opacity: 0;
	transition: all .3s;
}
#main_container > .sec03 ul li .img::before{
	z-index: 1;
	top: 50%; left: 50%;
	width: 9.2rem; 
	height: 2.3rem;
	background: url(../_img/main/sec04_viewMore.png) no-repeat center center / 9.2rem 2.3rem;
	transform: translate(-50%,-50%);
} 
#main_container > .sec03 ul li .img::after{
	top: 0; left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,.5);
} 
#main_container > .sec03 ul li .desc{
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 2.5rem 3rem;
	font-size: 2rem;
	color: #000;
	background: #fff;
}

/* hover */
#main_container > .sec03 ul li:hover a::before,
#main_container > .sec03 ul li:hover .img::before,
#main_container > .sec03 ul li:hover .img::after{
	opacity: 1;
}

#main_container > .sec03 .more{
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto;
	width: 6rem;
	height: 6rem;
	font-size: 3rem;
	color: #000;
	background: #dcdcdc;
	outline: none;
	border: none;
	border-radius: 50%;
}

@media (max-width:1199.98px) {
	#main_container > .sec03 .txt .tab span {
    margin-left: 3rem;
	}
	#main_container > .sec03 ul li .desc{
		min-height: 10.5rem;
	}
}
@media (max-width:991.98px) {
	#main_container > .sec03{
		padding-bottom: 10rem;
	}
	#main_container > .sec03 .txt {
    display: block;
	}
	#main_container > .sec03 ul li .desc{
    padding: 2rem;
    font-size: 1.8rem;
	}
}
@media (max-width:767.98px) {
	#main_container > .sec03{
		padding-bottom: 8rem;
	}
	#main_container > .sec03 ul{
		gap: 3rem;
	}
	#main_container > .sec03 ul li{
		width: calc(50% - 1.7rem);
	}
	#main_container > .sec03 ul li .desc{
		min-height: 8.5rem;
    padding: 1.5rem;
		font-size: 1.6rem;
	}
}




/*sec04*/
#main_container > .sec04 {
	position: relative;
	padding-top: 16.5rem;
	padding-bottom: 18rem;
}
#main_container > .sec04 .txt dl + dl{
	margin-top: 1rem;
}
#main_container > .sec04 .txt dt{
	margin-bottom: 8px;
	font-family: 'Poppins';
	font-size: 2rem;
}
#main_container > .sec04 .txt dd{
	font-size: 1.6rem;
	font-weight: 300;
	color: #333;
}
#main_container > .sec04 .txt dd a{
	display: flex;
	align-items: center;
	justify-content: center;
	margin-right: 5px;
	width: 4rem;
	height: 4rem;
	border-radius: 1rem;	
	background: #000;
}
#main_container > .sec04 .txt dd a img{
	max-width: 2.6rem;
}

#main_container > .sec04 > .map{
	position: absolute;
	top: 16.5rem;right: 0;
	width: 61.458333%;
	height: 56rem;
}
#main_container > .sec04 > .map > div,
#main_container > .sec04 .root_daum_roughmap .wrap_map{
	width: 100%;
	height: 100%;
}
#main_container > .sec04 > .map .root_daum_roughmap .wrap_controllers,
#main_container > .sec04 > .map .root_daum_roughmap .border1,
#main_container > .sec04 > .map .root_daum_roughmap .border3{
	display: none;
}


@media (max-width: 991.98px){
	#main_container > .sec04 {
    padding-top: 10rem;
		padding-bottom: 12rem;
	}
	#main_container > .sec04 > .map{
		position: unset;
		margin: 0 auto;
		margin-top: 4rem;
		padding: 0 15px;
		max-width: 720px;
		width: 100%;
		height: 45rem;
	}
	#main_container > .sec04 .txt div{
		display: flex;
		flex-wrap: wrap;
	}
	#main_container > .sec04 .txt div dl{
		width: 50%;
	}
}
@media (max-width: 767.98px){
	#main_container > .sec04 {
    padding-top: 8rem;
		padding-bottom: 10rem;
	}
	#main_container > .sec04 .txt dt{
		margin-bottom: 5px;
		font-size: 1.8rem;
	}
	#main_container > .sec04 > .map{
		max-width: 540px;
		height: 35rem;
	}
}
@media (max-width: 575.98px){
	#main_container > .sec04 > .map{
		height: 30rem;
	}
}