@charset "utf-8";
/* *******************************************************
 * filename : layout.css
 * description : 전체 레이아웃 CSS
 * date : 2022-01-24
******************************************************** */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700&amp;display=swap');


/* ========================================================
 * SETTING
======================================================== */
:root{
	--main-color: #62832b;
	--area-box-width: 1660px;
	--area-width: 1240px;
	--area-padding: 30px;
	--header-height: 100px;
	--full-height: 100vh;
}
::selection {
    background: var(--main-color);   
    color: #fff;
}
::-moz-selection {
    background: var(--main-color);    
    color: #fff;
}
html{font-size:10px; }

body, table, th, td, button, select, input, textarea {
	font-family:'Montserrat','Pretendard','Noto Sans KR', "나눔고딕", NanumGothic, "Nanum Gothic","돋움", Dotum, Arial, sans-serif;
	color:#666;
	-webkit-text-size-adjust:none;
	word-break:keep-all;
}
body { background-color:#fff; }
table, th, td{word-break:break-word;}

/* ========================================================
 * LAYOUT
======================================================== */
#wrap {overflow:hidden; width:100%; min-width:320px; position:relative; z-index:0}
.area{ max-width:var(--area-width); margin:0px auto;}
.area-box{ max-width:var(--area-box-width); margin:0px auto; }
.area-1450{ max-width:1450px; margin:0px auto; }
/* ****************** HEADER ********************** */
#header{position:absolute; height:var(--header-height); top:0; left:0; width:100%; z-index:9999;  opacity:0; transition:top ease-out 1s 0.4s, opacity 0.5s 0.4s}
#headerInnerWrap{
	position:absolute; top:0px; left:0px; width:100%; height:var(--header-height); z-index:9999; 
	-webkit-transition:background-color 0.3s;
	transition:background-color 0.3s
}
#headerInner{position:relative; display:flex; align-items:center; justify-content:space-between; height:var(--header-height); margin:0px auto; padding:0 13rem; }
#header .logo{position:relative; z-index:100; }
#header .logo a{display:block; }
#header .logo img{display:block; vertical-align:top;}
.active-page #header{top:7.8rem; opacity:1}
#header.sub{top:3rem; opacity:1; transition:top 0s 0s, opacity 0s 0s}
/* Header :: 언어선택 */
.header-lang-list {position:absolute; left:33.7rem; top:50%; transform:translateY(-50%); z-index:100;}
.header-lang-list li{float:left; font-size:14px; letter-spacing:0; color:#fff; margin-left:25px;}
.header-lang-list li:first-child{margin-left:0}
.header-lang-list li a{display:block; position:relative; color:#fff; transition:all 0.3s; font-weight:600}
.header-lang-list li a:after{
	position:absolute; bottom:-11px; left:-2px; right:-2px; 
	height:2px; 
	background-color:var(--main-color); 
	content:""; 
	transform:scaleX(0); 
	transition:transform 0.3s; 
	transform-origin:100% 0;
}
.header-lang-list li.cur a:after,
.header-lang-list li a:hover:after{transform:scaleX(1); transform-origin:0 0;}

/* Header :: 사이트맵버튼 */
.sitemap-line-btn{position:absolute; right:13rem; top:50%; transform:translateY(-50%); width:32px; height:32px; z-index:999}
.sitemap-line-btn .line{display:block; width:18px; height:2px; background-color:#333; border-radius:5px; margin: 3px auto; -webkit-transition: all 0.3s ease-in-out; transition: all 0.3s ease-in-out;}
/* active */
.sitemap-open-btn.active{position:relative; z-index:100000;}
.sitemap-open-btn.active .line:nth-child(2), 
.sitemap-open-btn.active .line:nth-child(4){opacity: 0;}
.sitemap-open-btn.active .line:nth-child(1){
	 -webkit-transform: translateY(5px) rotate(45deg);
	  transform: translateY(5px) rotate(45deg);
}
.sitemap-open-btn.active .line:nth-child(3){
	 -webkit-transform: translateY(-5px) rotate(-45deg);
	  transform: translateY(-5px) rotate(-45deg);
}

/* -------- Header :: GNB(PC) -------- */
.gnb-overlay-bg{position:fixed; top:0; left:0; width:100%; height:100%; visibility:hidden; opacity:0;filter:Alpha(opacity=0); background:rgba(0,0,0,0.5); z-index:9997;  -webkit-transition:all 0.3s; transition:all 0.3s; }	/* gnb overlay BG */
.gnb-overlay-bg.open{visibility:visible; opacity:1.0;filter:Alpha(opacity=100);}
#gnb{position:absolute; text-align:right; top:0; left:0px; width:100%; z-index:99; box-sizing:border-box; padding-right:30rem}
#gnb > ul{display:inline-block; *display:inline;*zoom:1;}
#gnb > ul > li{position:relative; float:left; word-break:keep-all;}
#gnb > ul > li > a{
	position:relative; z-index:100; display:block; line-height:100px; padding:0 4rem; text-align:center; color:#fff; font-size:1.8rem; letter-spacing:-0.035rem; font-weight:700; -webkit-transition:all 0.5s; transition:all 0.5s;
}
#gnb > ul > li > a:hover,
#gnb > ul > li > a:focus{color:var(--main-color);}

/* GNB :: 2차 전체메뉴 */
#gnbBg{
	overflow:hidden; position:absolute; left:0; top:0px; width:100%; height:0; background:#fff; z-index:98;
	opacity:0;filter:Alpha(opacity=0);
	-webkit-transition:height 0.3s ease-in-out, opacity 0.2s ease-in-out;
	transition:height 0.3s ease-in-out, opacity 0.2s ease-in-out;
}
#gnbBg:after{position:absolute; top:100px; width:100%; left:0; height:1px; background-color:#ddd; content:"";}
#gnb.total-menu > ul > li .gnb-2dep{
	position:absolute; 
	top:100px; 
	left:0px; 
	z-index:99;
	width:100%; 
	text-align:left; 
	border-right:1px solid #ddd;
	opacity:0;filter:Alpha(opacity=0);
	height:0;
	-webkit-transition: all 0.2s 0s;
    transition: all 0.2s 0s;
	visibility:hidden;
}
#gnb.total-menu > ul > li:first-child .gnb-2dep{border-left:1px solid #ddd;}
#gnb.total-menu > ul > li .gnb-2dep:before {
	content:""; position:absolute; left:0; top:0px; width:0; left:50%; height:1px; background-color:var(--main-color); 
	-webkit-transition:all 0.5s;-moz-transition:all 0.5s;-o-transition:all 0.5s;-ms-transition:all 0.5s;transition:all 0.5s; z-index:10;
}
#gnb.total-menu > ul > li:hover .gnb-2dep:before {width:100%; left:0;}
#gnb.total-menu > ul > li .gnb-2dep ul{padding:13px 0px;}
#gnb.total-menu > ul > li .gnb-2dep ul li{position:relative;}
#gnb.total-menu > ul > li .gnb-2dep ul li a{ display:block;  padding:7px 15px; color:#333; font-size:14px; letter-spacing:-0.5px; font-weight:400; line-height:1.3; -webkit-transition:all 0.2s;-moz-transition:all 0.2s;-o-transition:all 0.2s;-ms-transition:all 0.2s;transition:all 0.2s}
#gnb.total-menu > ul > li .gnb-2dep ul li a:hover{color:var(--main-color);}

