@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;}
.only-tablet-mobile {display:none;}
.only-tablet {display:none;}
.only-mobile {display:none;}

#wrapper {min-height:100vh; padding-top:80px; background:#242c41;}

/* header */
#header {position:fixed; top:0; left:0; width:100%; background:#242c41; z-index:100;}
#header .inner {position:relative; height:80px; z-index:2;}

.sitelogo {position:absolute; left:17px; top:50%; margin-top:-29px; z-index:2;}

#gnb {position:absolute; top:0; right:410px;}
#gnb > ul {display:flex;}
#gnb > ul > li {position:relative; padding:0 8px 0 59px;}
#gnb > ul > li > a {display:block; font-family:'Nunito Sans',sans-serif; color:#e4f0dc; font-size:19px; font-weight:700; line-height:80px; letter-spacing:0;}
#gnb .submenu {display:none; position:absolute; top:80px; left:0; width:100%; min-height:145px; text-align:right; border-right:1px solid #515457;}
#gnb .submenu ul {padding:16px 13px;}
#gnb .submenu ul li a {display:block; padding:3px 0; color:#242c41; white-space:nowrap; font-size:16px; font-weight:300; line-height:1.4em; letter-spacing:-.03em;}
#gnb .submenu ul li a:hover {font-weight:500;}

