@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. quickmenu
    04. footer
    05. page loader
    06. media queries
---------------------------------------------------
*/

/* ------------------------------
 * header
------------------------------ */
#header {position: fixed; top: 0; left: 0; right: 0; height: 100px; z-index: 1000; transition: all .3s}
#header .container-wide {position: relative; height: 100%}
#header .flex-row {height: 100%}
#header .logo {width: 226px; padding-bottom: 12px}
#header .logo a {display: block}
#header .logo a img {display: block; width: 100%}
#header .btn-nav-open {position: relative; display: inline-block; width: 32px; height: 23px; 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: 100%; height: 3px; margin-left: -16px; background-color: #fff; transition: all .3s}
#header .btn-nav-open span:first-child {top: 0}
#header .btn-nav-open span:nth-child(2) {top: 50%; margin-top: -1.5px}
#header .btn-nav-open span:last-child {bottom: 0}
/* #header .btn-nav-open:hover span:first-child {top: 0} */
/* #header .btn-nav-open:hover span:last-child {top: 18px} */
body.nav-is-open #header .side-nav {right: 0; opacity: 1}
#header .gnb .menu-items {display: inline-block; font-size: 0; vertical-align: middle}
#header .gnb .menu-items > li {position: relative; display: inline-block}
#header .gnb .menu-items > li > a {position: relative; display: block; font-size: 18px; font-weight: 700; color: #fff; letter-spacing: -0.03em; padding: 0 20px}
#header .gnb .menu-items > li > a:hover, #header .gnb .menu-items > li.is-active > a, #header .gnb .menu-items > li.is-open > a {color: #5ebfbf !important}
#header .gnb .menu-items > li > .subnav-wrap {position: absolute; display: block; top: 100%; left: 0; width: 240px; 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: 30px 0}
#header .gnb .menu-items > li .subnav > li > a {position: relative; display: block; font-size: 14px; color: #888; padding: 5px 35px; transition: color .25s}
#header .gnb .menu-items > li .subnav > li > a span {position: relative; display: block; overflow: hidden; transition: padding-left .25s}
#header .gnb .menu-items > li .subnav > 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 .gnb .menu-items > li .subnav > li > a:hover {color: #222}
#header .gnb .menu-items > li .subnav > li > a:hover span {padding-left: 20px}
#header .gnb .menu-items > li .subnav > li > a:hover span:before {left: 0; opacity: 1}
#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; 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}
#header.sticky {height: 80px; background-color: #4e4e4e}
#header.sticky .gnb .member-menu li a {line-height: 80px}
body:not(.main) #header {background-color: #fff}
body:not(.main) #header .logo .logo-light {display: none}
body:not(.main) #header .logo .logo-dark {display: block}
body:not(.main) #header .gnb .menu-items > li > a {color: #000}
body:not(.main) #header .btn-nav-open span {background-color: #000}

/* ------------------------------
 * container
------------------------------ */
main {overflow-x: hidden}
#container {position: relative; background-color: #fff; z-index: 20}

/* ------------------------------
 * quickmenu
------------------------------ */
#quickmenu {display: none; position: fixed; top: 25.1%; right: 0; width: 105px; z-index: 500}
#quickmenu ul li a {position: relative; display: block; padding: 18px 6px; text-align: center; background-color: #fff}
#quickmenu ul li:not(:first-child) + li a::before {content: ''; position: absolute; top: 0; left: 10px; right: 10px; height: 1px; background-color: #e3e3e3}
#quickmenu ul li a span {display: block; font-size: 16px; font-weight: 500; color: #555; letter-spacing: -0.04em; margin-top: 12px}
#quickmenu ul li:first-child a {background-color: #1ac1c1}
#quickmenu ul li:first-child a span {color: #fff}
#quickmenu .button-top {display: block; font-size: 14px; font-weight: 500; color: #fff; text-align: center; letter-spacing: 0; padding: 8px; background-color: #3e3e3e}
#quickmenu-mobile {display: none}