/* GNB :: 2차메뉴 Over (높이변경) */
#gnb.open #gnbBg{height:350px; opacity:1.0;filter:Alpha(opacity=100);}
#gnb.open > ul > li .gnb-2dep{
	height:250px; opacity:1.0;filter:Alpha(opacity=100);
	visibility:visible;
	-webkit-transition: height 0.5s ease-in-out, opacity 0.5s ease-in-out 0.2s;
    transition: height 0.5s ease-in-out, opacity 0.5s ease-in-out 0.2s;
}

/* GNB :: 2차 각각메뉴 */
#gnb.each-menu > ul > li .gnb-2dep{
	/* display:none; */
	position:absolute; 
	top:80px; 
	left:0px; 
	z-index:99;
	width:100%; 
	text-align:left; 
	visibility:hidden;
	opacity:0;filter:Alpha(opacity=0);
	-webkit-transition:all 0.2s cubic-bezier(0.4, 0, 1, 1);
	transition:all 0.2s cubic-bezier(0.4, 0, 1, 1);
}
#gnb.each-menu > ul > li .gnb-2dep:before{
	content:""; 
	position:absolute; top:0px; left:0px; right:0px; 
	height:0; 
	background-color:var(--main-color); 
	-webkit-transition:all 0.2s cubic-bezier(0.4, 0, 1, 1); 
	transition:all 0.2s cubic-bezier(0.4, 0, 1, 1);
}
#gnb.each-menu > ul > li .gnb-2dep ul{padding:15px 0px;}
#gnb.each-menu > ul > li .gnb-2dep ul li{position:relative; padding:8px 10px; opacity:0;filter:Alpha(opacity=0);-webkit-transition:all 0s 0s;-moz-transition:all  0s 0s;-o-transition:all  0s 0s;-ms-transition:all  0s 0s;transition:all  0s 0s; }
#gnb.each-menu > ul > li .gnb-2dep ul li a{display:block; color:#fff; font-size:14px; font-weight:400; text-align:center; line-height:1.4; opacity:0.9;filter:Alpha(opacity=90);}
#gnb.each-menu > ul > li .gnb-2dep ul li a:hover{opacity:1.0;filter:Alpha(opacity=100);}
/* over했을때 */
#gnb.each-menu > ul > li .gnb-2dep.open{visibility:visible; opacity:1.0;filter:Alpha(opacity=100);}
#gnb.each-menu > ul > li .gnb-2dep.open:before{height:100%;}
#gnb > ul > li .gnb-2dep.open ul li{opacity:1.0;filter:Alpha(opacity=100); -webkit-transition:all 0.8s;-moz-transition:all 0.8s;-o-transition:all 0.8s;-ms-transition:all 0.8s;transition:all 0.8s;}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(1){-webkit-transition-delay: 0.1s; transition-delay:0.1s;}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(2){-webkit-transition-delay: 0.2s; transition-delay:0.2s;}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(3){-webkit-transition-delay: 0.3s; transition-delay:0.3s;}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(4){-webkit-transition-delay: 0.4s; transition-delay:0.4s;}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(5){-webkit-transition-delay: 0.5s; transition-delay:0.5s;}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(6){-webkit-transition-delay: 0.6s; transition-delay:0.6s;}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(7){-webkit-transition-delay: 0.7s; transition-delay:0.7s;}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(8){-webkit-transition-delay: 0.8s; transition-delay:0.8s;}

