@charset "utf-8";
/* layout.css는 전체적인 스타일 정의 */
.wrap1{max-width:1846px; margin: 0 auto; padding: 0 20px; width: 100%; box-sizing: border-box;}
.wrap2{max-width:1480px; margin: 0 auto; padding: 0 20px; width: 100%; box-sizing: border-box;}
.wrap3{max-width:1620px; margin: 0 auto; padding: 0 20px; width: 100%; box-sizing: border-box;}
.contain {max-width:1480px; margin: 0 auto; padding: 0 20px; width: 100%; box-sizing: border-box;}


.header-wrap{position: fixed; left: 0; top: 0; width: 100%; z-index: 1000; height: 100px; transition:.5s; border-bottom: 1px solid rgba(255, 255, 255, 0.20); background: #FFF;}
#header{display: flex; height: 100%; align-items:center; justify-content: space-between; position: relative; z-index: 300; }
#header .sitelogo{position: relative; }

#header #gnb{margin-left: 58px; transition:.3s}
#header #gnb > ul{display: flex; align-items:center; gap:100px; transition:.3s}
#header #gnb > ul > li {position: relative;}
#header #gnb > ul > li > a{color: #222; font-size: 22px; font-weight: 600; line-height: 100px; text-align: center; padding: 0; transition:.3s;}
#header #gnb > ul > li > a:after{position: absolute; content: ''; width: 100%; height: 1px; background: #003F9D; left: 0; bottom: 0; opacity: 0; scale:0 1; transition:.3s;}
#header #gnb > ul > li .subm{position: absolute; left: 0; top: 100px; width: 100%; z-index: 20; display: none;}
#header #gnb > ul > li .subm > ul{display: flex; flex-direction: column; gap:16px; padding: 33px 0 40px}
#header #gnb > ul > li .subm > ul > li > a{color: #666; text-align: center; font-size: 20px; font-weight: 400; line-height: 160%; transition:.3s;}
#header #gnb > ul > li .subm > ul > li:hover > a{color: #003F9D; font-weight: 600; }
#header #gnb > ul > li .dep3{display: none;}

#header .hd-btn{display: flex; align-items:center; margin-right: -10px;; position: relative; transition:.3s;}
#header .hd-btn .mems > ul{display: flex; align-items:center;}
#header .hd-btn .mems > ul > li > a{display: flex; align-items:center; gap:8px; color: #666; font-size: 18px; font-weight: 400; line-height: 160%; text-align: center; align-items:center; justify-content: center;}
#header .hd-btn .mems > ul > li:first-child > a{color: #003F9D; gap:11px}
#header .hd-btn .mems > ul > li:first-child > a:after{content: '|'; margin: 0 21px 0 11px;color: #666;}

#header .hd-btn .hd-close{position: fixed; right: 120px; top: 20px; opacity: 0; transition:.3s; cursor: pointer; z-index: -100;}
#header .hd-btn .hd-close svg{transition:.3s;}
#header .hd-btn .hd-close:hover svg{rotate:180deg;}

#header .sitemap-btn{display: flex; flex-direction: column; align-items:center; justify-content: center; gap:10px; width: 100px; height: 100px; background: #003F9D; position: relative; margin-right: -40px; margin-left: 30px; display: none;}
#header .sitemap-btn span{width: 48px; height: 3px; background: #fff;}
#header .sitemap-btn span:last-child{width: 39px; margin-left: 9px;}
	

#header #gnb > ul > li:hover > a{color: #003F9D;
	&:after{scale:1; opacity: 1;;}
}

.header-wrap.on {
	#header #gnb{margin-left: 88px; }
	#header #gnb > ul{gap:40px;}
	#header #gnb > ul > li > a{padding: 0 49px;}
	#header .hd-btn .mems{opacity: 0; z-index: -1;}
	#header .hd-btn .hd-close{opacity: 1; z-index: 1;}
}

