@charset "utf-8";
#header { position: fixed; left: 0; right: 0; top: 0; width: 100%; z-index: 100; margin: 0 auto; background-color: #fff; transition: all 0.3s ease-in-out; }
#header::before { position: absolute; left: 0; top: 100px; content: ''; width: 100%; height: 1px; background-color: #ddd; z-index: 1; }
#header::after { display: none; position: absolute; left: 35px; top: 100px; content: ''; width: 100%; height: calc(100% - 100px); background: url('../images/gnb_bg.png') left bottom no-repeat; z-index: -1; }
#header.scroll { background-color: #fff; box-shadow: 0 0 14px rgba(0, 0, 0, .4); }
#header.ov { background-color: #fff; box-shadow: 0 13px 16px rgba(0, 0, 0, 0.1); }
#header.ov::before { background: rgba(0,0,0,0.05); }

.hd_wrap { position: relative; }
.hd_wrap .logo { position: absolute; left: 35px; top: 24px; width: 203px; height: 54px; background-image: url('../images/logo.png'); background-position: left top; background-repeat: no-repeat; background-size: contain; text-indent: -9999px; z-index: 110; transition: all 0.3s ease-in-out; }
.hd_wrap .logo a { display: block; width: 100%; height: 100%; }

.gnb_wrap { text-align: left; }
#gnb { display: inline-block; margin: 0 auto; margin-left: 275px; transition: all 0.4s; }
#gnb::after { content: ''; display: block; clear: both; visibility: hidden; }
#gnb > li { float: left; display: block; }
#gnb > li > a { position: relative; display: block; height: 100px; line-height: 100px; padding: 0 11px; margin: 0 11px; color: #000; font-size: 19px; z-index: 110; transition: all 0.4s; }
#gnb > li:hover > a { color: #e91415; }
#gnb > li > a::before { position: absolute; bottom: -1px; left: 50%; content: ''; width: 0; height: 1px; background-color: #e91415; transition: all 0.4s; }
#gnb > li:hover > a::before { width: 100%; margin-left: -50%; }
#gnb > li .sub_contain { display: none; position: absolute; top: 100px; left: 0; width: 100%; padding: 26px 0; background-color: #fff; box-shadow: 0px 5px 8px 0px rgba(0, 0, 0, 0.1); }
#gnb > li.on .sub_contain.on { display: block; }
#gnb > li .sub_contain .menu { max-width: 1244px; margin: 0 auto; }
#gnb > li .depth2 { display: flex; flex-wrap: wrap; }
#gnb > li .depth2 > li > a { position: relative; display: block; font-size: 18px; font-weight: 400; line-height: 1; color: #000; padding: 0 20px; }
#gnb > li .depth2 > li > a::before { display: none; position: absolute; bottom: -15px; left: 50%; content: ''; width: 6px; height: 6px; background-color: #e91415; border-radius: 50%; transform: translateX(-50%); transition: all 0.4s; }
#gnb > li .depth2 > li > a:hover { color: #e91415; }
#gnb > li .depth2 > li > a:hover::before { display: block; }
#gnb > li.gnb1dp1 .depth2 > li:first-child { margin-left: -44px; }
#gnb > li.gnb1dp2 .depth2 > li:first-child { margin-left: 80px; }

