@charset "utf-8";
/*
 * Name     : layout.css
 * Version  : 1.0.4
 * Author   : onepixel studio
 * Date     : 2020-05-10
 ---------------------------------------------------
 Table of contents
 ---------------------------------------------------
    01. header
    02. container
    03. footer
    04. media queries
---------------------------------------------------
*/
/* ------------------------------
 * body
------------------------------ */
body {opacity:0; transition:opacity 0.5s}
body.__load {opacity:1}

/* ------------------------------
 * header
------------------------------ */
#header {position:fixed; top:0; left:0; right:0; height:70px; border-bottom:1px solid rgba(255,255,255,0.15); background-color:transparent; z-index:1000; transition:height 0.3s, border-color 0.3s, background-color 0.3s}
#header .container-fluid {position:relative; height:100%}
#header .logo {position:absolute; top:0; left:32px; display:table; width:180px; height:100%}
#header .logo a {display:table-cell; vertical-align:middle}
#header .logo a img {display:block; width:100%; max-height:0; opacity:0; transition:opacity 0.3s}
#header .logo a img.logo-light {max-height:48px; opacity:1}
#header.sticky {height:60px; border-color:#e9e9e9; background-color:#fff}
#header.sticky .logo a img.logo-light {max-height:0; opacity:0}
#header.sticky .logo a img.logo-dark {max-height:48px; opacity:1}
/* ------------------------------
 * header
------------------------------ 
#header {position: fixed; top: 0; left: 0; right: 0; height: 160px; z-index: 1000; transition: all .3s}
#header .container-wide {position: relative; height: 100%}
#header .logo {position: absolute; top: 0; left: 80px; display: table; width: 210px; height: 160px; transition: height .3s}
#header .logo a {display: table-cell; vertical-align: middle}
#header .logo a img {display: block; width: 100%}
#header .btn-nav-open {position: absolute; top: 50%; right: 80px; width: 50px; height: 50px; margin-top: -25px; padding: 0; border: none; background-color: transparent; cursor: pointer; outline: 0}
#header .btn-nav-open span {position: absolute; display: block; left: 50%; width: 24px; height: 2px; margin-left: -12px; background-color: #333; transition: all .3s}
#header .btn-nav-open span:first-child {top: 14px}
#header .btn-nav-open span:nth-child(2) {top: 22px}
#header .btn-nav-open span:last-child {top: 30px}
#header .btn-nav-open:hover span:first-child {top: 10px}
#header .btn-nav-open:hover span:last-child {top: 34px}
#header .btn-nav-open[aria-expanded="true"] + .gnb {right: 0; opacity: 1}
#header .gnb {position: fixed; top: 0; right: -400px; bottom: 0; width: 400px; padding-top: 120px; background-color: #0c0c0c; z-index: 50; box-shadow: -30px 0 50px 0 rgba(0,0,0,.24); opacity: 0; transition: opacity .8s, right .45s; transition-timing-function: ease}
#header .gnb .btn-nav-close {position: absolute; top: 50px; right: 42px; width: 60px; height: 60px; font-size: 42px; color: #fff; padding: 0; border: none; background-color: transparent; outline: 0}
#header .gnb .scrollable {max-height: calc(100% - 160px); overflow-y: auto}
#header .gnb .menu-items {padding: 0 60px}
#header .gnb .menu-items > li {padding: 12px 0}
#header .gnb .menu-items > li > a {position: relative; display: block; font-size: 24px; font-weight: 500; color: #555; transition: color .25s}
#header .gnb .menu-items > li > a span {position: relative; display: inline-block; z-index: 5}
#header .gnb .menu-items > li > a span:before {content: ''; position: absolute; display: block; bottom: 6px; left: 0; width: 0; height: 6px; background-color: #4f9f6e; transition: width 0.25s ease-in-out; z-index: -1}
#header .gnb .menu-items > li.has-child-menu > a:after {content: '\e943'; position: absolute; top: 50%; right: 0; font-family: 'xeicon'; font-size: 17px; color: #aaa; margin-top: -12px; transition: transform .25s ease}
#header .gnb .menu-items > li > a:hover, #header .gnb .menu-items > li.is-open > a, #header .gnb .menu-items > li.is-active > a {color: #fff}
#header .gnb .menu-items > li > a:hover span:before, #header .gnb .menu-items > li.is-open > a span:before, #header .gnb .menu-items > li.is-active > a span:before {width: 100%}
#header .gnb .menu-items > li.is-open.has-child-menu > a:after {transform: rotate(180deg)}
#header .gnb .menu-items > li > .subnav {display: none; padding-top: 8px}
#header .gnb .menu-items > li > .subnav > li {padding: 8px 0}
#header .gnb .menu-items > li > .subnav > li > a {font-size: 17px; color: #666; transition: color .2s}
#header .gnb .menu-items > li > .subnav > li > a:hover, #header .gnb .menu-items > li > .subnav > li.is-active > a {color:#eee}
#header .gnb .member-menu {position: absolute; bottom: 0; left: 60px; right: 60px; font-size: 0; text-align: center; padding-top: 30px; padding-bottom: 60px; border-top: 4px solid rgba(255,255,255,.14)}
#header .gnb .member-menu li {display: inline-block}
#header .gnb .member-menu li a {font-size: 16px; color: #666}
#header .gnb .member-menu li+li a:before {content: '/'; display: inline-block; margin: 0 15px; color: #fff; opacity: .2}
#header .nav-dimmed {display: none; position: fixed; top: 0; left: 0; bottom: 0; right: 0; z-index: 30}
#header.sticky {height: 80px; background-color: rgba(255,255,255,.9)}
#header.sticky .logo {height: 80px}
#header.sticky .menu{margin-top:28px; top:0; height:0px;}

#header .menu{position: absolute; top: 0px; right: 100px; display: table; width: 800px; height: 50px; transition: height -.3s; margin-top:65px;}
#header .menu a {display: table-cell; vertical-align: middle; color;#6bc08c;}
#header .menu ul li{display:inline-block; padding-right:80px; font-size:18px;}

/* ------------------------------
 * container
------------------------------ */
main {overflow-x: hidden}
body.main #container {padding-top:100vh}
body.main #container .section-container {position: relative; background-color: #fff; z-index: 20}

