@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. page loader
    05. media queries
---------------------------------------------------
*/

/* ------------------------------
 * header
------------------------------ */
#header {position: absolute; top: 0; left: 0; right: 0; max-height: 200px; z-index: 1000; background-color:#fff}
#header .header-top {height: 120px}
#header .header-top .container {height: 100%}
#header .logo-wrapper {display: table; width: 100%; height: 100%}
#header .logo {display: table-cell; vertical-align: middle}
#header .logo a {display: block; width: 318px; margin: auto}
#header .logo a img {display: block; width: 100%}
#header .btn-nav-open {position: relative; display: none; width: 20px; height: 20px; margin-left: 20px; padding: 0; border: none; background-color: transparent; cursor: pointer; outline: 0; vertical-align: middle}
#header .btn-nav-open span {position: absolute; display: block; left: 50%; width: 16px; height: 2px; margin-left: -8px; background-color: #000; transition: all .3s}
#header .btn-nav-open span:first-child {top: 4px}
#header .btn-nav-open span:nth-child(2) {top: 9px}
#header .btn-nav-open span:last-child {top: 14px}
#header .btn-nav-open:hover span:first-child {top: 0px}
#header .btn-nav-open:hover span:last-child {top: 18px}
body.nav-is-open #header .side-nav {right: 0; opacity: 1}
#header .gnb {border-top: 1px solid #e3e3e3}
#header .gnb .menu-items {font-size: 0; text-align: center}
#header .gnb .menu-items > li {position: relative; display: inline-block}
#header .gnb .menu-items > li > a {position: relative; display: block; font-size: 17px; font-weight: 500; color: #525252; letter-spacing: -0.05rem; line-height: 52px; text-align: center; padding: 0 35px; transition: opacity .25s, line-height .3s}
#header .gnb .menu-items > li > a:hover, #header .gnb .menu-items > li.is-open > a, #header .gnb .menu-items > li.is-active > a {opacity: .8}
#header .gnb .menu-items > li > .subnav-wrap {position: absolute; display: block; top: 100%; left: 0; width: 200px; text-align: left; background-color: #fff; box-shadow: 0 5px 5px 0 rgba(0,0,0,.05); visibility: hidden; overflow: hidden}
#header .gnb .menu-items > li .subnav {padding: 20px 0 30px}
#header .gnb .menu-items > li .subnav > li > a {position: relative; display: block; font-size: 14px; color: #888; padding: 0 25px; transition: color .25s}
#header .gnb .menu-items > li .subnav > li > a span {position: relative; display: block; padding: 12px 0; border-bottom: 1px solid #eee}
#header .gnb .menu-items > li .subnav > li > a span:before {content: ''; position: absolute; bottom: 0; left: 0; width: 0; height: 1px; background-color: #aaa; z-index: 5; transition: width .3s ease}
#header .gnb .menu-items > li .subnav > li > a:hover {color: #222}
#header .gnb .menu-items > li .subnav > li > a:hover span:before {width: 100%}

