@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:absolute; top:0; left:0; width:100%; background:#fff; height:100px; z-index:90; letter-spacing:-.03em;}
#sub #header {position:relative;}
#header .contain {position:relative; max-width:1230px; margin:0 auto; z-index:20}
#header .sitelogo a {display:block; position:absolute; top:50%; margin-top:-23px; left:15px; z-index:10;}

.fp-viewing-Portfolio #header,
.fp-viewing-Contact-Us #header,
.fp-viewing-Foot #header{border-bottom:1px solid #ddd;}


#gnb>ul {display:flex; justify-content:flex-end; margin:0 -40px;} 
#gnb>ul>li {position:relative; text-align:center; padding:0 40px;}
#gnb>ul>li>a {position:relative; display:inline-block; color:#242424; font-size:20px; line-height:100px; font-weight:500;}
#gnb>ul>li.active>a {color:#5078ac;}
#gnb>ul>li.active>a:after {content:""; width:150px; height:3px; background-color:#5078ac; position:absolute; left:50%; bottom:-1px; margin-left:-75px;}

#gnb .submenu {position:absolute; top:100px; left:0; width:100%; height:0; overflow:hidden; z-index:20;}
#gnb .submenu ul {display:block; padding:32px 0;}
#gnb .submenu ul li {padding:0; text-align:center;}
#gnb .submenu ul li a {display:inline-block; color:#454545; font-size:16px; line-height:2em; position:relative; padding:1px 0;}
#gnb .submenu ul li a:hover {color:#5078ac;}
#gnb .submenu ul li a:hover:after {content:''; width:100%; height:1px; position:absolute; bottom:7px; left:0; background:#5078ac;}

.submenu-bg {background-color:rgba(255,255,255,0.8); display:none; border-top:1px solid rgba(221,221,221,0.3);}


.contain {position:relative; max-width:1230px; padding-left:15px; padding-right:15px; margin:0 auto; height:inherit; letter-spacing:-.03em;}
/* main */ 