/* ------------------------------
 * footer
------------------------------ */
#btn-to-top {position:fixed; display: block; bottom: 50px; right: -60px; width: 60px; height: 60px; font-size: 20px; color: #fff; text-align: center; line-height: 60px; border-radius: 50%; background-color: #6bc08c; opacity: 0; z-index: 500; transition: background-color .5s, opacity .5s, right .5s}
#btn-to-top.show {right: 50px; opacity: 1}
#btn-to-top:hover {background-color: #000}

#footer {position: relative; padding: 60px 0; background-color: #222325; z-index: 20}
#footer .col-logo {text-align: right}
#footer .col-logo img {max-width: 180px; opacity: .5}
#footer .col-info .link-items {font-size: 0; margin-bottom: 20px}
#footer .col-info .link-items li {display:inline-block; margin-right: 25px}
#footer .col-info .link-items li a {font-size: 14px; color: #999}
#footer .col-info .link-items li a:hover {color: #fff}
#footer .col-info p {font-size: 14px; color: #616161; line-height: 1.85}
#footer .col-info p .divider:before {content: ''; display: inline-block; width: 1px; height: 14px; margin: 0 10px; background-color: rgba(255,255,255,.14); vertical-align: -1px}

/* ------------------------------
 * media queries
------------------------------
@media (max-width:1200px) {
	#header .menu{display:none;}
}

@media (max-width:991px) {
    #header {height: 100px}
    #header .logo {left: 15px; height: 100px}
    #header .btn-nav-open {right: 15px}
	#header .menu{display:none;}
}

@media (max-width:767px) {
    #header .logo {width: 160px}
    #header .gnb {right: -300px; bottom: 0; width: 300px}
    #header .gnb .btn-nav-close {top: 40px; right: 10px}
    #header .gnb .scrollable {max-height: calc(100% - 160px)}
    #header .gnb .menu-items {padding: 0 25px}
    #header .gnb .menu-items > li > a {font-size: 19px}
    #header .gnb .menu-items > li > a span:before {content: ''; position: absolute; display: block; bottom: 6px; left: 0; width: 0; height: 6px; background-color: #e4b465; transition: width 0.25s ease-in-out; z-index: -1}
    #header .gnb .menu-items > li.has-child-menu > a:after {font-size: 15px; margin-top: -11px}
    #header .gnb .menu-items > li > .subnav > li > a {font-size: 15px}
    #header .gnb .member-menu {left: 25px; right: 25px}
    #header .gnb .member-menu li a {font-size: 14px}
    #header.sticky {height: 60px}
    #header.sticky .logo {height: 60px}

	#header .menu{display:none;}

    #btn-to-top {right: -50px; width: 50px; height: 50px; font-size: 18px; line-height: 50px}
    #btn-to-top.show {right: 15px}
    
    #footer .col-logo {text-align: left; margin-bottom: 30px}
    #footer .col-info .link-items li {margin-right: 15px}
    #footer .col-info .link-items li a {font-size: 12px}
    #footer .col-info p {font-size: 12px}
    #footer .col-info p .divider:before {height: 10px; margin: 0 8px}
}

/* ------------------------------
 * media queries
------------------------------ */
@media (min-width:992px) {
    #header nav {right:auto !important; opacity:1}
    #header nav .mobile-header {display:none}
    #header .gnb {position:absolute; top:0; left:50%; font-size:0; white-space: nowrap; transform: translateX(-50%); z-index: 100}
    #header .gnb > li {position:relative; display:inline-block; font-size:17px; text-align:center; vertical-align:top}
    #header .gnb > li > a {position:relative; display:block; color:#222; letter-spacing:0px; height:70px; line-height:70px; padding:0 50px; transition:color 0.3s, line-height 0.3s, height 0.3s}
    #header .gnb > li > a:after {content:''; position:absolute; display:block; bottom:0; left:50%; width:0; height:2px; background-color:#fff; transition:left 0.3s, width 0.3s}
    #header .gnb > li:hover > a, #header .gnb > li.is-active > a {color:#6bc08c !important}
    #header .gnb > li:hover > a:after {left:0; width:100%}
    #header .gnb > li > .subnav {display:none; position:absolute; left:0; right:0; padding:20px 30px; z-index:100}
    #header .gnb > li > .subnav li + li {margin-top:5px}
    #header .gnb > li > .subnav li a {font-size:15px; color:#8a8a8a; line-height:1.65; transition:color 0.2s}
    #header .gnb > li > .subnav li a:hover, #header .gnb > li > .subnav li.is-active a {color:#6bc08c}
    #header .member-nav {position:absolute; top:0; right:32px; text-align:right; font-size:0}
    #header .member-nav > li {display:inline-block; font-size:16px}
    #header .member-nav > li > a {display:block; font-size:14px; color:#fff; line-height:70px; margin:0 8px; opacity:0.8; transition:color 0.3s, line-height 0.3s}
    #header .btn-open-nav {display:none}
    #header .nav-dimmed {display:none !important}
    #header.sticky .gnb > li > a {height:60px; line-height:60px}
    #header.sticky .member-nav > li > a {line-height:60px}
    #header.is-active {border-color:#e9e9e9; background-color:#fff}
    #header.is-active .logo a img.logo-light {max-height:0; opacity:0}
    #header.is-active .logo a img.logo-dark {max-height:48px; opacity:1}
    #header.sticky .gnb > li > a:after, #header.is-active .gnb > li > a:after {background-color:#6bc08c;}
    #header.sticky .gnb > li > a, #header.is-active .gnb > li > a {color:#2b2b2b}
    #header.sticky .member-nav > li > a, #header.is-active .member-nav > li > a {color:#2b2b2b}
    #header .subnav-bg {position:absolute; display:none; left:0; right:0; margin-top:1px; background-color:#fff; box-shadow:0 1px 2px rgba(0,0,0,0.08); z-index:10}
}

