@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}

.contain {width:100%; max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}
.contain:after {content:""; display:block; clear:both;}

.only-desktop {display:block;}
.only-desktop-tablet {display:block;}
td.only-desktop-tablet {display:table-cell;}
.only-tablet-mobile {display:none;}
.only-tablet {display:none;}
.only-mobile {display:none;}

/* header */
#header {position:relative; width:100%; z-index:100;}
#header .contain {position:relative; max-width:1260px; height:100px; padding-left:30px; padding-right:30px;}

.sitelogo {position:absolute; top:50%; left:0; margin-top:-22.5px; z-index:5;}
.sitelogo a {display:block; width:165px; height:45px; overflow:hidden; text-indent:-9999em; background:url("../images/common/logo.png") 50% 50% no-repeat; background-size:contain;}

#gnb {position:relative; height:100px; width:100%; text-align:right; z-index:2; display:flex; justify-content:center;}
#gnb > ul {display:inline-block;}
#gnb > ul:after {content:" "; display:block; clear:both;}
#gnb > ul > li {position:relative; float:left; padding-right:35px; padding-left:35px; height:100px; z-index:1;}
#gnb > ul > li:last-child {padding-right:0;}
#gnb > ul > li > a {display:block; height:100px; line-height:100px; position:relative; font-size:20px; color:#242424; font-weight:500; z-index:5; letter-spacing:-0.03em;}
#gnb > ul > li:hover > a {color:#004f90;}
#gnb > ul > li:hover > a:before {position:absolute; content:""; left:50%; margin-left:-76.5px; bottom:0; width:153px; height:3px; background:#004f90;}
 

#header.header-hover {background:#fff;}
#header.header-hover .sitelogo a {background-image:url("../images/common/logo.png");}

#gnb .submenu {display:none; position:absolute; z-index:1; padding:0 30px; margin-top:-10px; left:50%; transform:translateX(-50%);}

#gnb .submenu ul {display:flex;}
#gnb .submenu ul:after {content:" "; display:block; clear:both;}
#gnb .submenu ul li {float:left; padding-top:20px; padding-right:30px; white-space:nowrap;}
#gnb .submenu ul li a {display:block; text-decoration:none; color:#505050; font-size:16px; line-height:40px; position:relative;} 
#gnb .submenu ul li.active a,
#gnb .submenu ul li:hover a {color:#004f90; text-decoration:underline;}
/* #gnb .submenu ul li.active a,
#gnb .submenu ul li:hover a:after {position:absolute; content:''; bottom:0; left:0; width:100%; height:1px; background-color:#004f90;}
 */
#gnb .m2 .submenu:before {left:50px;}
.submenu-bg {display:none; position:absolute; top:100px; left:0; width:100%; background:rgba(255, 255, 255, 0.89); border-top:1px solid #ddd; /* height:70px !important; */}


 /* main */ 
.main-visual {position:relative; overflow:hidden;}
.main-visual .item img {width:100%;}
.main-visual .caption {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100%; color:#fff; text-align:left; z-index:40;}
.main-visual .caption p {font-family: 'Montserrat', sans-serif; text-shadow:3px 0 5px rgba(0, 0 ,0 ,0.3); font-size:60px; font-weight:500; line-height:1.3em; letter-spacing:-.03em; padding-bottom:40px;}
.main-visual .caption h2 {font-family: 'NanumSquare'; font-weight:800; font-size:23px; line-height:1.3em; letter-spacing:-.03em;}
.main-visual .caption h3 {font-family: 'NanumSquare'; font-size:28px; line-height:1.571em; letter-spacing:-.03em;}
.main-visual .caption .bold {font-weight:500;}
.main-visual .slick-dots {max-width:1260px; text-align:center; padding-right:30px; margin:0 auto; margin-left:-180px; position:absolute; bottom:220px; left:0; width:100%; z-index:50; line-height:0; opacity:.8;}
.main-visual .slick-dots li {display:inline-block; margin:0 15px;}
.main-visual .slick-dots li button {display:block; width:15px; height:15px; background:transparent; border:4px solid #fff; border-radius:50%; overflow:hidden; text-indent:-9999px; border-radius:8px;}
.main-visual .slick-dots li.slick-active button {background:#fff; width:24px; height:24px; border-radius:50%; border:transparent; padding-top:8px;}
.main-visual .slick-arrow {width:21px; height:40px; border:none; overflow:hidden; text-indent:-999em; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; z-index:50; background-size:contain;}
.main-visual .slick-prev {background-image:url("../images/main/main-prev.png");}
.main-visual .slick-next {background-image:url("../images/main/main-next.png");}
.main-visual .btn-flex {display:flex; justify-content:space-between; align-items:center; margin-top:50px; max-width:260px;}
.main-visual .paging {font-weight:500;}
.main-visual .paging span {padding:0 5px;}
.main-visual span.current {font-size:20px; font-weight:700; letter-spacing:-.03em; line-height:1.200em; }


.visual-scroll {position:absolute; width:49px; height:64px; left:50%; animation:pulse 2s infinite; bottom:80px; margin-left:-24.5px;}
@-webkit-keyframes pulse {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  50% {
    -webkit-transform: translate(0, 10px);
            transform: translate(0, 10px); }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); } 
}

@keyframes pulse {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  50% {
    -webkit-transform: translate(0, 10px);
            transform: translate(0, 10px); }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); } 
}