/* ------------------------------
 * kakao banner
------------------------------ */
#kakao-banner {display: none; position: fixed; bottom: 60px; right: 42px; width: 132px; border-radius: 26px; background-color: #fff; z-index: 500; overflow: hidden}
#kakao-banner .icon {width: 53px; height: 53px; text-align: center; line-height: 51px; margin-right: 12px; border-radius: 50%; background-color: #ffe100}
#kakao-banner p {font-size: 18px; font-weight: 700; color: #000; letter-spacing: -0.04em}

/* ------------------------------
 * footer
------------------------------ */
#footer {background-color: #383838}
#footer .footer-top {padding-top: 75px}
#footer .footer-top .footer-row {margin-left: -90px; margin-right: -90px}
#footer .footer-top .footer-row > div {padding-top: 24px; padding-left: 90px; padding-right: 90px; padding-bottom: 90px}
#footer .footer-top .footer-row .col-info .kakao-info {margin-top: 54px}
#footer .footer-top .footer-row .col-info .timetable-info {margin-top: 56px}
#footer .footer-top .footer-row .col-info .info-row .info-header {width: 47.38%}
#footer .footer-top .footer-row .col-info .info-row .info-header .icon {width: 66px}
#footer .footer-top .footer-row .col-info .info-row .info-header .header {width: calc(100% - 66px)}
#footer .footer-top .footer-row .col-info .info-row .info-header .header h4 {font-size: 18px; font-weight: 500; color: #fff; letter-spacing: -0.04em}
#footer .footer-top .footer-row .col-info .info-row .info-content {width: 52.62%}
#footer .footer-top .footer-row .col-info .info-row .info-content h3 {font-size: 30px; font-weight: 500; color: #56babb; letter-spacing: -0.04em}
#footer .footer-top .footer-row .col-info .info-row .info-content h3 a {color: #56babb}
#footer .footer-top .footer-row .col-info .info-row .info-content p {font-size: 18px; color: #fff; letter-spacing: -0.04em; line-height: 1.55}
#footer .footer-top .footer-row .col-info .info-row .info-content p.kakao-content {margin-top: -4px}
#footer .footer-top .footer-row .col-info .info-row .info-content p span {color: #56bbbb}
#footer .footer-top .footer-row .col-info .info-row .info-content .timetable-list {font-size: 0; margin-top: -8px}
#footer .footer-top .footer-row .col-info .info-row .info-content .timetable-list dt, #footer .footer-top .footer-row .col-info .info-row .info-content .timetable-list dd {display: inline-block; font-size: 18px; line-height: 1.66; letter-spacing: -0.04em; vertical-align: top}
#footer .footer-top .footer-row .col-info .info-row .info-content .timetable-list dt {width: 48px; font-weight: normal; color: #fff; text-align: justify; margin-bottom: -1.66em; overflow: hidden}
#footer .footer-top .footer-row .col-info .info-row .info-content .timetable-list dt::after {content: ''; display: inline-block; width: 100%}
#footer .footer-top .footer-row .col-info .info-row .info-content .timetable-list dd {width: calc(100% - 48px); padding-left: 42px; font-weight: 300; color: #d3d3d3}
#footer .footer-top .footer-row .col-info .sns-group {margin-top: 50px}
#footer .footer-top .footer-row .col-info .sns-group h4 {font-size: 18px; font-weight: 700; color: #fff; letter-spacing: -0.04em; margin-bottom: 30px}
#footer .footer-top .footer-row .col-info .sns-group .sns-row {margin-left: -3px; margin-right: -3px}
#footer .footer-top .footer-row .col-info .sns-group .sns-item {padding-left: 3px; padding-right: 3px}
#footer .footer-top .footer-row .col-info .sns-group .sns-item > a {width: 100%; height: 64px; background-color: #424242}
#footer .footer-top .footer-row .col-info .sns-group .sns-item > a:hover {background-color: #4b4b4b}
#footer .footer-top .footer-row .col-info .sns-group .sns-item > a .sns-icon {margin-right: 36px}
#footer .footer-top .footer-row .col-info .sns-group .sns-item > a p {font-size: 14px; font-weight: 300; color: #d7d7d7}
#footer .footer-top .footer-row .col-location {border-left: 1px solid #676767}
#footer .footer-top .footer-row .col-location .map-wrapper {position: relative; margin-bottom: 32px; padding-bottom: 53.9%}
#footer .footer-top .footer-row .col-location .map-wrapper .root_daum_roughmap {position: absolute; top: 0; left: 0; width: 100% !important; height: 100% !important}
#footer .footer-top .footer-row .col-location .map-wrapper .root_daum_roughmap .wrap_map {height: 100% !important}
#footer .footer-top .footer-row .col-location .location-info {font-size: 0}
#footer .footer-top .footer-row .col-location .location-info dt, #footer .footer-top .footer-row .col-location .location-info dd {display: inline-block; font-size: 18px; letter-spacing: -0.04em; vertical-align: middle}
#footer .footer-top .footer-row .col-location .location-info dt {width: 172px; font-weight: 700; color: #fff}
#footer .footer-top .footer-row .col-location .location-info dd {width: calc(100% - 172px); font-weight: 300; color: #d3d3d3}
#footer .footer-top .footer-row .col-location .button-contact {width: 100%; height: 64px; margin-top: 30px; font-size: 18px; font-weight: 700; color: #fff; letter-spacing: -0.04em; background-color: #56bbbb}
#footer .footer-top .footer-row .col-location .button-contact:hover {background-color: #52b5b5}
#footer .footer-bottom {padding-top: 48px; padding-bottom: 60px; border-top: 1px solid #676767}
#footer .footer-bottom .footer-menu-items {font-size: 0; margin-bottom: 22px}
#footer .footer-bottom .footer-menu-items > a {display: inline-block; font-size: 17px; color: #fff; letter-spacing: -0.03em; margin-right: 40px}
#footer .footer-bottom address {margin-bottom: 0; font-size: 15px; color: #9c9c9c; letter-spacing: -0.03em; line-height: 2}
#footer .footer-bottom address span {display: inline-block; margin-left: 28px}

