@charset "UTF-8";

/* ==========================================================================
   Base
========================================================================== */
body {
  font-size: 100%;
}

.overlay:before {
  height: 114px;
}

#gNav-close {
   display: none !important;
}
#gNav-close-pc:before {
  content: '';
  width: 100%;
  height: 114px;
  position: absolute;
  left: 0;
  top: 0;
  background: #FFF;
}


/* ==========================================================================
   Layout
========================================================================== */
.container-fluid {
  padding-right: 30px;
  padding-left: 30px;
}
.container {
  padding-right: 40px;
  padding-left: 40px;
}
.row:not(.no-gutters) {
  margin-right: -20px;
  margin-left: -20px;
}
.row:not(.no-gutters) > .col,
.row:not(.no-gutters) > [class*=col-] {
  padding-right: 20px;
  padding-left: 20px;
}
@media only screen and (min-width: 1200px) {
  .container-fluid {
    padding-right: 30px;
    padding-left: 30px;
  }
  .container {
    padding-right: 50px;
    padding-left: 50px;
  }
  .row:not(.no-gutters) {
    margin-right: -25px;
    margin-left: -25px;
  }
  .row:not(.no-gutters) > .col,
  .row:not(.no-gutters) > [class*=col-] {
    padding-right: 25px;
    padding-left: 25px;
  }
}
@media only screen and (min-width: 1366px) {
  .container-fluid {
    padding-right: 50px;
    padding-left: 50px;
  }
  .container {
    padding-right: 85px;
    padding-left: 85px;
    max-width: 1268px;
  }
  .row:not(.no-gutters) {
    margin-right: -30px;
    margin-left: -30px;
  }
  .row:not(.no-gutters) > .col,
  .row:not(.no-gutters) > [class*=col-] {
    padding-right: 30px;
    padding-left: 30px;
  }
}
@media only screen and (min-width: 1540px) {
  .container {
    max-width: 1440px;
  }
}


#main-contents {
  margin-bottom: 10vw;
}

.section {
  margin-top: 100px;
  margin-bottom: 100px;
}
.content {
  margin-top: 50px;
  margin-bottom: 50px;
}
@media only screen and (min-width: 1200px) {
  .section {
    margin-top: 120px;
    margin-bottom: 120px;
  }
  .content {
    margin-top: 60px;
    margin-bottom: 60px;
  }
}
/* ==========================================================================
   Header
========================================================================== */
#siteHeader {
  height: 114px;
}
.inner-header {
  padding: 0 30px;
}
@media only screen and (min-width: 1200px) {
   .inner-header {
     padding: 0 40px;
   }
}

#logo {
  font-size: .75rem;
  width: 290px;
}

@media only screen and (min-width: 1200px) {
   #logo {
     width: 320px;
   }
}
/* ==========================================================================
   Navigation
========================================================================== */
.navBar {
  display: flex;
}
.navBar > ul {
  display: flex;
}

.gNav {
  display: block !important;
  height: 100%;
}
.gNav .gNav__inner {
  height: 100%;
}
.gNav .navBar {
  height: 100%;
}
.gNav .navBar > ul {
  align-items: center;
}
.gNav .navBar > ul.main-nav > li {
  height: 100%;
}
.gNav .navBar > ul.main-nav > li > a {
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.gNav .navBar > ul.main-nav > li > a:hover {
  opacity: .75;
}

.gNav .navBar .sub-menu {
   position: fixed;
   top: 114px;
   right: 0;
   left: 0;
   z-index: 2;
   display: block !important;
   height: 0;
   overflow: hidden;
   transition: .4s cubic-bezier(0.190, 1.000, 0.220, 1.000);
}
.gNav .navBar .sub-menu.on {
  height: auto;
  z-index: 3;
}

.gNav .navBar .sub-menu ul {
  max-width: 1366px;
  margin: 0 auto;
  padding: 0 20px;
  height: 0;
  overflow: hidden;
  transition: .4s cubic-bezier(0.190, 1.000, 0.220, 1.000);
}
.gNav .navBar .sub-menu.on ul {
  padding: 20px;
  height: auto;
  z-index: 3;
}
.gNav .navBar .sub-menu li {
  padding: 20px;
}
.gNav .navBar .sub-menu li .card {
  height: 240px;
  font-size: 1.125rem;
}

/* Sub Navigation */
.gNav .navBar .sub-nav .btn {
  width: 140px;
  margin-left: 15px;
}

/* Nav Btn */
.nav-btn {
  display: none !important;
}

@media only screen and (min-width: 1200px) {
   .gNav .navBar > ul > li > a {
     padding: 1em 23px;
   }
   .gNav .navBar > .sub-nav > li:first-child .btn {
     margin-left: 23px;
   }
   /* Sub Navigation */
   .gNav .navBar .sub-nav .btn {
     width: 200px;
   }
}

/* ==========================================================================
   Footer
========================================================================== */
.fNav {
   padding: 2.5em 0;
}
.fNav .navBar {
   justify-content: center;
}
.fNav .navBar > ul > li {
  min-width: 220px;
  padding: 0 20px;
}
.fNav .navBar ul li a {
  font-size: .813em;
}

#fLogo {
  border-top: 1px solid #CCC;
  padding: 2.5em 0;
}
#fLogo .logo__inner {
  width: 182px;
}

.footer-bottom {
  background: #F7F7F7;
  padding: 1em 0;
}
.footer-bottom-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.copyright {
  font-size: .688rem;
}