@charset "utf-8";
/* layout.css는 전체적인 레이아웃 스타일을 정의합니다. */

.only-desktop {display:block;}
.only-tablet {display:none;}
.only-mobile {display:none;}
.only-desktop-tablet {display:block;}

#wrapper {position:relative; overflow:hidden;}

#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 {position:relative; width:100%; max-width:1260px; padding-left:30px;padding-right:30px; margin:0 auto;}
.contain:after {content:" "; display:block; clear:both;}


/* header */
#header {position:relative; width:100%; left:0; top:0; background:#fff; z-index:2; transition:all 0.2s ease;}
#header .contain {position:relative; height:80px;}
#header .sitelogo {position:absolute; top:50%;  margin-top:-20.5px; left:30px; z-index:10}
#header .sitelogo a {display:block;}

#main #header {position:fixed;}


#gnb {position:absolute; top:0; right:30px; left: 50%; transform: translateX(-50%); z-index:20;}
#gnb > ul {display:flex; justify-content: center;}
#gnb > ul > li {position:relative; padding:0 90px; text-align:center;}
#gnb > ul > li > a {display:block; position:relative; color:#242424; font-size:18px; font-weight:700; line-height:80px; letter-spacing:-.04em; transition:all 0.2s ease;}
#gnb > ul > li.active a {color:#21409a;}

#gnb.type2 > ul > li {padding:0 60px;}
#gnb.type2 > ul > li.now > a {color:#21409a;}

#gnb .submenu {height:0; position:absolute; left:0; width:100%; z-index:102; overflow:hidden;}
#gnb .submenu ul {padding:18px 0;}
#gnb .submenu ul li {padding:5px 0;}
#gnb .submenu ul li a {display:inline-block; vertical-align:middle; position:relative; padding:3px 0;  color:#808080; font-size:16px; font-weight:400; line-height:1.4em; letter-spacing:-.03em;}
#gnb .submenu ul li a:hover {color:#fff;}


#header .submenu-bg {display:none; position:absolute; left:0; width:100%; background:rgba(0,0,0,0.5);}

