@charset "utf-8";
/* layout.css는 전체적인 스타일 정의 */
/* header */
#header {position:fixed; top:0; left:0; width:100%; height:90px; z-index:10000;  border-bottom:1px solid #ddd; transition:all 0.6s;}
#header .wrap1{display: flex; align-items:center; height: 90px; }
#header .wrap1 .sitelogo{height: 100%; margin-right: 71px;} 
#header .wrap1 .sitelogo > a{width: 100%; height: 100%; display: flex; align-items:center; }
#header .wrap1 #gnb{display: flex; flex-wrap:wrap;}
#header .wrap1 #gnb > li {position: relative; }
#header .wrap1 #gnb > li > a{font-size: 20px; line-height: 90px; font-weight: 300; padding: 0 27px; transition:.3s;}
#header .wrap1 #gnb > li .subm{position: absolute; left: 0; top: 90px; padding: 30px 0;  padding-left: 27px; width: 200%; display: none; background: #fff;}
#header .wrap1 #gnb > li .subm ul > li > a{font-size: 20px; line-height: 40px; color: #000; font-weight: 400; transition:.3s;}
#header .wrap1 #gnb > li .subm ul > li:hover > a{color: #ED1C24;}
.submenu-bg{position: fixed; background: #fff; left: 0; top: 90px; width: 100%; height: 220px; z-index: -1; display: none;}
#header:hover{background: #fff; border-bottom: 1px solid #000;}
#header:hover .wrap1 #gnb > li > a{color: #000;}
#header:hover .wrap1 #gnb > li:hover > a,
#header .wrap1 #gnb > li.current > a{color: #ED1C24 !important;}
#header.sc{background: #fff; border-bottom: 1px solid #000;}
#header.sc .wrap1 #gnb > li > a{color: #000;}
#header.sc .wrap1 #gnb > li:hover > a{color: #ED1C24;}
#sub #header{background: #fff; border-bottom: 1px solid #ddd;}
#sub #header .wrap1 #gnb > li > a{color: #000;}
#sub #header .wrap1 #gnb > li:hover > a{color: #ED1C24;}

.m_header{position: fixed; right: 0; top: 0; z-index: 10005; background: #fff; width: 83.333vw; height: 100dvh; overflow: hidden; box-sizing: border-box; padding: 4.11vw 4.44vw 0 10.667vw;}
.m_header .close{position: absolute; right: 4vw; top: 5vw; width: 8.88vw; }
.m_header .mobile_gnb{margin-top: 33.66vw;overflow-y:  auto; height: calc(100% - 33.66vw); box-sizing: border-box; padding-bottom: 3vw;}
.m_header .mobile_gnb > ul > li > a{position: relative; font-size: clamp(20px, 5.55vw, 50px); line-height: 2.7; color: #000; font-weight: 700; letter-spacing: 0.15em; transition:.3s;}
.m_header .mobile_gnb > ul > li.on > a,
.m_header .mobile_gnb > ul > li.current > a{color: #ED1C24;}
.m_header .mobile_gnb > ul > li > a:after{position: absolute; content: ''; width: 2.666vw; height: 1.777vw; background: url(../img/mobile/m_arr.png) center / 100% no-repeat; right: 3vw; top: 50%; margin-top: -0.8vw; transition:.3s;}
.m_header .mobile_gnb > ul > li.on > a:after{transform:rotate(180deg);}
.m_header .mobile_gnb > ul > li:nth-child(3) > a:after{transform:rotate(-90deg); }
.m_header .mobile_gnb > ul > li:nth-child(4) > a:after{transform:rotate(-90deg); }
.m_header .mobile_gnb > ul > li .subm{padding-left: 5.33vw; display: none;}
.m_header .mobile_gnb > ul > li .subm ul{padding: 5vw 0 ;}
.m_header .mobile_gnb > ul > li .subm ul > li > a{font-size: 3.8889vw; line-height: 2.9;}

.m_header{transform:translate(100%, 0); transition:.6s;}
.m_header.on{transform:translate(0, 0); }
.m_img{display: none;}



/* footer */
footer {background: #edebe5; padding-top: 40px;}
footer .ft-top{display: flex; flex-wrap:wrap; align-items:center; justify-content: space-between; border-top: 1px solid #fff; border-bottom: 1px solid #fff;  height: 100px;}
footer .ft-top .lbx{display: flex; flex-wrap:wrap; align-items:center;}
footer .ft-top .lbx ul{display: flex; flex-wrap:wrap; gap:20px; margin-left: 50px;}  
footer .ft-top .lbx ul > li > a{/* font-family: "Inter", sans-serif;  */font-size: 15px; line-height: 1; color: #8b2424; font-weight: 500; transition:.3s;}
footer .ft-top .lbx ul > li:not(:first-child) > a{font-family: "Inter", sans-serif; }
footer .ft-top .lbx ul > li:hover > a{color: #ED1C24;}
footer .ft-top .rbx{position: relative; width: 340px;}
footer .ft-top .rbx strong{position: relative; display: block; border-left: 1px solid #fff; font-family: "Inter", sans-serif; font-size: 15px; line-height: 100px; color: #fff; font-weight: 600; padding-left: 26px; cursor: pointer;}
footer .ft-top .rbx strong:after{position: absolute; content: ''; width: 12px; height: 7px; background: url(../img/layout/ft_select.png) center no-repeat; right: 15px; top: 50%; margin-top: -3px;}
footer .ft-top .rbx ul{position: absolute; left: 0; bottom: 101px; width: 100%; padding: 28px 21px 14px; background: #000; display: none;}
footer .ft-top .rbx ul > li > a{font-family: "Inter", sans-serif; font-size: 15px; line-height: 40px; font-weight: 600; color: #fff; }
footer .ft_bottom{display: flex; flex-wrap:wrap; align-items:center; justify-content: space-between;  height: 80px;}
footer .ft_bottom p{font-family: "Inter", sans-serif; font-size: 12px; line-height: 1.5; font-weight: 400; color: #432727; }
footer .ft_bottom p span{display: inline-block; margin-right: 26px;}
footer .ft_bottom copy{font-family: "Inter", sans-serif; font-size: 10px; line-height: 1.5; color: #999; font-weight: 400;}


footer .m_footer{display: none;}
footer .m_footer > ul{display: flex; flex-wrap:wrap; gap:20px; }  
footer .m_footer > ul > li > a{/* font-family: "Inter", sans-serif;  */font-size: 15px; line-height: 1; color: #fff; font-weight: 500; transition:.3s;}
footer .m_footer > ul > li:not(:first-child) > a{font-family: "Inter", sans-serif; }
footer .m_footer > ul > li:hover > a{color: #ED1C24;}
footer .m_footer > p{font-family: "Inter", sans-serif; font-size: 12px; line-height: 1.5; font-weight: 400; color: #fff; }
footer .m_footer > p span{display: block; margin-right: 26px;}
footer .m_footer .ft_box{display: flex; flex-wrap:wrap;}

footer .m_footer .ft_box .rbx{position: relative;}
footer .m_footer .ft_box .rbx strong{position: relative; display: block; border-left: 1px solid #fff; font-family: "Inter", sans-serif; font-size: 15px; line-height: 100px; color: #fff; font-weight: 600; padding-left: 26px; cursor: pointer;}
footer .m_footer .ft_box .rbx strong:after{position: absolute; content: ''; width: 12px; height: 7px; background: url(../img/layout/ft_select.png) center no-repeat; right: 15px; top: 50%; margin-top: -3px;}
footer .m_footer .ft_box .rbx ul{position: absolute; left: 0; bottom: 101px; width: 100%; padding: 28px 21px 14px; background: #000; display: none;}
footer .m_footer .ft_box .rbx ul > li > a{font-family: "Inter", sans-serif; font-size: 15px; line-height: 40px; font-weight: 600; color: #fff; }



/* 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:145px; 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:200px 0 100px;  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:800px;}
.site-wrap .wrap .info-wrap {width:100%; max-width:800px; display:flex; flex-direction:column; justify-content:space-between; padding-left:80px;}
.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:160px;}
.nav-menu > ul > li {margin-bottom:30px;}
.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:56px; 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:30px; 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;}
.nav-menu .submenu 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;}
.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;}

.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-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:80px;}
	.sitemap .sitemap-close {top: calc(40px / 2);}
	.site-wrap .wrap {padding:40px 0; height:calc(100vh - 80px); flex-direction:column-reverse;}
	.site-wrap .wrap .nav-menu {width:100%; padding-left:0;}
	.nav-menu > ul > li {margin-bottom:20px;}
	.nav-menu > ul > li > span a {font-size:24px; 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 .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:60px;}
	.sitemap .sitemap-close {top: calc(60px / 2);}	
	.site-wrap .wrap {padding:30px 0; height:calc(100vh - 60px);}
	.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;}
	
}