@charset "UTF-8";
/* ---------------------------------------------
  reset
--------------------------------------------- */
body {
  margin: 0;
  padding: 0;
  font-family: 'Noto Sans JP', sans-serif;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

/* 解析タグの隙間対策 */
body > img {
  display: none;
}

.lp_main div, .lp_main span, .lp_main iframe, .lp_main h1, .lp_main h2, .lp_main h3, .lp_main h4, .lp_main h5, .lp_main h6, .lp_main p, .lp_main address, .lp_main img, .lp_main small, .lp_main strong, .lp_main sub, .lp_main sup, .lp_main dl,
.lp_main dt, .lp_main dd, .lp_main ol, .lp_main ul, .lp_main form, .lp_main label, .lp_main table, .lp_main caption, .lp_main tbody, .lp_main tfoot, .lp_main thead, .lp_main tr, .lp_main th, .lp_main td, .lp_main article,
.lp_main aside, .lp_main footer, .lp_main header, .lp_main menu, .lp_main nav, .lp_main section, .lp_main video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 0;
  line-height: 0;
  vertical-align: baseline;
}
.lp_main article, .lp_main aside, .lp_main details, .lp_main figcaption, .lp_main figure,
.lp_main footer, .lp_main header, .lp_main menu, .lp_main nav, .lp_main section {
  display: block;
}
.lp_main ol, .lp_main ul {
  list-style: none;
}
.lp_main :focus {
  outline: 0;
}
.lp_main table {
  border-collapse: collapse;
  border-spacing: 0;
}
.lp_main *,
.lp_main *::before,
.lp_main *::after {
  box-sizing: border-box;
}
.lp_main img,
.lp_main video,
.lp_main svg {
  display: block;
  height: auto;
  vertical-align: bottom;
  width: 100%;
  max-width: 100%;
}


/* ---------------------------------------------
  common
--------------------------------------------- */
/* スムーススクロール */
html {
  scroll-behavior: smooth;
}
.lp_wrap {
  overflow-x: hidden;
}
.lp_main {
  position: relative;
  width: min(100%, 500px);
  margin: 0 auto;
  background-color: #fff;
  z-index: 2;
}
@media (max-width: 750px) {
  .lp_main {
    width: 100% !important;
  }
}


/* ---------------------------------------------
  PC表示エリア
--------------------------------------------- */
.pc_area {
  display: flex;
  justify-content: space-between;
  position: fixed;
  width: 100%;
  height: 100vh;
  background: url(../img/bg_pc.png) no-repeat center center / cover;
  z-index: 1;
}
@media (max-width: 750px) {
  .pc_area {
    display: none;
  }
}

.pc_area p {
  margin: 0;
  padding: 0;
}

/* pc_left */
.pc_area .pc_left {
  width: 280px;
  margin-left: 5%;
  margin-top: 90px;
}
.pc_area .pcLeft_inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.pc_area .pcLeft_logo {
  margin-bottom: 10%;
}
.pc_area .pcLeft_logo img,
.pc_area .pcLeft_btn img {
  display: block;
  width: 100%;
  height: auto;
}
@media (max-width: 1250px) {
  .pc_area .pc_left {
    width: 18%;
    margin-left: 3%;
  }
}
@media (max-width: 1000px) {
  .pc_area .pc_left {
    display: none;
  }
}

/* pc_right */
.pc_area .pc_right {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  width: 280px;
  margin-right: 5%;
  padding-bottom: 80px;
}
@media (max-width: 1250px) {
  .pc_area .pc_right {
    width: 15%;
    margin-right: 3%;
  }
}
@media (max-width: 1000px) {
  .pc_area .pc_right {
    display: none;
  }
}

/* pc_right Navi */
.pc_area .pcRight_nav {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}
.pc_area .pcRight_nav .nav_item {
  display: inline-block;
}
.pc_area .pcRight_nav .nav_item:not(:last-of-type) {
  margin-bottom: 16px;
}
.pc_area .pcRight_nav .nav_item a {
  transition: all ease 0.2s;
  font-size: 18px;
  line-height: 1.5;
  color: #fff;
  text-decoration: none;
  filter: brightness(0.3);
}
.pc_area .pcRight_nav .nav_item .current {
  filter: brightness(1);
}


/* ---------------------------------------------
 ハンバーガー・グローバルナビ
--------------------------------------------- */
.header_bar {
  position: relative;
}
.hamburger {
  position: absolute;
  top: 50%;
  right: min(calc((20 / 750) * 100vw), 20px);
  transform: translateY(-50%);
  width: min(calc((50 / 750) * 100vw), 50px);
  height: min(calc((36 / 750) * 100vw), 36px);
  padding: 0;
  border: none;
  background: none;
  cursor: pointer;
  z-index: 100;
}
@media (min-width: 751px) {
  .hamburger {
    width: 30px;
    height: 22px;
    right: 15px;
  }
}
@media (min-width: 1001px) {
  .hamburger {
    display: none;
  }
}
.hamburger span {
  display: block;
  position: absolute;
  left: 0;
  width: 100%;
  height: min(calc((3 / 750) * 100vw), 2px);
  background: #fff;
  transition: transform 0.3s, top 0.3s, bottom 0.3s, opacity 0.3s, background 0.3s;
}
.hamburger span:nth-child(1) { top: 0; }
.hamburger span:nth-child(2) { top: 50%; transform: translateY(-50%); }
.hamburger span:nth-child(3) { bottom: 0; }

.hamburger.is_active span {
  background: #0c244a;
}
.hamburger.is_active span:nth-child(1) {
  top: 50%;
  transform: translateY(-50%) rotate(40deg);
}
.hamburger.is_active span:nth-child(2) {
  opacity: 0;
}
.hamburger.is_active span:nth-child(3) {
  bottom: auto;
  top: 50%;
  transform: translateY(-50%) rotate(-40deg);
}

.gnav {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: min(100%, 500px);
  height: 100%;
  background-color: #fff;
  z-index: 99;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
  overflow-y: auto;
}
@media (max-width: 750px) {
  .gnav { width: 100%; }
}
.gnav.is_active {
  opacity: 1;
  visibility: visible;
}
.lp_main .gnav_inner {
  padding: min(calc((40 / 750) * 100vw), 26px) min(calc((40 / 750) * 100vw), 26px) min(calc((80 / 750) * 100vw), 53px);
  font-size: initial;
  line-height: initial;
  vertical-align: initial;
}
.lp_main .gnav_logo {
  width: min(calc((200 / 750) * 100vw), 133px);
  margin: 0 0 min(calc((100 / 750) * 100vw), 66px) 0;
}
.lp_main .gnav_nav {
  text-align: center;
}
.lp_main .gnav_list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.lp_main .gnav_list a {
  display: block;
  padding: min(calc((24 / 750) * 100vw), 16px) 0;
  color: #0c244a;
  text-decoration: none;
  line-height: 1.4;
}
.lp_main .gnav_list--main a {
  font-size: min(calc((36 / 750) * 100vw), 24px);
}
.lp_main .gnav_list--sub {
  margin-top: min(calc((30 / 750) * 100vw), 20px);
}
.lp_main .gnav_list--sub a {
  font-size: min(calc((24 / 750) * 100vw), 16px);
  padding: min(calc((12 / 750) * 100vw), 8px) 0;
}