@media (max-width:991px) {
    #header .logo {left:15px}
    #header nav {position:absolute; top:0; right:-240px; width:240px; height:100vh; padding-bottom:40px; background-color:#fff; box-shadow:-6px 0 18px 0 rgba(0,0,0,0.08); z-index:100; opacity:0; overflow-x:hidden; overflow-y:auto; transition:opacity 0.4s cubic-bezier(0.305,0.405,0.085,0.975), right 0.4s cubic-bezier(0.305,0.405,0.085,0.975)}
    #header nav .mobile-header {position:relative; padding:23px 25px; border-bottom:1px solid #fff; background-color:#fff;}
    #header nav .mobile-header img {max-width:160px}
    #header nav .btn-close-nav {position:absolute; top:50%; left:-50px; width:40px; height:40px; font-size:38px; color:#fff; line-height:1; margin-top:-20px; padding:0; border:none; background-color:transparent; outline:0; opacity:0; visibility:hidden; transition:opacity 0.25s; transition-delay:0.45s}
    #header .gnb {padding:24px 0}
    #header .gnb > li > a {position:relative; display:block; font-size:16px; color:#7a7a7a; padding:8px 25px}
    #header .gnb > li.has-child-menu > a:after {content:'\e943'; position:absolute; right:25px; font-family:'xeicon'; color:#aaa; transition:transform 0.3s ease}
    #header .gnb > li.is-active > a, #header .gnb > li.is-open > a {color:#6bc08c;}
    #header .gnb > li.is-open > a:after {transform:rotate(180deg)}
    #header .gnb > li > .subnav {display:none; padding:5px 25px}
    #header .gnb > li > .subnav.visible {display:block}
    #header .gnb > li > .subnav > li > a {position:relative; display:block; font-size:13px; color:#8a8a8a; padding:5px 0 5px 15px}
    #header .gnb > li > .subnav > li.is-active > a {color:#6bc08c;}
    #header .gnb > li > .subnav > li > a:before {content:''; position:absolute; display:block; top:50%; left:0; width:6px; height:1px; margin-top:-1px; background-color:#d8dde8}
    #header .gnb > li > .subnav > li.is-active > a:before {background-color:#6bc08c;}
    #header .member-nav {padding:24px 25px 0; text-align:center; border-top:1px solid #f1f1f1}
    #header .member-nav > li {display:inline-block}
    #header .member-nav > li + li:before {content:'/'; font-size:12px; font-style:italic; color:#ccc; margin:0 12px 0 8px}
    #header .member-nav > li > a {font-size:14px; color:#999}
    #header .member-nav > li .btn {display:block; width:100%}
    #header .btn-open-nav {position:absolute; top:50%; right:9px; width:36px; height:36px; margin-top:-18px; padding:0; border:none; background-color:transparent; cursor: pointer; outline:0}
    #header .btn-open-nav > span {position:absolute; display:block; left:50%; width:20px; height:2px; margin-left:-10px; border-radius:4px; background-color:#fff; transition:all 0.35s cubic-bezier(0.305,0.405,0.085,0.975)}
    #header .btn-open-nav > span:first-child {top:11px}
    #header .btn-open-nav > span:nth-child(2), #header .btn-open-nav > span:nth-child(3) {top:17px}
    #header .btn-open-nav > span:nth-child(4) {top:23px}
    #header .btn-open-nav > span:nth-child(4) {top:23px}
    #header .btn-open-nav[aria-expanded="true"] >span:first-child, #header .btn-open-nav[aria-expanded="true"] >span:nth-child(4) {top:17px; width:0; margin-left:0}
    #header .btn-open-nav[aria-expanded="true"] >span:nth-child(2) {transform:rotate(45deg)}
    #header .btn-open-nav[aria-expanded="true"] >span:nth-child(3) {transform:rotate(-45deg)}
    #header .btn-open-nav[aria-expanded="true"] + nav {right:0; opacity:1; transition-delay:0.45s}
    #header .btn-open-nav[aria-expanded="true"] + nav .btn-close-nav {opacity:1; visibility:visible}
    #header .nav-dimmed {display:none; position:absolute; top:0; left:0; right:0; height:100vh; background-color:#000; opacity:0.5; z-index:50}
    #header.sticky .btn-open-nav > span {background-color:#000}
}

@media (max-width:767px) {
    #footer .footer-nav li {margin:0 8px 15px}
    #footer .footer-nav li a {font-size:13px}
    #footer .sns-icons {margin:20px 0 30px}
    #footer .info {font-size:12px}
}