/* ------------------------------
 * page loader
------------------------------ */
#page-loader {display: none; 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 #1ac1c1; animation: loader 2s infinite ease}
#page-loader .loader .loader-inner {display: inline-block; width: 100%; background-color: #1ac1c1; 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: 992px) {
    body.main #quickmenu {display: block}
    body.main #kakao-banner {display: -ms-flexbox !important; display: flex !important}
}

@media (max-width: 1464px) {
    #header .gnb .menu-items > li > a {font-size: 16px; padding: 0 16px}
}

@media (max-width: 1323px) {
    #header .gnb .menu-items > li > a {font-size: 15px; padding: 0 6px}
}

@media (max-width:1199px) {
    #header .gnb .menu-items {display: none}

    #footer .footer-top .footer-row {margin-left: -45px; margin-right: -45px}
    #footer .footer-top .footer-row > div {padding-left: 45px; padding-right: 45px}
    #footer .footer-top .footer-row .col-info .info-row .info-header {width: 38%}
    #footer .footer-top .footer-row .col-info .info-row .info-content {width: 62%}
    #footer .footer-top .footer-row .col-location .location-info dt {width: 100px}
    #footer .footer-top .footer-row .col-location .location-info dd {width: calc(100% - 100px)}
}

@media (max-width: 991px) {
    #footer .footer-top {padding-top: 60px}
    #footer .footer-top .footer-row {margin-left: -10px; margin-right: -10px}
    #footer .footer-top .footer-row > div {padding-left: 10px; padding-right: 10px; padding-bottom: 60px}
    #footer .footer-top .footer-row .col-location {border-left: 0}
}

