@charset "UTF-8";
/* CSS Document */
/* ------------------------------
テキスト
------------------------------ */
.txt_indent {
  display: block;
  text-indent: -1em;
  margin-left: 1em;
}

.txt_ls_0 {
  letter-spacing: 0;
}

.txt_ls_01 {
  letter-spacing: 0.1em;
}

.txt_ls_015 {
  letter-spacing: 0.15em;
}

.txt_ls_02 {
  letter-spacing: 0.2em;
}

.txt_ls_005 {
  letter-spacing: 0.05em;
}

.txt_black {
  font-weight: 900;
}

.txt_bold {
  font-weight: 700;
}

.txt_en {
  font-family: "Oswald", sans-serif;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.txt_center {
  text-align: center !important;
}

.txt_right {
  text-align: right !important;
}

.blue {
  color: #008CA2;
}

.skyblue {
  color: #00AFCC;
}

.red {
  color: #E60F1A;
}

.pcbr {
  display: block;
}

.spbr {
  display: none;
}

.sp_only {
  display: none;
}

.fs_10 {
  font-size: 1rem;
}

.fs_12 {
  font-size: 1.2rem;
}

.fs_14 {
  font-size: 1.4rem;
}

.fs_16 {
  font-size: 1.6rem;
}

.fs_18 {
  font-size: 1.8rem;
}

.fs_20 {
  font-size: 2rem;
}

.fs_24 {
  font-size: 2.4rem;
}

.fs_26 {
  font-size: 2.6rem;
}

.fs_28 {
  font-size: 2.8rem;
}

.fs_30 {
  font-size: 3rem;
}

.fs_35 {
  font-size: 3.5rem;
}

.fs_40 {
  font-size: 4rem;
}

.fs_45 {
  font-size: 4.5rem;
}

.fs_50 {
  font-size: 5rem;
}

.fs_60 {
  font-size: 6rem;
}

.fs_70 {
  font-size: 7rem;
}

.fs_100 {
  font-size: 10rem;
}

.fw_100 {
  font-weight: 100;
}

.fw_200 {
  font-weight: 200;
}

.fw_300 {
  font-weight: 300;
}

.fw_400 {
  font-weight: 400;
}

.fw_500 {
  font-weight: 500;
}

.fw_700 {
  font-weight: 700;
}

.lh_10 {
  line-height: 1em !important;
}

.lh_12 {
  line-height: 1.2em !important;
}

.lh_14 {
  line-height: 1.4em !important;
}

.lh_15 {
  line-height: 1.5em !important;
}

.lh_16 {
  line-height: 1.6em !important;
}

.lh_18 {
  line-height: 1.8em !important;
}

.lh_20 {
  line-height: 2em !important;
}

.lh_25 {
  line-height: 2.5em !important;
}

.lh_28 {
  line-height: 2.8em !important;
}

.lh_30 {
  line-height: 3em !important;
}

.lh_32 {
  line-height: 3.2em !important;
}

.lh_35 {
  line-height: 3.5em !important;
}

.lh_40 {
  line-height: 4em !important;
}

.mrg__btm0 {
  margin-bottom: 0 !important;
}

.mrg__btm02 {
  margin-bottom: 0.2em !important;
}

.mrg__btm03 {
  margin-bottom: 0.3em !important;
}

.mrg__btm05 {
  margin-bottom: 0.5em !important;
}

.mrg__btm08 {
  margin-bottom: 0.8em !important;
}

.mrg__btm1 {
  margin-bottom: 1em !important;
}

.mrg__btm15 {
  margin-bottom: 1.5em !important;
}

.mrg__btm2 {
  margin-bottom: 2em !important;
}

.mrg__btm3 {
  margin-bottom: 3em !important;
}

.mrg__btm4 {
  margin-bottom: 4em !important;
}

.mrg__btm5 {
  margin-bottom: 5em !important;
}

.mrg__btm6 {
  margin-bottom: 6em !important;
}

.mrg__btm7 {
  margin-bottom: 7em !important;
}

.mrg__btm8 {
  margin-bottom: 8em !important;
}

.mrg__btm9 {
  margin-bottom: 9em !important;
}

.mrg__btm1-0 {
  margin-bottom: 10em !important;
}

.mrg__btm1-5 {
  margin-bottom: 15em !important;
}

.mrg__btm2-0 {
  margin-bottom: 20em !important;
}

.mrg__top0 {
  margin-top: 0 !important;
}

.mrg__top05 {
  margin-top: 0.5em !important;
}

.mrg__top1 {
  margin-top: 1em !important;
}

.mrg__top2 {
  margin-top: 2em !important;
}

.mrg__top3 {
  margin-top: 3em !important;
}

.mrg__top4 {
  margin-top: 4em !important;
}

.mrg__top5 {
  margin-top: 5em !important;
}

.mrg__top6 {
  margin-top: 6em !important;
}

.mrg__top7 {
  margin-top: 7em !important;
}

.mrg__top8 {
  margin-top: 8em !important;
}

.mrg__top9 {
  margin-top: 9em !important;
}

.mrg__left0 {
  margin-left: 0 !important;
}

.mrg__left1 {
  margin-left: 1em !important;
}

.mrg__left2 {
  margin-left: 2em !important;
}

.mrg__left3 {
  margin-left: 3em !important;
}

.mrg__right0 {
  margin-right: 0 !important;
}

.mrg__right1 {
  margin-right: 1em !important;
}

.mrg__right2 {
  margin-right: 2em !important;
}

.mrg__right3 {
  margin-right: 3em !important;
}

@media all and (max-width: 480px) {
  .txt__sp_ls_0 {
    letter-spacing: 0;
  }

  .txt__sp_ls_01 {
    letter-spacing: 0.1em;
  }

  .txt__sp_ls_02 {
    letter-spacing: 0.2em;
  }

  .txt__sp_s_005 {
    letter-spacing: 0.05em;
  }

  .pcbr {
    display: none;
  }

  .spbr {
    display: block;
  }

  .sp_only {
    display: block;
  }

  .txt__sp_center {
    display: block;
    text-align: center !important;
  }

  .txt__sp_right {
    display: block;
    text-align: right !important;
  }

  .txt__sp_left {
    display: block;
    text-align: left !important;
  }

  .fs__sp_10 {
    font-size: 1rem;
  }

  .fs__sp_12 {
    font-size: 1.2rem !important;
  }

  .fs__sp_14 {
    font-size: 1.4rem !important;
  }

  .fs__sp_16 {
    font-size: 1.6rem;
  }

  .fs__sp_18 {
    font-size: 1.8rem;
  }

  .fs__sp_20 {
    font-size: 2rem;
  }

  .fs__sp_24 {
    font-size: 2.4rem;
  }

  .fs__sp_30 {
    font-size: 3rem;
  }

  .fs__sp_40 {
    font-size: 4rem;
  }

  .fs__sp_70 {
    font-size: 7rem;
  }

  .lh__sp_10 {
    line-height: 1em !important;
  }

  .lh__sp_12 {
    line-height: 1.2em !important;
  }

  .lh__sp_14 {
    line-height: 1.4em !important;
  }

  .lh__sp_15 {
    line-height: 1.5em !important;
  }

  .lh__sp_16 {
    line-height: 1.6em !important;
  }

  .lh___sp_18 {
    line-height: 1.8em !important;
  }

  .lh__sp_20 {
    line-height: 2em !important;
  }

  .lh__sp_26 {
    line-height: 2.6em !important;
  }

  .lh__sp_30 {
    line-height: 3em !important;
  }

  .lh__sp_36 {
    line-height: 3.6em !important;
  }

  .lh__sp_40 {
    line-height: 4em !important;
  }

  .mrg__sp_btm0 {
    margin-bottom: 0 !important;
  }

  .mrg__sp_btm05 {
    margin-bottom: 0.5em !important;
  }

  .mrg__sp_btm1 {
    margin-bottom: 1em !important;
  }

  .mrg__sp_btm15 {
    margin-bottom: 1.5em !important;
  }

  .mrg__sp_btm2 {
    margin-bottom: 2em !important;
  }

  .mrg__sp_btm3 {
    margin-bottom: 3em !important;
  }

  .mrg__sp_btm4 {
    margin-bottom: 4em !important;
  }

  .mrg__sp_btm5 {
    margin-bottom: 5em !important;
  }

  .mrg__sp_btm6 {
    margin-bottom: 6em !important;
  }

  .mrg__sp_btm7 {
    margin-bottom: 7em !important;
  }

  .mrg__sp_btm8 {
    margin-bottom: 8em !important;
  }

  .mrg__sp_btm9 {
    margin-bottom: 9em !important;
  }

  .mrg__sp_top0 {
    margin-top: 0 !important;
  }

  .mrg__sp_top05 {
    margin-top: 0.5em !important;
  }

  .mrg__sp_top1 {
    margin-top: 1em !important;
  }

  .mrg__sp_top2 {
    margin-top: 2em !important;
  }

  .mrg__sp_top3 {
    margin-top: 3em !important;
  }

  .mrg__sp_top4 {
    margin-top: 4em !important;
  }

  .mrg__sp_top5 {
    margin-top: 5em !important;
  }

  .mrg__sp_top6 {
    margin-top: 6em !important;
  }

  .mrg__sp_top7 {
    margin-top: 7em !important;
  }

  .mrg__sp_top8 {
    margin-top: 8em !important;
  }

  .mrg__sp_top9 {
    margin-top: 9em !important;
  }
}
@font-face {
  font-family: "ns-j";
  font-weight: 400;
  src: url("https://xb285027.xbiz.jp/recruit/assets/font/notoSansJP-Regular.woff") format("woff");
}
@font-face {
  font-family: "ns-j";
  font-weight: 700;
  src: url("https://xb285027.xbiz.jp/recruit/assets/font/notoSansJP-Bold.woff") format("woff");
}
@font-face {
  font-family: "ns-j";
  font-weight: 900;
  src: url("https://xb285027.xbiz.jp/recruit/assets/font/notosansJP-Black.woff") format("woff");
}
/*---------------------------------------------
	FontSize Initialization
  ---------------------------------------------*/
html {
  font: 62.5%/1.231 "ns-j", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  width: 100%;
  height: -webkit-fill-available;
  overflow-y: scroll;
  overflow-x: hidden;
}

body {
  width: 100%;
  min-width: 1180px;
  min-height: 100vh;
  min-height: -webkit-fill-available;
  height: 100%;
  font-size: 1.6rem;
  font-weight: 400;
  color: #081639;
  -webkit-text-size-adjust: 100%;
  position: relative;
  background-color: #081639;
}
@media all and (max-width: 480px) {
  body {
    font-size: 1.4rem;
  }
}

p {
  letter-spacing: 0.05em;
}

/*スマートフォンのブレイクポイント*/
@media screen and (max-width: 480px) {
  body {
    /*初期化*/
    min-width: initial;
  }
}
select, input, button, textarea, table {
  font: 1rem "ns-j", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

pre, code, kbd, samp, tt {
  font-family: "ns-j", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1;
}

* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

@media all and (-ms-high-contrast: none) {
  html {
    font-family: "メイリオ", Meiryo, sans-serif;
  }
}
img {
  width: 100%;
  vertical-align: top;
  -ms-interpolation-mode: bicubic;
}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

.clearfix:before {
  content: "";
  display: block;
  clear: both;
}

.clearfix {
  display: block;
}

/*---------------------------------------------
	コンテンツ共通
  ---------------------------------------------*/
#wrap {
  position: relative;
  overflow: hidden;
  background-color: #ECEFF0;
  width: 100%;
  min-width: 1080px;
  opacity: 0;
  -webkit-clip-path: inset(0 0 0 100%);
          clip-path: inset(0 0 0 100%);
  -webkit-animation: page_Anim 1s cubic-bezier(0.69, 0, 0.29, 1.01);
          animation: page_Anim 1s cubic-bezier(0.69, 0, 0.29, 1.01);
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@media all and (max-width: 480px) {
  #wrap {
    min-width: 100%;
    overflow: hidden;
  }
}

@-webkit-keyframes page_Anim {
  0% {
    opacity: 0;
    -webkit-clip-path: inset(0 0 0 100%);
            clip-path: inset(0 0 0 100%);
  }
  100% {
    opacity: 1;
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
}

@keyframes page_Anim {
  0% {
    opacity: 0;
    -webkit-clip-path: inset(0 0 0 100%);
            clip-path: inset(0 0 0 100%);
  }
  100% {
    opacity: 1;
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
}
.contents {
  position: relative;
  z-index: 1;
  background-color: #ECEFF0;
  padding-bottom: 150px;
}
@media all and (max-width: 480px) {
  .contents {
    padding-bottom: 100px;
  }
}

.contents_inner {
  width: 1080px;
  padding-top: 50px;
  margin: 0 auto;
}
@media all and (max-width: 480px) {
  .contents_inner {
    width: 90%;
  }
}

.pan_nav {
  position: absolute;
  bottom: 15px;
  right: 35px;
}
@media all and (max-width: 480px) {
  .pan_nav {
    bottom: 10px;
    right: auto;
    left: 15px;
    width: 92%;
  }
}
.pan_nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.pan_nav ul li {
  margin-right: 20px;
  position: relative;
}
@media all and (max-width: 480px) {
  .pan_nav ul li {
    margin-right: 15px;
  }
}
.pan_nav ul li:after {
  content: "";
  width: 10px;
  height: 1px;
  background-color: #081639;
  position: absolute;
  top: 10px;
  right: -15px;
}
@media all and (max-width: 480px) {
  .pan_nav ul li:after {
    width: 6px;
    top: 9px;
    right: -10px;
  }
}
.pan_nav ul li:last-of-type:after {
  margin-right: 0;
}
.pan_nav ul li:last-of-type:after {
  display: none;
}
.pan_nav ul li a {
  opacity: 0.5;
  transition: -0.3s;
}
.pan_nav ul li a:hover {
  opacity: 1;
}

/*---------------------------------------------
	共通ボタンパーツ
  ---------------------------------------------*/
.link_btn a {
  border: 2px solid #fff;
  color: #fff;
  display: inline-block;
  padding: 6px 50px;
  border-radius: 30px;
  position: relative;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}

.link_btn a:before {
  content: "";
  position: absolute;
  top: 17px;
  right: 22px;
  width: 6px;
  height: 6px;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}

.link_btn a:after {
  content: "";
  position: absolute;
  top: 17px;
  right: 16px;
  width: 6px;
  height: 6px;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}

.link_btn a:hover:before {
  right: 16px;
}

/*---------------------------------------------
	ヘッダー
  ---------------------------------------------*/
.header {
  padding: 20px;
  position: absolute;
  z-index: 5;
}
@media all and (max-width: 480px) {
  .header {
    padding: 10px;
  }
}
.header h1 a {
  width: 325px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media all and (max-width: 480px) {
  .header h1 a {
    width: 280px;
  }
}
.header h1 a img {
  width: 114px;
  height: 38px;
  margin-right: 20px;
}
@media all and (max-width: 480px) {
  .header h1 a img {
    width: 80px;
    height: 27px;
    margin-right: 10px;
  }
}
.header h1 a p {
  padding-top: 3px;
  color: #fff;
}

/*---------------------------------------------
	グローバルナビ
  ---------------------------------------------*/
/*ハンバガーメニュー*/
.open_btn {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  border: 2px solid #fff;
  background-color: #081639;
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 9000;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
  cursor: pointer;
  opacity: 0;
  -webkit-animation: fadeIn 0.5s 1s ease-in-out;
          animation: fadeIn 0.5s 1s ease-in-out;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@media all and (max-width: 480px) {
  .open_btn {
    width: 60px;
    height: 60px;
    top: 10px;
    right: 10px;
  }
}
.open_btn span {
  width: 38px;
  height: 2px;
  display: block;
  background-color: #fff;
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 auto;
  z-index: 9000;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}
@media all and (max-width: 480px) {
  .open_btn span {
    width: 30px;
  }
}
.open_btn span:nth-of-type(1) {
  top: 38px;
}
@media all and (max-width: 480px) {
  .open_btn span:nth-of-type(1) {
    top: 23px;
  }
}
.open_btn span:nth-of-type(2) {
  top: 48px;
}
@media all and (max-width: 480px) {
  .open_btn span:nth-of-type(2) {
    top: 32px;
  }
}

.open_btn.active {
  border: none;
  background-color: transparent;
}
.open_btn.active span:nth-of-type(1) {
  -webkit-transform: translateY(5px) rotate(-35deg);
      -ms-transform: translateY(5px) rotate(-35deg);
          transform: translateY(5px) rotate(-35deg);
}
.open_btn.active span:nth-of-type(2) {
  -webkit-transform: translateY(-5px) rotate(35deg);
      -ms-transform: translateY(-5px) rotate(35deg);
          transform: translateY(-5px) rotate(35deg);
}

.g_nav {
  background-color: #081639;
  width: 100%;
  min-width: 1080px;
  height: 100vh;
  min-height: 100vh;
  position: fixed;
  top: 0;
  right: 0;
  z-index: -100;
  color: #fff;
  overflow: scroll;
  visibility: hidden;
  opacity: 0;
  -webkit-clip-path: inset(0 0 0 100%);
          clip-path: inset(0 0 0 100%);
  -webkit-transition: 0.5s cubic-bezier(0.69, 0, 0.29, 1.01);
  -o-transition: 0.5s cubic-bezier(0.69, 0, 0.29, 1.01);
  transition: 0.5s cubic-bezier(0.69, 0, 0.29, 1.01);
}
@media all and (max-width: 480px) {
  .g_nav {
    min-width: 100%;
  }
}
.g_nav a {
  color: #fff;
}
.g_nav nav {
  height: 100vh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media all and (max-width: 480px) {
  .g_nav nav {
    display: block;
    padding-top: 9vh;
  }
}
.g_nav nav .category {
  width: 25%;
  height: 50vh;
  min-height: 320px;
  border-right: 1px solid #516B7E;
  border-bottom: 1px solid #516B7E;
  padding: 60px 2vw 0;
  position: relative;
}
@media all and (max-width: 480px) {
  .g_nav nav .category {
    width: 100%;
    height: auto;
    min-height: auto;
    border: none;
    padding: 5px 0 0;
  }
}
.g_nav nav .category:nth-of-type(4), .g_nav nav .category:last-of-type {
  border-right: none;
}
.g_nav nav .category:nth-of-type(n + 5) {
  border-bottom: none;
}
.g_nav nav .category .top_link {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  padding: 60px 2.5vw 0;
  -webkit-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
}
@media all and (max-width: 480px) {
  .g_nav nav .category .top_link {
    position: static;
    display: block;
    padding: 15px 15px;
    height: auto;
    border: 2px solid #fff;
    width: 90%;
    margin: 0 auto 20px;
  }
}
.g_nav nav .category .top_link p {
  padding-left: 20px;
  opacity: 0;
  -webkit-clip-path: inset(0 0 0 100%);
          clip-path: inset(0 0 0 100%);
  -webkit-transition: 0.5s 0.2s cubic-bezier(0.69, 0, 0.29, 1.01);
  -o-transition: 0.5s 0.2s cubic-bezier(0.69, 0, 0.29, 1.01);
  transition: 0.5s 0.2s cubic-bezier(0.69, 0, 0.29, 1.01);
}
@media all and (max-width: 480px) {
  .g_nav nav .category .top_link p {
    opacity: 1;
    padding-left: 0;
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
    transiton: 0s 0s;
  }
}
.g_nav nav .category .top_link p .red {
  -webkit-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
}
.g_nav nav .category .top_link:hover {
  background-color: #E60F1A;
}
.g_nav nav .category .top_link:hover p .red {
  color: #081639;
}
.g_nav nav .category .site_tlt {
  font-size: 60px;
}
@media all and (max-width: 480px) {
  .g_nav nav .category .site_tlt {
    font-size: 6vw;
    text-align: center;
  }
  .g_nav nav .category .site_tlt br {
    display: none;
  }
}
.g_nav nav .category h2 {
  padding-left: 20px;
  opacity: 0;
  -webkit-clip-path: inset(0 0 0 100%);
          clip-path: inset(0 0 0 100%);
  -webkit-transition: 1s 0.5s cubic-bezier(0.69, 0, 0.29, 1.01);
  -o-transition: 1s 0.5s cubic-bezier(0.69, 0, 0.29, 1.01);
  transition: 1s 0.5s cubic-bezier(0.69, 0, 0.29, 1.01);
}
@media all and (max-width: 480px) {
  .g_nav nav .category h2 {
    position: relative;
    width: 90%;
    border-bottom: 2px solid #fff;
    margin: 0 auto;
    padding: 5px 20px;
    -webkit-transition-delay: 0.1s;
         -o-transition-delay: 0.1s;
            transition-delay: 0.1s;
  }
  .g_nav nav .category h2 br {
    display: none;
  }
}
@media all and (max-width: 480px) {
  .g_nav nav .category h2:before {
    content: "";
    position: absolute;
    top: 10px;
    right: 5px;
    width: 10px;
    height: 10px;
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
            transform: rotate(45deg);
    -webkit-transition: 0.3s;
    -o-transition: 0.3s;
    transition: 0.3s;
  }
}
@media all and (max-width: 480px) {
  .g_nav nav .category h2.active:before {
    top: 15px;
    -webkit-transform: rotate(-135deg);
        -ms-transform: rotate(-135deg);
            transform: rotate(-135deg);
  }
}
.g_nav nav .category ul {
  padding-left: 40px;
  opacity: 0;
  -webkit-clip-path: inset(0 0 0 100%);
          clip-path: inset(0 0 0 100%);
  -webkit-transition: 1s 0.5s cubic-bezier(0.69, 0, 0.29, 1.01);
  -o-transition: 1s 0.5s cubic-bezier(0.69, 0, 0.29, 1.01);
  transition: 1s 0.5s cubic-bezier(0.69, 0, 0.29, 1.01);
}
@media all and (max-width: 480px) {
  .g_nav nav .category ul {
    display: none;
    -webkit-transition: none;
    -o-transition: none;
    transition: none;
  }
}
.g_nav nav .category li {
  line-height: 1.3em;
}
.g_nav nav .category li a {
  position: relative;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}
@media all and (max-width: 480px) {
  .g_nav nav .category li a br {
    display: none;
  }
}
.g_nav nav .category li a:before {
  content: "";
  position: absolute;
  top: 10px;
  left: -20px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #516B7E;
  border-right: 2px solid #516B7E;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}
@media all and (max-width: 480px) {
  .g_nav nav .category li a:before {
    display: none;
  }
}
.g_nav nav .category li a:after {
  content: "";
  position: absolute;
  top: 10px;
  left: -14px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #516B7E;
  border-right: 2px solid #516B7E;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}
@media all and (max-width: 480px) {
  .g_nav nav .category li a:after {
    display: none;
  }
}
.g_nav nav .category li a:hover {
  color: #008CA2;
}
.g_nav nav .category li a:hover:before {
  left: -14px;
  border-color: #fff;
}
.g_nav nav .category li a:hover:after {
  border-color: #fff;
}
.g_nav nav .category li a .square {
  display: inline-block;
  width: 65px;
  height: 15px;
  border: 2px solid #fff;
  margin: 3px 0 0 3px;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}
.g_nav nav .category li a:hover .square {
  border-color: #008CA2;
}
.g_nav nav .category .in_nav {
  padding: 10px 0 0 0;
}
.g_nav nav .category .in_nav li a {
  font-weight: 400;
  color: #B4B8C3;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}
.g_nav nav .category .in_nav li a:before {
  display: none;
}
.g_nav nav .category .in_nav li a:after {
  display: none;
}
.g_nav nav .category .in_nav li a:hover {
  color: #fff;
}
.g_nav nav .category:nth-of-type(odd) li a:hover {
  color: #E60F1A;
}
.g_nav nav .category:nth-of-type(odd) .in_nav li a:hover {
  color: #fff;
}
.g_nav nav .category.twoLines {
  padding-top: 45px;
}
@media all and (max-width: 480px) {
  .g_nav nav .category.twoLines {
    padding-top: 15px;
  }
}

.g_nav.active {
  z-index: 8000;
  visibility: visible;
  opacity: 1;
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.g_nav.active nav .category .top_link p {
  padding-left: 0;
  opacity: 1;
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.g_nav.active nav .category h2 {
  padding-left: 0;
  opacity: 1;
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.g_nav.active nav .category ul {
  padding-left: 20px;
  opacity: 1;
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.g_nav.active nav .category ul .in_nav {
  padding-left: 0;
}

/*↓スマホ横css*/
@media screen and (min-width: 480px) and (max-width: 915px) {
  .g_nav {
    min-width: 100%;
    height: 100%;
    min-height: 100%;
    overflow: scroll;
  }
  .g_nav nav {
    height: 100%;
    overflow: scroll;
  }
  .g_nav nav .category {
    min-height: 370px;
  }
}
/*↓ipad用縦css*/
@media screen and (min-device-width: 744px) and (max-device-width: 1133px) and (orientation: portrait) {
  .g_nav {
    min-width: 100%;
    height: 100%;
    min-height: 100%;
    overflow: hidden;
  }
  .g_nav nav {
    height: 100%;
  }
  .g_nav nav .category {
    width: 50%;
    height: 25%;
    min-height: 25%;
    border-right: 1px solid #3B404B;
    border-bottom: 1px solid #3B404B;
    padding: 60px 7vw 0;
    position: relative;
  }
  .g_nav nav .category:nth-of-type(2n) {
    border-right: none;
  }
  .g_nav nav .category:nth-of-type(n + 5) {
    border-bottom: 1px solid #3B404B;
  }
  .g_nav nav .category:nth-of-type(n + 7) {
    border-bottom: none;
  }
  .g_nav nav .category .top_link {
    padding-left: 7vw;
  }
  .g_nav nav .category .top_link .site_tlt {
    font-size: 70px;
    line-height: 1.5em;
  }
  .g_nav nav .category .top_link .site_tlt br.padnone {
    display: none;
  }
  .g_nav nav .category h2 {
    font-size: 30px;
    margin-bottom: 20px !important;
  }
  .g_nav nav .category ul {
    font-size: 18px;
  }
}
/*↓ipad用横css*/
@media screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation: landscape) {
  .g_nav {
    min-width: 100%;
    height: 100%;
    min-height: 100%;
    overflow: hidden;
  }
  .g_nav nav {
    height: 100%;
  }
}
/*---------------------------------------------
	右下　固定ボタン
  ---------------------------------------------*/
.fixed_btn_area {
  position: fixed;
  width: 310px;
  height: 90px;
  bottom: 25px;
  right: 25px;
  z-index: 5000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  opacity: 0;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-animation: fadeIn 0.5s 1s ease-in-out;
          animation: fadeIn 0.5s 1s ease-in-out;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@media all and (max-width: 480px) {
  .fixed_btn_area {
    width: 100%;
    height: 50px;
    bottom: 0;
    right: 0;
  }
}
@media all and (max-width: 480px) {
  .fixed_btn_area .fixed_btn {
    width: 33.3333333333%;
  }
}
.fixed_btn_area .fixed_btn a {
  display: block;
  width: 90px;
  height: 90px;
  border-radius: 50%;
  background-color: #fff;
  padding-top: 20px;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}
@media all and (max-width: 480px) {
  .fixed_btn_area .fixed_btn a {
    width: 100%;
    height: 50px;
    border-radius: 0%;
    padding-top: 5px;
  }
}
.fixed_btn_area .fixed_btn a:hover {
  -webkit-transform: scale(1.1) translateY(-5px);
      -ms-transform: scale(1.1) translateY(-5px);
          transform: scale(1.1) translateY(-5px);
}
@media all and (max-width: 480px) {
  .fixed_btn_area .fixed_btn a:hover {
    -webkit-transform: none;
        -ms-transform: none;
            transform: none;
  }
}
.fixed_btn_area .fixed_btn:nth-of-type(3) a {
  padding-top: 13px;
}
@media all and (max-width: 480px) {
  .fixed_btn_area .fixed_btn:nth-of-type(3) a {
    padding-top: 8px;
  }
}
.fixed_btn_area .fixed_btn.entry a {
  background-color: #E60F1A;
}
.fixed_btn_area .fixed_btn.entry a span {
  color: #fff;
}
.fixed_btn_area .fixed_btn.mypage a span {
  color: #E60F1A;
}
.fixed_btn_area .fixed_btn.career a {
  background-color: #008CA2;
}
.fixed_btn_area .fixed_btn.career a span:nth-of-type(2) {
  color: #fff;
}

/*---------------------------------------------
	フッター
  ---------------------------------------------*/
.footer {
  background-color: #081639;
  color: #C1C2C3;
  padding: 70px 50px 50px;
  position: relative;
}
@media all and (max-width: 480px) {
  .footer {
    padding: 30px 15px 70px;
  }
}
.footer a {
  color: #C1C2C3;
}
.footer .site_tlt {
  font-size: 70px;
  line-height: 1em;
  opacity: 0.5;
}
@media all and (max-width: 480px) {
  .footer .site_tlt {
    font-size: 10vw;
  }
}
.footer .contact_link {
  letter-spacing: 0.1em;
  position: relative;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}
.footer .contact_link:before {
  content: "";
  position: absolute;
  top: 9px;
  right: -14px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #C1C2C3;
  border-right: 2px solid #C1C2C3;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}
@media all and (max-width: 480px) {
  .footer .contact_link:before {
    top: 7px;
  }
}
.footer .contact_link:after {
  content: "";
  position: absolute;
  top: 9px;
  right: -20px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #C1C2C3;
  border-right: 2px solid #C1C2C3;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: 0.3s 0.1s;
  -o-transition: 0.3s 0.1s;
  transition: 0.3s 0.1s;
}
@media all and (max-width: 480px) {
  .footer .contact_link:after {
    top: 7px;
  }
}
.footer .contact_link:hover {
  color: #fff;
}
.footer .contact_link:hover:before {
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  right: -20px;
}
.footer .contact_link:hover:after {
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}
.footer .corp_btn {
  position: absolute;
  top: 85px;
  right: 50px;
}
@media all and (max-width: 480px) {
  .footer .corp_btn {
    position: static;
  }
}
.footer .corp_btn a {
  border-color: #C1C2C3;
}
.footer .corp_btn a:before {
  border-color: #C1C2C3;
}
.footer .corp_btn a:after {
  border-color: #C1C2C3;
}
.footer .corp_btn a:hover {
  background-color: #C1C2C3;
  color: #081639;
}
.footer .corp_btn a:hover:before {
  border-color: #081639;
}
.footer .corp_btn a:hover:after {
  border-color: #081639;
}
.footer .footer_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media all and (max-width: 480px) {
  .footer .footer_link {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
.footer .footer_link li {
  margin-right: 25px;
  letter-spacing: 0.05em;
}
@media all and (max-width: 480px) {
  .footer .footer_link li {
    margin-right: 15px;
  }
}
.footer .footer_link li:last-of-type {
  margin-right: 0;
}
.footer .footer_link li a {
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
  opacity: 0.5;
}
.footer .footer_link li a:hover {
  color: #fff;
  opacity: 1;
}
.footer small {
  opacity: 0.5;
}

@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}