@charset "utf-8";
/* layout.css는 전체적인 스타일 정의 */

#wrapper {position:relative; overflow:hidden;}

.contain {position:relative; padding-left:15px; padding-right:15px; margin:0 auto; height:inherit; letter-spacing:-.03em;}
#header .contain {max-width:1790px !important;}
#footer .contain {max-width:1790px !important;}
#main .contain {max-width:1470px;}
#sub .contain {max-width:1470px;}


/* header */
#header {position:fixed; top:0; left:0; width:100%; height:110px; z-index:90; letter-spacing:-.03em; background:#fff; transition:all 0.6s;}
#header .sitelogo a {display:block; position:absolute; top:50%; left:15px; margin-top:-31px;}

#header.active {transform:translateY(0); border-bottom:1px solid #ddd;}
#header.hide {transform:translateY(-100%);}

#gnb>ul {display:flex; margin-left:160px;}
#gnb>ul>li {position:relative; text-align:center;}
#gnb>ul>li>a {position:relative; display:inline-block; color:#111; font-size:18px; line-height:110px; transition:all 0.6s; width:145px;}
#gnb>ul>li:hover>a {color:#046331;}

#gnb .submenu {position:absolute; top:110px; left:0; width:100%; height:0; overflow:hidden; z-index:91; border-left:1px solid #ddd;}
#gnb .submenu:before {content:''; width:0; height:2px; background:#046331; position:absolute; top:0; left:50%; transition:all 0.6s;}
#gnb>ul>li:hover .submenu:before {width:100%; left:0;}
#gnb .submenu:after {content:''; width:10px; height:0; background:#046331; position:absolute; top:-3px; left:50%; margin-left:-5px; border-radius:50%; transition:all 0.6s;}
#gnb>ul>li:hover .submenu:after {height:10px; transition-delay:.3s;}

#gnb>ul>li:last-child .submenu {border-right:1px solid #ddd;}
#gnb .submenu ul {display:block; padding:30px 0; height:320px; transition:all 0.6s;}
#gnb>ul>li:hover .submenu ul {background:#f6f6f6;}
#gnb .submenu ul li {text-align:center;}
#gnb .submenu ul li a {display:inline-block; color:#888; font-size:14px; line-height:34px; position:relative; font-weight:500; padding:0 3px;}
#gnb>ul>li:hover .submenu ul li a {color:#333;}
#gnb>ul>li:hover .submenu ul li a:hover {color:#046331; font-weight:700;}
#gnb .submenu ul li a:after {content:''; width:0; height:1px; background:#046331; position:absolute; left:50%; bottom:5px; transition:all 0.4s;}
#gnb>ul>li:hover .submenu ul li a:hover:after {width:100%; left:0;}

.kolas {position:absolute; right:135px; top:50%; margin-top:-17px;}

