@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:1460px; 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;}


/* header */
#header {position: fixed; top:0; left:0; width:100%; z-index:90; background: transparent;}
#header .contain {position:relative; max-width: 1780px;}

html.header-fixed #header {position: fixed; box-shadow: 0 0 3px rgb(0 0 0 / 15%);}

.sitelogo {position:absolute; top:50%; left: 30px; margin-top:-29px; z-index:2; transition:.2s; background-image:url("../images/common/logo.png"); background-size: contain; background-repeat: no-repeat; z-index: 50;}
.sitelogo a {display: block;}
.sitelogo img {visibility: hidden;}

#gnb {text-align:center; position: relative; z-index: 10;}
#gnb > ul {display:flex;justify-content: center;}
#gnb > ul > li {position: relative; margin:0 33px; position:relative; text-align:center;}
#gnb > ul > li:after {content:''; position: absolute; left: 50%; margin-left: -2px; top: 25px; width: 4px; height: 4px; background: #c9bc9c; border-radius:100%; opacity: 0; transform:translateY(4px); transition:all .2s;}
#gnb > ul > li.active:after {transform:translateY(0); opacity: 1;}
#gnb > ul > li > a {display:block; position:relative; color: #fff; font-size:18px; font-weight: 200; line-height:100px; letter-spacing:-.02em;}
#gnb .submenu {display:none; position:absolute; left:0;}
#gnb .submenu ul {display:flex; padding:24px 0;}
#gnb .submenu ul li {margin-left:40px;}
#gnb .submenu ul li:first-child {margin-left:0;}
#gnb .submenu ul li a {display:block; position:relative; white-space:nowrap; color:#505050; line-height:1.4em; letter-spacing:-.03em; transition:none;}

