@charset "utf-8";
:root {
	--app-height: 100%;
	--color-primary: #0c4da2;
	--color-secondary: #1865c9;
	--color-tertiary: #2d57d7;
	--border-line: #dddddd;
	--border-radius: 16px;
}

body { padding-top: 100px; }
body.main { padding-top: 0; }

#header { position: fixed; left: 0; right: 0; top: 0; width: 100%; height: 100px; z-index: 100; margin: 0 auto; background-color: #fff; transition: all 0.2s; }
/*#header.scroll { background-color: #fff; box-shadow: 0 0 14px rgba(0, 0, 0, .4); }*/
#header::before { position: absolute; left: 0; top: 100px; content: ''; width: 100%; height: 1px; background-color: #eaeaea; z-index: 1; }
#header.main { background: transparent; }
#header.main::before { display: none; }
#header.ov,
#header.scroll { background-color: #fff; box-shadow: 0 0 14px rgba(0, 0, 0, 0.1); }

.hd_wrap { display: flex; align-items: center; position: relative; height: 100%; padding: 0 40px; }
.hd_wrap .logo { position: absolute; left: 40px; top: 25px; width: 119px; height: 52px; 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%; }

.hd_wrap .util { position: absolute; right: 100px; top: 50%; display: flex; z-index: 110; transform: translateY(-50%); }
.hd_wrap .util a { display: flex; align-items: center; font-size: 18px; font-weight: 500; height: 40px; padding: 0 24px; border: 1px solid var(--color-primary); border-radius: 40px; transition: all 0.3s; }
.hd_wrap .util a:first-of-type { color: #fff; background-color: var(--color-primary); }
.hd_wrap .util a:last-of-type { color: var(--color-primary); background-color: transparent; margin-left: 6px; }
.hd_wrap .util a:hover { background-color: var(--color-secondary); color: #fff; }
.hd_wrap .util .icon_inquiry { display: inline-block; margin-right: 8px; width: 18px; height: 22px; background: url('../images/icon_inquiry.png') left center no-repeat; background-size: contain; }

#gnb { display: flex; margin-left: 224px; z-index: 100; }
#gnb li { position: relative; margin-right: 50px; }
#gnb li a { display: block; padding: 0 10px; }
#gnb li a span { font-size: 22px; font-weight: 700; color: #000; line-height: 100px; transition: all 0.3s; }
#gnb li a.on span, #gnb li a:hover span { color: var(--color-primary); }
#gnb-sub { display: none; position: absolute; top: 100px; left: 0; width: 100%; padding: 16px 0; background-color: #fff; border-top: 1px solid #efefef; box-shadow: 2px 2px 2px rgba(80,80,80,0.1); z-index: 110; }
#gnb-sub .gnb-sub-menu { position: relative; margin: 0 auto; width: 100%; }
#gnb-sub ul.snb1 { margin-left: 274px; }
#gnb-sub ul.snb2 { margin-left: 274px; /*margin-left: 402px;*/ }
#gnb-sub ul.snb3 { margin-left: 274px; /*margin-left: 548px;*/ }
#gnb-sub ul.snb { display: flex; position: relative; overflow: hidden; }
#gnb-sub ul.snb li { margin-right: 50px; }
#gnb-sub ul.snb li a { display: block; font-size: 18px; font-weight: 500; color: #000; line-height: 28px; transition: all 0.3s; }
#gnb-sub ul.snb li a.on, #gnb-sub ul.snb li a:hover { color: var(--color-secondary); }


/* GNB MOBILE BUTTON */
#mobileGnb_toggle { position: absolute; right: 40px; 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 { 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; }

/* 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: var(--color-primary); }
#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.14s; }
#gnb_moblie .m4 { transition-delay: 0.175s; }
#gnb_moblie .m5 { transition-delay: 0.21s; }

#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: #0c305e; margin-top: 198px; }
#footer.main { margin-top: 0; }
#footer .ft_wrap { padding: 78px 0; text-align: left; }
#footer.main .ft_wrap { padding-bottom: 134px; }
#footer .ft_wrap .ft_inner { position: relative; width: 100%; max-width: 1080px; margin: 0 auto; }
#footer .ft_wrap .address { font-size: 18px; letter-spacing: -0.25px; margin-top: 8px; color: #94aece; }
#footer .ft_wrap .address span { position: relative; display: inline-block; padding-right: 20px; margin-right: 10px; }
#footer .ft_wrap .address span::after { position: absolute; right: 0; top: 50%; content: ''; width: 1px; height: 14px; margin-top: -7px; background: #41546b; }
#footer .ft_wrap .address span:nth-child(2)::after,
#footer .ft_wrap .address span:last-child::after { display: none; }
#footer .ft_wrap .copyright { font-size: 13px; letter-spacing: 0; text-transform: uppercase; margin-top: 8px; color: #6b7f98; }

.ft_family { position: absolute; right: 0; top: 0; width: 176px; z-index: 10; }
.ft_family .btn_ft { display: block; text-align: left; font-size: 13px; background-color: #0a264a ; color: #fff; width: 100%; height: 33px; padding: 0 18px; line-height: 33px; transition: all 0.3s; }
.ft_family .btn_ft.open { background-color: var(--color-secondary); }
.ft_family .btn_ft .arrow { position: absolute; right: 22px; top: 50%; width: 8px; height: 8px; margin-top: -2px; background: transparent; border: 2px solid white; border-width: 2px 2px 0 0; transform: rotate(-45deg); transition: all 0.3s; }
.ft_family .btn_ft.open .arrow { margin-top: -7px; transform: rotate(135deg); }
.ft_family .ft_item { display: none; position: absolute; left: 0; bottom: 33px; }
.ft_family .ft_item ul { width: 176px; background-color: #282e39; }
.ft_family .ft_item ul li { margin-bottom: 1px; background-color: #282e39; border-bottom: 1px solid #313845; }
.ft_family .ft_item ul li:last-child { border-bottom: 0; margin-bottom: 0; }
.ft_family .ft_item ul li a { display: block; text-align: center; font-size: 14px; color: #fff; padding: 10px 18px; transition: all 0.3s; }
.ft_family .ft_item ul li a:hover { background-color: #3e4553; }

#fixed_inquiry { position: fixed; left: 0; bottom: 0; width: 100%; text-align: center; z-index: 90; background-color: #ffc63e; transition: all 0.5s cubic-bezier(0.65, 0.05, 0.36, 1); }
#fixed_inquiry .fx_btn { display: flex; align-items: center; justify-content: center; width: 100%; height: 56px; line-height: 56px; font-size: 18px; font-weight: 500; margin: 0 auto; color: #000; cursor: pointer; }
#fixed_inquiry .fx_btn .icon { position: relative; display: inline-block; width: 23px; height: 23px; margin-left: 6px; background-color: #000; border-radius: 50%; color: #fff; }
#fixed_inquiry .fx_btn .icon::after { position: absolute; left: 50%; top: 50%; content: '+'; font-size: 20px; transform: translate(-50%, -50%); font-style: normal; }

#TopBtn { opacity: 0; visibility: hidden; position: fixed; right: 26px; bottom: 26px; width: 50px; height: 50px; z-index: 500; transition: all 0.5s cubic-bezier(0.65, 0.05, 0.36, 1); }
#TopBtn.show { opacity: 1; visibility: visible; }
.btn-totop { position: absolute; right: 0; bottom: 0; width: 50px; height: 50px; border-radius: 50%; background: url('https://icongr.am/material/arrow-up.svg?size=28&color=ffffff') center no-repeat; background-color: rgba(0, 0, 0, 0.3); border: 0; }

@media all and (max-width:500px) {
    #TopBtn { right: 10px; bottom: 10px; }
}

@media all and (max-width:1280px) {
	body { padding-top: 80px; }
	#header { height: 80px; }
	#header::before { top: 80px; }
	.hd_wrap .logo { left: 20px; top: 15px; }
	#gnb { display: none; }
	#mobileGnb_toggle { right: 0; top: 0; width: 80px; height: 80px; }

	#footer { margin-top: 78px; }
	#footer br { display: none; }
	#footer .ft_wrap .ft_inner { padding: 0 20px; background-image: none; }
	#footer .ft_wrap { padding: 46px 0; text-align: center; }
	#footer.main .ft_wrap { padding-bottom: 102px; }
	#footer .ft_wrap .address span::after { display: none; }
	.ft_family { position: relative; right: auto; top: auto; margin: 24px auto 0; }
}

@media all and (max-width:768px) {
	html, body { font-size: 15px; }
	body { padding-top: 60px; }
	#header { height: 60px; }
	#header::before { top: 60px; }
	.hd_wrap .logo { top: 13px; width: 78px; height: 34px; }
	.hd_wrap .util { right: 60px; }
	.hd_wrap .util a { font-size: 13px; height: 28px; padding: 0 8px; border-radius: 28px; }
	.hd_wrap .util a:last-of-type { margin-left: 4px; }
	.hd_wrap .util .icon_inquiry { margin-right: 8px; width: 13px; height: 16px; }

	#mobileGnb_toggle { right: 0; top: 0; width: 60px; height: 60px; }
	
	#footer { margin-top: 50px; }
	#footer .ft_wrap .address { font-size: 14px; }
	#footer .ft_wrap .address span { padding-right: 5px; margin-right: 5px; }
}

@media all and (max-width:480px) {
	html, body { font-size: 13px; }
}


/* ****************** SUB LAYOUT ********************** */
/* SUB LAYOUT :: 비주얼 */
.svisual { position: relative; height: auto; max-height: 732px; min-height: 38.13vw; background-color: #fff; overflow: hidden; }
.svisual .bg { position: absolute; left: 0; top: 0; width: 100%; height: 100%; transition: all 2s ease-in-out; }
.svisual .bg.service { background: #f9f9f9 url('../images/service/svi_service.jpg') center center no-repeat; background-size: contain; } 
.svisual .intro { position: absolute; left: 50%; bottom: 30px; width: 100%; height: auto; z-index: 3; transform: translateX(-50%); }
.svisual .intro .txt_box { max-width: 1080px; margin: 0 auto; text-align: center; }
.svisual .intro .txt_box p { font-size: 26px; font-weight: 700; color: var(--color-primary); }

@media all and (max-width:768px) {
	.svisual { position: relative; min-height: calc(38.13vw + 100px); }
	.svisual .intro { bottom: 15px; }
	.svisual .intro .txt_box p { font-size: 20px; }
}

@media all and (max-width:480px) {
	.svisual .intro .txt_box p { font-size: 18px; }
}


/* SUB LAYOUT :: 서브 콘텐츠 */
.con { padding-top: 116px; }
.con.hasPdb { padding-bottom: 116px; }
.inner { width: 100%; max-width: 1080px; margin: 0 auto; }
.sec_title1 { font-size: 36px; font-weight: 700; color: var(--color-primary); line-height: 1.2; margin-bottom: 38px; }
.sec_title2 { font-size: 26px; line-height: 1.4; margin-bottom: 38px; }
.sec_title1 + .sec_title2 { margin-top: -24px; }
.res_image { text-align: center; }
.res_image.border_radius { border-radius: var(--border-radius); overflow: hidden; }
.res_image img { max-width: 100%; height: auto; transition: all 0.3s; }
.txt { line-height: 1.7; }
.txt + .txt { margin-top: 26px; }

.emphasis { color: var(--color-tertiary); }
.emphasis2 { color: #e50808; }

@media all and (max-width:1280px) {
	.con { padding-left: 20px; padding-right: 20px; }
}

@media all and (max-width:768px) {
	.con { padding-top: 64px; }
	.con.hasPdb { padding-bottom: 64px; }
	.sec_title1 { font-size: 26px; margin-bottom: 24px; }
	.sec_title2 { font-size: 20px; margin-bottom: 24px; }
	.sec_title1 + .sec_title2 { margin-top: -12px; }
	.txt { line-height: 1.6; }
	.txt br { display: none; }
}

aside a { position: fixed; right: 30px; 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: 156px; }
aside a.qc_2 { background-color: #e94243; bottom: 100px; color: #fff; }


@media all and (max-width:480px) {
	
}