@charset "utf-8";
/*
.font-serif(){
	//font-family: "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝";
	font-family: "Noto Serif JP", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
}
.font-serif-bold(){
	.font-serif();
	font-weight: bold;
}
*/
.abswh100 {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}
.wh100 {
  width: 100%;
  height: 100%;
}
.center {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
}
.abscenter {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
.hv_center {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
}
.h_center {
  position: absolute;
  right: 0;
  left: 0;
  margin: auto;
}
.v_center {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
}
.hover_scale {
  transition: all 200ms 0s ease;
}
.hover_scale:hover {
  transform: scale(1.03);
}
/*==============================================================
  ■ (PC)
==============================================================*/
.maincontent {
  overflow: hidden;
}
.inner {
  width: 1244px;
}
.kv {
  position: absolute;
  left: 0;
  top: 0;
  position: fixed;
  width: 100%;
  height: 550px;
  overflow: hidden;
}
.kv .inner {
  padding-top: 356px;
}
.kv__bg {
  width: 100%;
  height: 550px;
  background: url(../img/about/vision/kv_bg.jpg) top center / cover no-repeat;
  position: absolute;
  left: 0;
  top: 0;
}
.kv__title {
  color: white;
}
.kv__title__E {
  font-family: 'Albert Sans', 'Noto Sans JP', "游ゴシック体", 'Yu Gothic', "YuGothic", "Noto Sans JP", 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', "メイリオ", "Meiryo", "Osaka", 'ＭＳ Ｐゴシック', 'MS PGothic', "sans-serif";
  font-size: 80px;
  font-weight: 700;
}
.kv__title__J {
  font-size: 16px;
  margin-top: 10px;
}
main {
  position: relative;
  margin-top: 550px;
  background-color: #efede6;
  padding-bottom: 100px;
}
main .inner {
  padding-top: 150px;
  width: 1034px;
}
main .sec {
  position: relative;
  width: 820px;
  padding-top: 50px;
  padding-bottom: 150px;
  border-bottom: 1px solid #4b4b4b;
}
main .sec__title {
  color: #CBC09D;
  font-family: 'Albert Sans', 'Noto Sans JP', "游ゴシック体", 'Yu Gothic', "YuGothic", "Noto Sans JP", 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', "メイリオ", "Meiryo", "Osaka", 'ＭＳ Ｐゴシック', 'MS PGothic', "sans-serif";
  font-size: 150px;
  font-weight: 700;
  line-height: 100%;
  /* 150px */
  letter-spacing: 3px;
  -ms-writing-mode: tb-rl;
      writing-mode: vertical-rl;
  white-space: nowrap;
  position: absolute;
  right: -236px;
  top: 50px;
}
main .sec__head__catch {
  color: #CBC09D;
  font-size: 14px;
  font-weight: 700;
  line-height: 100%;
  /* 14px */
  letter-spacing: 0.05emx;
}
main .sec__head__subtitle {
  color: #4B4B4B;
  font-size: 34px;
  font-weight: 700;
  line-height: 130%;
  /* 44.2px */
  letter-spacing: 0.05em;
  margin-top: 20px;
}
main .sec__head__read {
  font-size: 16px;
  font-weight: 700;
  line-height: 169%;
  /* 28.8px */
  letter-spacing: 0.1em;
  margin-top: 60px;
}
main .temp1 .sec__head__img img {
  width: 100%;
  height: auto;
  margin-top: 60px;
}
main .temp1 .sec__head__link {
  width: 140px;
  margin-left: auto;
  display: block;
  text-align: right;
  margin-top: 40px;
  cursor: pointer;
}
main .temp1 .sec__head__link .arrow {
  position: relative;
  display: inline-block;
  width: 60px;
  height: 60px;
  background-color: white;
  border-radius: 100px;
  background: #4B4B4B;
  vertical-align: middle;
  overflow: hidden;
  transition: all 300ms 0s ease;
}
main .temp1 .sec__head__link .arrow:before {
  content: '';
  width: 60px;
  height: 60px;
  background-color: white;
  border-radius: 200px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  transform: scale(0);
  transition: all 300ms 0s ease;
}
main .temp1 .sec__head__link .arrow:after {
  content: '';
  display: block;
  width: 16px;
  height: 12px;
  background-image: url("../img/btn_arrow_w.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  text-indent: -9999px;
  overflow: hidden;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
main .temp1 .sec__head__link .text {
  font-family: 'Albert Sans', 'Noto Sans JP', "游ゴシック体", 'Yu Gothic', "YuGothic", "Noto Sans JP", 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', "メイリオ", "Meiryo", "Osaka", 'ＭＳ Ｐゴシック', 'MS PGothic', "sans-serif";
  font-size: 14px;
  font-weight: 700;
  color: #4B4B4B;
  margin-left: 14px;
}
main .temp1 .sec__head__link:hover .arrow {
  background-color: white;
  transition: all 300ms 0.2s ease;
}
main .temp1 .sec__head__link:hover .arrow:before {
  transform: scale(1);
}
main .temp1 .sec__head__link:hover .arrow:after {
  animation: 600ms ease-out 0s 1 normal forwards running overarrowinv;
}
@keyframes overarrowinv {
  0% {
    transform: translateX(0px);
  }
  40% {
    transform: translateX(60px);
  }
  41% {
    display: block;
    width: 16px;
    height: 12px;
    background-image: url("../img/btn_arrow.svg");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    text-indent: -9999px;
    overflow: hidden;
    transform: translateX(-60px);
  }
  100% {
    display: block;
    width: 16px;
    height: 12px;
    background-image: url("../img/btn_arrow.svg");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    text-indent: -9999px;
    overflow: hidden;
    transform: translateX(0px);
  }
}
main .temp1 .sec__head__link .arrow:after {
  display: block;
  width: 16px;
  height: 16px;
  background-image: url("../img/work/career/icon_plus.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  text-indent: -9999px;
  overflow: hidden;
}
main .temp1 .sec__head__link:hover .arrow:after {
  animation: 600ms ease-out 0s 1 normal forwards running overarrowinvca;
}
@keyframes overarrowinvca {
  0% {
    transform: translateX(0px);
  }
  40% {
    transform: translateX(60px);
  }
  41% {
    display: block;
    width: 16px;
    height: 16px;
    background-image: url("../img/work/career/icon_plus_b.svg");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    text-indent: -9999px;
    overflow: hidden;
    transform: translateX(-60px);
  }
  100% {
    display: block;
    width: 16px;
    height: 16px;
    background-image: url("../img/work/career/icon_plus_b.svg");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    text-indent: -9999px;
    overflow: hidden;
    transform: translateX(0px);
  }
}
main .temp2 {
  padding-bottom: 100px;
}
main .temp2 .sec__title {
  top: 0;
}
main .temp2 .sec__head__read {
  text-align: right;
  position: absolute;
  right: 0;
  top: -10px;
}
main .temp2.last {
  padding-bottom: 148px;
}
main .temp3 {
  padding-bottom: 100px;
}
main .temp3 .sec__title {
  top: 0;
}
main .il1 .sec__head__read {
  margin-top: 30px;
}
main .il1 b {
  font-weight: bold;
  display: block;
}
main .il1 p {
  margin-top: 25px;
}
main .il2 {
  border: none;
}
main .il2 .sec__head__img {
  width: 821px;
  height: 546px;
  background-image: url("../img/about/vision/logo.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
  margin-top: 20px;
}
main .il2 .sec__head__img a {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
main .il2 .sec__head__read {
  margin-top: 50px;
}
.rellink__titleE {
  top: 122px;
}
.rellink__titleJ {
  top: 262px;
}
.rellink__bg {
  background: url(../img/about/vision/rellink_bg.jpg) center center / cover no-repeat;
}
.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: none;
  z-index: 100;
}
.modal__bg {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: #222;
}
.modal__container {
  position: relative;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 80%;
  height: 80%;
}
.modal__container img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.modal__closebtn {
  width: 60px;
  height: 60px;
  border-radius: 100px;
  background-color: white;
  position: absolute;
  right: 30px;
  top: 40px;
  cursor: pointer;
  transition: all 300ms 0s ease;
}
.modal__closebtn .text {
  display: none;
}
.modal__closebtn:hover {
  transform: scale(1.05);
}
.modal__closebtn .arrow {
  display: block;
  width: 16px;
  height: 16px;
  background-image: url("../img/work/career/icon_plus_b.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  text-indent: -9999px;
  overflow: hidden;
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