#header .gnb .member-menu {display: inline-block; padding-left: 40px; vertical-align: middle}
#header .gnb .member-menu li {display: inline-block}
#header .gnb .member-menu li a {font-size: 12px; color: #fff; letter-spacing: 1px; line-height: 90px; transition: line-height .3s}
#header .gnb .member-menu li+li a:before {content: '|'; display: inline-block; margin: 0 15px; color: #fff; opacity: .2}
#header .side-nav {position: fixed; display: none; top: 0; right: -500px; bottom: 0; width: 440px; padding-top: 120px; background-color: #090a0a; z-index: 50; box-shadow: -30px 0 50px 0 rgba(0,0,0,.24); transition: right .45s; transition-timing-function: cubic-bezier(.77,0,.17,1)}
#header .side-nav .btn-nav-close {position: absolute; top: 50px; right: 42px; width: 40px; height: 40px; font-size: 24px; color: #fff; padding: 0; border: none; background-color: transparent; outline: 0; opacity: .6; transition: opacity .25s}
#header .side-nav .btn-nav-close:hover {opacity: 1}
#header .side-nav .side-logo {padding: 0 80px}
#header .side-nav .side-logo a {display: block; max-width: 200px}
#header .side-nav .side-logo a img {display: block; width: 100%}
#header .side-nav .scrollable {margin-top: 40px; max-height: calc(100% - 220px); overflow-y: auto}
#header .side-nav .menu-items {padding: 0 80px}
#header .side-nav .menu-items > li {padding: 12px 0}
#header .side-nav .menu-items > li > a {position: relative; display: block; font-size: 17px; font-weight: 500; color: #555; transition: color .25s}
#header .side-nav .menu-items > li > a span {position: relative; display: block; transition: padding-left .25s}
#header .side-nav .menu-items > li > a span:before {content: '\e907'; font-family: 'xeicon'; font-size: 13px; position: absolute; top: 3px; left: -10px; opacity: 0; transition: left .25s, opacity .25s}
#header .side-nav .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 .side-nav .menu-items > li > a:hover, #header .side-nav .menu-items > li.is-open > a, #header .side-nav .menu-items > li.is-active > a {color: #fff}
#header .side-nav .menu-items > li > a:hover span, #header .side-nav .menu-items > li.is-open > a span, #header .side-nav .menu-items > li.is-active > a span {padding-left: 20px}
#header .side-nav .menu-items > li > a:hover span:before, #header .side-nav .menu-items > li.is-open > a span:before, #header .side-nav .menu-items > li.is-active > a span:before {left: 0; opacity: 1}
#header .side-nav .menu-items > li.is-open.has-child-menu > a:after, #header .side-nav .menu-items > li.is-active.has-child-menu > a:after {transform: rotate(180deg)}
#header .side-nav .menu-items > li > .subnav {display: none; padding-top: 8px}
#header .side-nav .menu-items > li > .subnav > li {padding: 6px 0}
#header .side-nav .menu-items > li > .subnav > li > a {font-size: 14px; color: #666; transition: color .2s}
#header .side-nav .menu-items > li > .subnav > li > a:hover, #header .side-nav .menu-items > li > .subnav > li.is-active > a {color:#eee}
#header .side-nav .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 .side-nav .member-menu li {display: inline-block}
#header .side-nav .member-menu li a {font-size: 16px; color: #666}
#header .side-nav .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}

/* ------------------------------
 * container
------------------------------ */
main {overflow-x: hidden}
#container {position: relative; padding-top: 173px; background-color: #fff; z-index: 20}