.performance-list {justify-content:center; margin-bottom:-10px; flex-wrap:wrap; margin-bottom:40px;}
.performance-list ul {flex-wrap:wrap;}
.performance-list li {width:20%;}
.performance-list li.active a {color:#fff; font-weight:500; border:1px solid #004f90; background:#004f90;}
.performance-list li a {display:block; text-align:center; font-size:16px; color:#454545; letter-spacing:-.05em; height:49px; line-height:47px; border:1px solid #ddd; border-left:0;}
.performance-list li:nth-child(n+6) a {border-top:0;}
.performance-list li:nth-child(1) a,
.performance-list li:nth-child(6) a {border-left:1px solid #ddd;}
.performance-list li:first-child a {border-left:1px solid #ddd;}
.performance-list li:first-child.active a {color:#fff; font-weight:500; border:1px solid #004f90; background:#004f90;}

.main-tit {text-align:center; margin:100px 0 50px;}
.main-tit h3 {font-family: 'Montserrat', sans-serif; font-size:40px; color:#242424; font-weight:700; letter-spacing:-.03em; line-height:1.750em;}
.main-tit p {font-size:18px;}

.business-control {position:absolute; width:100%; max-width:1560px; right:0; bottom:0;}
.main-business {margin-bottom:100px;}
.main-business .slick-arrow {position:absolute; top:50%; margin-top:-42px; width:84px; height:84px; border:none; overflow:hidden; text-indent:-999em; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; z-index:50; background-size:contain;}
.main-business .slick-prev {left:-60px; background-image:url("../images/main/main-prevs.png");}
.main-business .slick-next {right:-60px; background-image:url("../images/main/main-nexts.png");}
.main-business .btn {display:block; margin:0 auto; margin-top:45px; text-align:center; width:180px; height:45px; line-height:43px; border-radius:25px; border:1px solid #ddd; color:#454545;}
.main-business .introduce .slick-list {margin:0 -8px;}
.main-business .introduce .slick-list .slick-slide {margin:0 8px;}
.main-business .introduce .img {position:relative; padding-bottom:100%; margin-bottom:12px; overflow:hidden;}
.main-business .introduce .img img {position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); -ms-transform:translate(-50%,-50%); -webkit-transform:translate(-50%,-50%); width:auto !important; height:auto !important; max-width:100%; max-height:100%; object-fit:contain;}


.main-thinking {background-size:cover; background-repeat:no-repeat; margin-bottom:170px;}
.main-thinking-flex {position:relative; display:flex; align-items:flex-end;}
.main-thinking-flex:before {position:absolute; content:""; bottom:-170px; left:0; width:100%; height:400px; z-index:-1; background:url("../images/main/thinking-bg.jpg")50% 50% no-repeat; background-size:cover;}
.main-thinking-flex .txt-box {width:53%; padding-left:60px;}
.main-thinking-flex .txt-box h4 {font-family: 'Montserrat', sans-serif; font-size:23px; font-weight:600; letter-spacing:-.05em; line-height:1.3em; color:#004f90;}
.main-thinking-flex .txt-box .lg-tit {font-family: 'NanumSquare'; font-size:40px; color:#242424; font-weight:800; letter-spacing:-.03em; line-height:1.250em; padding:10px 0 65px;}
.main-thinking-flex .txt-box .txt {font-family: 'NanumSquare'; color:#fff; font-size:18px; letter-spacing:-.03em; line-height:1.722em; margin-bottom:50px;}
.main-thinking-flex .txt-box .btn {display:block; width:180px; border-radius:25px; border:1px solid rgba(255, 255, 255, 0.3); text-align:center; color:#fff; text-align:center; height:45px; line-height:43px;}



.main-portfolio {padding: 100px 0 160px; overflow:hidden; background: no-repeat url("../images/main/bg_main_port.jpg") left bottom; background-size:100% 50%;}
.main-portfolio .contain {display: flex;}
.main-portfolio .main-tit {margin-right: 180px; text-align: left; margin-top:-30px;}
.main-portfolio .main-tit .btn {display:block; width:180px; border-radius:25px; border:1px solid rgba(255, 255, 255, 0.3); text-align:center; color:#fff; text-align:center; height:45px; line-height:43px; margin-top:80px;}
.main-portfolio .Port-Slider {margin-right: -50%; flex: 1 1 auto; min-width: 0; width: 1%; text-align: center; overflow:hidden;}
.main-portfolio .Port-Slider .items {}
.main-portfolio .Port-Slider .items .item {}
.main-portfolio .Port-Slider .items .item a {display: block;}
.main-portfolio .Port-Slider .thumb {position:relative; padding-bottom:64.74%; margin-bottom:12px; overflow:hidden;}
.main-portfolio .Port-Slider .thumb img {position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); -ms-transform:translate(-50%,-50%); -webkit-transform:translate(-50%,-50%); width:auto !important; height:auto !important; max-width:100%; max-height:100%; object-fit:cover;}
.main-portfolio .Port-Slider .thumb:after {content:""; position:absolute; top:0; left:0; right:0; bottom:0; border:1px solid rgba(0,0,0,.08);}
.main-portfolio .Port-Slider .tit  {color:#fff;}
.main-portfolio .Port-Slider .txt  {font-size:14px; color:#fff;}
.main-portfolio .Port-Slider .slick-list {overflow: visible; margin: 0 -15px;}
.main-portfolio .Port-Slider .slick-slide {width: 380px; margin: 0 15px;}

.main-portfolio .roll-btn {margin-top: 35px;}
.main-portfolio .slick-arrow {width:50px; height:50px; border:none; overflow:hidden; text-indent:-999em; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; z-index:50; background-size:contain;}
.main-portfolio .slick-prev {background-image:url("../images/main/port-prev.jpg"); margin-right: 16px;}
.main-portfolio .slick-next {background-image:url("../images/main/port-next.jpg");}

.main-contact {padding:100px 0;}
.main-contact ul {display:flex; margin-left:-30px;}
.main-contact ul li {position:relative; width:calc(50% - 30px); margin-left:30px;}
.main-contact ul li:hover .btn {background:#004f90; border:1px solid #004f90;}
.main-contact ul li .caption {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100%; color:#fff; text-align:center; z-index:40;}
.main-contact ul li .caption .tit {display:inline-block; position:relative; font-family: 'NanumSquare'; font-size:40px; font-weight:800; letter-spacing:-.03em; line-height:1.3em; padding-bottom:10px; margin-bottom:20px;}
.main-contact ul li .caption .tit:before {position:absolute; content:""; width:100%; height:20px; background:#f36d22; left:0; bottom:10px; z-index:-1;}
.main-contact ul li:last-child .caption .tit:before {background:#004f90;}
.main-contact ul li .caption .tit:after {position:absolute; content:""; width:50px; height:1px; left:50%; margin-left:-25px; background:#fff; bottom:0;}
.main-contact ul li .caption .txt {font-size:20px; letter-spacing:-.03em; font-weight:300; line-height:1.550em; margin-bottom:50px;}
.main-contact ul li .caption .btn {display:block; margin:0 auto; width:180px; border-radius:25px; border:1px solid rgba(255, 255, 255, 0.3); text-align:center; color:#fff; text-align:center; height:45px; line-height:43px;}



/* for mobile */
.btn-m-menu {position:absolute; top:50%; right:30px; margin-top:-12px; width:27px; height:24px; text-indent:-9999em; z-index:50;}
.btn-m-menu span {position:absolute; left:0; right:0; top:11px; height:2px; background:#242424;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; left:-5px; right:0; height:2px; background:#242424;}
.btn-m-menu span:before {top:-9px;}
.btn-m-menu span:after {bottom:-9px;}

.mobile-navigation {display:block; position:fixed; top:0; right:0; width:280px; height:100%; overflow:auto; transition:.2s linear; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:102;}
.mobile-navigation .home {padding:8px 20px;}
.mobile-navigation .home a {display:block;}
.mobile-navigation .home img {height:38px;}
.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:13px 20px; display:block; color:#242424; font-size:16px; font-weight:700; line-height:1.5em;}
.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 .nav-menu>ul>li.active>a {color:#004f90;}
.mobile-navigation .nav-menu>ul>li.active>a:after {transform:translateY(-35%) rotate(-135deg);}
.mobile-navigation .nav-menu .submenu {display:none; padding:10px 20px; background:#004f90; color:#fff; font-size:16px; line-height:1.5em;}
.mobile-navigation .nav-menu .submenu > ul >  li > a {display:block; padding:6px 0;}
.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:#242424; 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;}

/* sub */
.sub-visual {position:relative; display:table; table-layout:fixed; width:100%; height:300px; background-color:#fff; background-position:50% 50%; background-repeat:no-repeat; background-size:cover;}
.sub-visual .cell {display:table-cell; vertical-align:middle; width:100%; height:100%;}
.sub-visual .in {text-align:center;}
.sub-visual h3 {font-family: 'NanumSquare'; position:relative; font-size:40px; line-height:1.4em; color:#fff; letter-spacing:-.03em; font-weight:800; padding-bottom:15px;}
.sub-visual p {font-size:14px; line-height:1.3em; color:#fff; letter-spacing:0.8em;}
.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.bg6 {background-image:url("../images/common/sv6.jpg");}

#contArea {max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}
#contArea.wide {max-width:none;} 


.sub-title {text-align:center;}
.sub-title.pb {padding-bottom:0;}
.sub-title h2 {position:relative; font-family: 'NanumSquare'; color:#2c2c2c; font-size:30px; padding-bottom:20px; font-weight:700; line-height:1.3em; letter-spacing:-.04em;}
.sub-title h2:before {position:absolute; content:""; background:#004f90; width:50px; height:3px; left:50%; bottom:0; margin-left:-25px;}


.real-cont {padding-bottom:100px;}
.real-cont.pb0 {padding-bottom:0;}

/* lnb */

.lnb {margin-top:0; position:relative; z-index:2; margin-top:-40px;}
.lnb ul {display:flex; max-width:1200px; margin:0 auto;}
.lnb ul li {flex:1; position:relative; font-size:20px; font-weight:700; text-align:center; line-height:1.4em; letter-spacing:-.04em;}
.lnb ul li a {position:relative; display:flex; align-items:center; justify-content:center; height:80px; line-height:78px; padding:0 15px; color:rgba(255, 255, 255, 0.3); font-weight:500; background:#333;} 
.lnb ul li a:before {position:absolute; content:""; width:1px; height:20px; background:rgba(255, 255, 255, 0.34); top:50%; margin-top:-10px; right:0;}
.lnb ul li:last-child a:before {display:none;}
.lnb ul li.active a {color:#fff; background:#333333;}


/* footer */
#footer {padding:20px 0 50px; position:relative; background:#333333; line-height:28px; border-top:2px solid #004f90; color:#fff;}
#footer .contain {max-width:1260px; color:#cccbcb; font-size:15px; letter-spacing:-.03em; line-height:1.600em; align-items:center; text-align:center;}
#footer address {font-style:normal; font-weight:300; line-height:1.714em;}
#footer .foot_logo {font-size:18px; padding-bottom:15px; color:#2c2c2c; font-weight:500;}
.link-wrap {border-bottom:1px solid #666666;}
.foot-logo {order:1; padding:40px 0 30px;}
.foot-info .foot-link {display:inline-block; font-weight:400;}
.foot-info {text-align:center; font-size:15px; order:1; flex:1;}
.foot-info .foot-links {margin:0 auto; margin-bottom:10px;}
.foot-info .foot-link a {display:block; font-size:14px; color:#878787;}
.foot-info span {display:inline-block; padding-right:15px;}
.foot-info .bottom {padding-top:10px;}
.foot-info .foot-after {padding-right:25px; font-size:15px; letter-spacing:-.03em; line-height:1.600em;}
.foot-links {order:3; border-bottom:1px solid rgba(255, 255, 255, 0.6);}
.foot-links ul {display:flex; justify-content:center; padding-bottom:20px;}
.foot-links ul li {font-size:16px; position:relative; padding:0 15px;}
.foot-links ul li a {position:relative;}
.foot-links ul li:before {position:absolute; content:""; width:1px; height:16px; background:#adadad; top:50%; margin-top:-8px; left:0;}
.foot-links ul li:first-child:before {display:none;}
.foot-links .name {font-size:17px; font-weight:500; padding-right:33px;}
.go-top {position:fixed; right:100px; bottom:100px; z-index:1;}

/* quick */
.quick {position:fixed; bottom:0; right:50px; width:125px; text-align:center; z-index:90;}
.quick ul {border-radius:10px; border:1px solid transparent;}
.quick ul li .ico {display:block; margin:0 auto; width:45px; height:45px; background:url("../images/main/main-link2.png")50% 50% no-repeat; background-size:contain; margin-bottom:15px;}
.quick ul li:first-child {border-radius:10px 10px 0 0;}
.quick ul li:last-child {border-radius:0 0 10px 10px;}
.quick ul li a {display:block; font-size:16px; font-weight:500; color:#454545; line-height:1.3em; letter-spacing:-.03em;}
.quick ul li img {display:block; margin:0 auto 15px;}