/* -------- Header :: GNB(Mobile) -------- */
.nav-open-btn{display:none;}
#gnbM{display:none}

/* ****************** FOOTER ********************** */
/* Footer :: 레이아웃 */
#footer.sub-ft{background:#242424; padding:12.5rem 0 10.5rem}
#footer .footer-area{display:flex; align-items:end}
#footer.main-ft .footer-area{border-top:1px solid rgba(255,255,255,0.1); padding:14.5rem 0 13rem}
.footer-left-con{width:calc(100% - 41rem); display:flex; align-items:center; box-sizing:border-box; padding-right:1%}
.footer-right-con{text-align:right; width: 90rem;}
/* Footer :: TOP버튼 */
.to-top-btn{
	position:fixed; bottom:-100px; right:15px; display:block; width:46px; height:46px; background-color:#fff; text-align:center; color:#333; z-index:99;
	border:1px solid #eee;
	box-sizing:border-box;
	opacity:0;filter:Alpha(opacity=0);
	-webkit-transition:all 0.6s;-moz-transition:all 0.6s;-o-transition:all 0.6s;-ms-transition:all 0.6s;transition:all 0.6s
	-webkit-border-radius:50%;-moz-border-radius:50%;-o-border-radius:50%;border-radius:50%;
}
.to-top-btn.bottom-fixed{bottom:15px; opacity:1.0;filter:Alpha(opacity=100);}
.to-top-btn i{display:inline-block; font-size:16px; line-height:46px; transition:all 0.3s}
.to-top-btn:hover i{transform:translateY(-3px)}
#fullpage .to-top-btn{display:none;}