.util {position:absolute; right:30px; top:50%; margin-top:-20px;}
.util a {display:block; position:relative; border-radius:30px; background:#21409a; padding:0 30px; font-weight:400; font-size:18px; color:#fff; letter-spacing:-0.04em; line-height:40px; transition:all 0.2s ease; }


/* for mobile */
.btn-m-menu {display:none;position:absolute; top:50%; margin-top:-12px ; right:30px; width:20px; width:30px; height:24px; text-align:center; text-indent:-9999em; z-index:92; transition: all 0.5s ease-in-out;}
.btn-m-menu span {position:absolute; left:0; top:13px; height:2px; width:30px;background:#000;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; right:0; width:30px; height:2px; background:#000; transition-duration:0.3s, 0.3s; transition-delay:0.3s, 0s;}
.btn-m-menu span:before {top:-10px; transition-property:top, transform;}
.btn-m-menu span:after {bottom:-10px; transition-property:bottom, transform;}

.home img {height:40px; width:auto;}

.mobile-navigation {position:fixed; top:0; right:0; padding:20px 0; width:300px; height:100%; overflow:auto; transition:.3s ease-in-out; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:202;}
.mobile-navigation .home {margin-bottom:20px; padding-left:15px; font-size:20px; color:#2c2c2c; line-height:1.4em; font-weight:700;}
.mobile-navigation .nav-menu>ul>li {border-bottom:1px solid #dfdfdf;}
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:12px 15px; display:block; color:#2c2c2c; font-size:18px; font-weight:700; line-height:1.3em;}
.mobile-navigation .nav-menu>ul>li.active>a {color:#2c2c2c;}
.mobile-navigation .nav-menu>ul>li.active>a:after {transform:translateY(-35%) rotate(-135deg); border-color:#21409a;}
.mobile-navigation .nav-menu .submenu { margin:-1px 0 0 0; padding:0 15px 15px; background:#21409a;}
.mobile-navigation .nav-menu .submenu>ul {padding-top:10px;}
.mobile-navigation .nav-menu .submenu>ul:after {content:"";display:block;clear:both;}
.mobile-navigation .nav-menu .submenu>ul>li>a {display:block; position:relative; padding:5px 15px; color:#fff; font-size:16px; font-weight:400; line-height:1.3em;}
.mobile-navigation .nav-menu .submenu>ul>li>a:after {content:"";position:absolute; top:12px; left:5px; width:4px; height:4px; background:#dfdfdf; border-radius:50%; transition:.3s ease-in-out;}
.mobile-navigation .nav-menu .submenu>ul>li>a:hover{color:#fff}
.mobile-navigation .nav-menu .submenu>ul>li>a:hover:after {background:#fff}
.mobile-navigation .close {position:absolute; top:20px; right:15px; 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:20;}

html.menu-opened {overflow:hidden;}
html.menu-opened .mobile-navigation {-ms-transform:translateX(0); transform:translateX(0); }
html.menu-opened .mobile-overlay {display:block;}

/*mini*/

.direct-link {position:absolute; display:flex; bottom:65px; left:0; width:100%; max-width:1200px; left:50%; transform:translateX(-50%);}
.direct-link a { position:relative; display:flex; justify-content: space-between; width:33.333%; margin:0 10px; background:rgba(25,48,114,0.8); border-radius:17px 0 17px 0; padding:25px 30px; font-family:'Noto Sans KR';  font-size:21px; font-weight:500; line-height:1.4em; letter-spacing:-0.03em; color:#fff;}
.direct-link a span {display:block; padding-right:22px; font-size:15px; font-weight:400; color:#ccc;}
.direct-link a:before {content:""; position:absolute; width:11px; height:20px; background-image:url("../images/main/direct_icon.png"); background-repeat: no-repeat; background-position: 50% 50%; background-size:contain; right:20px; top:50%; margin-top:-10px;}
.direct-link a:hover span {color:#fff;}
.direct-link a:hover::before {background-image:url("../images/main/direct_icon_on.png");}

/* main */ 
#fp-nav {left:100px !important;}
#fp-nav ul li a.active span,
.fp-slidesNav ul li a.active span {width:16px !important; height:16px !important; background:#fff !important; border:0 !important;} 

#fp-nav ul li:first-child {display:none;}
#fp-nav ul li:last-child {display:none;}
#fp-nav ul li a span, .fp-slidesNav ul li a span {background:0 !important; border:2px solid #fff !important; width:16px !important; height:16px !important; }
#fp-nav ul li, .fp-slidesNav ul li {margin:10px 0 !important;}
/*#fp-nav ul li .fp-tooltip {top:0 !important;}*/
.main-visual .vis {background-size:cover; background-position:50% 50%; background-repeat:no-repeat; height:100vh; width:100%;}



.fp-viewing-Intro .fp-tableCell {vertical-align:top;}
.fp-viewing-Intro #fp-nav {display:none;}

.main-visual .item {background-size:cover; background-position:50% 50%; background-repeat:no-repeat; height:100vh; width:100%;}

 .main-visual .contain {height:100%; width:100%; display:flex; align-items: center; justify-content: center; text-align:center;}
.main-visual .cont {color:#fff;}
.main-visual .cont .img img{margin:35px auto 0 auto;}
.main-visual .cont p {font-size:36px; font-weight:200; line-height:1.7em; letter-spacing:-0.03em;}

.main-visual .cont .p1 {transform:translateY(50px); opacity:0; transition:1.5s 0.5s all ease;}
.main-visual .cont .p2 {transform:translateY(50px); opacity:0; transition:1.5s 1.5s all ease;}
.main-visual .cont .img {transform:translateY(50px); opacity:0; transition:1.5s 2s all ease;}

.main-visual .slick-slide.slick-active p {transform:translateY(0); opacity:1;}
.main-visual .slick-slide.slick-active .img {transform:translateY(0); opacity:1;}
.main-visual .slick-arrow {position:absolute; top:50%; margin-top:-34px; z-index:1; width:35px; height:68px; background:0; border:0; text-indent:-999em; overflow:hidden; background-size:contain; background-position:50% 50%; background-repeat:no-repeat;}
.main-visual .slick-prev {background-image:url("../images/main/slide_prev.png"); left:120px;}
.main-visual .slick-next {background-image:url("../images/main/slide_next.png"); right:120px;}
.main-visual .scroll {position:absolute; bottom:37px; left:50%; margin-left:-15.5px; text-align:center; z-index:50; animation:move_up_down 2s linear infinite;}
.main-visual .scroll span {display:block;font-size:15px; font-weight:400; letter-spacing:-0.03em; line-height:1em; color:#ccc; margin-bottom:20px;}
.main-visual .mv1 {background-image:url("../images/main/mv1.jpg");}



@keyframes move_up_down {
  0%,100%{
    transform:translateY(0);
  }
  50% {
    transform:translateY(15px);
  }
}

.sec1 {background:url("../images/main/sec1.jpg") no-repeat 50% 50%; background-size:cover;}
.main-tit {position:relative; padding-bottom:25px; margin-bottom:50px; text-align:center;}
.main-tit:before {content:""; position:absolute; width:80px; height:1px; background:#a5a6a6; bottom:0; left:50%; margin-left:-40px;}
.main-tit span {display:block; font-size:16px; font-weight:400; line-height:1.2em; letter-spacing:0.8em; color:#bbb; margin-bottom:5px;}
.main-tit h3 {font-size:32px; font-weight:700; line-height:1.2em; letter-spacing:-0.03em; color:#fff;}
.sec1 .cont-menu ul {display:flex; flex-wrap:wrap; margin:0 -10px -15px -10px;}
.sec1 .cont-menu ul li {width:25%; padding:0 10px; text-align:center; margin-bottom:15px; transition:0.5s all ease-in-out; opacity:0; transform:translateY(30px);}
.sec1.active .cont-menu ul li {opacity:1; transform:translateY(0);}
.sec1.active .cont-menu ul li:nth-child(1) {transition-delay:0.1s}
.sec1.active .cont-menu ul li:nth-child(2) {transition-delay:0.3s}
.sec1.active .cont-menu ul li:nth-child(3) {transition-delay:0.5s}
.sec1.active .cont-menu ul li:nth-child(4) {transition-delay:0.7s}
.sec1.active .cont-menu ul li:nth-child(5) {transition-delay:0.9s}
.sec1.active .cont-menu ul li:nth-child(6) {transition-delay:1.1s}
.sec1.active .cont-menu ul li:nth-child(7) {transition-delay:1.3s}
.sec1.active .cont-menu ul li:nth-child(8) {transition-delay:1.5s}


.sec1 .cont-menu ul li:hover a:before {content:""; position:absolute; width:100%; height:100%; left:0; top:0; border:2px solid #797676;}
.sec1 .cont-menu ul li:hover .tit {color:#fff;}
.sec1 .cont-menu ul li a {position:relative; display:flex; flex-direction: column; align-items: center; justify-content: center; min-height:222px; background:rgba(20, 41, 101, 0.4); padding:20px;}
.sec1 .cont-menu .tit { font-size:22px; font-weight:400; letter-spacing:-0.03em; line-height:1.3em; color:#ccc; margin-top:35px;}

.sec2 {background:url("../images/main/sec2.jpg") no-repeat 50% 50%; background-size:cover;}
.sec2 .contain {max-width:1390px; padding-left:95px; padding-right:95px;}
.sec2 .main-tit h3 {font-weight:200;}
.sec2 .main-tit h3 strong {font-weight:700;}
.sec2 .items {margin:0 -15px; transform:translateY(30px); opacity:0; transition:0.6s ease-in-out;}
.sec2.active .items {transform:translateY(0); opacity:1; transition-delay:0.4s}
.sec2 .item {padding:0 15px;}
.sec2 .item a {display:block;}
.sec2 .thumb {position:relative; padding-bottom:75.45%; overflow:hidden;}
.sec2 .thumb img {position:absolute; top:50%; left:0; transition:.4s ease-in-out; transform:translateY(-50%) scale(1); -ms-transform:translateY(-50%) scale(1); -webkit-transform:translateY(-50%) scale(1); width:100%; height:auto !important; max-width:100%; min-height:100%; object-fit:cover;}
.sec2 .item a:hover img {transform:translateY(-50%) scale(1.09); -ms-transform:translateY(-50%) scale(1.09); -webkit-transform:translateY(-50%) scale(1.09);}
.sec2 .thumb .case-cate {position:absolute; display:block; text-align:center; top:20px; left:20px; font-family:'Noto Sans KR';  font-size:14px; font-weight:400; color:#fff; background:#555; min-width:50px; padding:2px 5px;}
.sec2 .cnt {background:#fff; padding:15px 18px; min-height:180px;}
.sec2 .cnt .tit { font-size:18px; font-weight:700; line-height:1.3em; letter-spacing:-0.03em; color:#454545; margin-bottom:10px;} 
.sec2 .cnt .txt {font-family:'Noto Sans KR'; font-size:16px; font-weight:400; line-height:1.5em; letter-spacing:-0.03em; color:#454545; margin-bottom:25px; overflow: hidden;  text-overflow: ellipsis; word-break: break-all; white-space: normal; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;}
.sec2 .cnt .date {font-family:'Noto Sans KR'; font-size:14px; font-weight:400; line-height:1.2em; letter-spacing:-0.03em; color:#686868;}
.sec2 .items .slick-arrow {position:absolute; top:50%; margin-top:-21.5px; z-index:1; width:43px; height:43px; border-radius:100%; background:#fff; text-indent:-999em; overflow:hidden; border:0; background-repeat:no-repeat; background-position:50% 50%;}
.sec2 .items .slick-prev {left:-93px; background-image:url("../images/main/case_prev.png");}
.sec2 .items .slick-next {right:-93px; background-image:url("../images/main/case_next.png");}

.sec3 {position:relative; background:url("../images/main/sec3.jpg") no-repeat 50% 50%; background-size:cover;}
.sec3:before {content:""; position:absolute; left:0; top:0; width:35%; height:100%; background:#142965 url("../images/main/col_icon.gif") no-repeat bottom left;}

.sec3 .column {display:flex;}
.sec3 .column .cont-tit {position:relative; display:flex; flex-direction: column; justify-content: space-between; width:25.83%; max-width:310px;}
.sec3 .column .cont-tit h3 {font-size:32px; font-weight:700; line-height:1em; letter-spacing:-0.03em; color:#fff;}
.sec3 .column .cont-tit h3 span {display:block;font-size:16px; line-height:1.5em; font-weight:400; margin-top:13px;}
.sec3 .column-ctrl .paging {font-size:16px; font-weight:700; letter-spacing:-0.03em; color:#ccc; margin-bottom:40px;}
.sec3 .column-ctrl .paging .current {font-size:19px; color:#fff;}

.sec3 .column-ctrl .arrow {display:flex; position:relative; padding-bottom:33px;}
.sec3 .slick-arrow {display:block; width:27px; height:9px; border:0; background:0; text-indent:-999em; overflow:hidden;  background-position:50% 50%; background-repeat:no-repeat;}
.sec3 .slick-prev {position:relative; background-image:url("../images/main/paging_prev.png"); margin-right:44px;}
.sec3 .column-ctrl .arrow:before {content:""; position:absolute; width:2px; height:14px; background:#fff; opacity:0.3; left:49px; top:0px;}
.sec3 .slick-next {background-image:url("../images/main/paging_next.png");}

.sec3 .cont {width:74.16%; max-width:890px;}
.sec3 .cont .item ul {display:flex; flex-wrap:wrap; margin:0 -10px -20px -10px;}
.sec3 .cont .item ul li {width:33.333%; padding:0 10px; margin-bottom:20px;}
.sec3 .cont .item a {display:block;}
.sec3 .cont .item .tit {overflow: hidden; text-overflow: ellipsis; word-break: break-all; white-space: normal; display: -webkit-box; -webkit-line-clamp:1; -webkit-box-orient: vertical;}
.sec3 .cont .item .thumb {position:relative; padding-bottom:64.79%; overflow:hidden; margin-bottom:10px;}
.sec3 .cont .item .thumb img {position:absolute; top:50%; left:0; transition:.4s ease-in-out; transform:translateY(-50%) scale(1); -ms-transform:translateY(-50%) scale(1); -webkit-transform:translateY(-50%) scale(1); width:100%; height:auto !important; max-width:100%; min-height:100%; object-fit:cover;}
.sec3 .cont .item a:hover img {transform:translateY(-50%) scale(1.09); -ms-transform:translateY(-50%) scale(1.09); -webkit-transform:translateY(-50%) scale(1.09);}

.sec3 .cont .item .tit {font-size:16px; font-weight:400; line-height:1.4em; letter-spacing:-0.03em; color:#ccc; transition:0.2s all ease-in;}
.sec3 .cont .item a:hover .tit {color:#fff;}

.sec4 {background:url("../images/main/sec4.jpg") no-repeat 50% 50%; background-size:cover;}
.sec4 .main-contact {display:flex;}
.sec4 .main-contact .cont-tit {position:relative; display:flex; flex-direction: column; justify-content: space-between; width:25.83%; max-width:310px;}
.sec4 .main-contact .cont-tit h3 {font-size:32px; font-weight:700; line-height:1em; letter-spacing:-0.03em; color:#fff;}
.sec4 .main-contact .cont-tit h3 span {display:block; font-size:16px; line-height:1.5em; font-weight:400; margin-top:13px;}
.sec4 .cont {flex: 1 1 auto; min-width: 0; width: 1%; background:#fff; padding:50px;}
.sec4 .cont table {border-collapse:collapse; width:100%;}
.sec4 .cont table th {text-align:left; padding:8px 0; vertical-align:top; font-size:17px; font-weight:400; letter-spacing:-0.03em; line-height:44px; color:#454545;}
.sec4 .cont table td {padding:8px 0;}
.sec4 .buttons {margin:22px 0 0 0;}
.sec4 .btn-pack {font-size:16px;}

/* sub page */
.sub-visual {position:relative; width:100%; height:350px; padding-bottom:70px; display:flex; align-items:center; overflow:hidden; background-repeat:no-repeat; background-position:50% 50%; background-size:cover;}
.sub-visual .content {color:#fff; text-align:center; width:100%;}
.sub-visual .content h2 {font-size:36px;line-height:1em; font-weight:700; letter-spacing:-.40px;}


.sv1 {background-image:url("../images/common/sv1.jpg");}
.sv2 {background-image:url("../images/common/sv2.jpg");}
.sv3 {background-image:url("../images/common/sv3.jpg");}
.sv4 {background-image:url("../images/common/sv4.jpg");}

.sub-title {margin:80px 0 60px; text-align:center;}
.sub-title h2 {font-family:'Noto Sans KR';position:relative; color:#242424; font-size:38px; line-height:1.6em; font-weight:500;letter-spacing:-.40px; padding-bottom:12px;}
.sub-title h2:before {content:""; position:absolute; width:50px; height:2px; background:#21409a; left:50%; margin-left:-25px; bottom:0;}


#lnb {border-top:1px solid rgba(255,255,255,0.3); position:relative; margin-top:-70px}
#lnb .swiper-container {overflow:visible;}
.lnb {max-width:1200px; margin:0 auto;}
.lnb ul {display:flex; justify-content: center;}
.lnb ul li {position:relative; width:auto; text-align:center; letter-spacing:-.04em;}
.lnb ul li:first-child:after {display:none}
.lnb ul li a {position:relative; display:flex; align-items:center; justify-content:center; height:70px; font-weight:700; color:#aaa; font-size:17px; line-height:1.4em; padding:0 40px; }
.lnb ul li.active a:after {content:""; position:absolute; width:100%; height:2px; background:#21409a; top:-1px; left:0;}
.lnb ul li a:hover {color:#fff;}
.lnb ul li.active a {color:#fff;}

.real-cont {padding-bottom:120px;}
.real-cont.none {padding-bottom:0;}



/* footer */
.fp-viewing-5 #fp-nav {display:none;}

#footer {width:100%; bottom:0; background:#1a1a1a; color:#b3b3b3; font-size:14px; line-height:1.7em;}
#footer address {font-style:normal; font-weight:400; line-height:2em;}
.f-menu {padding:18px 0; border-bottom:1px solid rgba(255,255,255,0.3);}
.f-menu ul {display:flex;}
.f-menu li {font-size:14px; font-weight:400; line-height:1.3em; letter-spacing:-0.03em; color:#b3b3b3;}
.f-menu li:first-child {margin-right:38px;}

.f-info {display:flex;justify-content: space-between; align-items: center; flex-direction: row-reverse; padding:15px 0 25px 0;}
.f-info strong {display:block;}
.f-info span {display:inline-block;}
.f-info .bar {vertical-align: middle; height:14px; width:2px; background:#b3b3b3; margin:0 20px;}
.f-logos img {display:inline-block;}
.f-logos img:first-child {margin-right:30px;}

/*quick menu*/
.quickmenu {position:absolute; z-index:999; right:0; background:#fff;}
.quickmenu li {border-bottom:1px solid #ddd; border-left:1px solid #ddd;}
.quickmenu li:first-child {border-bottom:0; border-left:1px solid #21409a; background:#21409a;}
.quickmenu li:first-child a {color:#fff;}
.quickmenu li:last-child {background:#1a1a1a; border-left:1px solid #1a1a1a; border-bottom:0;}
.quickmenu li:last-child a {color:#fff; padding-top:30px;}
.quickmenu li a {display:block; padding:15px 5px; text-align:center; font-size:14px; font-weight:400; line-height:1em; letter-spacing:-0.03em;}
.quickmenu li a .icon {margin-bottom:10px;}
.scroll-top .top {position:relative;}
.scroll-top .top:after {content:""; position: absolute; width:15px; height:15px; top:-14px; left:50%; margin-left:-8.5px; border-top:1px solid #fff; border-right:1px solid #fff; transform: rotate(-45deg);}
.scroll-top.active {transition: all .3s ease;}