@charset "utf-8";
/* layout.css는 전체적인 레이아웃 스타일을 정의합니다. */ 

#skipToContent a {z-index:100000;position:absolute;top:0;left:0;width:1px;height:1px;font-size:0;line-height:0;overflow:hidden}
#skipToContent a:focus, 
#skipToContent a:active {width:200px;height:50px;background:#21272e;color:#fff;font-size:14px;font-weight:bold;text-align:center;text-decoration:none;line-height:50px}

.only-desktop-tablet {display:block;}
.only-desktop {display:block;}
.only-tablet {display:none;}
.only-mobile {display:none;}

.contain {max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}

#wrapper {overflow:hidden;}

/* header */
#header {position:fixed; width:100%; z-index:100; background:#fff; height:130px;}
#header .contain {position:relative; max-width:1260px; padding-left:30px; padding-right:30px;}

.sitelogo {position:absolute; top:30px; left:50%; margin-left:-72.5px; z-index:5;}

.gnb-wrap {height:0;}
#gnb {position:relative; height:60px; width:100%; z-index:2; display:flex; justify-content:space-around; border-radius:10px; margin-top:100px;}
#gnb > ul {background:#005e99; border-radius:10px; width:100%; display:inline-block; height:65px;}
#gnb > ul:after {content:" "; display:block; clear:both;}
#gnb > ul > li {width:20%; position:relative; float:left; height:65px; z-index:1;}
#gnb > ul > li:last-child {padding-right:0;}
#gnb > ul > li > a {display:block; height:65px; line-height:65px; position:relative; color:#fafafa; font-size:20px; font-weight:700; z-index:5; letter-spacing:-0.04em; text-align:center;}
/* #gnb > ul > li a {border-radius:10px 0 0 0;}
#gnb > ul > li a {border-radius:0 10px 0 0;} */
#gnb > ul > li.active > a,
#gnb > ul > li:hover > a {font-weight:500; color:#005e99; background:#fff;}

#gnb .submenu ul li.active a,
#gnb .submenu ul li:hover a {font-weight:500;}

#gnb .submenu {display:none; position:absolute; z-index:1; padding:0 5px; padding-top:20px; padding-bottom:20px; width:100%; left:0;}
#gnb .submenu ul:after {content:" "; display:block; clear:both;}
#gnb .submenu ul li {text-align:center;}
#gnb .submenu ul li a {font-size:16px; display:inline-block; text-decoration:none; color:#505050; letter-spacing:-.04em; font-weight:400; line-height:1.3em; margin-bottom:15px; position:relative;} 
#gnb .submenu ul li.active a,
#gnb .submenu ul li:hover a {color:#005e99; text-decoration:underline;}