/* Footer :: 푸터메뉴 */
.foot-menu{}
.foot-menu li{display:inline-block; vertical-align:bottom; position:relative; width:19rem; border-bottom:3px solid #fff; text-align:left}
.foot-menu li + li{margin-left:1.8rem}
.foot-menu li a{display:block; padding-bottom:2rem; position:relative; font-weight:500; font-size:1.5rem; color:#fff; letter-spacing:-0.065rem}
.foot-menu li a i{position:absolute; right:2.5rem; top:0; font-size:1.86rem}

/* Footer :: 푸터로고 */
.foot-logo{display:block;}

/* Footer :: 정보 */
.foot-address-copy{margin-left:4rem}
.footer-address-info-box{margin-bottom:1.5rem;}
.footer-address-list dl{display:inline-block; vertical-align:middle; color:#fff; font-size:1.5rem; line-height:1.5; margin-right:2.5rem; letter-spacing:-0.075rem; margin-bottom:1.5rem}
.footer-address-list dl:last-child{margin-right:0}
.footer-address-list dl dt,
.footer-address-list dl dd{vertical-align:middle; display:inline-block; font-weight:500}
.footer-address-list dl dt{margin-right:1.5rem; opacity:0.6; font-weight:600}
.footer-address-list a{color:inherit}

/* Footer :: Copyright */
.footer-copyright{font-size:1.5rem; letter-spacing:-0.035rem; font-weight:500; color:#fff; opacity:0.5; line-height:1.4}


/* ****************** SUB LAYOUT ********************** */
/*  SUB LAYOUT :: 비주얼 */
#visual{position:relative; width:100%; height:670px;}
#visual .visual-img-con{overflow:hidden; position:absolute; width:100%; height:100%; overflow:hidden}
#visual .visual-img-con .img-wrap{position:absolute; top:0; left:0; width:100%; height:100%; transition:all 0.3s}
#visual .visual-img-con span{	
	position:absolute; 
	top:0px; 
	left:0px; 
	width:100%;
	height:100%;
	background-size:cover !important;
    -webkit-transform: scale(1.1,1.1); 
     transform: scale(1.1,1.1);
	-webkit-transition:transform 5000ms  ease-in-out, margin-top 0.3s ;
    transition:transform 5000ms ease-in-out, margin-top 0.3s;	}
#visual .visual-txt-con{position:relative; z-index:1;display:table; width:100%; height:100%; letter-spacing:-0.5px; color:#fff; box-sizing:border-box}
#visual .visual-txt-container{position:relative; width:100%; }
#visual .visual-tit,
#visual .visual-sub-txt{
	opacity:0;filter:Alpha(opacity=0);
}
#visual .visual-tit{font-weight:700; letter-spacing:-0.06rem; font-size:6rem; }
#visual .visual-tit em{font-weight:700; font-style:normal !important;text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);}
#visual .visual-sub-txt{font-size:2rem; font-weight:600; letter-spacing:0; padding-top:2rem; color:rgba(255,255,255,0.5)}
#visual .visual-sub-txt em{font-weight:600; font-style: normal !important;text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);}

/* SUB LAYOUT :: 상단효과 active */
#visual.active .visual-img-con span{
    -webkit-transform: scale(1.0,1.0) rotate(0.002deg);
     transform: scale(1.0,1.0) rotate(0.002deg);
}
#visual.active .visual-tit,
#visual.active .visual-sub-txt{
	opacity:1.0;filter:Alpha(opacity=100);
}

#visual .txt-effect.splitting .char{
	-webkit-animation: text-fade-out 1.5s cubic-bezier(0.4, 0, 0.2, 1) both;
	animation: text-fade-out 1.5s cubic-bezier(0.4, 0, 0.2, 1) both;
}
#visual.active .txt-effect.splitting .char{
	-webkit-animation: text-active-animation 1.5s cubic-bezier(0.4, 0, 0.2, 1) both;
	animation: text-active-animation 1.5s cubic-bezier(0.4, 0, 0.2, 1) both;
}




