@charset "utf-8";

/*
.header.ov 마우스 오버시
.header.load 페이지 로드시
.header.active 스크롤 발생시
.header.bamfff 전체메뉴 클릭시
*/

#wrap { }

#header, .logo, .logo a, .gnbWrap, #gnb, #gnb a, #gnb div, #gnb li {
	-webkit-transition: all 0.35s cubic-bezier(0.215, 0.610, 0.355, 1.000);
    -moz-transition: all 0.35s cubic-bezier(0.215, 0.610, 0.355, 1.000);
    transition: all 0.35s cubic-bezier(0.215, 0.610, 0.355, 1.000);
}

#header { position: fixed; left: 0; top: -40px; width: 100%; z-index: 900; background-color: #fff;
	-webkit-transition: all .4s ease-in-out;
	-moz-transition: all .4s ease-in-out;
	transition: all .4s ease-in-out;
}
#header.load { top: 0; }
#header.active { box-shadow: 0 0 14px rgba(0, 0, 0, .3); }
#header .inner { position: relative; max-width: calc(100% - 80px); height: 100%; }

#header h1.logo { position: absolute; left: 0; top: 16px; width: 131px; height: 68px; z-index: 97; background: url(../images/logo.png) left top no-repeat; background-size: 131px 68px; text-indent: -9999px; }
#header h1 a { display: block; height: 100%; }

#header .utilWrap { position: absolute; right: 0; top: 20px; display: flex; align-items: center; gap: 20px; z-index: 210; }
#lang { display: flex; gap: 20px; }
#lang a { position: relative; display: block; font-size: 15px; font-weight: 500; color: #777; line-height: 1; margin: 7px 0; }
#lang a::after { position: absolute; right: -10px; top: 1px; content: ''; width: 1px; height: 12px; background: #777; }
#lang a:last-child::after { display: none; }
#lang a:hover { color: #000; }
#lang a.active { font-weight: 700; color: #000; }

/* GNB MOBILE BUTTON */
#mobileGnb_toggle { position: relative; width: 60px; height: 60px; z-index: 210; }
#mobileGnb_toggle > a { position: absolute; left: 50%; top: 50%; width: 20px; height: 20px; margin-left: -10px; margin-top: -10px; }
#mobileGnb_toggle span { position: absolute; right: 0; height: 3px; background-color: #000; width: 100%; border-radius: 2px; transition: all 0.2s ease-in-out; }
#mobileGnb_toggle span.barTop { top: 0; }
#mobileGnb_toggle span.barMid { top: 8px; width: 70%; }
#mobileGnb_toggle span.barBot { top: 16px; }
#mobileGnb_toggle a.on span { background-color: #000; }
#mobileGnb_toggle a.on span.barTop { width: 100%; top: 12px; transform: rotate(45deg); }
#mobileGnb_toggle a.on span.barBot { width: 100%; top: 12px; transform: rotate(-45deg); }
#mobileGnb_toggle a.on span.barMid { width: 0; }

#header .gnbWrap { position: relative; text-align: center; margin-left: 62px; }
#gnb { position: relative; font-size: 0; text-align: center; display: inline-block; vertical-align: top; letter-spacing: 0; }
#gnb:after { content: ''; display: block; clear: both; visibility: hidden; } 
#gnb > li { float: left; display: block; text-align: center; }
#gnb > li > a { position: relative; display: block; line-height: 100px; color: #000; margin: 0 30px; font-family: 'Noto Sans KR', sans-serif; font-size: 18px; font-weight: 500; }
#gnb > li > a:after { position: absolute; left: 50%; bottom: -1px; content: ''; width: 0; height: 2px; background-color: #000;
	-webkit-transition: all .3s ease-out;
	-moz-transition: all .3s ease-out;
	transition: all 0.3s ease-out;
}
#gnb > li:hover > a { color: #000; }
#gnb > li:hover > a:after { left: 0; width: 100%; }
#gnb > li > a > span { display: block; position: relative; }

/* GNB MOBILE */
#gnb_moblie a span, #gnb_moblie .inner, #gnb_moblie li { transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1) 0s; }
#gnb_moblie { position: fixed; left: -100%; top: 0; width: 100%; height: 100%; z-index: 200; visibility: hidden; }
#gnb_moblie .back { position: absolute; right: -100%; top: 0; width: 100%; height: 100%; background: #000; opacity: 0; }
#gnb_moblie .back::before { position: absolute; right: 0; top: 0; width: 100%; height: 100%; content: ''; background: #000; display: block; opacity: 0.4; z-index: 1; }
#gnb_moblie .inner { position: absolute; right: -100%; top: 0; width: 320px; height: 100%; margin-right: -320px; background: rgba(255,255,255,1); z-index: 3; overflow: hidden; overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

