@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;}

#sub #wrapper {position:relative; padding-top:80px;}

.contain {width:100%; max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}

/* header */
#header {position:fixed; top:0; left:0; width:100%; padding:0 50px; background:#fff; border-bottom:1px solid #ddd; transition:.2s; z-index:100;}
.header {position:relative; display:flex; align-items:center; justify-content:space-between; height:89px; z-index:2;}

#gnb > ul {display:flex;}
#gnb > ul > li {padding:0 70px;}
#gnb > ul > li > a {position:relative; display:block; color:#242424; font-size:18px; font-weight:500; line-height:89px; letter-spacing:-.02em; transition:.4s;}
#gnb > ul > li > a:after {content:""; position:absolute; top:50%; left:50%; margin-top:14px; width:0; height:2px; background:#2daede; transition:.4s;}
#gnb > ul > li.active > a {color:#2daede; font-weight:700;}
#gnb > ul > li.active > a:after {left:0; width:100%;}

.top-tel {display:flex; align-items:center; padding:0 13px 0 20px; height:44px; color:#05529f; font-size:21px; font-weight:700; line-height:1.3em; letter-spacing:-.01em; border:1px solid #ddd;}
.top-tel:hover {border-color:#05529f;}
.top-tel img {vertical-align:middle; margin:0 10px 0 0;}

/* for mobile */
.btn-m-menu {display:none; position:absolute; top:50%; right:0; width:24px; height:24px; margin-top:-14px; text-indent:-9999em; z-index:50;}
.btn-m-menu span {position:absolute; left:0; right:0; top:12px; height:2px; background:#2c2c2c;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; left:0; right:0; height:2px; background:#2c2c2c;}
.btn-m-menu span:before {top:-9px;}
.btn-m-menu span:after {bottom:-9px;}

.mobile-navigation {display:none; position:fixed; top:0; right:0; width:300px; height:100%; overflow:auto; transition:.2s linear; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:102;}
.mobile-navigation .home {display:flex; align-items:center; height:70px; padding:10px 20px;}
.mobile-navigation .nav-menu>ul {border-top:1px solid #dfdfdf;}
.mobile-navigation .nav-menu>ul>li {border-bottom:1px solid #dfdfdf;}
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:12px 48px 12px 20px; display:block; color:#2c2c2c; font-size:17px; font-weight:700; line-height:1.5em;}
.mobile-navigation .nav-menu>ul>li.active>a {color:#2daede}
.mobile-navigation .nav-menu .submenu {display:none; padding:12px 20px; background:#2daede; color:#fff; font-size:15px; font-weight:500; line-height:1.5em;}
.mobile-navigation .nav-menu .submenu > ul > li > a {display:block; position:relative; padding:6px 0;}
.mobile-navigation .close {position:absolute; top:20px; right:18px; 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.6; z-index:101;}

html.menu-opened {overflow:hidden;}
html.menu-opened .mobile-navigation {-ms-transform:translateX(0); transform:translateX(0);}
html.menu-opened .mobile-overlay {display:block;}

/* main */
.main-visual {position:relative; height:100vh; color:#fff; overflow:hidden;}
.main-visual .item {position:relative; height:100vh; background-position:50% 50%; background-repeat:no-repeat; background-size:cover; overflow:hidden;}
.main-visual .item .img {position:absolute; top:0; left:0; width:100%; height:100%;}
.main-visual .item .img img {position:absolute; top:50%; left:0; transform:translateY(-50%); -ms-transform:translateY(-50%); -webkit-transform:translateY(-50%); width:100%; height:auto !important; max-width:100%; min-height:100%; object-fit:cover;}
.main-visual .slick-dots {position:absolute; bottom:134px; left:0; width:100%; text-align:center; line-height:0; z-index:50;}
.main-visual .slick-dots li {display:inline-block; vertical-align:top; margin:0 5px;}
.main-visual .slick-dots li button {display:block; width:12px; height:12px; background:#fff; border:0; overflow:hidden; text-indent:-9999em; border-radius:100%;}
.main-visual .slick-dots li.slick-active button {background:#2daede;}
.main-visual .slick-arrow {position:absolute; top:50%; margin-top:-25px; width:50px; height:50px; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; border:0; z-index:50; overflow:hidden; text-indent:-9999em;}
.main-visual .slick-prev {left:115px; background-image:url("../images/main/slide_prev.png");}
.main-visual .slick-next {right:115px; background-image:url("../images/main/slide_next.png");}
.main-visual .caption {position:absolute; top:50%; left:0; width:100%; padding:0 200px; transform:translateY(-50%); z-index:40;}
.main-visual .caption .contain {display:flex; justify-content:flex-end;}
.main-visual .caption .inner {width:100%; max-width:52%;}
.main-visual .caption p {opacity:0;}
.main-visual .caption .txt1 {color:#2eb1e0; font-size:18px; font-weight:500; line-height:1.3em; letter-spacing:.5em; margin-bottom:2px;}
.main-visual .caption .txt2 {color:#fff; font-size:84px; font-weight:600; line-height:1.3em; letter-spacing:-.01em; margin-bottom:2px;}
.main-visual .caption .txt3 {color:#fff; font-size:18px; line-height:1.3em; letter-spacing:-.01em;}
.main-visual .slick-current .item .img {animation:bgScale 8000ms 1 ease-out;}
.main-visual .slick-current .caption .txt1 {animation:txtMove .7s .4s forwards ease-out;}
.main-visual .slick-current .caption .txt2 {animation:txtMove .7s .6s forwards ease-out;}
.main-visual .slick-current .caption .txt3 {animation:txtMove .7s .8s forwards ease-out;}

.main-home .scroll {animation:scrollDown 1.7s linear infinite; position:absolute; bottom:40px; left:50%; width:100px; margin-left:-50px; text-align:center; color:#fff; font-size:14px; line-height:1em; letter-spacing:0.02em; padding-bottom:40px; background:url("../images/main/scroll.png") 50% 100% no-repeat; z-index:50;}

@keyframes bgScale {
	0% { transform: scale(1.4); }
	100% { transform: scale(1) rotate(0.02deg); }
}

@keyframes txtMove {
	0% {opacity:0; transform:translateX(30px);}
	100% {opacity:1; transform:translateX(0);}
}

@keyframes scrollDown {
	0% {transform:translateY(0);}
	50% {transform:translateY(15px);}
	100% {transform:translateY(0);}
}

@keyframes moveUp {
	0% {opacity:0; transform:translateY(-30%);}
	100% {opacity:1; transform:translateY(-50%);}
}

@keyframes txtUp {
	0% {opacity:0; transform:translateY(30px);}
	100% {opacity:1; transform:translateY(0);}
}

.section-inner {padding:90px 200px 0;}

.main-company {background:url("../images/main/company_bg.jpg") 50% 50% no-repeat; background-size:cover;}
.main-company .contain {max-width:1460px;}
.main-company .en {color:#2eb1e0; font-size:18px; font-weight:500; line-height:1.3em; letter-spacing:.5em; opacity:0;  margin-bottom:2px;}
.main-company h2 {color:#fff; font-size:84px; font-weight:600; line-height:1.3em; letter-spacing:-.01em; opacity:0; margin-bottom:2px;}
.main-company .txt {color:#fff; font-size:18px; line-height:1.3em; letter-spacing:-.01em; opacity:0; margin-bottom:35px;}
.main-company .txt strong {font-weight:600;}
.main-company .btn {display:inline-flex; align-items:center; height:50px; padding:0 20px; color:#fff; font-size:18px; font-weight:700; line-height:1.3em; border:1px solid rgba(255,255,255,.4); border-radius:5px; opacity:0;}
.main-company .btn:after {content:""; margin-left:15px; width:20px; height:9px; background:url("../images/main/btn_arrow.png") 50% 50% no-repeat;}
.main-company .btn:hover {background:#2eb1e0; border-color:#2eb1e0;}
.main-company.current .en {animation:txtMove .7s .0s forwards;}
.main-company.current h2 {animation:txtMove .7s .15s forwards;}
.main-company.current .txt {animation:txtMove .7s .3s forwards;}
.main-company.current .btn {animation:txtMove .7s .45s forwards;}

.main-product ul {display:flex; height:100vh;}
.main-product ul li {flex:1; position:relative;}
.main-product ul li a {display:block; position:absolute; top:0; left:0; width:100%; height:100%; overflow:hidden; background:#000;}
.main-product ul li .img {position:absolute; top:0; left:0; width:100%; height:100%; overflow:hidden; opacity:.3; transition:.4s;}
.main-product ul li .img img {position:absolute; top:50%; left:0; transform:translateY(-50%); -ms-transform:translateY(-50%); -webkit-transform:translateY(-50%); width:100%; height:auto !important; max-width:100%; min-height:100%; object-fit:cover;}
.main-product ul li .info {position:absolute; top:50%; left:0; width:100%; padding:70px 17px 0; color:#fff; text-align:center; transform:translateY(-40%); opacity:0; transition:.4s;}
.main-product ul li .info .txt {font-size:26px; font-weight:500; line-height:1.3em; letter-spacing:-.01em; margin-bottom:25px;}
.main-product ul li .info .mark {background:rgba(255,255,255,.6); border-radius:5px; margin-bottom:30px;}
.main-product ul li .info .arrow {height:13px; background:url("../images/main/link_arrow.png") 50% 50% no-repeat;}
.main-product ul li a:hover .img {opacity:.8;}
.main-product.current ul li:nth-child(1) .info {animation:moveUp .4s .0s forwards;}
.main-product.current ul li:nth-child(2) .info {animation:moveUp .4s .15s forwards;}
.main-product.current ul li:nth-child(3) .info {animation:moveUp .4s .3s forwards;}
.main-product.current ul li:nth-child(4) .info {animation:moveUp .4s .45s forwards;}
.main-product.current ul li:nth-child(5) .info {animation:moveUp .4s .6s forwards;}
.main-product.current ul li:nth-child(6) .info {animation:moveUp .4s .75s forwards;}
.main-product.current ul li:nth-child(7) .info {animation:moveUp .4s .9s forwards;}

.main-community {color:#fff; text-align:center; background:url("../images/main/comm_bg.jpg") 50% 50% no-repeat; background-size:cover;}
.main-community .head {margin-bottom:45px; opacity:0;}
.main-community .head .en {color:#7ed8f5; font-size:16px; font-weight:500; line-height:1.3em; letter-spacing:-.01em; margin-bottom:2px;}
.main-community .head h2 {color:#fff; font-size:84px; font-weight:600; line-height:1.3em; letter-spacing:-.01em; margin-bottom:2px;}
.main-community .head .txt {color:#fff; font-size:18px; line-height:1.3em; letter-spacing:-.01em; margin-bottom:35px;}
.main-community .head .txt strong {font-weight:600;}
.main-community .links {display:flex; justify-content:center; opacity:0;}
.main-community .links .link {display:flex; flex-direction:column; justify-content:center; margin:0 20px; width:200px; height:200px; border-radius:100%;}
.main-community .links .link.st1 {background:rgba(55,172,215,.64);}
.main-community .links .link.st2 {background:rgba(8,49,90,.64);}
.main-community .links .link.st1:hover {background:rgba(55,172,215,1);}
.main-community .links .link.st2:hover {background:rgba(8,49,90,1);}
.main-community .links .link .ico {margin-bottom:10px;}
.main-community .links .link .tit {font-size:26px; font-weight:500; line-height:1.3em; letter-spacing:-.01em; margin-bottom:12px;}
.main-community .links .link .go {display:flex; align-items:center; justify-content:center; font-size:16px; font-weight:500; line-height:1.3em; letter-spacing:-.02em;}
.main-community .links .link .go:after {content:""; margin-left:8px; width:13px; height:7px; background:url("../images/main/btn_arrow2.png") 50% 50% no-repeat;}
.main-community.current .head {animation:txtUp .4s .0s forwards;}
.main-community.current .links {animation:txtUp .4s .2s forwards;}

/* sub */
.sub-visual {display:flex; align-items:center; text-align:center; height:300px; color:#fff; background-position:50% 50%; background-repeat:no-repeat; background-size:cover;}
.sub-visual .inner {width:100%; padding:20px;}
.sub-visual .en {font-size:18px; font-weight:500; line-height:1.3em; letter-spacing:.5em; margin-left:.5em; margin-bottom:8px;}
.sub-visual h2 {font-size:40px; line-height:1.3em; letter-spacing:-.01em;}
.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");}

.lnb-wrap {background:#2eb1e1; text-align:center; color:#fff; padding:0 15px;}
.lnb ul {width:auto; max-width:100%; display:inline-flex;}
.lnb ul li {width:auto; position:relative; display:flex; align-items:center; height:70px;}
.lnb ul li:before {content:""; width:1px; height:15px; background:#fff; margin:0 30px;}
.lnb ul li:first-child::before {display:none;}
.lnb ul li a {display:block; font-size:18px; line-height:1.3em; letter-spacing:-.02em;}
.lnb ul li.active a {font-weight:700; border-bottom:1px solid #fff;}

#contArea {max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}
#contArea.wide {max-width:100%; padding-left:0; padding-right:0;}

.sub-title {text-align:center; padding:65px 0 35px;}
.sub-title h2 {color:#242424; font-size:30px; font-weight:600; line-height:1.3em; letter-spacing:-.02em;}

.real-cont {min-height:500px; padding-bottom:120px;}

/* footer */
#main #footer .contain {max-width:1460px;}

#footer {padding:40px 0; color:#454545; font-weight:500; line-height:1.5em; letter-spacing:-.01em; background:#e3f2f8;}
#footer .contain {display:flex; align-items:center;}
#footer address {font-style:normal;}
#footer a:hover {text-decoration:underline;}

.foot-info {flex:1 1 auto; min-width:0; width:1%;}
.foot-info .comp-name {color:#082f56; font-size:20px; font-weight:600; line-height:1.3em; margin-bottom:14px;}
.foot-info .link {display:inline-flex; align-items:center; color:#082f56; margin-right:35px;}
.foot-info .link:before {content:""; width:15px; height:15px; margin-right:8px; background:url("../images/common/icon_doc.png") 50% 50% no-repeat;}
.foot-info address span {display:inline-block; margin-right:35px;}
.foot-info .copyright {color:#686868; font-size:13px; font-weight:300; line-height:1.3em; margin-top:10px;}
.foot-info .designed {display:inline-block; margin-left:4px;}