.main-visual {position:relative; overflow:hidden;}
.main-visual .item {position:relative; height:100vh;}
.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 .wrap {max-width:1230px; width:100%; height:100%; padding:0 15px; margin:0 auto; position:relative;}
.main-visual .wrap .txt {position:absolute; top:50%; transform:translateY(-50%); left:15px; z-index:1; color:#fff; padding-bottom:130px;}
.main-visual .wrap .txt .tt1 {font-size:23px; font-weight:500; left:1.2em; text-shadow:5px 5px 5px rgba(0,0,0,0.3); margin-bottom:14px;}
.main-visual .wrap .txt h2 {font-size:60px; line-height:1.1em; margin-bottom:20px; text-shadow:5px 5px 5px rgba(0,0,0,0.3);}
.main-visual .wrap .txt p {font-size:20px; line-height:1.3em; font-weight:500; text-shadow:5px 5px 5px rgba(0,0,0,0.3);}
.main-visual .box {max-width:1230px; width:100%; height:100%; padding:0 15px; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);}
.main-visual .visual-btns {position:absolute; top:50%; transform:translateY(-50%); left:15px; padding-top:200px; width:260px;}
.main-visual .custom_paging {text-align:center;}
.main-visual .slick-dots li {display:none;}
.main-visual .slick-dots li.slick-active {display:block;}
.main-visual .slick-dots li .nums {color:#fff; font-size:16px; font-weight:500; line-height:1.6em; line-height:36px;}
.main-visual .slick-dots li .nums span {padding:0 10px;}
.main-visual .slick-dots li .nums span:nth-child(1) {font-size:20px; font-weight:700;}
.main-visual .slick-arrow {position:absolute; bottom:0; margin-top:0; width:19px; height:35px; cursor:pointer; background-size:cover; background-repeat:no-repeat; font-size:0; border:0; background-color:transparent;}
.main-visual .slick-prev {background-image:url('../images/main/visual-prev.png'); left:0;}
.main-visual .slick-next {background-image:url('../images/main/visual-next.png'); right:0;}
.main-visual .scroll-down {position:absolute; bottom:80px; left:50%; margin-left:-25px; z-index:11;}

.section-common {background-repeat:no-repeat; background-size:cover; background-position:center center; background-color:#fff;}
.section-common.section1 {background-image:url('../images/main/sec1-bg.jpg');} 
.section-common.section2 {background-image:url('../images/main/sec2-bg.jpg');} 
.section-common .wrap {position:absolute; top:50%; left:0; padding:0 15px; transform:translateY(-50%); width:100%; padding-top:100px;}
.section-common .head {text-align:center; margin-bottom:56px; position:relative;}
.section-common .head .tt {font-size:23px; font-weight:700; color:#5078ac; line-height:1.2em; margin-bottom:14px;}
.section-common .head h3 {font-family:'Montserrat'; font-size:40px; line-height:1.1em; color:#242424; font-weight:600; margin-bottom:14px;}
.section-common .head p {font-size:18px; color:#454545; line-height:1.5em;}
.section-common a.moreview {display:inline-block; border:1px solid; padding:0 23px; font-size:16px; font-family:'Montserrat'; line-height:49px;}
.section-common a.moreview:before {content:''; width:16px; height:16px; background-size:cover; display:inline-block; margin-right:10px; margin-top:-2px; vertical-align:middle; background-repeat:no-repeat;}

.section1 .col {display:flex; margin:0 -15px;}
.section1 .row {width:33.3333333%; padding:0 15px;}
.section1 .row a {display:block;}
.section1 .row a .pic {position:relative; height:0; padding-bottom:70.266%; overflow:hidden;}
.section1 .row 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;}
.section1 .row a .txt {padding:24px 20px; background:#fff; border:1px solid #ddd; border-top:0;}
.section1 .row a .txt h4 {font-size:22px; font-weight:500; color:#242424; line-height:1.3em; margin-bottom:22px;}
.section1 .row a .txt dl {display:flex; font-size:16px; color:#454545; line-height:1.8em; margin-bottom:10px;}
.section1 .row a .txt dl:last-child {margin-bottom:0;}
.section1 .row a .txt dt {width:80px; font-weight:500;}
.section1 .row a .txt dd {width:1%; flex:1 1 auto; white-space:nowrap; text-overflow:ellipsis; overflow:hidden;}
.section1 .row a .box {max-width:240px; width:100%; margin:30px auto 0; background:#fafafa; color:#454545; line-height:48px; border:1px solid #ddd; font-size:16px; text-align:center;}
.section1 .row a .box:before {content:''; width:16px; height:16px; background:url('../images/main/more-s-icon-b.png') 0 0 no-repeat; background-size:cover; display:inline-block; margin-right:10px; margin-top:-2px; vertical-align:middle;}
.section1 .row a:hover .box {background:#5078ac; color:#fff;}
.section1 .row a:hover .box:before {background:url('../images/main/more-s-icon.png') 0 0 no-repeat;}
.section1 a.moreview {position:absolute; bottom:0; right:0; border-color:#c6aa58; background:#fff; color:#454545;}
.section1 a.moreview:before {background-image:url('../images/main/more-p-icon.png');}

.section2 .head .tt {color:#c0dbff;}
.section2 .head h3 {color:#fff;}
.section2 .head p {color:#fff;}
.section2 .tab-cnt {margin-bottom:70px;}
.section2 .tab-cnt ul {display:flex; position:relative;}
.section2 .tab-cnt ul:after {content:''; width:100%; height:100%; position:absolute; top:0; left:0; border:1px solid rgba(255,255,255,0.3); border-radius:25px; z-index:1;}
.section2 .tab-cnt ul li {width:33.333333%; text-align:center; position:relative;}
.section2 .tab-cnt ul li:after {content:''; width:1px; height:13px; background:rgba(255,255,255,0.3); position:absolute; top:50%; margin-top:-7px; right:0;}
.section2 .tab-cnt ul li:last-child:after {display:none;}
.section2 .tab-cnt ul li a {display:block; line-height:50px; font-size:16px; color:#fff; font-weight:500; position:relative; z-index:3;}
.section2 .tab-cnt ul li.active a {background:#5078ac; border-radius:25px;}
.section2 .slider-box {position:relative;}
.section2 .items {margin:0 -7px;}
.section2 .item {padding:0 7px;}
.section2 .item .pic {position:relative; height:0; padding-bottom:100%; overflow:hidden;}
.section2 .item .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 .sec2-arrow {position:absolute; width:70px; height:70px; cursor:pointer; background-repeat:no-repeat; background-size:cover; top:50%; margin-top:-35px; z-index:11;}
.section2 .sec2-prev {background-image:url('../images/main/sec2-prev.png'); left:-50px;}
.section2 .sec2-next {background-image:url('../images/main/sec2-next.png'); right:-50px;}
.section2 .box {text-align:center;}
.section2 a.moreview {border-color:#fff; background:transparent; color:#fff; margin-top:70px;}
.section2 a.moreview:before {background-image:url('../images/main/more-p-icon-w.png');}

.section3 .col {display:flex; margin:0 -15px;}
.section3 .row {padding:0 15px; height:100%;}
.section3 .row01 {width:44.5%;}
.section3 .row02 {width:55.5%;}
.section3 .tit {font-size:23px; font-weight:800; font-family:'NanumSqua'; line-height:1.3em;}
.section3 .inner {border:1px solid #ddd; padding:26px 30px; position:relative; height:100%;}
.section3 .inner .tit {color:#242424; margin-bottom:20px;}
.section3 .inner .box {display:block; margin-bottom:24px; padding-bottom:24px; border-bottom:1px solid #ddd;}
.section3 .inner .box h4 {font-size:24px; font-weight:500; color:#242424; margin-bottom:24px; white-space:nowrap; text-overflow:ellipsis; overflow:hidden;}
.section3 .inner .box p {font-size:16px; margin-bottom:40px; color:#686868; line-height:1.6em; height:calc(1.6em * 1 * 2); overflow:hidden; text-overflow:ellipsis; word-break:break-all; white-space:normal; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;}
.section3 .inner .box .date {font-size:15px; color:#9e9e9e;}
.section3 .inner ul li {font-size:16px; padding-left:8px; position:relative; color:#454545; line-height:1.8em; margin-bottom:4px; white-space:nowrap; text-overflow:ellipsis; overflow:hidden;}
.section3 .inner ul li:last-child {margin-bottom:0;}
.section3 .inner ul li:before {content:''; width:4px; height:4px; border-radius:50%; background:#454545; position:absolute; top:12px; left:0;}
.section3 .inner .more {display:block; position:absolute; top:30px; right:30px;}
.section3 .row02 ul {display:flex; flex-wrap:wrap; margin:0 -15px -30px;}
.section3 .row02 ul li {padding:0 15px; margin-bottom:30px; width:50%;}
.section3 .row02 ul li:nth-child(3) {width:100%;}
.section3 .row02 ul li a {padding:26px 30px; display:block; position:relative; min-height:185px;}
.section3 .row02 ul li:nth-child(1) a {background:#c7aa57;}
.section3 .row02 ul li:nth-child(2) a {background:#5078ac;}
.section3 .row02 ul li:nth-child(3) a {background:#1f3651;}
.section3 .row02 ul li a .tit {color:#fff; margin-bottom:12px;}
.section3 .row02 ul li a .txt {font-size:16px; color:#fff; line-height:1.6em;}
.section3 .row02 ul li a span {position:absolute; top:30px; right:30px; display:block;}
.section3 .row02 ul li a .tt {font-size:30px; color:#d0e8a3; margin-top:24px; line-height:1.2em; font-family:'Montserrat'; font-weight:700;}
.section3 .row02 ul li a:before {content:''; width:70px; height:70px; position:absolute; bottom:20px; right:20px; background-repeat:no-repeat; background-size:cover;}
.section3 .row02 ul li:nth-child(1) a:before {background-image:url('../images/main/sec3-icon01.png');}
.section3 .row02 ul li:nth-child(2) a:before {background-image:url('../images/main/sec3-icon02.png');}
.section3 .row02 ul li:nth-child(3) a:before {background-image:url('../images/main/sec3-icon03.png');}
.section3 .scroll-up {text-align:center; margin:80px 0 0;}
.section3 .scroll-up a {display:inline-block;}
/* footer */
#footer {background:#dddddd;}
#footer address {font-style:normal;}
.foot-pop {border-bottom:1px solid rgba(255,255,255,0.6); padding:20px 0;}
.foot-pop ul.pop {display:flex; justify-content:center; margin:0 -18px;}
.foot-pop ul.pop li {padding:0 18px; position:relative;}
.foot-pop ul.pop li:after {content:''; width:1px; height:16px; position:absolute; right:0; top:50%; margin-top:-8px; background:rgba(255,255,255,0.6);}
.foot-pop ul.pop li:last-child:after {display:none;}
.foot-pop ul.pop li a {display:block; font-size:15px; color:#242424; line-height:1.6em;}
.foot-group {padding:30px 0;}
.foot-logo {margin-bottom:30px; text-align:center;}
.foot-info {text-align:center;}
.foot-info p {font-size:15px; color:#242424; line-height:1.5em;}
.foot-info p span {margin:0 14px;}
.foot-info p a {font-size:12px; display:inline-block; margin-left:4px;}

.family {position:absolute; right:15px; top:50%; margin-top:-20px; z-index:111;}
.family .tit {border:1px solid #fff; line-height:38px; width:220px; padding-left:20px; color:#454545; display:block; background:transparent; position:relative; font-size:15px;}
.family .tit:after {content:''; width:10px;	height:5px; top:50%; right:20px; margin-top:-3px; position:absolute; background-image:url('../images/bbs/family-arrow.png'); background-repeat:no-repeat; background-size:cover; transform:rotate(0);}
.family .tit.active:after {transform:rotate(180deg);}
.family .family-open {display:none; position:absolute; top:40px; width:220px; left:0;}
.family .family-open ul {display:flex; flex-direction:column; background:#fff; padding:5px 0; height:170px; overflow-y:scroll;}
.family .family-open ul li {text-align:center;}
.family .family-open a {display:inline-block; line-height:1.5em; color:#454545; font-size:14px; padding:5px 0;}
.family .family-open a:hover {color:#5078ac; text-decoration:underline;}
.family .family-open.active {display:block;}

/* sub page */
.sub-visual {position:relative; height:380px; 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; width:100%; text-align:center; top:50%; transform:translateY(-50%); z-index:11; font-size:40px; line-height:1.2em; color:#ffffff; text-shadow:0px 5px 5px rgba(0,0,0,0.3); font-weight:700;}

.lnb {max-width:1200px; margin:-60px auto 0; position:relative; z-index:11;}
.lnb ul {display:flex;}
.lnb ul li {width:100% !important; position:relative; margin-left:-1px;}
.lnb ul li:after {content:''; width:1px; height:100%; background:rgba(255,255,255,0.5); position:absolute; right:0; top:0; z-index:1;}
.lnb ul li:last-child:after {display:none;}
.lnb ul li a {display:block; text-align:center; line-height:60px; background:rgba(0,0,0,0.5); color:#fff; font-size:20px; font-weight:500; position:relative;}
.lnb ul li.active a {background:#5078ac; z-index:11;}

.sub-title {text-align:center; margin:50px 0 40px;}
.sub-title h2 {font-size:30px; font-weight:500; color:#242424; line-height:1.2em; padding-bottom:20px; position:relative;}
.sub-title h2:after {content:''; width:50px; height:3px; background:#003775; 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:#5078ac}
.mobile-navigation .nav-menu>ul>li.active>a:after {transform:translateY(-35%) rotate(-135deg); border-color:#5078ac;}
.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:#5078ac}
.mobile-navigation .nav-menu .submenu>ul>li>a:hover:after {background:#5078ac}
.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);}