@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:1460px; padding-left:30px;padding-right:30px; margin:0 auto;}
.contain:after {content:" "; display:block; clear:both;}


/* header */
#header  {position:absolute; z-index:90; left:0; top:0; width:100%; transition:0.2s all ease;}
#header .contain{position:relative; max-width:1780px; padding-left:30px; padding-right:30px;}
.sitelogo {position:absolute; left:30px; top:50%; margin-top:-28.5px; z-index:10;}
.sitelogo a {display:block;}

#header.header-hover {background:#fff;}
#header.header-hover #gnb > ul > li > a  {color:#1e1e1e;}
#header.header-hover .language ul li a {color:#4f4f4f;}
#header.header-hover .language ul li.on a {color:#fff;}

#gnb  {padding-right:160px;}
#gnb > ul {position:relative; display:flex; justify-content: flex-end; height: 100px; align-items: flex-end; margin-right:-60px;}
#gnb > ul > li {position:relative;text-align:center;}
#gnb > ul > li > a {display:flex; font-size:20px; font-weight:600; line-height:1.4em; letter-spacing:-0.03em; color:#fff; padding:0 60px;align-items: center; justify-content: center; height:100px;}
#gnb > ul > li.active > a {color:#324997;}

#gnb .submenu {position:absolute; display:none; left:50%; width:150px; transform:translateX(-50%); text-align:center; z-index:21; background:#2a3e80;}
#gnb .submenu ul {padding:23px 0;}
#gnb .submenu ul li {line-height:1.4em; transition:0.2s all ease;}
#gnb .submenu ul li a {position:relative; display:block; font-size:16px; font-weight:400; padding:7px 0;  color:#fff; line-height:1.2em; transition:0.2s all ease;}
#gnb .submenu ul li:hover {}
#gnb .submenu ul li:hover a {color:#ffd800;} 

