@charset "utf-8";
/* layout.css는 전체적인 레이아웃 스타일을 정의합니다. */

#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}

/* header */
#header {position:relative; width:100%; background:#fff; height:100px; z-index:90; letter-spacing:-.04em;}
#header .contain {position:relative; max-width:1550px !important; margin:0 auto; z-index:20}
#header .sitelogo a {display:block; position:absolute; top:50%; margin-top:-23px; left:15px; z-index:10;}

#gnb {margin-right:100px;}
#gnb>ul {display:flex; justify-content:flex-end; margin:0 -50px;} 
#gnb>ul>li {position:relative; text-align:center; padding:0 50px;}
#gnb>ul>li>a {position:relative; display:inline-block; color:#242424; font-size:18px; line-height:100px; font-weight:500;}


#header:hover {border-bottom:2px solid #00479d;}

#gnb .submenu {position:absolute; top:98px; height:100%; left:50%; margin-left:-100px; width:200px; display:none;}
#gnb .submenu ul {display:block; display:flex; flex-direction:column; white-space:nowrap; position:relative; background:#fff; overflow:hidden; border:2px solid #00479d; border-top:0;}
#gnb .submenu ul li {padding:0;}
#gnb .submenu ul li a {display:block; color:#454545; font-size:16px; line-height:43px; position:relative; border-bottom:1px solid #ddd; text-align:left; padding-left:20px;}
#gnb .submenu ul li:last-child a {border-bottom:0;}
#gnb .submenu ul li a:hover {color:#00479d;}
#gnb .submenu ul li a:after {content:''; width:0; height:1px; position:absolute; bottom:5px; left:0; background:#fff; transition:all 0.4s;}
#gnb .submenu ul li a:hover:after {width:100%;}