#gnb_moblie nav { margin: 98px 0; }
#gnb_moblie a { display: block; text-align: left; padding-left: 48px; font-size: 22px; font-weight: 500; line-height: 2; color: #000; }
#gnb_moblie li { transform: translate3d(250px, 0, 0); }
#gnb_moblie .sub { display: none; margin: 0 auto 10px; padding: 12px 0; background-color: var(--clr-primary); }
#gnb_moblie .sub li > a { color: #fff; font-size: 20px; text-align: left; line-height: 1.4; padding-top: 8px; padding-bottom: 8px; }
#gnb_moblie .on > a { text-decoration: underline; }
#gnb_moblie .m1 { transition-delay: 0.035s; }
#gnb_moblie .m2 { transition-delay: 0.07s; }
#gnb_moblie .m3 { transition-delay: 0.14s; }
#gnb_moblie .m4 { transition-delay: 0.175s; }
#gnb_moblie .m5 { transition-delay: 0.21s; }
#gnb_moblie .m6 { transition-delay: 0.245s; }

#gnb_moblie.show { visibility: visible; }
#gnb_moblie.show .back { opacity: 0.7; }
#gnb_moblie.show .inner { margin-right: 0; }
#gnb_moblie.show .inner, #gnb_moblie.show li {
	-webkit-transform: translate3d(0, 0, 0);
	-moz-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);	
}


#container { }
#contents { }

#footer { background: #775b42; }
#footer_wrap { padding: 60px 0; text-align: left; }
#footer_wrap .ft_inner { position: relative; width: 100%; max-width: 1280px; min-height: 78px; margin: 0 auto; padding-left: 226px; background: url(../images/f_logo.png) left center no-repeat; background-size: 150px 78px; }
#footer_wrap .address { padding-top: 28px; }
#footer_wrap .address span { position: relative; display: inline-block; font-size: 16px; line-height: 1.4; padding-right: 10px; margin-right: 5px; color: #fff; }
#footer_wrap .address span:after { position: absolute; right: 0; top: 50%; content: ''; width: 1px; height: 14px; margin-top: -7px; background: #a18770; }
#footer_wrap .address span:last-child:after { display: none; }
#footer_wrap .btn_sns { position: absolute; right: 0; top: 28px; }
#footer_wrap .btn_sns img { display: block; width: 32px; height: 32px; }

.inner { width: 100%; max-width: 1280px; margin: 0 auto; }

/* table style */
.tb_1 { border-top: 2px solid #343434; border-bottom: 1px solid #343434; overflow: hidden; }
.tb_1 > table { margin-top: -1px; font-size: 15px; }
.tb_1 th { color: #000; text-align: center; vertical-align: middle; }
.tb_1 td { text-align: center; vertical-align: middle; }

/* btn type */
a.btnSt { position: relative; display: block; width: 205px; height: 57px; line-height: 57px; font-size: 16px; text-align: center; border-radius: 8px; overflow: hidden; 
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
}
a.btnSt:after { position: absolute; left: 0; top: 0; content: ''; width: 0; height: 100%; z-index: -1;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
 }
a.btnSt.w { color: #fff; border: 1px solid #fff; }
a.btnSt.w:after { background: #3b38be; }
a.btnSt.w:hover { color: #fff; border: 1px solid #3b38be; }
a.btnSt.w:hover:after { width: 100%; } 

@media all and (max-width:1320px) {
    .inner { padding-left: 20px; padding-right: 20px; }
    #footer_wrap { padding-left: 20px; padding-right: 20px; }
}
@media all and (max-width:1280px) {
    #header { height: 70px; }
    #header .inner { max-width: calc(100% - 40px); }
    #header h1.logo { top: 11px; width: 92px; height: 48px; background-size: 92px 48px; }
    #header .gnbWrap { display: none; }
    #header .utilWrap { right: -10px; top: 5px; }
}
@media all and (max-width:1024px) {
    #footer_wrap .ft_inner { padding-left: 0; padding-top: 72px; background-position: left top; background-size: 104px 54px; }
    #footer_wrap .address { padding-top: 0; }
    #footer_wrap .btn_sns { top: 0; }
}
@media all and (max-width:768px) {
    #footer_wrap .address span { font-size: 14px; }
}