@media (max-width:767px) {
    #header {height: 60px}
    #header .logo {width: 147px; padding-bottom: 6px}
    #header .gnb {height: 100%}
    #header .gnb:before {content: ''; display: inline-block; width: 1px; height: 100%; vertical-align: middle}
    #header .gnb .member-menu {display: none}
    #header .btn-nav-open {width: 27px; height: 19.5px}
    #header .btn-nav-open span {height: 2px; margin-left: -13.5px; background-color: #000; transition: all .3s}
    #header .btn-nav-open span:nth-child(2) {margin-top: -1px}

    body:not(.main) #header {background-color: #fff}
    body:not(.main) #header .logo .logo-light {display: none}
    body:not(.main) #header .logo .logo-dark {display: block}
    body.main #header .logo .logo-dark {display: none}
    body.main #header .btn-nav-open span {background-color: #fff}

    #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 {height: 60px; background-color: #fff; box-shadow: 0 2px 2px 0 rgba(0,0,0,.05)}
    #header.sticky .logo .logo-light {display: none !important}
    #header.sticky .logo .logo-dark {display: block !important}
    #header.sticky .btn-nav-open span {background-color: #000 !important}

    body:not(.main) #container {margin-top: 60px}

    #quickmenu-mobile {position: fixed; bottom: 0; left: 0; right: 0; z-index: 500}
    #quickmenu-mobile .button-contact {width: 100%; height: 62px; background-color: #424242}
    #quickmenu-mobile .button-contact.naver {background-color: #59c8c8}
    #quickmenu-mobile .button-contact .icon {width: 18px; margin-right: 8px; font-size: 0}
    #quickmenu-mobile .button-contact .icon img {max-height: 17px}
    #quickmenu-mobile .button-contact p {font-size: 15px; font-weight: 700; color: #fff; letter-spacing: -0.04em}
    body.main #quickmenu-mobile {display: block}

    body.main #kakao-banner {display: -ms-flexbox !important; display: flex !important; bottom: 90px; right: 25px; width: auto}
    #kakao-banner .icon {width: 52px; height: 52px; margin-right: 0; line-height: 48px}
    #kakao-banner p {display: none}

    #footer .footer-top {padding-top: 48px}
    #footer .footer-top .footer-row > div {padding-top: 0; padding-bottom: 0}
    #footer .footer-top .footer-row .col-info .kakao-info {display: none}
    #footer .footer-top .footer-row .col-info .info-row .info-header {width: 140px}
    #footer .footer-top .footer-row .col-info .info-row .info-content {width: calc(100% - 140px)}
    #footer .footer-top .footer-row .col-info .info-row .info-header .icon {width: 28px}
    #footer .footer-top .footer-row .col-info .info-row .info-header .icon img {width: 15px}
    #footer .footer-top .footer-row .col-info .info-row .info-header .header {width: calc(100% - 28px)}
    #footer .footer-top .footer-row .col-info .info-row .info-header .header h4 {font-size: 16px}
    #footer .footer-top .footer-row .col-info .info-row .info-content h3 {font-size: 28px}
    #footer .footer-top .footer-row .col-info .timetable-info {margin-top: 30px}
    #footer .footer-top .footer-row .col-info .info-row .info-content .timetable-list {margin-top: 0}
    #footer .footer-top .footer-row .col-info .info-row .info-content .timetable-list dt, #footer .footer-top .footer-row .col-info .info-row .info-content .timetable-list dd {font-size: 15px}
    #footer .footer-top .footer-row .col-info .info-row .info-content .timetable-list dt {width: 40px}
    #footer .footer-top .footer-row .col-info .info-row .info-content .timetable-list dd {width: calc(100% - 40px); padding-left: 36px}
    #footer .footer-top .footer-row .col-info .sns-group {display: none}
    #footer .footer-top .footer-row .col-location {margin-top: 30px; padding-bottom: 38px}
    #footer .footer-top .footer-row .col-location .map-wrapper {margin-bottom: 26px}
    #footer .footer-top .footer-row .col-location .location-info dt {width: 86px; font-size: 16px}
    #footer .footer-top .footer-row .col-location .location-info dd {width: calc(100% - 86px); font-size: 13px}
    #footer .footer-top .footer-row .col-location .button-contact {display: none !important}
    #footer .footer-bottom {padding-top: 30px; padding-bottom: 35px}
    #footer .footer-bottom .footer-menu-items {display: none}
    #footer .footer-bottom address {font-size: 13px; line-height: 1.769}
    #footer .footer-bottom address .divider {display: inline-block; font-style: normal}
    #footer .footer-bottom address .divider::after {content: 'ㅣ'}
    body.main #footer .footer-bottom {padding-bottom: 120px}
}