.top-links {position:absolute; top:0; right:30px;}
.top-links ul {display:flex;}
.top-links ul li {margin-left:10px;}
.top-links ul li a {display:block; position:relative; padding:20px 0; color:#515457; white-space:nowrap; font-size:16px; font-weight:300; line-height:1.3em; letter-spacing:-.03em;}
.top-links ul li a span {display:none; position:absolute; top:80px; right:-5px; min-height:145px; padding:20px 8px; border-right:1px solid #515457;}

.submenu-bg {display:none; position:absolute; left:0; width:100%; background:rgba(255,255,255,.2); border-bottom:1px solid #515457;}
#sub .submenu-bg {background:rgba(255,255,255,.9);}
.submenu-bg2 {display:none; position:absolute; left:0; width:100%; background:rgba(255,255,255,.6); border-bottom:1px solid #515457;}
#sub .submenu-bg2 {background:rgba(255,255,255,.9);}

/* for mobile */
.btn-m-menu {display:none; position:absolute; top:50%; right:30px; width:28px; height:28px; margin-top:-14px; text-indent:-9999em; z-index:50;}
.btn-m-menu span {position:absolute; left:0; right:0; top:13px; height:3px; background:#e5f1de;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; left:0; right:0; height:3px; background:#e5f1de;}
.btn-m-menu span:before {top:-10px;}
.btn-m-menu span:after {bottom:-10px;}

.mobile-navigation {display:none; 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 {font-size:18px; font-weight:700; color:#242c41; line-height:70px; padding:0 20px;}
.mobile-navigation .nav-menu>ul {border-top:1px solid #ddd;}
.mobile-navigation .nav-menu>ul>li {border-bottom:1px solid #ddd;}
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:11px 20px; display:block; color:#242c41; font-size:19px; font-weight:500; 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 #242c41; border-bottom:2px solid #242c41;}
.mobile-navigation .nav-menu>ul>li.active>a {color:#242c41;}
.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:#242c41; 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:20px; right:18px; 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:#242c41; 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;}

/* main */
.main-visual {position:relative; overflow:hidden;}
.main-visual .item img {width:100%;}
.main-visual .slick-dots {position:absolute; bottom:30px; left:0; width:100%; line-height:0; text-align:center; z-index:50;}
.main-visual .slick-dots li {display:inline-block; margin:0 5px; padding:1px; vertical-align:top;}
.main-visual .slick-dots li button {display:block; width:10px; height:10px; background:#242c41; border:2px solid #242c41; border-radius:100%; overflow:hidden; text-indent:-999em; opacity:.7;}
.main-visual .slick-dots li.slick-active {padding:0;}
.main-visual .slick-dots li.slick-active button {background:transparent; width:12px; height:12px; opacity:1;}

.main-gallery {padding:50px 30px 60px; overflow:hidden;}
.main-gallery ul {display:flex; margin:0 -5px;}
.main-gallery ul li {width:33.33333333%; padding:0 5px;}
.main-gallery ul li  a {display:block; position:relative; color:#e5f1de; text-align:center;}
.main-gallery .thumb {position:relative; padding-bottom:74.8%; overflow:hidden;}
.main-gallery .thumb img {position:absolute; top:50%; left:0; transform:translateY(-50%); -ms-transform:translateY(-50%); -webkit-transform:translateY(-50%); width:100%; height:auto !important; max-width:100%; min-height:100%; object-fit:cover;}
.main-gallery .tt {border:1px solid #fff; padding:8px; font-size:18px; font-weight:500; line-height:1.3em;}
.main-gallery .hover {position:absolute; top:0; left:0; width:100%; height:100%; display:flex; justify-content:center; align-items:center; opacity:0; transition:.2s; background:rgba(0,0,0,.8); opacity:0; z-index:2;}
.main-gallery .hover .in {width:80%; max-width:290px; transition:.4s .2s; opacity:0; transform:translateY(10px);}
.main-gallery .hover .txt {font-size:22px; font-weight:500; line-height:1.455em; letter-spacing:-.03em;}
.main-gallery .hover .more {display:inline-block; margin-top:20px; padding:0 25px; font-size:15px; font-weight:300; line-height:38px; letter-spacing:-.03em; border-radius:20px; border:1px solid rgba(255,255,255,.3);}
.main-gallery a:hover .hover {opacity:1;}
.main-gallery a:hover .hover .in {opacity:1; transform:translateY(0);}

/* sub */
.sub-title {text-align:center; padding:35px 0 20px; color:#e5f1de;}
.sub-title h2 {font-family:'Nunito Sans',sans-serif; font-size:25px; line-height:1.3em; letter-spacing:0;}

.lnb {margin-bottom:30px; text-align:center; color:#e5f1de;}
.lnb ul {display:inline-flex; width:auto;}
.lnb ul li {width:auto; position:relative;}
.lnb ul li:before {content:""; position:absolute; top:50%; left:0; width:1px; height:15px; background:#e5f1de; margin-top:-7px;}
.lnb ul li:first-child:before {display:none;}
.lnb ul li a {display:block; padding:0 37px; font-size:16px; font-weight:300; line-height:25px; letter-spacing:-.03em; transition:none;}
.lnb ul li a:hover,
.lnb ul li.active a {font-weight:500; font-size:20px;}

.real-cont {max-width:1260px; min-height:300px; padding:0 30px 100px; margin:0 auto;}
.real-cont.wide {max-width:100%;}
.real-cont.wide .cont-box {max-width:1300px; margin:0 auto;}

.cont-box {background:#e4f0dc; padding:50px;}
.cont-box .paginate a {background:transparent; border:0; font-size:15px;}
.cont-box .paginate strong {background:#242c41; border-color:#242c41; font-size:15px;}
.cont-box .paginate a:focus,
.cont-box .paginate a:hover {background-color:transparent;}
.cont-box .paginate a.direction {background-size:auto !important;}

.board-wrap {max-width:1500px; margin:0 auto;}

.contact-wrap {max-width:1000px; margin:0 auto;}

/* footer */
#footer {padding:17px 70px 27px 50px; text-align:center; color:#e5f1de; font-size:13px; font-weight:300; line-height:1.5em; letter-spacing:-.03em;}
#footer address {font-style:normal;}

.foot-info .f-links {display:inline-block; vertical-align:middle; margin:6px 16px 6px 0; font-size:15px; font-weight:400;}
.foot-info .f-links ul {display:flex;}
.foot-info .f-links ul li {margin-right:22px;}
.foot-info .f-links ul li:last-child {margin-right:0;}
.foot-info .f-links ul li a {display:block; padding-left:20px; font-weight:500; background:url("../images/common/icon_blank.png") 0 2px no-repeat;}
.foot-info address {display:inline-block; vertical-align:middle; margin:6px 0;}
.foot-info address span {display:inline-block;}
.foot-info address .bar {width:1px; height:12px; background:#ddd; vertical-align:middle; margin:-.2em 9px 0;}

.scroll-top {position:fixed; bottom:-200px; right:30px; width:40px; height:40px; background:#e4f0dc url("../images/common/top.png") 50% 50% no-repeat; transition:.4s; z-index:100;}
.scroll-top.active {bottom:30px;}