.mems {position:absolute; top:50%; transform:translateY(-50%); right:135px; z-index:11;}
.mems ul {display:flex; background:#f6f6f6; padding:0 6px; border-radius:5px;}
.mems ul li {padding:0 12px; position:relative;}
.mems ul li:after {content:''; width:1px; height:14px; background:#ddd; position:absolute; top:50%; margin-top:-7px; right:0;}
.mems ul li:last-child:after {display:none;}
.mems ul li a {display:block; font-size:15px; line-height:40px; color:#999; transition:all 0.6s;}
.mems ul li a:hover {color:#000;}


.search {width:30px; height:30px; position:absolute; z-index:11; right:65px; top:50%; margin-top:-15px;}
.search .open img {transition:all 0.6s; cursor:pointer;}
.search .open:hover img {transform:rotate(15deg);}
#sub div.open {display:none;}

.search.search-open .search-wrap {transform:translateX(0);}
.search-wrap {transform:translateX(150%); position:absolute; top:65px; right:0; background:#fff; padding:20px 60px 20px 20px; border:1px solid #ddd; transition:all 0.6s; z-index:1;}
.search-wrap:before {content:''; width:20px; height:20px; background:#fff; position:absolute; top:-11px; right:3px; border-top:1px solid #ddd; border-right:1px solid #ddd; transform:rotate(-45deg);}
.search-wrap .close {width:30px; height:30px; background:#f5f5f5; border-radius:50%; position:absolute; right:15px; top:50%; margin-top:-15px; display:block; transform:rotate(45deg); transition:all 0.6s;}
.search-wrap .close:hover {background:#999;}
.search-wrap .close:before, 
.search-wrap .close:after {content:''; background:#000; top:50%; left:50%; position:absolute;}
.search-wrap .close:before {width:10px; height:2px; margin-top:-1px; margin-left:-5px;}
.search-wrap .close:after {width:2px; height:10px; margin-top:-5px; margin-left:-1px;}
.search-wrap .search-box {position:relative;}
.search-wrap .input {width:300px; padding:0 45px 0 15px;}
.search-wrap .search-btn {width:20px; height:20px; background:transparent url('../img/layout/search.png') center center no-repeat; background-size:cover; border:0; position:absolute; right:10px; top:50%; margin-top:-10px;}

.sitemap-btn {position:absolute; top:50%; right:15px; width:22px; height:30px; margin-top:-15px; z-index:11;}
.sitemap-btn span {position:absolute; top:0; background:#000; width:2px; transition:all 0.6s;}
.sitemap-btn:hover span {background:#046331;}
.sitemap-btn span.side {height:20px; top:5px;}
.sitemap-btn span.left {left:0;}
.sitemap-btn span.right {right:0;}
.sitemap-btn span.mid {height:100%; left:50%; margin-left:-1px;}
.sitemap-btn:hover span.left {animation:tobo 1s linear both}
.sitemap-btn:hover span.right {animation:boto 1s linear both}
@keyframes tobo{0%{transform:translateY(0px)}25%{transform:translateY(-5px)}50%{transform:translateY(0px)}75%{transform:translateY(5px)}100%{transform:translateY(0px)}}
@keyframes boto{0%{transform:translateY(0px)}25%{transform:translateY(5px)}50%{transform:translateY(0px)}75%{transform:translateY(-5px)}100%{transform:translateY(0px)}}

.submenu-bg {background-color:#fff; border-top:1px solid #ddd; display:none; border-bottom:1px solid #ddd;}

/* footer */
.foot-info {background:#fff; position:relative; padding:60px 0; display:flex; justify-content:space-between; flex-wrap:wrap;}
.foot-info .info {width:100%; max-width:480px; margin-bottom:40px;}
.foot-info .info .tit {margin-bottom:40px; display:flex; align-items:flex-end;}
.foot-info .info .tit p {color:#000; margin-left:30px;}
.foot-info .info p {font-size:14px; color:#666; line-height:2.1em;}
.foot-info .info p a {display:inline-block;}
.foot-info .info p br {display:none;}
.foot-nav {max-width:1080px; width:100%;}
.foot-nav > ul {display:flex;}
.foot-nav > ul > li {width:100%;}
.foot-nav > ul > li > a {font-size:16px; line-height:1.6em; color:#000; margin-bottom:20px; display:inline-block; transition:all 0.6s; position:relative;}
.foot-nav > ul > li:hover > a {color:#046331;}
.foot-nav .submenu ul li a {display:inline-block; font-size:14px; line-height:34px; color:#666; transition:all 0.6s; position:relative;}
.foot-nav .submenu ul li a:hover {color:#046331;}
.foot-nav .submenu ul li a:after {content:''; width:0; height:1px; background:#046331; position:absolute; bottom:5px; left:0; transition:all 0.6s;}
.foot-nav .submenu ul li a:hover:after {width:100%;}
.foot-cnt {background:#f6f6f6;}
.foot-cnt .col {display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap;}
.foot-cnt .link {padding:30px 0; display:flex; max-width:840px; width:100%; align-items:center;}
.foot-cnt .link ul {display:flex;}
.foot-cnt .link .pop li {padding-right:5px;}
.foot-cnt .link .pop li a {display:block; width:180px; border:1px solid #ddd; border-radius:5px; background:#fff; line-height:40px; padding:0 20px; font-size:14px; color:#666; transition:all 0.6s; position:relative;}
.foot-cnt .link .pop li a:hover {background:#666; border-color:#666; color:#fff;}
.foot-cnt .link .pop li a:after {content:''; width:8px; height:8px; background-repeat:no-repeat; background-size:cover; position:absolute; transition:all 0.6s; right:20px; top:50%; margin-top:-4px; background-image:url('../img/layout/foot-arrow.png');}
.foot-cnt .link .pop li a:hover:after { background-image:url('../img/layout/foot-arrow-on.png');}
.foot-cnt .link .smenu {margin-left:25px;}
.foot-cnt .link .smenu li {padding:0 15px; position:relative;}
.foot-cnt .link .smenu li:after {content:''; width:1px; height:16px; background:#ddd; position:absolute; right:0; top:50%; margin-top:-8px;}
.foot-cnt .link .smenu li:last-child:after {display:none;}
.foot-cnt .link .smenu li a {font-size:16px; line-height:1.8em; color:#666; transition:all 0.6s;}
.foot-cnt .link .smenu li a:hover {color:#000;}
.foot-cnt .sns {max-width:280px; width:100%; padding:25px 0 30px;}
.foot-cnt .sns ul {display:flex; justify-content:flex-end;}
.foot-cnt .sns ul li {margin-left:5px;}
.foot-cnt .sns ul li a {display:block; padding-top:5px; transition:all 0.2s;}
.foot-cnt .sns ul li a:hover {padding-top:0; padding-bottom:5px;}
/* quick */
.quick {position:fixed; top:50%; right:0; transform:translateY(-50%); z-index:70; display:block; transition:all 1s;}
.quick-open {display:none; width:40px; height:40px; background:#046331; position:absolute; top:40px; left:-40px; border-radius:5px 0 0 5px;}
.quick-open .ar {transform:rotate(180deg); position:absolute; width:20px; height:20px; top:50%; left:50%; margin-top:-10px; margin-left:-10px; transition:all 1s;}
.quick-open .ar span {transition:all 0.6s; position:absolute; top:0; left:0;}
.quick-open .ar span.ar01 {opacity:.3;}
.quick-open .ar span.ar02 {opacity:.6;}
.quick-open .ar span.ar03 {opacity:1;}
.quick-open:hover .ar span.ar01 {transform:translateX(-6px);}
.quick-open:hover .ar span.ar03 {transform:translateX(6px);}
.quick .wrap {width:130px; background:#fff; border-radius:10px 0 0 10px; overflow:hidden; box-shadow:0 0 10px 5px rgba(153,153,153,0.35); letter-spacing:-.03em;}
.quick .sns-box {padding:20px 3px; border-bottom:1px solid #ddd;}
.quick .sns-box .quick-logo {margin-bottom:8px; text-align:center;}
.quick .sns-box ul {display:flex; flex-wrap:wrap;}
.quick .sns-box ul li {width:50%;}
.quick .sns-box ul li a {display:flex; flex-direction:column; text-align:center; align-items:center;}
.quick .sns-box ul li a img {width:32px; height:37px; padding-top:5px; transition:all 0.2s;}
.quick .sns-box ul li a:hover img {padding-top:0; padding-bottom:5px;}
.quick .sns-box ul li a span {font-size:14px; color:#666; font-weight:500; transition:all 0.2s;}
.quick .sns-box ul li a:hover span {color:#046331;}
.quick  .mall-box {padding:20px 13px 30px;}
.quick  .mall-box a p {font-size:14px; line-height:20px; height:20px; font-weight:500; position:relative; overflow:hidden; display:flex;}
.quick  .mall-box .link01 {border:1px solid #0a337a; margin-bottom:10px; width:100%; height:110px; display:flex; flex-direction:column; justify-content:center; padding:0 10px; background:#e8e9e9; border-radius:5px;}
.quick  .mall-box .link01 .icon {text-align:center; margin-bottom:10px;}
.quick  .mall-box .link01 p {color:#000;}
.quick  .mall-box .link01 p.arrow:after {content:''; width:6px; height:10px; background:url('../img/layout/p-arrow.png') no-repeat; position:absolute; top:50%; margin-top:-5px; right:0;}
.quick  .mall-box .link02 {background:#a71255; width:100%; padding:5px 0; position:relative; height:30px; border-radius:5px;}
.quick  .mall-box .link02:before {content:''; width:16px; height:16px; background:url('../img/layout/quick-link02.png') no-repeat; position:absolute; top:50%; margin-top:-8px; left:14px;}
.quick  .mall-box .link02:after {content:''; width:6px; height:10px; background:url('../img/layout/p-arrow.png') no-repeat; position:absolute; top:50%; margin-top:-5px; right:12px; filter:invert(1);}
.quick  .mall-box .link02 p {color:#fff; justify-content:center;}
.quick  .mall-box a p .over {display:flex; overflow:hidden;}
.quick  .mall-box a:hover p .over {position:absolute;}
.quick  .mall-box a:hover p .over span {transform:translateY(20px);}
.quick  .mall-box a p .over span:nth-child(1) {transition:all 0.2s;}
.quick  .mall-box a p .over span:nth-child(2) {transition:all 0.3s;}
.quick  .mall-box a p .over span:nth-child(3) {transition:all 0.4s;}
.quick  .mall-box a p .over span:nth-child(4) {transition:all 0.5s;}
.quick  .mall-box a p .over2 {display:flex; position:absolute; overflow:hidden;}
.quick  .mall-box a p .over2 span {transform:translateY(-20px);}
.quick  .mall-box a:hover p .over2 span {transform:translateY(0);}
.quick  .mall-box a p .over2 span:nth-child(1) {transition:all 0.2s;}
.quick  .mall-box a p .over2 span:nth-child(2) {transition:all 0.3s;}
.quick  .mall-box a p .over2 span:nth-child(3) {transition:all 0.4s;}
.quick  .mall-box a p .over2 span:nth-child(4) {transition:all 0.5s;}
.quick  .scroll-top {height:40px; background:#19232b; position:relative;}
.quick  .scroll-top:after {content:''; width:40px; height:80px; background-image:url('../img/layout/scroll-top.png'); background-position:bottom center; position:absolute; top:0; left:50%; margin-left:-20px; transition:all 0.6s;}
.quick  .scroll-top:hover:after {background-position:top center;}

/* 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;}

.sitemap .sitemap-close {position:absolute; top:calc(70px/2); right:2.25%; 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 {max-width:1830px; width:100%; padding:0 15px; margin:0 auto; height:100vh; position:relative;}
.site-wrap .head {position:absolute; top:0; left:15px; width:100%; height:110px; display:flex; align-items:center; z-index:11;}
.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;}

.site-wrap .wrap {padding:140px 0 80px;  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-left:0;}
.site-wrap .info .box {margin-bottom:40px; 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:15px;}
.site-wrap .info .box dl:last-child {margin-bottom:0;}
.site-wrap .info .box dt {width:170px; 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; border-radius:3px;}
.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.6s; padding-top:10px; padding-bottom:0;}
.site-wrap .btn-wrap ul li a:hover {padding-top:0; padding-bottom:10px;}
.site-wrap .wrap .nav-menu {width:1%; flex:1 1 auto; padding-left:100px;}
.nav-menu > ul > li {margin-bottom:20px;}
.nav-menu > ul > li > span {display:block; position:relative; transition:all 0.6s; overflow:hidden;}
.nav-menu > ul > li > span a {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 5px; color:#fff;}
html.sitemap-opened .nav-menu > ul > li > span a {transform:translateY(0); transition-delay:0.5s; transition-property:transform;}
.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 .submenu {display:none;}
.nav-menu .submenu ul {display:flex; flex-wrap:wrap; padding-top:20px; padding-left:15px;}
.nav-menu .submenu ul li {padding-right:40px; margin-bottom:20px;}
.nav-menu .submenu ul li a {display:inline-block; font-size:24px; line-height:1.5em; position:relative; color:#888; transition:all 0.6s;}
.nav-menu .submenu ul li a:hover {color:#fff;}

/* sitemap-white */
.sitemap-white:before {background:url('../img/layout/sitemap-white.jpg') center center no-repeat;}
.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 > span a {color:#000;}
.sitemap-white .nav-menu > ul > li > span a:after {background:#000; opacity:0.1;}
.sitemap-white .nav-menu .submenu ul li a {color:#666;}
.sitemap-white .nav-menu .submenu ul li a:hover {color:#000;}


.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-left:0;}
	.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 .submenu ul {padding-top:20px; padding-left:0;}
	.nav-menu .submenu ul li {padding-right:20px;}
	.nav-menu .submenu ul li a {font-size:20px;}
}
@media (max-width:1024px){
	.site-wrap .wrap:after {display:none;}
	.site-wrap .head {position:relative; left:0; height:90px;}
	.sitemap .sitemap-close {top: calc(45px / 2);}
	.site-wrap .wrap {padding:30px 0; height:calc(100vh - 90px); flex-direction:column-reverse;}
	.site-wrap .wrap .nav-menu {width:100%; padding-left:0;}
	.nav-menu > ul > li {margin-bottom:12px;}
	.nav-menu > ul > li > span a {font-size:20px; padding:0 5px;}
	.nav-menu .submenu ul {padding-top:10px;}
	.nav-menu .submenu ul li {padding-right:15px; margin-bottom:10px;}
	.nav-menu .submenu 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:10px;}
	.site-wrap .info .box dl {margin-bottom:8px;}
	.site-wrap .btn-wrap {display:flex; justify-content:space-between; align-items:center; margin-top:20px;}
	.site-wrap .btn-wrap .more {width:160px; line-height:50px; font-size:16px; padding:0 20px; margin-bottom:0;}
	.site-wrap .btn-wrap .more:after {right:20px;}
}
@media (max-width:640px){
	.sitemap:before {background-position:bottom right;}
	.nav-menu > ul > li > span a {font-size:24px;}
	.nav-menu > ul > li > span a:after {height:10px; bottom:0;}
	.nav-menu .submenu ul li {padding-right:15px; margin-bottom:8px;}
	.nav-menu .submenu ul li a {font-size:16px;}
	.site-wrap .wrap .info-wrap {display:none;}
	
}