.submenu-bg {display:none; position:absolute; left:0; width:100%; height:0; background:#fff9f3;}

#header.header-hover {background: #fff;}
#header.header-hover .sitelogo {background-image:url("../images/common/logo_on.png");}
#header.header-hover #gnb > ul > li > a {color: #2c2c2c; font-weight: 400;}
#header.header-hover .btn-m-menu {color: #505050; border-color:#505050;}

#header.header-fixed {background: #fff; box-shadow:rgba(0,0,0,.1) 0 0 15px;}
#header.header-fixed .sitelogo {background-image:url("../images/common/logo_on.png");}
#header.header-fixed #gnb > ul > li > a {color: #2c2c2c; font-weight: 400;}
#header.header-fixed .btn-m-menu {color: #505050; border-color:#505050;}

.top-call {position:absolute; display:flex; align-items:center; top:50%; right:90px; margin-top:-20px; padding:0 20px; color:#505050; font-weight:700; line-height:40px; background:#fff9f3; border-radius:40px; z-index:11;}
.top-call i {margin-right:10px;}
.top-call svg {display:block;}

/* for mobile */
.btn-m-menu {position:absolute; top:50%; right:30px; margin-top: -20px; width: 40px; height: 40px; color: #fff; font-size: 11px; letter-spacing: -.04em; font-weight: 500; line-height: 40px; border: 1px solid #fff; border-radius:100%; text-align:center; z-index:50; transition:all 0.5s linear;}

.mobile-navigation {position:fixed; top:0; right:0; width:100%; height:100%; display: flex;align-items: center; overflow:auto; transition:.4s linear; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff9f3; z-index:102;}
.mobile-navigation .home {position: absolute; top: 0; left: 0; width: 100%; height:100px; padding: 19px 5.2%;}
.mobile-navigation .home a {display: inline-block;  color: #000; font-size: 18px; font-weight: 700; line-height: 1.3em;}
.mobile-navigation .allmenu-bg {position: absolute; top: 0; left: 0; height: 100%; width: 43.75%; background: no-repeat url("../images/common/all_menu.jpg") center center / cover; border-radius:0 0 260px 0; z-index: -1;}
.mobile-navigation .nav-menu {margin-left: 51%; padding: 30px; overflow:hidden;}
.mobile-navigation .nav-menu>ul {}
.mobile-navigation .nav-menu>ul>li {display: flex;align-items: center; margin: 50px 0;}
.mobile-navigation .nav-menu>ul>li>a {position:relative; display:block; min-width: 296px; color:#2c2c2c; font-size:48px; font-weight:600; line-height:1.2em; letter-spacing: -.04em;}
.mobile-navigation .nav-menu>ul>li>a span {position: relative;}
.mobile-navigation .nav-menu>ul>li>a span:after {content:''; position: absolute; bottom: 100%; left: 100%; width: 8px; height: 8px; border-radius:100%; background-color: #c9bc9c; transform:translateY(4px); opacity: 0; transition:.2s;}
.mobile-navigation .nav-menu>ul>li.active>a span:after, 
.mobile-navigation .nav-menu>ul>li:hover>a span:after {transform:translateY(0); opacity: 1;}
.mobile-navigation .nav-menu .submenu {}
.mobile-navigation .nav-menu .submenu ul {display: flex;flex-wrap:wrap; margin: -3px -20px;}
.mobile-navigation .nav-menu .submenu ul li {margin: 3px 20px;}
.mobile-navigation .nav-menu .submenu ul li a {display:block; color:#505050; font-size:18px; letter-spacing: -.04em; line-height:1.3em;}
.mobile-navigation .nav-menu .submenu ul li a:hover {color: #2c2c2c; text-decoration: underline;}
.mobile-overlay {display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:#000; opacity:0.6; z-index:101;}

.mobile-navigation .close {position:absolute; right:5.2%; top:36px; width:22px; height:22px;}
.mobile-navigation .close:before,
.mobile-navigation .close:after {position:absolute; left:11px; content:""; height:25px; width:2px; background-color:#505050;transition-duration:0.4s, 0.4s; transition-delay:0.4s, 0s;}
.mobile-navigation .close:before {transform:rotate(90deg); transition-property:transform;}
.mobile-navigation .close:after {transform:rotate(-90deg); transition-property:transform;}

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 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:#1191d0; height:2px;}
html.menu-opened .btn-m-menu span:before {top:0; transform:rotate(45deg);}
html.menu-opened .btn-m-menu span:after {bottom:2px; transform:rotate(-45deg);}
html.menu-opened .close:before {transform:rotate(45deg);}
html.menu-opened .close:after {transform:rotate(-45deg);}

/* main */
.main-visual {position:relative;}
.main-visual .item {position:relative; height: 100vh;}
.main-visual .item img {position:absolute; top:50%; left:0; transition:.4s ease-in-out; 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-visual .caption {position: absolute; top: 50%; left: 0; width: 100%; text-align: center; transform:translateY(-50%); animation: fadein 3s;}

@keyframes fadein {
    from {
        opacity:0;
    }
    to {
        opacity:1;
    }
}

.main-visual .slick-arrow {position:absolute; top:50%; width:21px; height:40px; margin-top:-20px; z-index:50; background-size: contain; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; border:0; opacity: .6; overflow:hidden; text-indent:-9999em; transition:.2s;}
.main-visual .slick-arrow:hover {opacity: 1;}
.main-visual .slick-prev {background-image:url("../images/main/slide_prev.png"); left:5.2%;}
.main-visual .slick-next {background-image:url("../images/main/slide_next.png"); right:5.2%;}


/* sub */
.sub-visual {position: relative; display:table; table-layout:fixed; width: 100%; height:670px; margin: 0 auto; overflow:hidden; color:#fff; background-color:#eee; background-position:50% 50%; background-attachment:scroll; background-repeat:no-repeat; background-size:cover; border-radius:0 0 260px 0;}
.sub-visual .cell {position: relative; z-index: 1; width: 100%; display:table-cell; vertical-align:bottom; padding: 100px 0;}
.sub-visual h2 {display: inline-block; font-family: 'Lora', serif; color: #fff; font-size:120px; font-weight: 500; line-height:.8em; letter-spacing: -.03em; margin-right: 55px;}
.sub-visual h2 span {position: relative; display: inline-block;}
.sub-visual h2 span:after {content:''; position: absolute; bottom: 100%; left: calc(100% + 5px); width: 12px; height: 12px; background-color: #fff; border-radius:100%;}


.sub-visual .background {
	position: absolute; top: 0; left: 0; width: 100%; height: 100%;
	background-position:20% 50%; background-attachment:scroll; background-repeat:no-repeat; background-size:cover;
	transform:scale(1.09);
    -ms-transform:scale(1.09); /* IE 9 */
    -moz-transform:scale(1.09); /* Firefox */
    -webkit-transform:scale(1.09); /* Safari and Chrome */
    -o-transform:scale(1.09); /* Opera */
	transition: all 2s ease-out 0s;
	transition-delay: 0.1s;
	filter: blur(5px);
}
.sub-visual.loaded .background{
	transform:scale(1);
    -ms-transform:scale(1); /* IE 9 */
    -moz-transform:scale(1); /* Firefox */
    -webkit-transform:scale(1); /* Safari and Chrome */
    -o-transform:scale(1); /* Opera */
	filter: blur(0);
}

.sub-visual .bg1 {background-image:url("../images/common/sv1.jpg")}
.sub-visual .bg2 {background-image:url("../images/common/sv2.jpg")}
.sub-visual .bg3 {background-image:url("../images/common/sv3.jpg")}
.sub-visual .bg4 {background-image:url("../images/common/sv4.jpg")}
.sub-visual .bg5 {background-image:url("../images/common/sv5.jpg")}
.sub-visual .bg6 {background-image:url("../images/common/sv6.jpg")}

.lnb {position: relative; display: inline-block; text-align:center;}
.lnb ul {display:flex; margin: 0 -14px;}
.lnb ul li {position:relative; width: auto; padding: 0 14px;}
.lnb ul li a {position: relative; display: block; color: #fff; font-weight: 300; line-height:1.75em; letter-spacing:-.02em; transition:none;}
.lnb ul li a:after {content:''; position: absolute; bottom: 0; left: auto; right: 0;  width: 0; height: 1px; background-color: #fff; transition:width .2s ease-out;}
.lnb ul li a:hover:after,
.lnb ul li.active a:after {width: 100%; left: 0; right: auto;}

#contArea {max-width:1460px; padding-left:30px; padding-right:30px; padding-top: 90px; margin:0 auto;}
#contArea.wide {max-width: 100%; padding-left: 0; padding-right: 0;}

.sub-title {padding-bottom: 50px;}
.sub-title h2 {font-size:32px; font-weight: 600; line-height:1.4em; letter-spacing:-.04em;}


.real-cont {min-height:300px; padding-bottom:100px;}
.real-cont.flex {display: flex;}

/* footer */
#main #footer {position: absolute; bottom: 0; left: 0; width: 100%; color: #fff; font-weight: 200; background-color: transparent; border-top: 0;}
#main .foot-company {color: #fff; font-weight: 400;}
#main .scroll-top {display: none;}

#footer {position: relative; background: #fff; color: #505050; font-size: 15px; padding: 45px 0; border-top: 1px solid #ddd;}
#footer .contain {max-width: 1780px;}
#footer address {font-style:normal;}

.footer {display: flex;}

.foot-company {width: 105px; color: #2c2c2c; font-size: 1.333em; font-weight: 600;}

.foot-info {flex:1 1 auto; min-width:0; width:1%;}
.foot-info address {margin-left: -35px;}
.foot-info address span {display:inline-block; margin-left: 35px;}

.foot-links {order: 3;}
.foot-links ul {display:flex; margin: 0 -17px;}
.foot-links ul li {padding: 0 17px;}
.foot-links ul li a {display:block;}

.scroll-top {position: fixed; bottom: 30px; right: 5.2%; width:65px; height:65px; z-index:101; color:#fff; font-size:13px; font-weight:400; line-height:1em; text-align:center; padding:21px 0; background:#c9bc9c; border-radius:100%;}
.scroll-top:before {content:""; display:block; width:0; height:0; margin:0 auto 7px; border-left:6px solid transparent; border-right:6px solid transparent; border-bottom:8px solid #fff;}
.scroll-top.ab {position: absolute; bottom: auto; top: -114px;}

.bottom-call {display:none;}