#sub .header-wrap{border: 1px solid rgba(204, 204, 204, 0.30); box-shadow: 0 4px 10px 0 rgba(0, 0, 0, 0.10);}

.submenu-bg{position: fixed; left: 0; top: 100px; width: 100%; height: 537px; z-index: 290; background: rgba(255, 255, 255, 0.94); box-shadow:-13px 18px 20px 0 rgba(0, 0, 0, 0.1); backdrop-filter: blur(15px); display: none; border-top: 1px solid #ddd;}


.header-wrap.active {transform:translateY(0);}
.header-wrap.hide {transform:translateY(-100%);}


/* footer */
.ft-wrap{border-top: 1px solid #eee; height: 279px; display: flex; align-items:center; }
#footer{display: flex; flex-wrap:wrap; align-items:center; justify-content: space-between; padding-top: 20px;}
#footer .ft-left{display: flex; gap:60px;}
#footer .ft-left ul{display: flex; flex-direction: column; gap:2px;}
#footer .ft-left ul > li{color: #666; font-size: 18px; font-weight: 400; line-height: 160%; display: flex; flex-wrap:wrap; align-items:center; gap:28px;}
#footer .ft-left ul > li span{display: flex; align-items:center; gap:6px;}
#footer .ft-left ul > li i{line-height: 0;}
#footer .ft-left ul > li.copy{margin-top: 21px;}

#footer .ft-right{text-align: right; display: flex; flex-direction: column; align-items: flex-end; margin-top: -20px;}
#footer .ft-right p{color: #666; font-size: 18px; font-weight: 600; line-height: 160%; margin-bottom: 6px;}
#footer .ft-right b{display: flex; align-items:center; gap:5px; color: #003F9D; font-size: 32px; font-weight: 700; line-height: 100%; margin-bottom: 29px;}
#footer .ft-right ul{display: flex; align-items:center; }
#footer .ft-right ul > li{display: flex; align-items:center;}
#footer .ft-right ul > li > a{ color: #666; font-size: 18px; font-weight: 600; line-height: 160%; }
#footer .ft-right ul > li:first-child:after{content: ''; width: 1px; height: 17px; background: #EEE; margin: 0 20px; }
#footer .ft-right ul > li:first-child > a{color: #070707;}
#footer .ft-right ul > li:hover > a{text-decoration: underline;}

.ft-fix{position: fixed; right: -100px; bottom: 244px; z-index: 100; opacity: 0; transition:.3s;}
.ft-fix .quick-bt{position: relative; bottom: 89px; height: 80px;}
.ft-fix .quick-bt figure{position: absolute; width: 80px; height: 80px; border-radius: 50%; z-index: 1;display: flex; align-items:center; justify-content: center; text-align: center; right: 0; top: 0; transition: .3s; opacity: 0; }
.ft-fix .quick-bt figure:before{position: absolute; content: ''; width: 100%; height: 100%; border-radius: 100px; opacity: 0.9; background: linear-gradient(90deg, #00CAFF -32.16%, #0048B3 102.16%); backdrop-filter: blur(5px); left: 0; top: 0; z-index: -1;}
.ft-fix .quick-bt .on{position: absolute; right: 0; top: 0; width: 225px; height: 80px;  border-radius: 100px;  display: flex; align-items: flex-start; flex-direction: column; justify-content: center; padding: 0 30px; opacity: 1; overflow: hidden; transition:.3s;}
.ft-fix .quick-bt .on:before{position: absolute; content: ''; left: 0; top: 0; border-radius: 100px; opacity: 0.9;  width: 100%; height: 100%; background: linear-gradient(90deg, #00CAFF -32.16%, #0048B3 102.16%); backdrop-filter: blur(5px); z-index: -1;}
.ft-fix .quick-bt .on:after{position: absolute; content: ''; width: 32px; height: 32px; background: url(../img/layout/quick-bt-arr.png) center no-repeat; right: 20px; top: 50%; margin-top: -16px;}
.ft-fix .quick-bt .on p{align-items:center; color: #FFF; font-size: 16px; font-weight: 600; line-height: 160%; display: flex; gap:2px;}
.ft-fix .quick-bt .on p i{line-height: 0;}
.ft-fix .quick-bt .on b{color: #FFF; font-size: 24px; font-weight: 700; line-height: 100%; margin-top: 2px;}
 .ft-fix .quick-bt.active{
	figure{opacity: 1; }
	.on{opacity: 0; width: 80px;}
} 

.ft-fix .scroll-top{position: absolute; right: 0px; bottom: 0px; display: flex; width: 72px; height: 72px; justify-content: center; align-items: center; background: rgba(141, 141, 141, 0.50); border-radius: 50%; backdrop-filter: blur(4.363637447357178px); cursor: pointer; transition:.3s;}
.ft-fix .scroll-top:hover{background: #000;}

.ft-fix.sc{ right: 12px; opacity: 1;}


/* siteMap : S */
.sitemap {position:fixed; max-width:100vw; max-height:100vh; width:0; height:0; z-index:1111;  display:block; top:0; right:0; overflow:hidden; letter-spacing:0;}
html.sitemap-opened .sitemap {width:100%; height:100%; visibility:visible;}
.sitemap:before {content:''; position:fixed; z-index:-1; top:0; left:0; width:100vw; height:100vh; background:url('../img/layout/sitemap-black.jpg') center center no-repeat; background-size:cover; transition:all 0.6s ease 0.2s; display:none;}
html.sitemap-opened .sitemap:before {display:block;}

.site-wrap {max-width:1830px; width:100%; padding:0 15px; margin:0 auto; height:100vh; position:relative;}
.site-wrap .head {position:absolute; top:0; left:0; width:100%; height:120px; display:flex; align-items:center; z-index:11; padding:0 15px;}
.site-wrap .head ul {margin-left:50px; margin-top:10px; display:flex;}
.site-wrap .head ul li {padding-right:15px; margin-right:15px; position:relative;}
.site-wrap .head ul li:after {content:''; width:1px; height:12px; background:#fff; position:absolute; top:50%; margin-top:-6px; right:0;}
.site-wrap .head ul li:last-child:after {display:none;}
.site-wrap .head ul li a {font-size:14px; color:#888; letter-spacing:0; line-height:1.6em; transition:all 0.6s; font-weight:700; font-family:'Montserrat';}
.site-wrap .head ul li.active a {color:#fff;}

.sitemap .sitemap-close {position:absolute; top:50%; margin-top:-18px; right:15px; width:36px; height:36px; z-index:12; transition:all 0.6s;}
.sitemap .sitemap-close:hover {opacity:0.6;}
.sitemap .sitemap-close:before,
.sitemap .sitemap-close:after {content:''; width:36px; height:2px; background:#fff; position:absolute; left:0; transition:all 0.6s;}
.sitemap .sitemap-close:before {top:10px;}
.sitemap .sitemap-close:after {bottom:10px;}
html.sitemap-opened .sitemap .sitemap-close:before {transform:rotate(45deg); top:50%; margin-top:-1px;}
html.sitemap-opened .sitemap .sitemap-close:after {transform:rotate(-45deg); bottom:50%; margin-bottom:-1px;}

.site-wrap .wrap {padding:160px 0 60px;  height:100vh;display:flex; position:relative;}
.site-wrap .wrap:after {content:''; width:1px; height:100vh; background:rgba(255,255,255,0.2); position:absolute; top:0; left:700px;}
.site-wrap .wrap .info-wrap {width:100%; max-width:700px; display:flex; flex-direction:column; justify-content:space-between; padding-right:60px;}
.site-wrap .info .box {margin-bottom:50px; position:relative; left:100px; opacity:0; transition:all 0.6s;}
html.sitemap-opened .site-wrap .info .box {transition-delay:0.1s; left:0; opacity:1;}
html.sitemap-opened .site-wrap .info .box:nth-child(2) {transition-delay:0.2s;}

.site-wrap .info .box:last-child {margin-bottom:0;}
.site-wrap .info .box h4 {font-size:18px; font-weight:700; color:#fff; line-height:1.6em; font-family:'Montserrat'; margin-bottom:16px;}
.site-wrap .info .box dl {display:flex; font-size:18px; line-height:1.6em; margin-bottom:8px;}
.site-wrap .info .box dt {width:50px; font-weight:500; color:#bbb;}
.site-wrap .info .box dd {width:1%; flex:1 1 auto; color:#888;}
.site-wrap .info .box dd a.mail {text-decoration:underline;}
.site-wrap .btn-wrap .more {display:inline-block; width:230px; line-height:62px; border:1px solid #fff; color:#fff; font-size:18px; padding:0 30px; position:relative; margin-bottom:50px;}
.site-wrap .btn-wrap .more:after {content:''; width:12px; height:12px; background:url('../img/layout/sitemap-btn-w.png') no-repeat; position:absolute; top:50%; margin-top:-6px; right:30px;}
.site-wrap .btn-wrap .more:hover:after {animation: btn-move 1s both .1s;}
@keyframes btn-move {
    0% {right:30px;}
    25% {right:20px;}
    50% {right:30px;}
    75% {right:25px;}
    100 {right:30px;}
}
.site-wrap .btn-wrap ul {display:flex;}
.site-wrap .btn-wrap ul li {margin-right:12px;}
.site-wrap .btn-wrap ul li a {display:block; transition:all 0.3s;}
.site-wrap .btn-wrap ul li a:hover {opacity:0.6;}
.site-wrap .wrap .nav-menu {width:1%; flex:1 1 auto; padding-left:100px;}
.nav-menu > ul > li {position: relative; margin-bottom:0px; margin-bottom: 5px;}
.nav-menu > ul > li > span {display:block; position:relative; transition:all 0.6s; overflow:hidden;}
.nav-menu > ul > li > span a {position: relative; display:inline-block; font-size:44px; line-height:1.2em; transition:all 0.6s ease 0s; position:relative; transform:translateY(110%); font-weight:500; padding:0 20px; color:#fff; }
.nav-menu > ul > li > span a:before{position: absolute; content: ''; width: 24px; height: 24px; background: url(../img/layout/sitemap-arr-box.png) center no-repeat; right: 0; top: 50%; margin-top: -12px;; rotate:180deg; transition:.3s;}
.nav-menu > ul > li:last-child > span a:before{display: none;}
.nav-menu > ul > li.on > span a:before{rotate:0deg;}

html.sitemap-opened .nav-menu > ul > li > span a {display: block; transform:translateY(0); transition-delay:0.5s; transition-property:transform; border-bottom: 1px solid #eee;}
.nav-menu > ul > li > span a:after {content:''; background:#fff; width:0; height:20px; position:absolute; bottom:5px; left:0; z-index:-1; opacity:0.2; transition:all 0.6s;}
.nav-menu > ul > li.active > span a:after {width:100%;}
.nav-menu > ul > li > span a:hover:after {width:100%;}

.nav-menu .subm {display:none; border-bottom: 1px solid #eee;}
.nav-menu .subm ul {display:flex; flex-wrap:wrap; padding-top:20px; padding-left:15px;}
.nav-menu .subm ul li {padding-right:40px; margin-bottom:20px;}
.nav-menu .subm ul li a {display:inline-block; font-size:24px; line-height:1.5em; position:relative; color:#888;}
.nav-menu .subm ul li a:hover {color:#fff; font-weight:700;}

/* sitemap-white */
.sitemap-white:before {background:url('../img/layout/sitemap-white.jpg') center center no-repeat; background-size: cover;}
.sitemap-white .sitemap-close:before,
.sitemap-white .sitemap-close:after {background:#000;}
.sitemap-white {color:#000;}
.sitemap-white .head ul li:after {background:#ddd;}
.sitemap-white .head ul li a {font-size:14px; color:#666;}

.sitemap-white .head ul li.active a {color:#000;}
.sitemap-white .wrap:after {background:#ddd;}
.sitemap-white .info .box h4 {color:#000;}
.sitemap-white .info .box dt {color:#000;}
.sitemap-white .info .box dd {color:#666;}
.sitemap-white .btn-wrap .more {border:1px solid #000; color:#fff; background:#000;}
.sitemap-white .nav-menu > ul > li{}
.sitemap-white .nav-menu > ul > li > span a {color:#000; padding: 20px 0;}

/* .sitemap-white .nav-menu > ul > li > span a:after {background:#000; opacity:0.1;} */
.sitemap-white .nav-menu > ul > li:hover > span a {color: #003F9D;}

.sitemap-white .nav-menu .subm ul li a {color:#666;}
.sitemap-white .nav-menu .subm ul li a:hover {color:#000;}
.sitemap-white .nav-menu .subm ul li.current a{color: #003F9D;}

.sitemap-white .nav-menu .subm .dep3{display: none;}
.sitemap-white .btn-wrap ul li a img {filter:invert(1);}

.sm-bt {position:absolute; bottom:60px; right:60px; background:#fff; width:30px; height:30px; border-radius:50%; cursor:pointer; transition:all 0.6s; z-index:111;}
.sitemap-white .sm-bt {background:#000;}



/* siteMap : E */
/* siteMap : responsive */
@media (max-width:1400px){
	.site-wrap .wrap:after {left:500px;}
	.site-wrap .wrap .info-wrap {max-width:500px; padding-right:40px;}
	.site-wrap .info .box dl {font-size:16px;}	
	.site-wrap .wrap .nav-menu {padding-left:60px;}
	.nav-menu > ul > li > span a {font-size:40px;}
	.nav-menu .subm ul {padding-top:20px; padding-left:0;}
	.nav-menu .subm ul li {padding-right:20px;}
	.nav-menu .subm ul li a {font-size:20px;}
}
@media (max-width:1024px){
	.site-wrap .wrap:after {display:none;}
	.site-wrap .head {position:relative; left:0; height:80px; padding: 0 5px;}
	.site-wrap .head .logo{width: 180px;;}
	.sitemap .sitemap-close {right:0;}
	
	.site-wrap .wrap {padding:40px 0; height:calc(100vh - 100px); flex-direction:column-reverse;}
	.site-wrap .wrap .nav-menu {width:100%; padding-left:0;}
	
	.nav-menu > ul > li {}
	.nav-menu > ul > li > span a {font-size:24px; padding:0 5px;}
	.nav-menu .subm ul {padding-top:10px;}
	.nav-menu .subm ul li {padding-right:15px; margin-bottom:10px;}
	.nav-menu .subm ul li a {font-size:16px;}
	
	.site-wrap .wrap .info-wrap {max-width:none;}
	.site-wrap .info .box {margin-bottom:20px;}
	.site-wrap .info .box h4 {font-size:16px; margin-bottom:10px;}
	.site-wrap .info .box:last-child {margin-bottom:20px;}
	.site-wrap .btn-wrap .more {width:200px; line-height:50px; font-size:16px; padding:0 20px; margin-bottom:20px;}
	.site-wrap .btn-wrap .more:after {right:20px;}
}
@media (max-width:640px){
	.site-wrap .head {height:100px;}
	.site-wrap .wrap {padding:30px 0; height:calc(100vh -100px);}
	.nav-menu > ul > li > span a {font-size:20px;}
	.nav-menu > ul > li > span a:after {height:10px; bottom:0;}
	.nav-menu .subm ul li {width: 50%; padding: 0 5px; box-sizing: border-box;}
	.nav-menu .subm ul li a {font-size:16px;}
	.site-wrap .wrap .info-wrap {display:none;}

}

@media (max-width:480px){
	.site-wrap .head{height: 60px; padding: 0 6px;}
	.site-wrap .head .logo{width: 140px;}
}


html.map_v2_opened #header {display:none;}
.s68 {height:300px;}


.map_v2 {width:100px; height:100px; border:4px solid #ddd; display:block; margin:0 auto 60px; z-index:1111;}
.sitemap_v2 {width:100%; height:100vh; background:#000; /*position:fixed; top:0; left:0; transition:all 0.6s;  transform:translateX(100%); opacity:0; */}

/* html.map_v2_opened .sitemap_v2 {transform:translateX(0); opacity:1;} */

.sitemap_v2 .wrap {width:100%; max-width:1830px; margin:0 auto; justify-content:space-between; color:#fff;}
.sitemap_v2 .sitemap-head {height:120px; display:flex; align-items:center; justify-content:space-between; }
.sitemap_v2 .sitemap-head .closed {width:50px; height:50px; position:relative; border-radius:50%; border:2px solid #fff;}
.sitemap_v2 .sitemap-head .closed:before,
.sitemap_v2 .sitemap-head .closed:after {content:''; position:absolute; width:30px; height:4px; margin-top:-2px; margin-left:-15px; border-radius:2px; background:#fff; top:50%; left:50%; transition:all 0.6s 0.6s; opacity:0;}
html.map_v2_opened .sitemap_v2 .sitemap-head .closed:before {transform:rotate(45deg); opacity:1;}
html.map_v2_opened .sitemap_v2 .sitemap-head .closed:after {transform:rotate(-45deg); opacity:1;}

.sitemap_v2 .nav_v2 {width:100%; max-width:1630px; margin:0 auto 60px; padding:0 15px;}
.sitemap_v2 .nav_v2 > ul > li {margin-bottom:30px; padding-bottom:30px; border-bottom:1px solid rgba(255,255,255,0.4); display:flex; align-items:flex-end;}
.sitemap_v2 .nav_v2 > ul > li:last-child {margin-bottom:0; padding-bottom:0; border-bottom:0;}
.sitemap_v2 .nav_v2 > ul > li > a {width:100%; max-width:300px; font-size:36px; line-height:1.2em; height:1.2em; font-weight:800; position:relative;}
.sitemap_v2 .nav_v2 > ul > li > a span {display:block; transition:all 0.8s; position:relative;}
.sitemap_v2 .nav_v2 > ul > li > a span:nth-child(1) {transform:translate(0);}
.sitemap_v2 .nav_v2 > ul > li:hover > a span:nth-child(1) {transform:translate3d(0, -25px, -25px) rotateX(90deg); opacity:0;}
.sitemap_v2 .nav_v2 > ul > li > a span:nth-child(2) {transform:translate3d(0, 25px, -25px) rotateX(-90deg); position:absolute; left:0; bottom:0; opacity:0; color:#0047bb;}
.sitemap_v2 .nav_v2 > ul > li:hover > a span:nth-child(2) {transform:translate(0); opacity:1;}
.sitemap_v2 .nav_v2 .subm {width:1%; flex:1 1 auto;}
.sitemap_v2 .nav_v2 .subm ul {display:flex; margin:0 -10px;}
.sitemap_v2 .nav_v2 .subm ul li {padding:0 10px;}
.sitemap_v2 .nav_v2 .subm ul li a {font-size:20px; line-height:1.5em;}
.sitemap_v2 .nav_v2 .subm ul li a:hover {color:#0047bb;}
 
 .sitemap_v2 .sitemap-info {display:flex;}
 .sitemap_v2 .sitemap-info div {margin-right:60px;}
 .sitemap_v2 .sitemap-info div:last-child {margin-right:0;}
 .sitemap_v2 .sitemap-info h4 {font-size:20px; line-height:1.5em; font-weight:600; margin-bottom:20px;}
 .sitemap_v2 .sitemap-info p {font-size:16px; line-height:1.8em;}
 .sitemap_v2 .sitemap-info p a {display:inline-block;}