.btn-inquiry { position: absolute; right: 90px; top: 29px; display: flex; align-items: center; justify-content: center; width: 138px; height: 43px; font-size: 17px; font-weight: 500; color: #fff; text-align: center; background-color: #d74042; border-radius: 46px; z-index: 110; }
.btn-inquiry .icon { margin-right: 8px; }
.btn-inquiry .icon img { display: block; width: 18px; height: 22px; }

/* GNB MOBILE BUTTON */
#mobileGnb_toggle { position: absolute; right: 25px; top: 25px; width: 50px; height: 50px; 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.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; }

/* 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: 25px; font-weight: 500; text-transform: uppercase; line-height: 2; color: #000; }
#gnb_moblie li { transform: translate3d(250px, 0, 0); }
#gnb_moblie dl { display: none; margin: 0 auto 10px; padding: 12px 0; background-color: #1a72cb; }
#gnb_moblie dt { font-size: 0; line-height: 0; visibility: hidden; }
#gnb_moblie dd > a { color: #fff; font-size: 16px; 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.105s; }
#gnb_moblie .m4 { transition-delay: 0.14s; }
#gnb_moblie .m5 { transition-delay: 0.175s; }
#gnb_moblie .m6 { transition-delay: 0.21s; }
#gnb_moblie .m7 { 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 { overflow: hidden; }

#footer { background-color: #fff; }
#footer .ft_wrap { padding: 54px 0 54px; text-align: left; }
#footer .ft_wrap .ft_inner { position: relative; width: 100%; max-width: 1244px; margin: 0 auto; background: url('../images/f_logo.png') right 35px center no-repeat; background-size: auto; }
#footer .ft_wrap .ft_info { font-size: 14px; letter-spacing: 0; margin-top: 8px; color: #6c6c6c; }
#footer .ft_wrap .ft_info li { margin: 4px 0; }
#footer .ft_wrap .ft_info span { position: relative; display: inline-block; padding-right: 20px; margin-right: 10px; }
#footer .ft_wrap .ft_info span::after { position: absolute; right: 0; top: 50%; content: ''; width: 1px; height: 13px; background: #c0c0c0; transform: translateY(-50%); }
#footer .ft_wrap .ft_info span:last-child::after { display: none; }
#footer .ft_wrap .copyright { font-size: 12px; letter-spacing: 0; text-transform: uppercase; margin-top: 12px; color: #b6b6b6; }

@media all and (min-width:1550px) {
	#gnb > li > a { padding: 0 18px; margin: 0 18px; font-size: 21px; }
}

@media all and (min-width:1281px) {
	#footer .ft_wrap .ft_inner { padding: 0 35px; }	
}

@media all and (max-width:1280px) {
	#header { height: 80px; }
	#header::before { top: 80px; }
	.hd_wrap { height: 80px; }
	.hd_wrap .logo { left: 20px; top: 13px; }
	.gnb_wrap { display: none; }
	.btn-inquiry { top: 18px; }
	#mobileGnb_toggle { right: 0; top: 0; width: 80px; height: 80px; }

	#footer br { display: none; }
	#footer .ft_wrap .ft_inner { padding: 0 20px; background-image: none; }
	#footer .ft_wrap { padding: 42px 0 42px; text-align: center; }
}

@media all and (max-width:768px) {
	html, body { font-size: 15px; }
	#header { height: 60px; }
	#header::before { top: 60px; }
	.hd_wrap .logo { top: 14px; width: 128px; height: 34px; }
	.btn-inquiry { right: 60px; top: 14px; width: 112px; height: 32px; font-size: 14px; border-radius: 32px; }
	.btn-inquiry .icon img { width: 16px; height: 18px; }
	#mobileGnb_toggle { right: 0; top: 0; width: 60px; height: 60px; }
	
	#footer .ft_wrap .ft_info { font-size: 13px; }
	#footer .ft_wrap .ft_info span { padding-right: 10px; margin-right: 5px; }
}

@media all and (max-width:480px) {
	html, body { font-size: 13px; }
	#footer .ft_wrap .ft_info { font-size: 12px; }
	#footer .ft_wrap .ft_info span::after { height: 10px; }
	
}


/* SUB LAYOUT :: 서브 콘텐츠 */
#content { padding-top: 100px; }

.con { position: relative; padding: 112px 0; }
.c-inner { max-width: 1244px; margin: 0 auto; }
.con-title { font-size: 56px; font-weight: 700; line-height: 1; color: #000; margin-bottom: 24px; }
.con-desc { font-size: 20px; color: #353535; }
.con-container { margin-top: 54px; }

.image-box { text-align: center; }
.image-box img { max-width: 100%; height: auto; transition: all 0.3s; }
.txt { line-height: 1.7; }
.txt + .txt { margin-top: 32px; }

@media all and (max-width:1280px) {
	#content { padding-top: 80px; }
	.con { padding: 86px 0; }
	.c-inner { padding: 0 20px; }
	.con-title { font-size: 45px; margin-bottom: 20px; }
	.con-desc { font-size: 18px; }
}

@media all and (max-width:768px) {
	#content { padding-top: 60px; }
	.con { padding: 78px 0; }
	.con-title { font-size: 34px; margin-bottom: 18px; }
	.con-desc { font-size: 16px; }
	/* .con + .con { margin-top: 68px; } */
	.txt + .txt { margin-top: 26px; }
	.txt br { display: none; }
}

@media all and (max-width:480px) {
	.con { padding: 65px 0; }
	.con-title { font-size: 30px; margin-bottom: 15px; }
	.con-desc { font-size: 15px; }
	.con-container { margin-top: 38px; }
	/* .con + .con { margin-top: 50px; } */
	.txt + .txt { margin-top: 20px; }
}

aside a { position: fixed; right: 50px; display: flex; justify-content: center; align-items: center; font-size: 15px; font-weight: 700; line-height: 1.2; width: 100px; height: 100px; border-radius: 50%; z-index: 100; cursor: pointer; text-align: center; box-shadow: 3px 8px 12px rgba(0, 0, 0, 0.2); transition: all .5s ease-in-out; }
aside a img { display: inline-block; margin-bottom: 5px; }
aside a.qc_1 { background-color: #fae300; bottom: 266px; }
aside a.qc_2 { background-color: #e94243; bottom: 156px; color: #fff; }
aside a.qc_3 { background-color: #5ab534; bottom: 46px; color: #fff; }

@media all and (max-width:860px) {
	aside a { right: 16px; font-size: 12px; width: 72px; height: 72px; }
	aside a img { width: 25px; height: 25px; margin-bottom: 3px; }
	aside a.qc_1 { bottom: 180px; }
	aside a.qc_2 { bottom: 98px; }
	aside a.qc_3 { bottom: 16px; }
}