@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;
}
.kv {
  position: absolute;
  left: 0;
  top: 0;
  position: fixed;
  width: 100%;
  height: 660px;
  overflow: hidden;
}
.kv__bg {
  width: 100%;
  height: 100%;
  background: url(../img/about/vision/sp_kv_bg.jpg) center center / cover no-repeat;
  position: absolute;
  left: 0;
  top: 0;
}
.kv__title__E {
  color: white;
  font-size: 72px;
  position: absolute;
  left: 0;
  top: 470px;
}
.kv__title__J {
  color: white;
  font-size: 26px;
  position: absolute;
  left: 0;
  top: 540px;
}
main {
  position: relative;
  margin-top: 660px;
  background-color: #efede6;
  padding-bottom: 60px;
  padding-top: 200px;
}
main .sec {
  position: relative;
  width: 500px;
  padding-top: 40px;
  padding-bottom: 300px;
  border-bottom: 2px solid #4b4b4b;
}
main .sec:first-of-type {
  border-top: 2px 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: 120px;
  font-weight: 700;
  line-height: 100%;
  /* 150px */
  -ms-writing-mode: tb-rl;
      writing-mode: vertical-rl;
  white-space: nowrap;
  position: absolute;
  right: -208px;
  top: 100px;
}
main .sec__head__catch {
  color: #CBC09D;
  font-size: 20px;
  font-weight: 700;
  line-height: 100%;
  /* 14px */
  letter-spacing: 0.1em;
}
main .sec__head__subtitle {
  color: #4B4B4B;
  font-feature-settings: 'palt' on;
  font-size: 48px;
  font-weight: 700;
  line-height: 130%;
  /* 44.2px */
  letter-spacing: 0.05em;
  margin-top: 20px;
}
main .sec__head__read {
  font-size: 26px;
  font-weight: 700;
  line-height: 170%;
  /* 28.8px */
  margin-top: 40px;
}
main .temp1 .sec__title {
  top: 0;
}
main .temp1 .sec__head__img img {
  width: 100%;
  height: auto;
  margin-top: 60px;
}
main .temp1 .sec__head__link {
  white-space: nowrap;
  display: block;
  text-align: right;
  margin-top: 48px;
}
main .temp1 .sec__head__link .arrow {
  position: relative;
  display: inline-block;
  width: 100px;
  height: 100px;
  background-color: white;
  border-radius: 200px;
  background: white;
  vertical-align: middle;
}
main .temp1 .sec__head__link .arrow:before {
  content: '';
  width: 4.267vw;
  height: 3.2vw;
  background-image: url("../img/btn_arrow.svg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
main .temp1 .sec__head__link .arrow:before a {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
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: 28px;
  font-weight: 700;
  color: white;
  margin-left: 28px;
}
main .temp1 .sec__head__link.inv .arrow {
  background-color: #4B4B4B;
}
main .temp1 .sec__head__link.inv .arrow:before {
  width: 4.267vw;
  height: 3.2vw;
  background-image: url("../img/btn_arrow_w.svg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
}
main .temp1 .sec__head__link.inv .arrow:before a {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
main .temp1 .sec__head__link.inv .text {
  color: #4B4B4B;
}
main .temp1 .sec__head__link.out .arrow {
  transform: rotate(-45deg);
}
main .temp1 .sec__head__link .arrow::before {
  display: none !important;
}
main .temp1 .sec__head__link .arrow::after {
  content: '';
  width: 4.267vw;
  height: 4.267vw;
  background-image: url("../img/work/career/icon_plus.svg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
main .temp1 .sec__head__link .arrow::after a {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
main .temp2 {
  padding-bottom: 80px;
}
main .temp2 .sec__title {
  top: 0;
}
main .temp2.last {
  padding-bottom: 160px;
}
main .temp3 {
  padding-bottom: 100px;
}
main .temp3 .sec__title {
  top: 0;
}
main .il1 .sec__head__read {
  margin-top: 20px;
}
main .il1 b {
  font-weight: bold;
  display: block;
}
main .il1 p {
  margin-top: 0px;
}
main .il2 {
  border: none;
}
main .il2 .sec__head__img {
  width: 66.933vw;
  height: 44.533vw;
  background-image: url("../img/about/vision/sp_logo.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  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: 40px;
}
.rellink__bg {
  background: url(../img/about/vision/sp_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: 638px;
  height: 904px;
}
.modal__container img {
  width: 100%;
  height: auto;
}
.modal__closebtn {
  width: 300px;
  height: 100px;
  border-radius: 200px;
  background-color: white;
  position: absolute;
  margin: auto;
  left: 0;
  right: 0;
  bottom: 80px;
  cursor: pointer;
}
.modal__closebtn .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: 28px;
  font-weight: 700;
  letter-spacing: 0.56px;
  position: absolute;
  left: 80px;
  top: 4px;
}
.modal__closebtn .arrow {
  display: block;
  width: 4.267vw;
  height: 4.267vw;
  background-image: url("../img/work/career/icon_plus_b.svg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
  transform: rotate(45deg);
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  right: 40px;
}
.modal__closebtn .arrow a {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