.contain {position:relative; max-width:1230px; padding-left:15px; padding-right:15px; margin:0 auto; height:inherit;}
/* main */ 
.main-visual {position:relative; overflow:hidden;}
.main-visual .item {position:relative; height:880px;}
.main-visual .secting-img {position:absolute; top:0; left:0; width:100%; height:100%; background-repeat:no-repeat; background-position:center center; background-size:cover;}
.main-visual .txt-box {position:absolute; top:50%; transform:translateY(-50%); left:0; width:100%; color:#fff; text-align:center;}
.main-visual .txt-box p {font-size:32px; font-weight:500; line-height:1.3em; margin-bottom:20px; position:relative; top:50px; opacity:0; transition:all 0.6s; transition-delay:0.2s;}
.main-visual .txt-box h2 {font-size:50px; line-height:1.1em; position:relative; top:50px; opacity:0; transition:all 0.6s; transition-delay:0.6s;}
.main-visual .txt-box.active p {top:0; opacity:1;}
.main-visual .txt-box.active h2 {top:0; opacity:1;}
.main-visual .slick-arrow {width:33px; height:64px; position:absolute; top:50%; margin-top:-32px; border:0; background-color:transparent; background-repeat:no-repeat; background-size:cover; font-size:0; z-index:11;}
.main-visual .slick-prev {background-image:url('../images/main/visual-prev.png'); left:100px;}
.main-visual .slick-next {background-image:url('../images/main/visual-next.png'); right:100px;}
.main-visual .scroll-down {display:inline-block; position:absolute; left:50%; margin-left:-46px; bottom:50px; z-index:11;}

.section .tit {text-align:center; margin-bottom:36px;}
.section .tit h3 {font-size:34px; color:#242424; line-height:1.2em; margin-bottom:10px;}
.section .tit p {font-size:16px; color:#686868; line-height:1.6em;}

.section1 {padding:100px 0;}
.section1 .tit {position:relative;}
.section1 .tit .img-box {position:absolute; top:0; left:50%; transform:translateX(-50%); opacity:.2;}
.section1 .col {display:flex; margin:0 -20px;}
.section1 .row {width:100%; padding:0 20px;}
.section1 .txt-box {margin:-80px 25px 0; background:#fff; padding:40px 30px; position:relative; z-index:1; border-radius:10px; text-align:center;min-height:366px;}
.section1 .txt-box h4 {font-size:22px; font-weight:500; color:#242424; line-height:1.3em; margin-bottom:16px;}
.section1 .txt-box p {font-size:15px; color:#686868; line-height:1.6em; margin-bottom:26px;}
.section1 .txt-box span {display:inline-block; width:40px; height:40px; background-image:url('../images/main/sec1-more.png'); background-color:#eeeeee; border-radius:50%; background-repeat:no-repeat; background-size:50%; background-position:50% 50%; transition:all 0.4s;}
.section1 a:hover .txt-box span {background-image:url('../images/main/sec1-more-w.png'); background-color:#00479d;}

.section2 {padding:60px 0; background:#f8f8f8; margin-bottom:90px;}
.section2 .wrap {position:relative;}
.section2 .items {margin:0 -10px;}
.section2 .item {padding:0 10px;}
.section2 .item a {background:#fff; height:100%; display:block; position:relative; margin-bottom:20px;}
.section2 .item a .pic {position:relative; height:0; padding-bottom:64.913%; overflow:hidden;}
.section2 .item a .pic img {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100% !important; height:100% !important; max-width:100%; min-height:100%; object-fit:cover; transition:0.3s;}
.section2 .item a .txt {padding:20px 20px 50px;}
.section2 .item a .txt p {font-size:14px; color:#454545; line-height:1.8em; margin-bottom:4px;}
.section2 .item a .txt h4 {font-size:16px; color:#454545; line-height:1.6em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.section2 .item a span {position:absolute; bottom:-20px; left:50%; margin-left:-20px; opacity:0; transition:all 0.4s;}
.section2 .item a:hover span {opacity:1;}
.section2 .slick-arrow {position:absolute; width:32px; height:58px; top:50%; margin-top:-28px; border:0; background-color:transparent; background-repeat:no-repeat; background-size:cover; font-size:0; z-index:11;}
.section2 .slick-prev {background-image:url('../images/main/sec2-prev.png'); left:-100px;}
.section2 .slick-next {background-image:url('../images/main/sec2-next.png'); right:-100px;}

.section3 .col {display:flex;}
.section3 .row {width:100%; background-repeat:no-repeat; background-size:cover; background-position:center center; display:flex; height:400px; flex-direction:column; align-items:center; justify-content:center; text-align:center; color:#fff;}
.section3 .row1 {background-image:url('../images/main/sec3-bg1.jpg');}
.section3 .row2 {background-image:url('../images/main/sec3-bg2.jpg');}
.section3 .row h3 {font-size:30px; line-height:1.3em; margin-bottom:24px; padding-bottom:18px; position:relative;}
.section3 .row h3:after {content:''; width:36px; height:1px; background:#fff; position:absolute; left:50%; margin-left:-18px; bottom:0;}
.section3 .row p {font-size:16px; line-height:1.6em; height:calc(1.6em * 1 * 3); margin-bottom:36px;}
.section3 .row a {display:inline-block; width:200px; border:1px solid rgba(255,255,255,.5); line-height:48px; font-size:14px; font-weight:500;}
/* footer */
#footer {background:#222222; padding:36px 0;}
#footer address {font-style:normal;}
.foot-info .tit {font-size:15px; font-weight:500; color:#ffffff; line-height:1.8em; margin-bottom:16px;}
.foot-info p {font-size:14px; line-height:2em; color:#eeeeee;}
.foot-info p span {padding:0 14px; position:relative;}
.foot-info p span:after {content:''; width:1px; height:14px; background:rgba(255,255,255,0.3); position:absolute; left:50%; top:50%; margin-top:-7px;}
/* sub page */
.sub-visual {position:relative; height:360px; z-index:10; letter-spacing:-.03em;}
.sub-visual .background {position:absolute; top:0; left:0; width:100%; height:100%; background-position:center; background-size:cover;}
.sub-visual .tit {position:absolute; top:50%; transform:translateY(-50%); width:100%; left:0; text-align:center; z-index:1; color:#fff;}
.sub-visual .tit h2 {font-size:40px; line-height:1.2em; margin-bottom:20px;}
.sub-visual .tit p {font-size:16px; font-weight:500; letter-spacing:.2em;}

.lnb {position:relative; max-width:1200px; margin:-34px auto 0; z-index:11; background:#fff;}
.lnb:after {content:''; width:100%; height:100%; position:absolute; top:0; left:0; border:1px solid #ddd; z-index:-1;}
.lnb ul {display:flex;}
.lnb ul li {width:100%; position:relative;}
.lnb ul li:after {content:''; width:1px; height:20px; background:#ddd; position:absolute; right:-1px; top:50%; margin-top:-10px;}
.lnb ul li:last-child:after {display:none;}
.lnb ul li a {line-height:68px; text-align:center; display:block; font-size:16px; color:#454545; position:relative;}
.lnb ul li.active a {background:linear-gradient(120deg, #00479d, #76bf67); color:#fff; font-weight:500; z-index:11;}
.lnb ul li.active:after {display:none;}

.sub-title {margin:60px 0 50px; text-align:center;}
.sub-title h2 {font-size:28px; color:#242424; line-height:1.3em; padding-bottom:20px; position:relative;}
.sub-title h2:after {content:''; width:50px; height:3px; background:#00479d; position:absolute; bottom:0; left:50%; margin-left:-25px;}

.real-cont {letter-spacing:-.03em; margin-bottom:100px;}


/* for mobile */
.only-mobile {display:none;}
.btn-m-menu {display:none; position:absolute; top:29px; right:15px; width:30px; height:22px;  text-align:center; text-indent:-9999em; z-index:220; transition:all 0.5s ease-in-out;}
.btn-m-menu span {position:absolute; right:0; top:50%; margin-top:-1px; height:2px; width:23px;background:#242424;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; right:0; width:30px; height:2px; background:#242424; 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:80px 0; width:400px; height:100%; overflow:auto; transition:.3s ease-in-out; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:202;}
.mobile-navigation .logo {margin-bottom:20px; padding-left:15px;}
.mobile-navigation .logo img {height:23px;}
.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:#454545; font-size:18px; font-weight:500; line-height:1.3em;}
.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 #2c2c2c; border-bottom:2px solid #2c2c2c;}
.mobile-navigation .nav-menu>ul>li.active>a {color:#00479d}
.mobile-navigation .nav-menu>ul>li.active>a:after {transform:translateY(-35%) rotate(-135deg); border-color:#00479d;}
.mobile-navigation .nav-menu .submenu {display:none; margin:-1px 0 0 0; padding:0 15px 15px;}
.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:#454545; font-size:16px; font-weight:400; line-height:1.3em;}
.mobile-navigation .nav-menu .submenu>ul>li>a:after {display:block; content:"";position:absolute; top:14px; 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:#00479d}
.mobile-navigation .nav-menu .submenu>ul>li>a:hover:after {background:#00479d}
.mobile-overlay {display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:#000; opacity:0.6; z-index:201;}

html.menu-opened {overflow:hidden;}
html.menu-opened .mobile-navigation {-ms-transform:translateX(0); transform:translateX(0); }
html.menu-opened .mobile-overlay {display:block;}
html.menu-opened .btn-m-menu {top:20px; right:15px;}
html.menu-opened .btn-m-menu span {background:none;}
html.menu-opened .btn-m-menu span:before,
html.menu-opened .btn-m-menu span:after {transition-delay:0s, 0.3s; background:#414141;}
html.menu-opened .btn-m-menu span:before {top:0; transform:rotate(45deg);}
html.menu-opened .btn-m-menu span:after {bottom:0; transform:rotate(-45deg);}