#gnb .m2 .submenu:before {left:50px;}
.submenu-bg {display:none; position:absolute; top:35px; max-width:1200px; margin:0 auto; width:100%; background:#fafafa; height:450px !important; border-radius:0 0 10px 10px;}
.submenu-bg:before {position:absolute; content:""; background:url('../images/common/ts-logo.png')50% 50% no-repeat; background-size:contain; bottom:0; left:60px; width:249px; height:180px;}

/* 전체메뉴 */
.btn-all-menu {position:relative; width:40px; height:40px; z-index:2; overflow:hidden; text-indent:-9999em;}
.btn-all-menu span {position:absolute; top:50%; left:0; right:0; height:1px; background:#fff;}
.btn-all-menu span:before,
.btn-all-menu span:after {content:" "; position:absolute; left:0; right:0; height:1px; background:#fff;}
.btn-all-menu span:before {top:-12px;}
.btn-all-menu span:after {bottom:-12px;}

.allmenu {display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,.9); z-index:102;}
.allmenu .nav {height:100%; width:100%; max-width:1460px; padding:30px; margin:0 auto; display:flex; align-items:center;}
.allmenu .nav > ul {display:flex; width:100%;}
.allmenu .nav > ul > li {flex:1; text-align:center;}
.allmenu .nav > ul > li:first-child {border-left:0;}
.allmenu .nav > ul > li > a {display:flex; flex-direction:column; justify-content:flex-end; height:120px; color:#fff; font-size:30px; font-weight:600; line-height:1.2em;}
.allmenu .nav .submenu {margin-top:25px;}
.allmenu .nav .submenu ul li {padding:8px 0;}
.allmenu .nav .submenu ul li a {display:block; color:#fff; font-size:18px; line-height:1.4em; letter-spacing:-.02em; opacity:.7;}
.allmenu .nav .submenu ul li a:hover {text-decoration:underline;}
.allmenu .close {position:absolute; top:0; right:0; width:100px; height:120px; text-indent:-9999em; overflow:hidden;}
.allmenu .close:before,
.allmenu .close:after {content:" "; position:absolute; top:50%; left:50%; margin:-2px 0 0 -15px; width:30px; height:3px; background:#fff;}
.allmenu .close:before {transform:rotate(45deg);}
.allmenu .close:after {transform:rotate(-45deg);}

html.all-menu-opened {overflow:hidden;}
html.all-menu-opened .allmenu {display:block;}

/* for mobile */

.btn-m-menu {position:absolute; display:none; top:50%; right:30px; width:40px; height:34px; margin-top:-17px; text-align:center; text-indent:-9999em; z-index:50;}
.btn-m-menu span {position:absolute; left:20px; right:0; top:17px; height:2px; background:#000;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:""; position:absolute; left:-11px; right:0; height:2px; background:#000;}
.btn-m-menu span:before {top:-15px;}
.btn-m-menu span:after {bottom:-15px;}

.mobile-navigation {position:fixed; display:none; top:0; right:0; width:300px; bottom:0; transition:.2s ease-out; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:102;}
.mobile-navigation .inner {position:absolute; top:0; left:0; width:100%; height:100%; overflow:auto;}
.mobile-navigation .brand-image {border-bottom:1px solid #d6dfd1; background-color:#e9ede7; height:128px;}
.mobile-navigation .brand-image a {display:block; padding-top:40px; padding-left:40px;}
.mobile-navigation .nav-menu .depth3 {display:block; margin-left:23px; padding-bottom:18px;}
.mobile-navigation .nav-menu .depth3 ul li a {display:block; padding:4px 0; color:#fff; font-size:18px; font-weight:300; line-height:1.4em; letter-spacing:-.04em;}
.mobile-navigation .close {position:absolute; top:18px; right:22px; width:26px; height:26px; text-indent:-9999em; overflow:hidden;} 
.mobile-navigation .close:before, 
.mobile-navigation .close:after {content:" "; position:absolute; top:12px; left:0; width:100%; height:3px; background:#2c2c2c; border-radius:3px;} 
.mobile-navigation .close:before {transform:rotate(45deg);} 
.mobile-navigation .close:after {transform:rotate(-45deg);} 
.mobile-overlay {display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:#000; opacity:0.8; z-index:101;}

html.menu-opened {overflow:hidden;}
html.menu-opened .mobile-navigation {-ms-transform:translateX(0); transform:translateX(0);}
html.menu-opened .mobile-navigation .close {display:block;}
html.menu-opened .mobile-overlay {display:block;}

nav.nav-menu {position:relative; border-top:1px solid #ddd;}
.mobile-navigation .nav-menu>ul>li {border-bottom:1px solid #dfdfdf;}
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:10px 18px; display:block; color:#333; font-size:17px; font-weight:500; line-height:1.3em;}
.mobile-navigation .nav-menu>ul>li.active {background:#f4f4f4}
.mobile-navigation .nav-menu>ul>li.active>a {color:#fff; background:#0c4da2;}
.mobile-navigation .nav-menu>ul>li.active>a:after {transform:translateY(-35%) rotate(-135deg); border-color:#fff}
.mobile-navigation .nav-menu>ul>li.home>a {padding:19px 18px;}
.mobile-navigation .nav-menu>ul>li.home>a:after {display:none;}
.mobile-navigation .nav-menu .submenu {display:none; margin:-1px 0 0 0; padding:10px 0;}
.mobile-navigation .nav-menu .submenu>ul>li>a {display:block; padding:5px 18px; color:#454545; font-size:15px; font-weight:400; line-height:1.4em;}
.mobile-navigation .nav-menu .submenu>ul>li>a:hover {color:#0c4da2;}
.mobile-navigation .nav-menu>ul>li>a:after {content:""; position:absolute; top:50%; right:20px; transform:translateY(-75%) rotate(45deg); width:12px; height:12px; border-right:2px solid #242424; border-bottom:2px solid #242424;}
.mobile-navigation img {width:40%; margin:17px;}
.mobile-navigation .close {position:absolute; top:16px; right:10px; width:24px; height:24px; text-indent:-9999em; overflow:hidden;}
.mobile-navigation .close:before,
.mobile-navigation .close:after {content:" "; position:absolute; top:11px; left:0; width:100%; height:2px; background:#fff; border-radius:3px;}
.mobile-navigation .close:before {transform:rotate(45deg);}
.mobile-navigation .close:after {transform:rotate(-45deg);}

.btn-m-menu span:before, .btn-m-menu span:after {left:-10px;}
.btn-m-menu span:before {top:-10px;}
.btn-m-menu span:after {bottom:-10px;}

/* main */
.main-visual {position:relative;}
.main-visual .img {position:relative;}
.main-visual .img:before {position:absolute; content:""; width:100%; height:100%; top:0; left:0; background:rgba(0, 0, 0, 0.3);}
.main-visual .img img {width:100%;}

.main-visual .pc {display:block;}
.main-visual .mo {display:none;}
.main-visual .slick-arrow {position:absolute; top:50%; margin-top:0; z-index:50; width:31px; height:61px; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; border:0; overflow:hidden; text-indent:-9999em; transition:.2s; background-size:contain;}
.main-visual .slick-prev {left:100px; background-image:url("../images/main/main-prev.png"); opacity:0.5;}
.main-visual .slick-prev:hover {opacity:1;}
.main-visual .slick-next {right:100px; background-image:url("../images/main/main-next.png"); opacity:0.5;}
.main-visual .slick-next:hover {opacity:1;}
.main-visual .caption {position:absolute; top:58%; left:0; transform:translateY(-50%); width:100%; color:#fff; text-align:center; z-index:40;}
.main-visual .caption p {font-size:26px; font-weight:700; line-height:1.217em; letter-spacing:0.4em; margin-bottom:35px;}
.main-visual .caption h2 {text-align:center;display:inline-block; position:relative; font-size:50px; color:#fff; font-weight:800; line-height:1.333em; letter-spacing:-.04em;}
.main-visual .con-wrap {width:100%; max-width:1520px; padding-left:30px; padding-right:30px; margin:0 auto;}
.main-visual .caption .bold {font-weight:500;}
.main-visual .caption h3 {font-family:'GmarketSans',sans-serif; font-size:72px; font-weight:700; letter-spacing:-.025em; line-height:1.0em;}
.main-visual .caption .btn {color:rgba(238, 239, 240, 0.8); margin-top:100px; display:inline-block; font-size:28px; letter-spacing:-.025em; font-weight:100; height:60px; line-height:58px; border:1px solid #eeeff0; border-radius:30px; padding:0 30px;}
.main-visual .caption .btn span img {display:inline-block; vertical-align:baseline; margin-right:10px;}
.main-visual .caption .btn.mg {margin-top:30px;}

.main-visual .scroll-wrap {position: relative; width: 100%; max-width: 1400px; margin: 0 auto;}
.main-visual .scroll {position:absolute; bottom:0; left:50%; width:150px; text-align:center; margin-left:-75px; color:#fff; font-size:17px; font-weight:500; line-height:1.3em; letter-spacing:.3em; z-index:50; }
.main-visual .scroll span {transform:rotate(270deg); display: inline-block; margin-bottom:55px;}
.main-visual .scroll .track {display:block; margin:20px auto 0; position:relative; width:1px; height:90px; background:rgba(255,255,255,.52);}
.main-visual .scroll .track:after {content:""; position:absolute; top:0; left:-2.5px; width:5px; height:20px; background:#fff; animation:hero-scroll 2s linear infinite;}

@keyframes hero-scroll{  
  0%{
    top:0;
    opacity:1
  }
  50%{
    opacity:1
  }
  to{
    top:90px;
    opacity:0
  }
}

.main-tit {text-align:center; margin-bottom:75px;}
.main-tit h3 {font-size:46px; font-weight:700; color:#231f20; letter-spacing:-.04em; line-height:1.3em;}

.main-product {padding:100px 0 250px; background:#f4f4f4;}
.main-product .slick-list {overflow:visible; margin:0 -15px;}
.main-product .slick-slide {padding:0 15px;}
.main-product .slick-arrow {position:absolute; bottom:-120px; z-index:50; width:64px; height:64px; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; border:0; overflow:hidden; text-indent:-9999em; transition:.2s; background-size:contain;}
.main-product .slick-prev {left:50%; margin-left:-50px; background-image:url("../images/main/pro-prev.png");}
.main-product .slick-prev:hover {background-image:url("../images/main/pro-prev_w.png");}
.main-product .slick-next {right:50%; margin-right:-100px; background-image:url("../images/main/pro-next.png");}
.main-product .slick-next:hover {background-image:url("../images/main/pro-next_w.png");} 
.main-product .items {}
.main-product .item {}
.main-product .item a {display:block;}
.main-product .item .img {}
.main-product .item .thumb {}
.main-product .item .thumb img {}
.main-product .item .txt-box {background:#fff; min-height:220px; padding-left:35px; box-shadow:0 10px 30px rgba(0, 0, 0, 0.15);}
.main-product .item .txt-box .tit {font-size:18px; font-weight:600; color:#231f20; letter-spacing:-.04em; line-height:1.3em; padding:25px 0 15px;}
.main-product .item .txt-box .txt {}

.main-apply {padding:120px 0;}
.main-apply-list {position:relative;}
.main-apply-list:before {position:absolute; content:""; width:578px; height:263px; background:url('../images/main/main-apply-tit.png')50% 50% no-repeat; background-size:contain; bottom:30px; right:0;}
.main-apply-list ul {display:flex; flex-wrap:wrap; margin-bottom:-30px; margin-left:-30px;}
.main-apply-list ul li {position:relative; width:calc(50% - 30px); margin-left:30px; margin-bottom:30px; background-size:cover; background-repeat:no-repeat; background-position:50% 50%; min-height:330px; box-shadow:0px 10px 30px rgba(0, 0, 0, 0.15);}
.main-apply-list ul li a {display:block; width:100%; height:100%;}
.main-apply-list ul li a:hover:before {position:absolute; content:""; width:100%; height:100%; top:0; left:0; background: linear-gradient(#3070b8, #062f87); opacity:0.96;}
.main-apply-list ul li a:hover:after {position:absolute; content:""; width:79px; height:17px; background:url('../images/main/go-btn.png')50% 50% no-repeat; background-size:contain; bottom:40px; right:40px;}
.main-apply-list ul li .tit {position:absolute; bottom:30px; left:30px; font-size:28px; font-weight:700; letter-spacing:-.04em; line-height:1.3em; color:#fff;}

.main-customer {background:#f4f4f4; padding:110px 0 140px;}
.main-customer {}
.main-customer .main-customer-list .main-customer-list-flex {display:flex; margin-left:-30px;}  
.main-customer .main-customer-list .main-customer-box {background:#fff; width:calc(33.3333% - 30px); margin-left:30px; padding:50px 40px;}
.main-customer .main-customer-list .main-customer-box.bg {background-repeat:no-repeat; background-size:cover; background-position:50% 50%;}
.main-customer .main-customer-list .main-customer-box.bg a {display:block; width:100%; height:100%;}
.main-customer .main-customer-list .main-customer-box.bg h3 {font-size:24px; color:#fff; font-weight:700; margin-bottom:10px;}
.main-customer .main-customer-list .main-customer-box.bg .txt {color:#fff;}
.main-customer .main-customer-list .main-customer-box .tit {display:flex; justify-content:space-between; padding-bottom:15px; border-bottom:1px solid #a8a8a8; font-size:24px; font-weight:700; color:#231f20; letter-spacing:-.04em; line-height:1.3em;}
.main-customer .main-customer-list .main-customer-box .tit a {font-size:14px; color:#f98700; letter-spacing:-.04em; text-decoration:underline;}
.main-customer .main-customer-list .main-customer-box dl {padding:15px 0; border-bottom:1px solid #ddd;}
.main-customer .main-customer-list .main-customer-box dl:last-child {border-bottom:0; padding-bottom:0;}
.main-customer .main-customer-list .main-customer-box dl dt {overflow:hidden; text-overflow:ellipsis; word-break:break-all; white-space:normal; display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; font-size:16px; color:#505050; letter-spacing:-.04em; margin-bottom:5px;}
.main-customer .main-customer-list .main-customer-box dl dt a {}
.main-customer .main-customer-list .main-customer-box dl dd {font-size:15px; color:#878787; letter-spacing:-.04em; line-height:1.733em;}


/* sub */
.sub-visual {position:relative; text-align:center; height:300px; color:#fff; overflow:hidden; background:#333; margin-top:130px;}
.sub-visual .bg {position:absolute; top:0; left:0; width:100%; height:100%; overflow:hidden; transition:2s; opacity:0; transform:scale(1.1); background-repeat:no-repeat; background-position:50% 50%; background-size:cover;}
.sub-visual .inner {position:absolute; top:50%; margin-top:20px; left:0; width:100%; transform:translateY(-50%);}
.sub-visual h2 {font-size:45px; line-height:1.300em; letter-spacing:-.04em;}
.sub-visual p {font-size:30px; font-weight:100; line-height:1.4em; letter-spacing:-.025em;}
.sub-visual .bg1 {background-image:url("../images/common/sv1.jpg");}
.sub-visual .bg2 {background-image:url("../images/common/sv2.jpg");}
.sub-visual .bg3 {background-image:url("../images/common/sv3.jpg");}
.sub-visual .bg4 {background-image:url("../images/common/sv4.jpg");}
.sub-visual .bg5 {background-image:url("../images/common/sv5.jpg");}
.sub-visual [data-aos=fade-up] {transform: translate3d(0,30px,0);}
.loaded .sub-visual .bg {transform:scale(1); opacity:1;}

.path-wrap {position:relative; color:#000; font-size:20px; z-index:50; border-bottom:1px solid #ddd;}
.path-wrap .wrap {display:flex; max-width:1200px; margin:0 auto; background:#fff;}
.path-wrap .home a {display:block; width:64px; height:64px; background:url("../images/common/home.png") 50% 50% no-repeat; background-size:cover; text-indent:-999em; overflow:hidden; border-right:1px solid #e3e3e3;}
.path-wrap .part {position:relative; width:33%; max-width:315px; border-right:1px solid #e3e3e3; z-index:50;}
.path-wrap .part > a {font-size:17px; color:#2c2c2c; display:flex; align-items:center; position:relative; height:65px; color:#333; line-height:1.3em; padding:0 60px 0 30px;}
.path-wrap .part > a:after {content:""; position:absolute; top:50%; right:30px; margin-top:-12px; width:24px; height:24px; background:url("../images/common/path_down.png") 50% 50% no-repeat;}
.path-wrap .part ul {display:none; position:absolute; left:-1px; right:-1px; background:#fff; border:1px solid #ddd; z-index:50;}
.path-wrap .part ul li {color:#555; line-height:1.3em; border-bottom:1px solid #ddd;}
.path-wrap .part ul li:last-child {border-bottom:0;}
.path-wrap .part ul li a {display:block; padding:20px;}
.path-wrap .part ul li a:hover,
.path-wrap .part ul li.active a {color:#fff; background:#005e99;}
.path-wrap .btn {display:flex; align-items:center; padding:0 30px; height:60px; border-left:1px solid rgba(255,255,255,.5); border-right:1px solid rgba(255,255,255,.5);}
.path-wrap .btn:before {content:""; width:35px; height:35px; background:url("../images/common/icon_qa.png") 50% 50% no-repeat; margin-right:9px;}

#contArea {max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}
#contArea.wide {max-width:100%; padding-left:0; padding-right:0;}
#contArea.wide .sub-title {padding-left:10px; padding-right:10px;}

.sub-title {padding:100px 0 75px; text-align:center;}
.sub-title h2 {font-size:42px; color:#231f20; font-weight:700; line-height:1.3em; letter-spacing:-.04em;}

.real-cont {min-height:300px; padding-bottom:140px;}
.real-cont.none {padding-bottom:0;}


/* footer */
#main #footer .contain {max-width:1580px;}
#footer {padding:60px 0 55px; background:#fff; color:#505050; font-size:16px; font-weight:400; line-height:1.5em; letter-spacing:-.025em;}
#footer address {font-style:normal;}
#footer .contain {display:flex; justify-content:space-between; position:relative;}
#footer span {display:inline-block; line-height:2.0em;}
#footer a:hover {text-decoration:underline;}
#footer .img {margin-bottom:30px;}

.foot-links {padding:28px 0; color:#999; font-weight:400; border-bottom:1px solid #393d46;;}
.foot-links .contain {display:flex; align-items:center; justify-content:space-between;}
.foot-links .links ul {display:flex; flex-wrap:wrap;}
.foot-links .links ul li {padding:4px 0; display:flex; align-items:center;}
.foot-links .links ul li:before {content:""; width:1px; height:15px; margin:0 20px; background:#393d46;}
.foot-links .links ul li:first-child::before {display:none;}

.foot-menu {}
.foot-menu ul {display:flex; margin-right:-20px;}
.foot-menu ul li {font-size:13px; color:#505050; letter-spacing:-.04em; line-height:1.3em; margin-right:20px; font-weight:400;}

.foot-info address span {margin-right:18px;}

.foot-info .copyright {font-size:13px; margin-top:10px; color:#878787; font-weight:400;}
.foot-info .designed {display:inline-block; font-size:13px; color:#878787; font-size:12px; font-weight:300;}

.go-top {position:absolute; right:0; bottom:30px;}

.quick-menu {position:fixed; right:0; top:500px; z-index:99;}
.quick-menu .img {margin-bottom:0 !important;}