.language {position:absolute; right:30px; top:50%; transform:translateY(-50%);}
.language ul {display:flex; align-items:center;}
.language ul li {position:relative; padding:0 14px;}
.language ul li:before {content:""; position:absolute; right:0; width:1px; height:20px; top:50%; margin-top:-10px; background:#dfdfdf;}
.language ul li:last-child:before {display:none;}
.language ul li a {display:block; font-family:'Montserrat'; font-size:11px; font-weight:700; line-height:1.2em; letter-spacing:0; color:#bdbdbd;}
.language ul li.on a {width:32px; height:32px; border-radius:100%; text-align:center; background:#324997; color:#fff; line-height:32px;}

.m-lang  {display:none;}
.m-lang ul {display:flex;}
.m-lang ul li {flex:1; border:1px solid #ddd; border-right:0;}
.m-lang ul li:first-child {border-left:0;}
.m-lang ul li.on a {background:#122780; color:#fff;}
.m-lang ul li a {display:flex; text-align:center; align-items: center; justify-content: center; min-height:40px; font-size:15px; font-weight:400; line-height:1.2em; letter-spacing:-0.03em; color:#454545;}



/* for mobile */
.btn-m-menu {display:none; position:absolute; top:50%; margin-top:-12px; right:30px; width:27px; 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:3px; width:27px;background:#fff;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; right:0; width:27px; height:3px; background:#fff; 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;}

.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:#ffffff; z-index:101;}
.mobile-navigation .home {padding-bottom:20px; padding-left:15px;}
.mobile-navigation .home img {height:34px; width:auto;}
.mobile-navigation .nav-menu>ul>li {border-bottom:1px solid #ddd;}
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:14px 15px; display:block; color:#242424; font-size:1.3em; font-weight:500; line-height:1.3em;}
.mobile-navigation .nav-menu>ul>li.active>a {color:#122780;}
.mobile-navigation .nav-menu>ul>li>a:after {content:""; position:absolute; top:50%; right:15px; transform:translateY(-75%) rotate(45deg); width:10px; height:10px; border-right:2px solid #122780; border-bottom:2px solid #122780;}
.mobile-navigation .nav-menu>ul>li.active>a:after{transform: translateY(-35%) rotate(-135deg); border-color: #122780;}
.mobile-navigation .nav-menu .submenu {display:none; position:static; transform: translateX(0); margin:-1px 0 0 0; width:100%;  padding:10px 0;background:#122780; padding-bottom:10px;}
.mobile-navigation .nav-menu .submenu>ul {display:block; width:100%;}
.mobile-navigation .nav-menu .submenu>ul>li {text-align:left; padding:0;}
.mobile-navigation .nav-menu .submenu>ul>li>a {display:block; position:relative; padding:5px 0 5px 25px; 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:14px; left:15px; width:4px; height:4px; border-radius:100%; background:#fff; transition:.2s 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:18px; width:24px; height:24px; text-indent:-9999em; overflow:hidden;}
.mobile-navigation .close:before,
.mobile-navigation .close:after {content:" "; position:absolute; top:12px; left:0; width:100%; height:2px; background:#242424;}
.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:.76; z-index:98;} 

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 */ 
#fp-nav {right:50px !important; transform:translate(0) !important;}
#fp-nav ul li a span, .fp-slidesNav ul li a span {color:#818181 !important; right:auto !important;}
#fp-nav ul li, .fp-slidesNav ul li {display:block !important; line-height:25px !important; height:auto !important; margin:0 !important;}
#fp-nav ul li a.active span {background:#187ad4 !important;}
#fp-nav ul li a.active span:before {content:""; position:absolute; width:21px; height:21px; left:-5.8px; top:-5.3px; border:1px solid #187ad4; border-radius:100%;}
.main-visual {position:relative;}
.main-visual .mv {height:100vh; background-repeat:no-repeat; background-size:cover; background-position:50% 50%; display:flex !important; align-items: center; justify-content: center;}
.main-visual .contain {max-width:1780px; text-align:right; color:#fff;}

.main-visual .mv .tt {font-size:24px; font-family:'Acumin'; font-weight:400; letter-spacing:0.5em; line-height:1.2em; margin-bottom:35px; margin-right:-2px; position:relative; opacity:0; transform:translateY(50px); transition:1s 1s all ease-in-out;}
.main-visual .mv .tx {font-size:38px; font-weight:400; line-height:1.3em; letter-spacing:-0.01em; opacity:0;  transform:translateY(50px); transition:1s 2s all ease-in-out;}

.main-visual .reset-animation .tt  {opacity:0;   transform:translateY(50px); transition:1s 1s all ease-in-out;}
.main-visual .reset-animation .tx {opacity:0;  transform:translateY(50px); transition:1s 2s all ease-in-out;}

.main-visual .slick-active .tt {opacity:1 !important; transform:translateY(0);}
.main-visual.active2 .slick-active .tt {opacity:1 !important; transform:translateY(0);}

.main-visual .slick-active .tx {opacity:1 !important; transform:translateY(0);}
.main-visual.active2 .slick-active .tx {opacity:1 !important; transform:translateY(0);}

.main-visual .mv .tx strong {font-weight:700;}
.main-visual .slick-dots {position:absolute; bottom:25px; display:flex;justify-content: center; width:100%;}
.main-visual .slick-dots li {padding:0 4px;}
.main-visual .slick-dots li button {width:11px; height:11px; background:#b4b4b4; border-radius:100%; display:block; border:0; text-indent:-999em; overflow:hidden;}
.main-visual .slick-dots li.slick-active button {background:#95cbff;}
.main-visual .slick-arrow {position:absolute; z-index:1; top:50%; width:49px; height:49px; margin-top:-24.5px; background-position:50% 50%; background-size:contain; background-repeat:no-repeat; border:0; text-indent:-999em; overflow:hidden; background-color:transparent;}
.main-visual .slick-prev {left:100px; background-image:url("../images/main/mv_prev.png")}
.main-visual .slick-next {right:100px; background-image:url("../images/main/mv_next.png")}

.main-business ul {display:flex;}
.main-business ul li {flex:1;}
.main-business ul li a {position:relative; display:flex; height:100vh; color:#fff; background-repeat:no-repeat; background-size:cover; background-position:50% 50%; text-align:center;flex-direction:column; align-items:center; padding-top:40vh;}
.main-business ul li a:before {content:""; position:absolute; width:23px; height:22px; background:url("../images/main/main_more.png") no-repeat 50% 50%; left:50%; margin-left:-11.5px; bottom:30vh;}
.main-business ul li .tit {font-size:32px; font-weight:600; line-height:1.2em; letter-spacing:-0.01em; margin-bottom:30px; padding-bottom:10px; position:relative;}
.main-business ul li .tit:before {content:""; position:absolute; width:20px; height:2px; background:#fff; left:50%; margin-left:-10px; bottom:0;}
.main-business ul li .txt {font-size:18px; font-weight:400; line-height:1.5em; letter-spacing:-0.01em; color:#fff;}
.main-business ul li:nth-child(1) a {background-image:url("../images/main/biz1.jpg")}
.main-business ul li:nth-child(2) a {background-image:url("../images/main/biz2.jpg")}
.main-business ul li:nth-child(3) a {background-image:url("../images/main/biz3.jpg")}
.main-business ul li:nth-child(4) a {background-image:url("../images/main/biz4.jpg")}
.main-business ul li:nth-child(1):hover a {background-image:url("../images/main/biz1_2.jpg")}
.main-business ul li:nth-child(2):hover a {background-image:url("../images/main/biz2_2.jpg")}
.main-business ul li:nth-child(3):hover a {background-image:url("../images/main/biz3_2.jpg")}
.main-business ul li:nth-child(4):hover a {background-image:url("../images/main/biz4_2.jpg")}

.main-about {background:url("../images/main/about_1.jpg") no-repeat 50% 50%; background-size:cover;}
.main-about a {width:100vw; height:100vh; display: flex; align-items: center;}
.main-about .contain {color:#fff;}
.main-about p {transform:translateY(100px); opacity:0; transition:1s all ease-in-out;}
.main-about p.deco {font-family:'Acumin'; font-size:24px; font-weight:400; letter-spacing:0.5em; line-height:1.2em; margin-bottom:30px; transition-delay:0.3s;}
.main-about .tit {font-size:38px; font-weight:400; line-height:1.3em; letter-spacing:-0.01em; margin-bottom:15px;  transition-delay:0.8s;}
.main-about .tit strong {font-weight:700;}
.main-about .small {font-size:18px; font-weight:400; line-height:1.2em; letter-spacing:-0.01em;  transition-delay:1s;}

.main-about p.active {opacity:1; transform:translate(0);}

.outro {background:url("../images/main/out_1.jpg") no-repeat 50% 50%; background-size:cover;}
.outro .fp-tableCell {vertical-align:bottom;}
.outro .cnt {padding-bottom:17vh; text-align:center;}
.outro .cnt .main-tit {font-size:38px; font-weight:700; line-height:1.3em; letter-spacing:-0.01em; color:#fff; margin-bottom:5px;}
.outro .cnt .sub-txt {font-size:18px; font-weight:400; line-height:1.2em; letter-spacing:-0.01em; color:#fff;}
.outro .cnt ul {display:flex; justify-content: center; margin:0 -40px;}
.outro .cnt ul li {width:33.333%; max-width:300px; margin-top:80px; padding:0 40px; position:relative;}
.outro .cnt ul li a {display:flex; border-radius:20px 0; border:1px solid rgba(255,255,255,0.5);flex-direction: column; align-items: center; justify-content: center; min-height:220px; padding:20px;}
.outro .cnt ul li:hover a {background-color:rgba(50,73,151,0.7);}
.outro .cnt ul li .icon {margin-bottom:14px; padding-bottom:20px; position:relative;}
.outro .cnt ul li .icon:before {content:""; position:absolute; left:50%; margin-left:-10px; width:20px; height:2px; background:#fff; bottom:0;}
.outro .cnt ul li .tit {font-size:18px; font-weight:700; line-height:1.2em; letter-spacing:-0.01em; color:#fff;}

/* sub page */ 
.sub-visual {position:relative; width:100%; height:476px; display:flex; align-items:center; overflow:hidden; background-repeat:no-repeat; background-position:50% 50%; background-size:cover;}
.sub-visual .content {color:#fff; width:100%; max-width:1260px; padding:0 30px; margin:0 auto; text-align:center;}
.sub-visual .content h2 {font-size:32px; line-height:1em; font-weight:700; letter-spacing:-0.01em;}
.sub-visual .content p {font-family:'Acumin'; font-weight:400; letter-spacing:0.5em; line-height:1em;}

.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:70px 0 50px; text-align:center;}
.sub-title h2 {position:relative; color:#202020; font-size:32px; line-height:1.2em; font-weight:700; letter-spacing:-0.01em; padding-bottom:15px;}
.sub-title h2:before {content:""; position:absolute; width:26px; height:3px; background:#154d9b; left:50%; margin-left:-13px; bottom:0;}


#lnb {position:relative; margin-top:-60px; background:#262626}
.lnb {position:relative; max-width:1200px; margin:0 auto; }
.lnb ul {display:flex; width:100%; justify-content: center}
.lnb ul li {position:relative; width:auto; text-align:center; letter-spacing:-.04em; flex:1; margin-left:-1px;}
.lnb ul li a {position:relative; display:flex; align-items:center; justify-content:center; height:60px; color:#fff; font-weight:600; font-size:18px; line-height:1.4em; padding:0 25px; border-right:1px solid #585858;}
.lnb ul li:last-child a {border-right:0;}
.lnb ul li.active a {background:#253e94; border-color:#253e94;}

#contArea {max-width:1460px; padding-left:30px; padding-right:30px; margin:0 auto;}
#contArea.wide {max-width:100%; padding-left:0; padding-right:0;}

.real-cont {padding-bottom:70px;}
.real-cont.none {padding-bottom:0;}



/* footer */

#footer {position:relative; background:#f8f8f8; color:#818181; font-size:15px; line-height:1.6em; padding:30px 0;}

#footer address {font-style:normal; font-weight:400; letter-spacing:-0.02em; flex: 1 1 auto; min-width: 0; width: 1%;}
#footer address span {display:inline-block; margin-right:24px;}
#footer address strong {font-weight:500; display:inline-block; margin-right:24px; font-size:17px; color:#2d2d2d;}
#footer .copyright {display:block; font-size:15px; font-weight:300; letter-spacing:-0.04em; color:#acacac;}
#footer .copyright a {display:inline-block; margin-left:30px; font-size:14px; font-weight:500; letter-spacing:0;}
.f-cnt {display:flex; align-items: center;}
.f-logo {margin-right:70px;}