/* ------------------------------
 * common bottom section
------------------------------ */
.common-bottom-section {padding: 110px 0}
.common-bottom-section .col-contact .contact-group {padding: 35px 25px 25px; border: 1px solid #dfdfdf}
.common-bottom-section .col-contact .contact-group:first-child {padding: 35px 25px 18px}
.common-bottom-section .col-contact .contact-group + .contact-group {margin-top: 15px}
.common-bottom-section .col-contact .contact-group h3 {font-size: 30px; font-weight: 700; color: #000; margin-bottom: 27px}
.common-bottom-section .col-contact .contact-group dl {font-size: 0}
.common-bottom-section .col-contact .contact-group dl dt, .common-bottom-section .col-contact .contact-group dl dd {display: inline-block; font-size: 20px; color: #000; letter-spacing: -0.05rem; line-height: 2; vertical-align: top}
.common-bottom-section .col-contact .contact-group dl dt {width: 105px; font-weight: normal; text-align: justify; margin-bottom: -2em}
.common-bottom-section .col-contact .contact-group dl dt:after {content: ''; display: inline-block; width: 100%}
.common-bottom-section .col-contact .contact-group dl dd {width: calc(100% - 105px); padding-left: 15px}
.common-bottom-section .col-contact .contact-group dl dd strong {font-weight: normal; color: #fe8340}
.common-bottom-section .col-contact .contact-group dl dd .night {display: inline-block; color: #fff; line-height: 1; margin-left: 10px; padding: 5px 7px; background-color: #fe8340; vertical-align: middle}
.common-bottom-section .col-contact .contact-group .tel-link {display: block}
.common-bottom-section .col-location address {font-size: 28px; color: #000; letter-spacing: -0.05rem; margin-bottom: 25px; padding: 0 30px}
.common-bottom-section .col-location address b {font-size: 30px; margin-right: 20px}

/* ------------------------------
 * quickmenu
------------------------------ */
#quickmenu {position: absolute; top: 173px; right: 0; width: 100px; z-index: 998}
#quickmenu .quick-body ul li a {display: block; font-size: 15px; color: #535353; letter-spacing: -0.06rem; text-align: center; padding: 15px 5px; border: 1px solid #ccc; background-color: #fff}
#quickmenu .quick-body ul li a img {display: block; margin: auto auto 10px}
#quickmenu .quick-body ul li + li a {border-top: 0}
#quickmenu .quick-body ul li .tel {background-color: #f39128}
#quickmenu .quick-body ul li .btn-to-top {font-weight: 700; color: #fff; letter-spacing: 0; background-color: #464646; transition: background-color .25s}
#quickmenu .quick-body ul li .btn-to-top:hover {background-color: #000}

/* ------------------------------
 * footer
------------------------------ */
#footer {padding: 70px 0 90px; text-align: center; background-color: #efeeec}
#footer .footer-logo {max-width: 247px; margin-bottom: 27px}
#footer .sns-link {font-size: 0; margin-bottom: 30px}
#footer .sns-link li {display: inline-block}
#footer .sns-link li + li {margin-left: 7px}
#footer .sns-link li a {display: block}
#footer address {font-size: 17px; font-weight: 300; color: #1a1a1a; line-height: 1.47; margin-bottom: 17px}
#footer .copyright {font-size: 13px; font-weight: 300; color: #7a7a7a; letter-spacing: -0.06rem}

/* ------------------------------
 * page loader
------------------------------ */
#page-loader {position: fixed; top: 0; left: 0; bottom: 0; right: 0; background-color: #f8f9fa; z-index: 9999}
#page-loader .loader {position: absolute; top: 50%; left: 50%; display: inline-block; width: 40px; height: 40px; margin: -20px 0 0 -20px; border: 5px solid #f6b220; animation: loader 2s infinite ease}
#page-loader .loader .loader-inner {display: inline-block; width: 100%; background-color: #f6b220; vertical-align: top; animation: loader-inner 2s infinite ease-in}

@keyframes loader {
    0% {transform: rotate(0deg)}
    25% {transform: rotate(180deg)}
    50% {transform: rotate(180deg)}
    75% {transform: rotate(360deg)}
    100% {transform: rotate(360deg)}
}

@keyframes loader-inner {
    0% {height: 0%}
    25% {height: 0%}
    50% {height: 100%}
    75% {height: 100%}
    100% {height: 0%}
}


/* ------------------------------
 * media queries
------------------------------ */
@media (min-width:768px) {
    /* #header .logo .logo-dark {display: none} */
}

@media (min-width:1200px) {
    #header .btn-call {display: none}
    #header.sticky {position: fixed; top: -121px}
}

@media (max-width: 1359px) {
    .common-bottom-section .col-contact .contact-group dl dt, .common-bottom-section .col-contact .contact-group dl dd {font-size: 18px}
}

@media (max-width: 1299px) {
    #header .gnb .menu-items > li > a {padding: 0 24px}
    #quickmenu {display: none}
}

@media (max-width:1199px) {
    #header {position: fixed; height: 80px; max-height: inherit; padding-left:40%; }
    #header .header-top {height: 100%}
    #header .logo-wrapper {position: absolute; width: auto; z-index: 20}
    #header .logo a {width: 180px; margin-left: 0}
    #header .btn-call {display: inline-block; width: 32px; height: 32px; font-size: 19px; color: #fff; text-align: center; line-height: 32px; border-radius: 50%; background-color: #f39128; vertical-align: middle}
    #header .btn-nav-open {display: inline-block}
    #header .gnb {position: absolute; left: 0; right:0; top:50%; max-width: 970px; margin-top:-16px; margin-left: auto; margin-right: auto; text-align:right; border:0}
    #header .gnb .menu-items {display: none}
    #header .side-nav {display: block}

    .common-bottom-section .col-contact .contact-group {padding: 25px 25px 32px}
    .common-bottom-section .col-contact .contact-group h3 {font-size: 21px; margin-bottom: 20px}
    .common-bottom-section .col-contact .contact-group dl dt, .common-bottom-section .col-contact .contact-group dl dd {font-size: 15px}
    .common-bottom-section .col-contact .contact-group dl dt {width: 72px}    
    .common-bottom-section .col-contact .contact-group dl dd {width: calc(100% - 72px)}
    .common-bottom-section .col-location address {font-size: 21px; margin-bottom: 20px; padding: 0 20px}
    .common-bottom-section .col-location address b {font-size: 23px; margin-right: 10px}

    #container {padding-top: 80px}
}

@media (max-width: 991px) {
    #header .gnb {max-width: 750px}

    .common-bottom-section .col-location address {font-size: 17px; margin-bottom: 15px; padding: 0}
    .common-bottom-section .col-location address b {font-size: 19px}
}

@media (max-width:767px) {
    #header {height: 70px; padding-left:10%; }
    #header .logo {width: 160px}
    #header .gnb {padding-left: 15px; padding-right: 15px}
    #header .gnb .member-menu {display: none}
    #header .btn-nav-open span {background-color: #000}
    #header .side-nav {right: -360px; bottom: 0; width: 300px; padding-top: 100px}
    #header .side-nav .btn-nav-close {top: 40px; right: 10px}
    #header .side-nav .side-logo {padding: 0 40px}
    #header .side-nav .side-logo a {max-width: 160px}
    #header .side-nav .scrollable {max-height: calc(100% - 180px)}
    #header .side-nav .menu-items {padding: 0 40px}
    #header .side-nav .menu-items > li > a {font-size: 15px}
    #header .side-nav .menu-items > li > a span:before {top: 2px}
    #header .side-nav .menu-items > li.has-child-menu > a:after {font-size: 15px; margin-top: -11px}
    #header .side-nav .menu-items > li > .subnav > li > a {font-size: 13px}
    #header .side-nav .member-menu {left: 40px; right: 40px}
    #header .side-nav .member-menu li a {font-size: 13px}
    #header.sticky {box-shadow: 0 1px 2px 0 rgba(0,0,0,.12)}

    #container {padding-top: 70px}

    .common-bottom-section {padding: 60px 0}
    .common-bottom-section .col-contact .contact-group {padding: 30px 25px !important}
    .common-bottom-section .col-contact .contact-group h3 {font-size: 19px; margin-bottom: 15px}
    /* .common-bottom-section .col-contact .contact-group dl dt, .common-bottom-section .col-contact .contact-group dl dd {font-size: 13px; line-height: 1.8} */
    /* .common-bottom-section .col-contact .contact-group dl dt {width: 54px; margin-bottom: -1.8em} */
    /* .common-bottom-section .col-contact .contact-group dl dd {width: calc(100% - 54px)} */
    .common-bottom-section .col-contact .contact-group .tel-link {max-width: 160px}
    .common-bottom-section .col-location {margin-top: 30px}
    .common-bottom-section .col-location address {font-size: 14px}
    .common-bottom-section .col-location address b {font-size: 14px}

    #footer {padding: 50px 0 70px}
    #footer .footer-logo {max-width: 160px}
    #footer address {font-size: 13px}
    #footer .copyright {font-size: 12px}
}