/*  SUB LAYOUT :: 서브메뉴(스타일3) */
#topMenu04{position:absolute; bottom:7rem; left:0; right:0; z-index:9; text-align:right;}
#topMenu04 .side-menu-inner{width:100%;}
#topMenu04 .location-to-home-btn{display:inline-block; vertical-align:middle; width:3.8rem; height:3.8rem; background-color:var(--main-color); text-align:center; border-radius:50%}
#topMenu04 .location-to-home-btn i{color:#fff; font-size:1.6rem; line-height:3.8rem;}
#topMenu04 .menu-location{position:relative; display:inline-block; width:19rem; margin-left:5rem; vertical-align:middle}
#topMenu04 .menu-location:after{position:absolute; content:"\e93f"; font-family:"xeicon"; left:-3.8rem; top:50%; transform:translateY(-50%); color:#fff; opacity:0.2; font-size:1.8rem; }
#topMenu04 .menu-location > .cur-location{position:relative; display:block; width:100%; height:6rem; padding:0 35px 0 0; text-align:left; border-bottom:1px solid rgba(255,255,255,0.3)}
#topMenu04 .menu-location > .cur-location span{display:block; width:100%; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; line-height:6rem; color:#fff; font-weight:400; font-size:18px; letter-spacing:-0.5px;}
#topMenu04 .menu-location > .cur-location .arrow{position:absolute; top:50%; right:0; margin-top:-10px; font-size:20px; color:#fff}
#topMenu04 .menu-location.open > .cur-location .arrow{transform:rotate(-180deg); margin-top:-10px;}
#topMenu04 .menu-location .location-menu-con{display:none; position:absolute; top:100%; left:-1px; right:0px; border:1px solid #ddd; border-top:0; background-color:#fff; z-index:11; text-align:left}
#topMenu04 .menu-location .location-menu-con li a{display:block; padding:10px 20px; font-size:15px; word-break:keep-all; line-height:1.5;}
#topMenu04 .menu-location .location-menu-con li.on{position:relative;}
#topMenu04 .menu-location .location-menu-con li.on a{color:var(--main-color); font-weight:500;}

/* SUB LAYOUT :: 서브메뉴 Fixed (공통) */
@media all and (min-width:1025px){
	.fixed-sub-menu.top-fixed .side-menu-inner{position:fixed; top:0px; left:0px; z-index:9999;}
}

/* SUB LAYOUT :: 모바일메뉴(공통)  */
#topMenuM01,
#topMenuM02{display:none;}

/*  SUB LAYOUT :: 컨텐츠 레이아웃 */
#content:not(.wide){padding:13rem 0}
#content.wide{padding:13rem 0 0 0}

/* ****************** MODAL LAYERPOPUP ********************** */
/* modal layer */
.modal-fixed-pop-wrapper{display:none; overflow-y:scroll; overflow-x:hidden;  position:fixed; top:0px; left:0px; width:100%; height:100%; z-index:9999; background:#000; background:rgba(0,0,0,0.8);}
.modal-fixed-pop-inner{position:absolute; display:table; width:100%; height:100%; text-align:center;}
.modal-inner-box{ position:relative; display:table-cell; vertical-align:middle;}
.modal-loading{position:absolute; top:50%; left:50%; margin:-25px 0 0 -25px; z-index:10000;}
.modal-inner-content{text-align:left;}
.loading {
  display: inline-block;
  width: 50px;
  height: 50px;
  border: 8px solid rgba(255,255,255,.3);
  border-radius: 50%;
  border-top-color: #fff;
  animation: spin 1s ease-in-out infinite;
  -webkit-animation: spin 1s ease-in-out infinite;
}
@keyframes spin {
  to { -webkit-transform: rotate(360deg); transform: rotate(360deg); }
}
@-webkit-keyframes spin {
  to { -webkit-transform: rotate(360deg); transform: rotate(360deg);  }
}
/* modal layer content */
.footer-modal-content{position:relative; width:96%; max-width:1000px; margin:20px auto; }
.footer-modal-content h1{font-size:24px; font-weight:600; letter-spacing:-0.5px; text-align:center; padding:0 50px 20px; color:#fff;}
.modal-close-btn{position:absolute; top:-6px; right:-6px; color:#fff; }
.modal-close-btn i{font-size:38px;}
.modal-close-btn i:hover {color:#fff}
.footer-inner-box{padding:30px; background-color:#fff; }
.footer-inner{padding:20px; height:400px; overflow-y:auto; overflow-x:hidden; border:1px solid #ddd; }

