@charset "UTF-8";

/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}

.slick-list:focus {
  outline: none;
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.slick-track:before, .slick-track:after {
  content: "";
  display: table;
}

.slick-track:after {
  clear: both;
}

.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}

[dir="rtl"] .slick-slide {
  float: right;
}

.slick-slide img {
  display: block;
}

.slick-slide.slick-loading img {
  display: none;
}

.slick-slide.dragging img {
  pointer-events: none;
}

.slick-initialized .slick-slide {
  display: block;
}

.slick-loading .slick-slide {
  visibility: hidden;
}

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}


/* --------------------------------------------
   layout
----------------------------------------------- */
html {
  font-family: "游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
  font-size: 62.5%;
}

body {
  word-wrap: break-word;
  overflow-wrap: break-word;
}

input, button, textarea, select {
  font-family: "游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
}

.wrapper {
  width: 100%;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.main {
  width: 100%;
}

.js-noImage {
  object-fit: cover !important;
  font-family: "object-fit: cover;" !important;
}

a,
button {
  color: #0A203B;
  text-decoration: none;
  cursor: pointer;
  transition: color 0.2s ease-out 0s, background-color 0.2s ease-out 0s, opacity 0.2s ease-out 0s;
}

a:hover,
button:hover {
  transition: color 0.2s ease-out 0s, background-color 0.2s ease-out 0s, opacity 0.2s ease-out 0s;
}

@media only screen and (max-width: 767px) {
  .main {
    margin-bottom: 80px;
  }
  .only-pc {
    display: none !important;
  }
  .mt-sp-0 {
    margin-top: 0px !important;
  }
  .ml-sp-0 {
    margin-left: 0px !important;
  }
  .mr-sp-0 {
    margin-right: 0px !important;
  }
  .mb-sp-0 {
    margin-bottom: 0px !important;
  }
  .mt-sp-2 {
    margin-top: 2px !important;
  }
  .ml-sp-2 {
    margin-left: 2px !important;
  }
  .mr-sp-2 {
    margin-right: 2px !important;
  }
  .mb-sp-2 {
    margin-bottom: 2px !important;
  }
  .mt-sp-3 {
    margin-top: 3px !important;
  }
  .ml-sp-3 {
    margin-left: 3px !important;
  }
  .mr-sp-3 {
    margin-right: 3px !important;
  }
  .mb-sp-3 {
    margin-bottom: 3px !important;
  }
  .mt-sp-4 {
    margin-top: 4px !important;
  }
  .ml-sp-4 {
    margin-left: 4px !important;
  }
  .mr-sp-4 {
    margin-right: 4px !important;
  }
  .mb-sp-4 {
    margin-bottom: 4px !important;
  }
  .mt-sp-5 {
    margin-top: 5px !important;
  }
  .ml-sp-5 {
    margin-left: 5px !important;
  }
  .mr-sp-5 {
    margin-right: 5px !important;
  }
  .mb-sp-5 {
    margin-bottom: 5px !important;
  }
  .mt-sp-6 {
    margin-top: 6px !important;
  }
  .ml-sp-6 {
    margin-left: 6px !important;
  }
  .mr-sp-6 {
    margin-right: 6px !important;
  }
  .mb-sp-6 {
    margin-bottom: 6px !important;
  }
  .mt-sp-8 {
    margin-top: 8px !important;
  }
  .ml-sp-8 {
    margin-left: 8px !important;
  }
  .mr-sp-8 {
    margin-right: 8px !important;
  }
  .mb-sp-8 {
    margin-bottom: 8px !important;
  }
  .mt-sp-10 {
    margin-top: 10px !important;
  }
  .ml-sp-10 {
    margin-left: 10px !important;
  }
  .mr-sp-10 {
    margin-right: 10px !important;
  }
  .mb-sp-10 {
    margin-bottom: 10px !important;
  }
  .mt-sp-12 {
    margin-top: 12px !important;
  }
  .ml-sp-12 {
    margin-left: 12px !important;
  }
  .mr-sp-12 {
    margin-right: 12px !important;
  }
  .mb-sp-12 {
    margin-bottom: 12px !important;
  }
  .mt-sp-15 {
    margin-top: 15px !important;
  }
  .ml-sp-15 {
    margin-left: 15px !important;
  }
  .mr-sp-15 {
    margin-right: 15px !important;
  }
  .mb-sp-15 {
    margin-bottom: 15px !important;
  }
  .mt-sp-16 {
    margin-top: 16px !important;
  }
  .ml-sp-16 {
    margin-left: 16px !important;
  }
  .mr-sp-16 {
    margin-right: 16px !important;
  }
  .mb-sp-16 {
    margin-bottom: 16px !important;
  }
  .mt-sp-18 {
    margin-top: 18px !important;
  }
  .ml-sp-18 {
    margin-left: 18px !important;
  }
  .mr-sp-18 {
    margin-right: 18px !important;
  }
  .mb-sp-18 {
    margin-bottom: 18px !important;
  }
  .mt-sp-20 {
    margin-top: 20px !important;
  }
  .ml-sp-20 {
    margin-left: 20px !important;
  }
  .mr-sp-20 {
    margin-right: 20px !important;
  }
  .mb-sp-20 {
    margin-bottom: 20px !important;
  }
  .mt-sp-24 {
    margin-top: 24px !important;
  }
  .ml-sp-24 {
    margin-left: 24px !important;
  }
  .mr-sp-24 {
    margin-right: 24px !important;
  }
  .mb-sp-24 {
    margin-bottom: 24px !important;
  }
  .mt-sp-30 {
    margin-top: 30px !important;
  }
  .ml-sp-30 {
    margin-left: 30px !important;
  }
  .mr-sp-30 {
    margin-right: 30px !important;
  }
  .mb-sp-30 {
    margin-bottom: 30px !important;
  }
  .mt-sp-32 {
    margin-top: 32px !important;
  }
  .ml-sp-32 {
    margin-left: 32px !important;
  }
  .mr-sp-32 {
    margin-right: 32px !important;
  }
  .mb-sp-32 {
    margin-bottom: 32px !important;
  }
  .mt-sp-36 {
    margin-top: 36px !important;
  }
  .ml-sp-36 {
    margin-left: 36px !important;
  }
  .mr-sp-36 {
    margin-right: 36px !important;
  }
  .mb-sp-36 {
    margin-bottom: 36px !important;
  }
  .mt-sp-40 {
    margin-top: 40px !important;
  }
  .ml-sp-40 {
    margin-left: 40px !important;
  }
  .mr-sp-40 {
    margin-right: 40px !important;
  }
  .mb-sp-40 {
    margin-bottom: 40px !important;
  }
  .mt-sp-48 {
    margin-top: 48px !important;
  }
  .ml-sp-48 {
    margin-left: 48px !important;
  }
  .mr-sp-48 {
    margin-right: 48px !important;
  }
  .mb-sp-48 {
    margin-bottom: 48px !important;
  }
  .mt-sp-60 {
    margin-top: 60px !important;
  }
  .ml-sp-60 {
    margin-left: 60px !important;
  }
  .mr-sp-60 {
    margin-right: 60px !important;
  }
  .mb-sp-60 {
    margin-bottom: 60px !important;
  }
  .mt-sp-64 {
    margin-top: 64px !important;
  }
  .ml-sp-64 {
    margin-left: 64px !important;
  }
  .mr-sp-64 {
    margin-right: 64px !important;
  }
  .mb-sp-64 {
    margin-bottom: 64px !important;
  }
  .mt-sp-80 {
    margin-top: 80px !important;
  }
  .ml-sp-80 {
    margin-left: 80px !important;
  }
  .mr-sp-80 {
    margin-right: 80px !important;
  }
  .mb-sp-80 {
    margin-bottom: 80px !important;
  }
  .mt-sp-96 {
    margin-top: 96px !important;
  }
  .ml-sp-96 {
    margin-left: 96px !important;
  }
  .mr-sp-96 {
    margin-right: 96px !important;
  }
  .mb-sp-96 {
    margin-bottom: 96px !important;
  }
  .mt-sp-120 {
    margin-top: 120px !important;
  }
  .ml-sp-120 {
    margin-left: 120px !important;
  }
  .mr-sp-120 {
    margin-right: 120px !important;
  }
  .mb-sp-120 {
    margin-bottom: 120px !important;
  }
  .pb-sp-0 {
    padding-bottom: 0px !important;
  }
  .pb-sp-8 {
    padding-bottom: 8px !important;
  }
}

@media only screen and (min-width: 768px) {
  body {
    min-width: 960px;
  }
  .main {
    margin-bottom: 60px;
  }
  .only-sp {
    display: none !important;
  }
  .mt-pc-0 {
    margin-top: 0px !important;
  }
  .ml-pc-0 {
    margin-left: 0px !important;
  }
  .mr-pc-0 {
    margin-right: 0px !important;
  }
  .mb-pc-0 {
    margin-bottom: 0px !important;
  }
  .mt-pc-2 {
    margin-top: 2px !important;
  }
  .ml-pc-2 {
    margin-left: 2px !important;
  }
  .mr-pc-2 {
    margin-right: 2px !important;
  }
  .mb-pc-2 {
    margin-bottom: 2px !important;
  }
  .mt-pc-3 {
    margin-top: 3px !important;
  }
  .ml-pc-3 {
    margin-left: 3px !important;
  }
  .mr-pc-3 {
    margin-right: 3px !important;
  }
  .mb-pc-3 {
    margin-bottom: 3px !important;
  }
  .mt-pc-4 {
    margin-top: 4px !important;
  }
  .ml-pc-4 {
    margin-left: 4px !important;
  }
  .mr-pc-4 {
    margin-right: 4px !important;
  }
  .mb-pc-4 {
    margin-bottom: 4px !important;
  }
  .mt-pc-5 {
    margin-top: 5px !important;
  }
  .ml-pc-5 {
    margin-left: 5px !important;
  }
  .mr-pc-5 {
    margin-right: 5px !important;
  }
  .mb-pc-5 {
    margin-bottom: 5px !important;
  }
  .mt-pc-6 {
    margin-top: 6px !important;
  }
  .ml-pc-6 {
    margin-left: 6px !important;
  }
  .mr-pc-6 {
    margin-right: 6px !important;
  }
  .mb-pc-6 {
    margin-bottom: 6px !important;
  }
  .mt-pc-8 {
    margin-top: 8px !important;
  }
  .ml-pc-8 {
    margin-left: 8px !important;
  }
  .mr-pc-8 {
    margin-right: 8px !important;
  }
  .mb-pc-8 {
    margin-bottom: 8px !important;
  }
  .mt-pc-10 {
    margin-top: 10px !important;
  }
  .ml-pc-10 {
    margin-left: 10px !important;
  }
  .mr-pc-10 {
    margin-right: 10px !important;
  }
  .mb-pc-10 {
    margin-bottom: 10px !important;
  }
  .mt-pc-12 {
    margin-top: 12px !important;
  }
  .ml-pc-12 {
    margin-left: 12px !important;
  }
  .mr-pc-12 {
    margin-right: 12px !important;
  }
  .mb-pc-12 {
    margin-bottom: 12px !important;
  }
  .mt-pc-15 {
    margin-top: 15px !important;
  }
  .ml-pc-15 {
    margin-left: 15px !important;
  }
  .mr-pc-15 {
    margin-right: 15px !important;
  }
  .mb-pc-15 {
    margin-bottom: 15px !important;
  }
  .mt-pc-16 {
    margin-top: 16px !important;
  }
  .ml-pc-16 {
    margin-left: 16px !important;
  }
  .mr-pc-16 {
    margin-right: 16px !important;
  }
  .mb-pc-16 {
    margin-bottom: 16px !important;
  }
  .mt-pc-18 {
    margin-top: 18px !important;
  }
  .ml-pc-18 {
    margin-left: 18px !important;
  }
  .mr-pc-18 {
    margin-right: 18px !important;
  }
  .mb-pc-18 {
    margin-bottom: 18px !important;
  }
  .mt-pc-20 {
    margin-top: 20px !important;
  }
  .ml-pc-20 {
    margin-left: 20px !important;
  }
  .mr-pc-20 {
    margin-right: 20px !important;
  }
  .mb-pc-20 {
    margin-bottom: 20px !important;
  }
  .mt-pc-24 {
    margin-top: 24px !important;
  }
  .ml-pc-24 {
    margin-left: 24px !important;
  }
  .mr-pc-24 {
    margin-right: 24px !important;
  }
  .mb-pc-24 {
    margin-bottom: 24px !important;
  }
  .mt-pc-30 {
    margin-top: 30px !important;
  }
  .ml-pc-30 {
    margin-left: 30px !important;
  }
  .mr-pc-30 {
    margin-right: 30px !important;
  }
  .mb-pc-30 {
    margin-bottom: 30px !important;
  }
  .mt-pc-32 {
    margin-top: 32px !important;
  }
  .ml-pc-32 {
    margin-left: 32px !important;
  }
  .mr-pc-32 {
    margin-right: 32px !important;
  }
  .mb-pc-32 {
    margin-bottom: 32px !important;
  }
  .mt-pc-36 {
    margin-top: 36px !important;
  }
  .ml-pc-36 {
    margin-left: 36px !important;
  }
  .mr-pc-36 {
    margin-right: 36px !important;
  }
  .mb-pc-36 {
    margin-bottom: 36px !important;
  }
  .mt-pc-40 {
    margin-top: 40px !important;
  }
  .ml-pc-40 {
    margin-left: 40px !important;
  }
  .mr-pc-40 {
    margin-right: 40px !important;
  }
  .mb-pc-40 {
    margin-bottom: 40px !important;
  }
  .mt-pc-48 {
    margin-top: 48px !important;
  }
  .ml-pc-48 {
    margin-left: 48px !important;
  }
  .mr-pc-48 {
    margin-right: 48px !important;
  }
  .mb-pc-48 {
    margin-bottom: 48px !important;
  }
  .mt-pc-60 {
    margin-top: 60px !important;
  }
  .ml-pc-60 {
    margin-left: 60px !important;
  }
  .mr-pc-60 {
    margin-right: 60px !important;
  }
  .mb-pc-60 {
    margin-bottom: 60px !important;
  }
  .mt-pc-64 {
    margin-top: 64px !important;
  }
  .ml-pc-64 {
    margin-left: 64px !important;
  }
  .mr-pc-64 {
    margin-right: 64px !important;
  }
  .mb-pc-64 {
    margin-bottom: 64px !important;
  }
  .mt-pc-80 {
    margin-top: 80px !important;
  }
  .ml-pc-80 {
    margin-left: 80px !important;
  }
  .mr-pc-80 {
    margin-right: 80px !important;
  }
  .mb-pc-80 {
    margin-bottom: 80px !important;
  }
  .mt-pc-96 {
    margin-top: 96px !important;
  }
  .ml-pc-96 {
    margin-left: 96px !important;
  }
  .mr-pc-96 {
    margin-right: 96px !important;
  }
  .mb-pc-96 {
    margin-bottom: 96px !important;
  }
  .mt-pc-120 {
    margin-top: 120px !important;
  }
  .ml-pc-120 {
    margin-left: 120px !important;
  }
  .mr-pc-120 {
    margin-right: 120px !important;
  }
  .mb-pc-120 {
    margin-bottom: 120px !important;
  }
  .pb-pc-0 {
    padding-bottom: 0px !important;
  }
  .ml-pc-auto {
    margin-left: auto;
  }
  .mr-pc-auto {
    margin-right: auto;
  }
}

@media only screen and (max-width: 767px) {
  /* --------------------------------------------
   footer_sp
----------------------------------------------- */
  .footer {
    position: relative;
    width: 100%;
    background: #F5F7F9;
  }
  .footer__page-top {
    display: block;
    width: 36px;
    height: 36px;
    line-height: 40px;
    text-align: center;
    background: #0A203B;
    position: absolute;
    top: -81px;
    right: 16px;
  }
  .footer__page-top a {
    font-size: 0;
    display: block;
    width: 100%;
    height: 100%;
  }
  .footer__page-top a::before {
    display: inline-block;
    vertical-align: middle;
    zoom: 1;
    content: "";
    width: 11px;
    height: 11px;
    border-left: 1px solid #fff;
    border-top: 1px solid #fff;
    transform: rotate(45deg);
  }
  .footer .footerNav {
    width: 100%;
    background: #F5F7F9;
  }
  .footer .footerNav__inner {
    margin: 0 auto;
  }
  .footer .footerNav-title {
    position: relative;
    padding: 20px 0 20px 16px;
    border-top: 1px solid #E6E6E6;
  }
  .footer .footerNav-title .footerNav-title__icon.is-active::after {
    opacity: 0;
  }
  .footer .footerNav-title span {
    display: block;
  }
  .footer .footerNav-title__main-title {
    font-size: 1.4rem;
    line-height: 14px;
    color: #0A203B;
    letter-spacing: 0.05em;
    font-weight: bold;
  }
  .footer .footerNav-title__icon {
    display: block;
    position: absolute;
    width: 48px;
    height: 48px;
    right: 2px;
    top: 0px;
    bottom: 0;
    margin: auto;
  }
  .footer .footerNav-title__icon::before, .footer .footerNav-title__icon::after {
    position: absolute;
    top: 23px;
    left: 50%;
    content: '';
    display: inline-block;
    width: 13px;
    height: 13px;
    border-top: 2px solid #0A203B;
    transform: translateX(-50%);
  }
  .footer .footerNav-title__icon::after {
    top: 17px;
    left: 11px;
    transform: rotate(90deg);
  }
  .footer .footerNav-menu {
    display: none;
  }
  .footer .footerNav-menu:last-child {
    margin-bottom: 0;
  }
  .footer .footerNav-menu__title {
    font-size: 1.4rem;
    line-height: 14px;
    color: #0A203B;
    letter-spacing: 0.05em;
    font-weight: bold;
    padding: 20px 0 20px 0;
    margin-left: 32px;
    border-top: 1px solid #E6E6E6;
  }
  .footer .footerNav-menuList__item {
    margin-left: 48px;
    border-top: 1px solid #E6E6E6;
  }
  .footer .footerNav-menuList__item:last-child {
    margin-bottom: 0;
  }
  .footer .footerNav-menuList__item a {
    display: block;
    width: 100%;
    height: 100%;
    padding: 20px 0 20px 0;
    font-size: 1.4rem;
    line-height: 14px;
    color: #0A203B;
    letter-spacing: 0.05em;
    font-weight: normal;
  }
  .footer .footerSubnav {
    width: 100%;
    background: #0F3F69;
    padding: 0 6%;
  }
  .footer .footerSubnav-list {
    padding: 0 0;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .footer .footerSubnav-list__item {
    width: 47%;
    text-align: center;
    padding: 20px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }
  .footer .footerSubnav-list__item:nth-last-child(-n+2) {
    border-bottom: none;
  }
  .footer .footerSubnav-list__item a {
    font-size: 1.2rem;
    line-height: 12px;
    color: #FFFFFF;
    letter-spacing: 0.1em;
    font-weight: normal;
  }
  .footer .footerBottom {
    width: 100%;
    padding: 18px 0;
    background: #0A203B;
    text-align: center;
  }
  .footer .footerBottom__copyright {
    font-size: 1.2rem;
    line-height: 12px;
    color: #FFFFFF;
    letter-spacing: 0.1em;
    font-weight: normal;
    font-family: "FiraSansCondensed";
  }
  /* --------------------------------------------
   header-home_sp
----------------------------------------------- */
  .header-home {
    height: 70px;
    background: #0A203B;
  }
  .header-home-wrap {
    position: relative;
    height: 100%;
  }
  .header-home__logo {
    position: absolute;
    left: 20px;
    top: 0;
    bottom: 0;
    background-image: url("/assets/img/common/ttl-logo_home-sp.svg");
    background-repeat: no-repeat;
    background-position: 50% 50%;
    margin: auto;
    width: 60px;
    height: 40px;
    font-size: 0px;
  }
  .header-home__logo a {
    display: block;
    width: 100%;
    height: 100%;
  }
  .header-home .infonav {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    flex-direction: row;
    flex-wrap: nowrap;
    position: absolute;
    right: 20px;
    height: 20px;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  .header-home .infonav-func {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    flex-direction: row;
    flex-wrap: nowrap;
    position: relative;
    height: 20px;
    margin-right: 20px;
  }
  .header-home .infonav-func__item {
    margin-right: 25px;
    font-size: 0;
    width: 20px;
    height: 20px;
  }
  .header-home .infonav-func__item a {
    display: block;
    width: 100%;
    height: 100%;
  }
  .header-home .infonav-func__history {
    background-image: url("/assets/img/common/ico-clock.svg");
    background-repeat: no-repeat;
    background-position: 50% 50%;
  }
  .header-home .infonav-func__favorite {
    background-image: url("/assets/img/common/ico-bookmark.svg");
    background-repeat: no-repeat;
    background-position: 50% 50%;
  }
  .header-home .infonav-func__contact {
    background-image: url("/assets/img/common/ico-letter.svg");
    background-repeat: no-repeat;
    background-position: 50% 50%;
  }
  .header-home .infonav-func::after {
    display: block;
    position: absolute;
    width: 1px;
    height: 40px;
    right: 0;
    top: -10px;
    background: #3B4D62;
    content: '';
  }
  .header-home .infonav__gnav-btn {
    display: inline-block;
    width: 20px;
    height: 14px;
    margin-top: 2px;
    vertical-align: middle;
    cursor: pointer;
    position: relative;
    z-index: 100;
    transition: all .6s;
  }
  .header-home .infonav__gnav-btn span {
    display: inline-block;
    box-sizing: border-box;
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #A1A9B2;
    border-radius: 1px;
  }
  .header-home .infonav__gnav-btn span:nth-of-type(1) {
    top: 0;
  }
  .header-home .infonav__gnav-btn span:nth-of-type(2) {
    top: 6px;
  }
  .header-home .infonav__gnav-btn span:nth-of-type(3) {
    bottom: 0;
  }
  .header-home .infonav__gnav-btn.is-active {
    left: 26px;
    top: 40px;
    position: fixed;
    transition: all .6s;
  }
  .header-home .infonav__gnav-btn.is-active span {
    background-color: #fff;
  }
  .header-home .infonav__gnav-btn.is-active span:nth-of-type(1) {
    top: 6px;
    transform: rotate(-45deg);
  }
  .header-home .infonav__gnav-btn.is-active span:nth-of-type(2) {
    opacity: 0;
  }
  .header-home .infonav__gnav-btn.is-active span:nth-of-type(3) {
    top: 6px;
    transform: rotate(45deg);
  }
  .header-home .gnav {
    width: calc(100vw - 73px);
    height: 100%;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 10;
    transform: translate(calc(100vw - 73px));
    transition: all .2s ease-out;
    background: #fff;
    opacity: 0;
    overflow-y: auto;
    overflow-x: hidden;
  }
  .header-home .gnav.is-active {
    transform: translateZ(0);
    opacity: 1;
    transition: all .4s ease-out;
  }
  .header-home .gnav-wrap {
    transition: all .2s ease-out;
    transform: translateZ(0);
  }
  .header-home .gnav-list {
    width: 100%;
  }
  .header-home .gnav-list__item {
    position: relative;
    width: 100%;
    border-bottom: 1px solid #E6E6E6;
    background: #F5F7F9;
  }
  .header-home .gnav-list__item::after {
    display: block;
    right: 16px;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    display: inline-block;
    position: absolute;
    width: 6px;
    height: 8px;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url("/assets/img/common/ico-arrow_right-glay1.svg");
  }
  .header-home .gnav-list__item a {
    display: block;
    padding: 20px 25px 20px 16px;
    font-size: 1.4rem;
    line-height: 14px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: bold;
  }
  .header-home .gnav-foot {
    width: 100%;
    margin-top: 56px;
    padding: 20px 0;
    background: #F5F7F9;
    border-top: 1px solid #E6E6E6;
    border-bottom: 1px solid #E6E6E6;
    visibility: hidden;
    height: 0;
  }
  .header-home .gnav-foot.is-active {
    visibility: visible;
    height: auto;
  }
  .header-home .gnav-sub {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row;
    flex-wrap: nowrap;
  }
  .header-home .gnav-sub__item {
    width: 40%;
    text-align: center;
    margin: 0 auto 16px;
  }
  .header-home .gnav-sub__item a {
    font-size: 1.2rem;
    line-height: 19px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: normal;
  }
  .header-home .gnav-sub__language a {
    margin-right: -6px;
    font-size: 1.2rem;
    line-height: 12px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: normal;
    font-family: "FiraSansCondensedLight";
  }
  .header-home .gnav-sub__language a::after {
    display: inline-block;
    width: 10px;
    height: 8px;
    margin-left: 6px;
    background: url("/assets/img/common/ico-blank.svg");
    background-repeat: no-repeat;
    background-size: 10px auto;
    content: '';
  }
  .header-home .gnav-search__input {
    display: block;
    width: calc(100% - 32px);
    height: 30px;
    margin: 0 auto;
    padding-left: 30px;
    background: url("/assets/img/common/ico-glass_glay2.svg"), #fff;
    background-position: left 11px center , center;
    background-repeat: no-repeat,repeat;
    background-size: 12px 12px, 100%;
    border-radius: 15px;
  }
  .header-home .gnav__overlay {
    content: "";
    display: block;
    width: 0;
    height: 0;
    background-color: rgba(10, 32, 59, 0.6);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 2;
    opacity: 0;
    transition: opacity .4s ease-out;
  }
  .header-home .gnav__overlay.is-active {
    width: 100%;
    height: 100%;
    opacity: 1;
  }
  .header-home .gmenu {
    width: calc(100vw - 73px);
    height: 100%;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 10;
    transform: translate(calc(100vw - 73px));
    transition: all .2s ease-out;
    background: #fff;
    overflow-y: auto;
    overflow-x: hidden;
  }
  .header-home .gmenu.is-active {
    transform: translateZ(0);
    transition: all .2s ease-out;
  }
  .header-home .gmenu-wrap {
    display: none;
  }
  .header-home .gmenu-wrap.is-active {
    display: block;
  }
  .header-home .gmenu-foot {
    width: 100%;
    margin-top: 56px;
    padding: 20px 0;
    background: #F5F7F9;
    border-top: 1px solid #E6E6E6;
    border-bottom: 1px solid #E6E6E6;
    display: none;
  }
  .header-home .gmenu-foot.is-active {
    display: block;
  }
  .header-home .gmenu-sub {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .header-home .gmenu-sub__item {
    width: 40%;
    text-align: center;
    padding-bottom: 16px;
    margin: 0 auto 16px;
    border-bottom: 1px solid #E6E6E6;
  }
  .header-home .gmenu-sub__item a {
    font-size: 1.2rem;
    line-height: 12px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: normal;
  }
  .header-home .gmenu-sub__item:nth-last-child(-n+2) {
    border-bottom: none;
    margin-bottom: 0;
  }
  .header-home .gmenu-sub__gmenu a {
    font-size: 1.2rem;
    line-height: 19px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: bold;
  }
  .header-home .gmenu-sub__language a {
    margin-right: -6px;
    font-size: 1.2rem;
    line-height: 12px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: normal;
    font-family: "FiraSansCondensedLight";
  }
  .header-home .gmenu-sub__language a::after {
    display: inline-block;
    width: 10px;
    height: 8px;
    margin-left: 6px;
    background: url("/assets/img/common/ico-blank.svg");
    background-repeat: no-repeat;
    background-size: 10px auto;
    content: '';
  }
  .header-home .gmenu-search__input {
    display: block;
    width: calc(100% - 32px);
    height: 30px;
    margin: 0 auto;
    padding-left: 30px;
    background: url("/assets/img/common/ico-glass_glay2.svg"), #fff;
    background-position: left 11px center , center;
    background-repeat: no-repeat,repeat;
    background-size: 12px 12px, 100%;
    border-radius: 15px;
  }
  .header-home .gmenuParent {
    transition: all .2s ease-out;
    transform: translateZ(0);
  }
  .header-home .gmenuParent-head {
    position: relative;
    width: 100%;
    height: 56px;
    border-bottom: 1px solid #E6E6E6;
  }
  .header-home .gmenuParent-head__main-title {
    text-align: center;
    font-size: 1.6rem;
    line-height: 56px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: bold;
  }
  .header-home .gmenuParent-head__back-btn {
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    display: inline-block;
    position: absolute;
    width: 42px;
    height: 100%;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url("/assets/img/common/ico-arrow_left-glay1.svg");
    background-size: 5px auto;
    background-position: center center;
    font-size: 0;
  }
  .header-home .gmenuParent__title {
    padding: 20px 0 20px 16px;
    font-size: 1.4rem;
    line-height: 14px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: bold;
    text-align: left;
    border-bottom: 1px solid #E6E6E6;
  }
  .header-home .gmenuParent-list__item {
    position: relative;
    width: 100%;
    border-bottom: 1px solid #E6E6E6;
    background: #F5F7F9;
  }
  .header-home .gmenuParent-list__item::after {
    display: block;
    right: 16px;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    display: inline-block;
    position: absolute;
    width: 6px;
    height: 8px;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url("/assets/img/common/ico-arrow_right-glay1.svg");
  }
  .header-home .gmenuParent-list__item span,
  .header-home .gmenuParent-list__item a {
    display: block;
    padding: 20px 25px 20px 32px;
    font-size: 1.4rem;
    line-height: 14px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: normal;
  }
  .header-home .gmenuParent-list__item--categoryTop a {
    padding: 20px 25px 20px 16px;
  }
  .header-home .gmenuChild {
    position: absolute;
    width: calc(100vw - 73px);
    height: 100%;
    top: 0;
    right: 0;
    z-index: 10;
    transform: translate(calc(100vw - 73px));
    transition: all .2s ease-out;
    background: #fff;
  }
  .header-home .gmenuChild.is-active {
    transform: translateZ(0);
    transition: all .2s ease-out;
  }
  .header-home .gmenuChild-head {
    position: relative;
    width: 100%;
    height: 56px;
    border-bottom: 1px solid #E6E6E6;
  }
  .header-home .gmenuChild-head__back-btn {
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    display: inline-block;
    position: absolute;
    width: 42px;
    height: 100%;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url("/assets/img/common/ico-arrow_left-glay1.svg");
    background-size: 5px auto;
    background-position: center center;
    font-size: 0;
  }
  .header-home .gmenuChild-head__title {
    text-align: center;
    font-size: 1.6rem;
    line-height: 56px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: bold;
  }
  .header-home .gmenuChild-list__item {
    position: relative;
    width: 100%;
    border-bottom: 1px solid #E6E6E6;
    background: #F5F7F9;
  }
  .header-home .gmenuChild-list__item::after {
    display: block;
    right: 16px;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    display: inline-block;
    position: absolute;
    width: 6px;
    height: 8px;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url("/assets/img/common/ico-arrow_right-glay1.svg");
  }
  .header-home .gmenuChild-list__item a {
    display: block;
    padding: 20px 25px 20px 16px;
    font-size: 1.4rem;
    line-height: 14px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: normal;
  }
  /* --------------------------------------------
   header_sp
----------------------------------------------- */
  .header {
    height: 70px;
    background: #0A203B;
  }
  .header-wrap {
    position: relative;
    height: 100%;
  }
  .header__logo {
    position: absolute;
    left: 20px;
    top: 0;
    bottom: 0;
    background-image: url("/assets/img/common/ttl-logo_sp.svg");
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: 100% auto;
    margin: auto;
    width: 65px;
    height: 42px;
    font-size: 0px;
  }
  .header__logo a {
    display: block;
    width: 100%;
    height: 100%;
  }
  .header .infonav {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    flex-direction: row;
    flex-wrap: nowrap;
    position: absolute;
    right: 20px;
    height: 20px;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  .header .infonav-func {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    flex-direction: row;
    flex-wrap: nowrap;
    position: relative;
    height: 20px;
    margin-right: 20px;
  }
  .header .infonav-func__item {
    margin-right: 25px;
    font-size: 0;
    width: 20px;
    height: 20px;
  }
  .header .infonav-func__item a {
    display: block;
    width: 100%;
    height: 100%;
  }
  .header .infonav-func__history {
    background-image: url("/assets/img/common/ico-clock.svg");
    background-repeat: no-repeat;
    background-position: 50% 50%;
  }
  .header .infonav-func__favorite {
    background-image: url("/assets/img/common/ico-bookmark.svg");
    background-repeat: no-repeat;
    background-position: 50% 50%;
  }
  .header .infonav-func__contact {
    background-image: url("/assets/img/common/ico-letter.svg");
    background-repeat: no-repeat;
    background-position: 50% 50%;
  }
  .header .infonav-func::after {
    display: block;
    position: absolute;
    width: 1px;
    height: 40px;
    right: 0;
    top: -10px;
    background: #3B4D62;
    content: '';
  }
  .header .infonav__gnav-btn {
    display: inline-block;
    width: 20px;
    height: 14px;
    margin-top: 2px;
    vertical-align: middle;
    cursor: pointer;
    position: relative;
    z-index: 100;
    transition: all .6s;
  }
  .header .infonav__gnav-btn span {
    display: inline-block;
    box-sizing: border-box;
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #A1A9B2;
    border-radius: 1px;
  }
  .header .infonav__gnav-btn span:nth-of-type(1) {
    top: 0;
  }
  .header .infonav__gnav-btn span:nth-of-type(2) {
    top: 6px;
  }
  .header .infonav__gnav-btn span:nth-of-type(3) {
    bottom: 0;
  }
  .header .infonav__gnav-btn.is-active {
    left: 26px;
    top: 40px;
    position: fixed;
    transition: all .6s;
  }
  .header .infonav__gnav-btn.is-active span {
    background-color: #fff;
  }
  .header .infonav__gnav-btn.is-active span:nth-of-type(1) {
    top: 6px;
    transform: rotate(-45deg);
  }
  .header .infonav__gnav-btn.is-active span:nth-of-type(2) {
    opacity: 0;
  }
  .header .infonav__gnav-btn.is-active span:nth-of-type(3) {
    top: 6px;
    transform: rotate(45deg);
  }
  .header .gnav {
    width: calc(100vw - 73px);
    height: 100%;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 10;
    transform: translate(calc(100vw - 73px));
    transition: all .2s ease-out;
    background: #fff;
    opacity: 0;
    overflow-y: auto;
    overflow-x: hidden;
  }
  .header .gnav.is-active {
    transition: all .4s ease-out;
    transform: translateZ(0);
    opacity: 1;
  }
  .header .gnav-wrap {
    transition: all .4s;
    transform: translateZ(0);
  }
  .header .gnav-list {
    width: 100%;
  }
  .header .gnav-list__item {
    position: relative;
    width: 100%;
    border-bottom: 1px solid #E6E6E6;
    background: #F5F7F9;
  }
  .header .gnav-list__item::after {
    display: block;
    right: 16px;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    display: inline-block;
    position: absolute;
    width: 6px;
    height: 8px;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url("/assets/img/common/ico-arrow_right-glay1.svg");
  }
  .header .gnav-list__item a {
    display: block;
    padding: 20px 25px 20px 16px;
    font-size: 1.4rem;
    line-height: 20px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: bold;
  }
  .header .gnav-foot {
    width: 100%;
    margin-top: 56px;
    padding: 20px 0;
    background: #F5F7F9;
    border-top: 1px solid #E6E6E6;
    border-bottom: 1px solid #E6E6E6;
    visibility: hidden;
    height: 0;
  }
  .header .gnav-foot.is-active {
    visibility: visible;
    height: auto;
  }
  .header .gnav-sub {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row;
    flex-wrap: nowrap;
  }
  .header .gnav-sub__item {
    width: 40%;
    text-align: center;
    margin: 0 auto 16px;
  }
  .header .gnav-sub__item a {
    font-size: 1.2rem;
    line-height: 12px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: normal;
  }
  .header .gnav-sub__language a {
    margin-right: -6px;
    font-size: 1.2rem;
    line-height: 12px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: normal;
    font-family: "FiraSansCondensedLight";
  }
  .header .gnav-sub__language a::after {
    display: inline-block;
    width: 10px;
    height: 8px;
    margin-left: 6px;
    background: url("/assets/img/common/ico-blank.svg");
    background-repeat: no-repeat;
    background-size: 10px auto;
    content: '';
  }
  .header .gnav-search__input {
    display: block;
    width: calc(100% - 32px);
    height: 30px;
    margin: 0 auto;
    padding-left: 30px;
    background: url("/assets/img/common/ico-glass_glay2.svg"), #fff;
    background-position: left 11px center , center;
    background-repeat: no-repeat,repeat;
    background-size: 12px 12px, 100%;
    border-radius: 15px;
    font-size: 1.6rem;
    line-height: 16px;
    color: #0A203B;
    letter-spacing: 0.05em;
    font-weight: normal;
  }
  .header .gnav__overlay {
    content: "";
    display: none;
    width: 100%;
    height: 100%;
    background-color: rgba(10, 32, 59, 0.6);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 2;
    opacity: 0;
    transition: all .2s ease-out;
  }
  .header .gnav__overlay.is-active {
    display: block;
    animation: fadein .4s ease-out;
    opacity: 1;
  }
  .header .gmenu {
    width: calc(100vw - 73px);
    height: 100%;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 10;
    transform: translate(calc(100vw - 73px));
    transition: all .2s ease-out;
    background: #fff;
    overflow-y: auto;
    overflow-x: hidden;
  }
  .header .gmenu.is-active {
    transform: translateZ(0);
    transition: all .2s ease-out;
  }
  .header .gmenu-foot {
    width: 100%;
    margin-top: 56px;
    padding: 20px 0;
    background: #F5F7F9;
    border-top: 1px solid #E6E6E6;
    border-bottom: 1px solid #E6E6E6;
    display: none;
  }
  .header .gmenu-foot.is-active {
    display: block;
  }
  .header .gmenu-sub {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .header .gmenu-sub__item {
    width: 40%;
    text-align: center;
    padding-bottom: 16px;
    margin: 0 auto 16px;
    border-bottom: 1px solid #E6E6E6;
  }
  .header .gmenu-sub__item a {
    font-size: 1.2rem;
    line-height: 12px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: normal;
  }
  .header .gmenu-sub__item:nth-last-child(-n+2) {
    border-bottom: none;
    margin-bottom: 0;
  }
  .header .gmenu-sub__gmenu a {
    font-size: 1.2rem;
    line-height: 19px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: bold;
  }
  .header .gmenu-sub__language a {
    margin-right: -6px;
    font-size: 1.2rem;
    line-height: 12px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: normal;
    font-family: "FiraSansCondensedLight";
  }
  .header .gmenu-sub__language a::after {
    display: inline-block;
    width: 10px;
    height: 8px;
    margin-left: 6px;
    background: url("/assets/img/common/ico-blank.svg");
    background-repeat: no-repeat;
    background-size: 10px auto;
    content: '';
  }
  .header .gmenu-search__input {
    display: block;
    width: calc(100% - 32px);
    height: 30px;
    margin: 0 auto;
    padding-left: 30px;
    background: url("/assets/img/common/ico-glass_glay2.svg"), #fff;
    background-position: left 11px center , center;
    background-repeat: no-repeat,repeat;
    background-size: 12px 12px, 100%;
    border-radius: 15px;
    font-size: 1.6rem;
    line-height: 16px;
    color: #0A203B;
    letter-spacing: 0.05em;
    font-weight: normal;
  }
  .header .gmenuParent {
    transition: all .2s ease-out;
    transform: translateZ(0);
  }
  .header .gmenuParent-wrap {
    display: none;
  }
  .header .gmenuParent-wrap.is-active {
    display: block;
    transition: all .2s ease-out;
  }
  .header .gmenuParent-head {
    position: relative;
    border-bottom: 1px solid #E6E6E6;
  }
  .header .gmenuParent-head__main-title {
    text-align: center;
    font-size: 1.6rem;
    line-height: 56px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: bold;
  }
  .header .gmenuParent-head__back-btn {
    display: block;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    display: inline-block;
    position: absolute;
    width: 42px;
    height: 100%;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url("/assets/img/common/ico-arrow_left-glay1.svg");
    background-size: 5px auto;
    background-position: center center;
    font-size: 0;
  }
  .header .gmenuParent-caption {
    position: relative;
    width: 100%;
    height: 56px;
    border-bottom: 1px solid #E6E6E6;
    padding-left: 16px;
  }
  .header .gmenuParent-caption__main-title {
    text-align: left;
    font-size: 1.4rem;
    line-height: 56px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: bold;
  }
  .header .gmenuParent-list__item {
    position: relative;
    width: 100%;
    border-bottom: 1px solid #E6E6E6;
    background: #F5F7F9;
  }
  .header .gmenuParent-list__item::after {
    display: block;
    right: 16px;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    display: inline-block;
    position: absolute;
    width: 6px;
    height: 8px;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url("/assets/img/common/ico-arrow_right-glay1.svg");
  }
  .header .gmenuParent-list__item a {
    display: block;
    padding: 20px 25px 20px 32px;
    font-size: 1.4rem;
    line-height: 20px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: normal;
  }
  .header .gmenuParent-list__item--categoryTop a {
    padding: 20px 25px 20px 16px;
  }
  .header .gmenuChild {
    position: absolute;
    width: calc(100vw - 73px);
    height: 100%;
    top: 0;
    right: 0;
    z-index: 10;
    transform: translate(calc(100vw - 73px));
    transition: all .2s ease-out;
    background: #fff;
  }
  .header .gmenuChild.is-active {
    transition: all .2s ease-out;
    transform: translateZ(0);
  }
  .header .gmenuChild__wrap {
    display: none;
  }
  .header .gmenuChild__wrap.is-active {
    display: block;
  }
  .header .gmenuChild-head {
    position: relative;
    width: 100%;
    height: 56px;
    border-bottom: 1px solid #E6E6E6;
  }
  .header .gmenuChild-head__back-btn {
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    display: inline-block;
    position: absolute;
    width: 42px;
    height: 100%;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url("/assets/img/common/ico-arrow_left-glay1.svg");
    background-size: 5px auto;
    background-position: center center;
    font-size: 0;
  }
  .header .gmenuChild-head__main-title {
    text-align: center;
    font-size: 1.6rem;
    line-height: 56px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: bold;
  }
  .header .gmenuChild-list__item {
    position: relative;
    width: 100%;
    border-bottom: 1px solid #E6E6E6;
    background: #F5F7F9;
  }
  .header .gmenuChild-list__item::after {
    display: block;
    right: 16px;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    display: inline-block;
    position: absolute;
    width: 6px;
    height: 8px;
    background-size: contain;
    background-repeat: no-repeat;
    background-image: url("/assets/img/common/ico-arrow_right-glay1.svg");
  }
  .header .gmenuChild-list__item a {
    display: block;
    padding: 20px 25px 20px 16px;
    font-size: 1.4rem;
    line-height: 14px;
    color: #0A203B;
    letter-spacing: 1px;
    font-weight: normal;
  }
}
