/* LESS Document */
/*+++++++++++++++++++++++++++++++++++++++++++
	見出し
+++++++++++++++++++++++++++++++++++++++++++ */
main {
  /*+++++++++++++++++++++++++++++++++++++++++++
	アニメーション用クラス
+++++++++++++++++++++++++++++++++++++++++++ */
  /*+++++++++++++++++++++++++++++++++++++++++++
	mv
+++++++++++++++++++++++++++++++++++++++++++ */
  /*+++++++++++++++++++++++++++++++++++++++++++
	philosophy_stepArea
+++++++++++++++++++++++++++++++++++++++++++ */
  /*+++++++++++++++++++++++++++++++++++++++++++
	philosophy_stepArea
+++++++++++++++++++++++++++++++++++++++++++ */
  /*+++++++++++++++++++++++++++++++++++++++++++
	visionArea
+++++++++++++++++++++++++++++++++++++++++++ */
  /*+++++++++++++++++++++++++++++++++++++++++++
	banaArea
+++++++++++++++++++++++++++++++++++++++++++ */
}
main::before {
  content: none;
}
main hgroup h1 {
  color: #3B8B8B;
  border-bottom: 2px solid #3B8B8B;
  max-width: 176px;
  width: 100%;
  font-weight: 800;
  margin: 0 auto;
  margin-bottom: 42px;
  padding-bottom: 13.5px;
}
@media screen and (max-width: 767px) {
  main hgroup h1 {
    max-width: 32vw;
  }
}
main h2 {
  font-size: 3.6rem;
}
@media screen and (max-width: 767px) {
  main h2 {
    font-size: 7.2vw;
  }
}
main .catch2 h2,
main .catch2 p {
  color: #444444;
}
main .catch2 h2 {
  font-size: 12.8rem;
  font-style: italic;
  font-weight: 800;
  font-family: 'Roboto', sans-serif;
  line-height: 0.8;
}
@media screen and (max-width: 1023px) {
  main .catch2 h2 {
    font-size: 10.8rem;
  }
}
@media screen and (max-width: 767px) {
  main .catch2 h2 {
    font-size: 13vw;
  }
}
main .catch2 p {
  margin: -3px 0 35px 0;
  font-weight: 800;
}
main .fade-up,
main .fade-left,
main .box-fade,
main .text-fade {
  opacity: 0;
  transform: translateY(30px);
  transition: all 0.8s ease-out;
}
main .fade-up.inview,
main .fade-left.inview,
main .box-fade.inview,
main .text-fade.inview {
  opacity: 1;
  transform: translateY(0);
}
main .fade-left {
  transform: translateX(-30px);
}
main .fade-left.inview {
  transform: translateX(0);
}
main .mv {
  overflow: visible;
  position: relative;
}
main .mv::before {
  background: url(../img/mv_back.png) top no-repeat;
  background-size: cover;
  background-position: center;
  position: absolute;
  content: '';
  top: -139px;
  width: 100%;
  height: 100%;
  z-index: -1;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  main .mv::before {
    background-position: 0 -3vw;
    background-size: 102vw auto;
    top: -43px;
  }
}
main .mv .flex {
  justify-content: center;
  align-items: flex-start;
  gap: 0;
}
@media screen and (max-width: 767px) {
  main .mv .flex {
    gap: 10px;
  }
}
main .mv .flex img {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  main .mv .flex img {
    height: 100%;
    object-fit: cover;
  }
}
main .mv .flex img:nth-child(1) {
  transform: translateX(15px);
}
@media screen and (max-width: 767px) {
  main .mv .flex img:nth-child(1) {
    width: 18%;
  }
}
main .mv .flex img:nth-child(2) {
  position: relative;
  z-index: 2;
  transform: translateX(29px);
}
@media screen and (max-width: 767px) {
  main .mv .flex img:nth-child(2) {
    width: 25%;
    transform: translateX(18%);
  }
}
main .mv .flex img:nth-child(3) {
  transform: translate(-15px, -10px);
}
@media screen and (max-width: 767px) {
  main .mv .flex img:nth-child(3) {
    width: 18%;
  }
}
main .mv .flex img:nth-child(4) {
  transform: translate(-15px, -10px);
}
@media screen and (max-width: 767px) {
  main .mv .flex img:nth-child(4) {
    width: 24%;
  }
}
main .mv .mv_box {
  background: #fff;
  padding: 62px 43px 41px 30px;
  border-radius: 30px;
  max-width: 840px;
  margin: 0 auto;
  margin-top: -64px;
}
@media screen and (max-width: 1023px) {
  main .mv .mv_box {
    padding: 62px 13px 41px 7px;
  }
}
main .mv .mv_box.box-fade {
  opacity: 0;
  transform: translateY(50px);
  transition: all 0.8s ease-out;
}
main .mv .mv_box.box-fade.inview {
  opacity: 1;
  transform: translateY(0);
}
main .mv .mv_box h3 .text-fade,
main .mv .mv_box p .text-fade {
  opacity: 0;
  transform: translateY(20px);
  transition: all 1s ease-out;
  transition-delay: 0.5s;
}
.box-fade.inview main .mv .mv_box h3 .text-fade,
.box-fade.inview main .mv .mv_box p .text-fade {
  opacity: 1;
  transform: translateY(0);
}
main .mv .mv_box h3 {
  color: #3B8B8B;
  padding-bottom: 20px;
  line-height: 2;
}
main .mv .mv_box h3 span {
  line-height: 1.5;
}
main .mv .mv_box p {
  border-top: 4px solid #3B8B8B;
  padding-top: 31px;
  margin-left: 11px;
  line-height: 1.6;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 1023px) {
  main .mv .mv_box p {
    width: 95%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  main .mv .mv_box p {
    text-align: left;
  }
}
main .philosophy_stepArea {
  margin: 134px 0 83px 0;
}
main .philosophy_stepArea .flex {
  position: relative;
  margin: 0 auto;
  opacity: 0;
  transform: translateX(50px);
  transition: opacity 1s ease, transform 0.8s ease;
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex {
    margin-bottom: 23px;
  }
}
main .philosophy_stepArea .flex.from-left {
  transform: translateX(-50px);
}
main .philosophy_stepArea .flex.inview {
  opacity: 1;
  transform: translateX(0);
}
main .philosophy_stepArea .flex::before,
main .philosophy_stepArea .flex::after {
  position: absolute;
  font-size: 39rem;
  font-weight: 800;
  font-family: 'Roboto', sans-serif;
  font-style: italic;
  line-height: 0.5;
  color: #3B8B8B;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex::before,
  main .philosophy_stepArea .flex::after {
    font-size: 62vw;
  }
}
main .philosophy_stepArea .flex:nth-of-type(1) {
  max-width: 944px;
  gap: 41px;
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex:nth-of-type(1) {
    max-width: none;
    gap: 20px;
  }
}
main .philosophy_stepArea .flex:nth-of-type(1)::before {
  content: '1';
  top: -24px;
  left: -125px;
}
@media screen and (max-width: 1023px) {
  main .philosophy_stepArea .flex:nth-of-type(1)::before {
    left: -42px;
  }
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex:nth-of-type(1)::before {
    left: -36px;
  }
}
main .philosophy_stepArea .flex:nth-of-type(2) {
  max-width: 1108px;
  gap: 159px;
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex:nth-of-type(2) {
    max-width: none;
    gap: 10px;
    margin-bottom: 73px;
  }
}
main .philosophy_stepArea .flex:nth-of-type(2) .flexImg {
  margin-top: 17px;
}
main .philosophy_stepArea .flex:nth-of-type(2)::after {
  content: '2';
  top: -24px;
  right: -5px;
}
main .philosophy_stepArea .flex:nth-of-type(3) {
  max-width: 933px;
  gap: 16px;
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex:nth-of-type(3) {
    max-width: none;
  }
}
main .philosophy_stepArea .flex:nth-of-type(3)::before {
  content: '3';
  top: -31px;
  left: -123px;
}
@media screen and (max-width: 1023px) {
  main .philosophy_stepArea .flex:nth-of-type(3)::before {
    left: -2px;
  }
}
main .philosophy_stepArea .flex:nth-of-type(4) {
  max-width: 1168px;
  gap: 139px;
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex:nth-of-type(4) {
    max-width: none;
    gap: 0;
  }
}
main .philosophy_stepArea .flex:nth-of-type(4) .flexImg {
  margin-top: 47px;
}
main .philosophy_stepArea .flex:nth-of-type(4) .flexText p {
  margin-right: 41px;
}
main .philosophy_stepArea .flex:nth-of-type(4)::after {
  content: '4';
  top: 7px;
  right: 26px;
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex:nth-of-type(4)::after {
    right: -8px;
  }
}
main .philosophy_stepArea .flex:nth-of-type(2),
main .philosophy_stepArea .flex:nth-of-type(4) {
  flex-direction: row-reverse;
}
main .philosophy_stepArea .flex:nth-of-type(2) .flexText,
main .philosophy_stepArea .flex:nth-of-type(4) .flexText {
  text-align: right;
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex:nth-of-type(2) .flexText,
  main .philosophy_stepArea .flex:nth-of-type(4) .flexText {
    text-align: left;
  }
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex:nth-of-type(3) .flexImg img,
  main .philosophy_stepArea .flex:nth-of-type(4) .flexImg img {
    width: 17vw;
  }
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex .flexImg img {
    width: 13vw;
    margin-top: -4vw;
  }
}
main .philosophy_stepArea .flex .flexText h2 {
  font-size: 3.6rem;
  margin-top: 17px;
  line-height: 1.2;
}
@media screen and (max-width: 1023px) {
  main .philosophy_stepArea .flex .flexText h2 {
    font-size: 3rem;
  }
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex .flexText h2 {
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex .flexText h2 {
    font-size: 7.2vw;
  }
}
main .philosophy_stepArea .flex .flexText p {
  font-size: 2rem;
  margin-top: 2px;
  font-feature-settings: "palt";
}
@media screen and (max-width: 767px) {
  main .philosophy_stepArea .flex .flexText p {
    font-size: 4vw;
  }
}
main .promiseArea {
  padding-bottom: 119px;
}
@media screen and (max-width: 767px) {
  main .promiseArea {
    padding-bottom: 70px;
  }
}
main .promiseArea hgroup {
  display: block;
}
main .promiseArea .promiseBox {
  background: url(../img/promise_back.png) no-repeat center / contain;
  height: 721px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 80px;
}
@media screen and (max-width: 767px) {
  main .promiseArea .promiseBox {
    height: auto;
    gap: 34px;
    padding: 4vw 0;
  }
}
@media screen and (max-width: 767px) {
  main .promiseArea .promiseBox p {
    margin-bottom: 0;
  }
}
main .promiseArea .promiseBox p .btn {
  min-width: 443px;
  min-height: 104px;
  border-radius: 50px;
  font-size: 4.8rem;
  font-weight: 800;
  position: relative;
  flex-direction: column;
  background: #fff;
  color: #9A0034;
  box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
  font-feature-settings: "palt";
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  main .promiseArea .promiseBox p .btn {
    min-width: auto;
    max-width: none;
    width: 55vw;
    min-height: 10px;
    font-size: 5.6vw;
  }
}
main .promiseArea .promiseBox p .btn span {
  font-size: 2.4rem;
  margin-top: 8px;
}
@media screen and (max-width: 767px) {
  main .promiseArea .promiseBox p .btn span {
    font-size: 3.5vw;
  }
}
main .promiseArea .promiseBox p .btn::before {
  position: absolute;
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  content: "\f105";
  width: 28px;
  height: 28px;
  background: #9A0034;
  border-radius: 50%;
  right: 13px;
  font-size: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
}
@media screen and (max-width: 767px) {
  main .promiseArea .promiseBox p .btn::before {
    width: 5vw;
    height: 5vw;
    font-size: 4vw;
  }
}
main .promiseArea .promiseBox .imgBox {
  margin-top: -20px;
}
@media screen and (max-width: 767px) {
  main .promiseArea .promiseBox .imgBox {
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  main .promiseArea .promiseBox .imgBox img {
    width: 65%;
  }
}
main .promiseArea .promiseBox .flex {
  gap: 123px;
  position: relative;
  top: 12px;
}
@media screen and (max-width: 1023px) {
  main .promiseArea .promiseBox .flex {
    gap: 0px;
    width: 100%;
  }
}
main .promiseArea .promiseBox .flex .flexBtn .btn {
  color: #014268;
}
main .promiseArea .promiseBox .flex .flexBtn .btn::before {
  background: #014268;
}
@media screen and (max-width: 1023px) {
  main .promiseArea .promiseBox .flex .flexBtn .btn {
    width: 100%;
    min-width: 380px;
    font-size: 4rem;
  }
}
@media screen and (max-width: 767px) {
  main .promiseArea .promiseBox .flex .flexBtn .btn {
    font-size: 4vw;
    min-width: auto;
    width: 45vw;
  }
}
main .promiseArea .promiseBox .flex .flexBtn:nth-child(2) .btn {
  color: #C24900;
}
main .promiseArea .promiseBox .flex .flexBtn:nth-child(2) .btn::before {
  background: #C24900;
}
main .promiseArea .modalOverlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  backdrop-filter: blur(8px);
  display: none;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  display: flex;
}
main .promiseArea .modalContent {
  background: #fff;
  padding: 18px 27px 48px 40px;
  border-radius: 16px;
  max-width: 850px;
  width: 90%;
}
@media screen and (max-width: 767px) {
  main .promiseArea .modalContent {
    width: 95%;
    max-width: none;
    padding: 20px 15px;
  }
}
main .promiseArea .modalContent .modalInner h3 {
  margin-bottom: 16px;
  font-feature-settings: "palt";
  font-weight: 800;
  font-size: 4.8rem;
  text-align: center;
  /* モーダルタイトル色 */
}
@media screen and (max-width: 767px) {
  main .promiseArea .modalContent .modalInner h3 {
    font-size: 9.4vw;
    margin-bottom: 0;
  }
}
main .promiseArea .modalContent .modalInner h3.modalTitle-employee {
  color: #9A0034;
}
main .promiseArea .modalContent .modalInner h3.modalTitle-customer {
  color: #014268;
}
main .promiseArea .modalContent .modalInner h3.modalTitle-future {
  color: #C24900;
}
main .promiseArea .modalContent .modalInner .closeModalBtn.btn {
  font-size: 2.3rem;
  min-width: 320px;
  min-height: 56px;
  position: relative;
  border-radius: 50px;
  padding-left: 10px;
  gap: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
@media screen and (max-width: 767px) {
  main .promiseArea .modalContent .modalInner .closeModalBtn.btn {
    font-size: 4.6vw;
    min-width: auto;
    padding: 0 12vw;
  }
}
main .promiseArea .modalContent .modalInner .closeModalBtn.modalBtn-employee {
  background-color: #9A0034 !important;
  color: #fff !important;
}
main .promiseArea .modalContent .modalInner .closeModalBtn.modalBtn-customer {
  background-color: #014268 !important;
  color: #fff !important;
}
main .promiseArea .modalContent .modalInner .closeModalBtn.modalBtn-future {
  background-color: #C24900 !important;
  color: #fff !important;
}
main .promiseArea .modalContent .modalInner .closeModalBtn:hover {
  opacity: 0.9;
}
main .visionArea {
  position: relative;
}
main .visionArea .inner {
  border-bottom: 3px solid #3B8B8B;
  padding-bottom: 108px;
}
@media screen and (max-width: 767px) {
  main .visionArea .inner {
    padding: 0 0 70px 0;
    margin: 0 10px;
  }
}
main .visionArea .inner .textBox {
  background: url(../img/vision_back.png) no-repeat center / contain;
  height: 419px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1s ease, transform 1s ease;
}
@media screen and (max-width: 767px) {
  main .visionArea .inner .textBox {
    height: 40vw;
  }
}
main .visionArea .inner .textBox.fadeUp {
  opacity: 1;
  transform: translateY(0);
}
main .visionArea .inner .textBox h2 {
  color: #fff;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
  font-feature-settings: "palt";
}
main .banaArea {
  margin: 98px 0 33px 0;
}
@media screen and (max-width: 767px) {
  main .banaArea {
    margin: 70px 0 33px 0;
  }
}
main .banaArea .flex {
  justify-content: center;
  gap: 73px;
}
@media screen and (max-width: 767px) {
  main .banaArea .flex {
    flex-direction: column;
    gap: 20px;
  }
}
@media screen and (max-width: 767px) {
  main .banaArea .flex .flexImg {
    width: 90%;
    margin: 0 auto;
  }
}
