@charset "UTF-8";
@media screen and (min-width: 1200px) {
  body {
    margin-top: 0px;
  }
}
#page.index.in.top {
  color: #333333;
  /* company-mv-text の1行ごとフェードイン */
  /* 各行のフェードイン */
  /* 行ごとの遅延設定 */
}
#page.index.in.top .first {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: bottom center;
  height: calc(100vh - 180px);
  width: 100%;
}
#page.index.in.top .first.active {
  background-image: url(../img/top/top_first01.jpg);
  -webkit-mask: url(../img/top/smoke.png);
          mask: url(../img/top/smoke.png);
  -webkit-mask-size: 1800% 100%;
          mask-size: 1800% 100%;
  -webkit-animation: mask-play 1.3s steps(17) forwards;
          animation: mask-play 1.3s steps(17) forwards;
  opacity: 1;
}
@-webkit-keyframes mask-play {
  from {
    -webkit-mask-position: 100% 0;
            mask-position: 100% 0;
  }
  to {
    -webkit-mask-position: 0% 0;
            mask-position: 0% 0;
  }
}
@keyframes mask-play {
  from {
    -webkit-mask-position: 100% 0;
            mask-position: 100% 0;
  }
  to {
    -webkit-mask-position: 0% 0;
            mask-position: 0% 0;
  }
}
#page.index.in.top .mv-text-area {
  padding-top: 25px;
}
#page.index.in.top .company-page-title {
  font-size: 3.2rem;
  letter-spacing: 0.2em;
  font-weight: 400;
  line-height: 1.625;
  text-align: center;
  display: inline-block;
  width: 100%;
}
#page.index.in.top .company-page-title span {
  opacity: 0; /* 初期状態は非表示 */
  display: inline-block;
  -webkit-transition: opacity 0.6s ease;
  transition: opacity 0.6s ease;
}
#page.index.in.top .company-page-title.show span {
  opacity: 1; /* 表示 */
}
#page.index.in.top .company-page-title.show span.text-f {
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
}
#page.index.in.top .company-page-title.show span.text-s {
  -webkit-transition-delay: 0.8s;
          transition-delay: 0.8s;
}
#page.index.in.top .company-page-title.show span.text-t {
  -webkit-transition-delay: 1.2s;
          transition-delay: 1.2s;
}
@media screen and (min-width: 410px) {
  #page.index.in.top .mv-text-area {
    padding-top: 9%;
  }
}
@media screen and (min-height: 800px) {
  #page.index.in.top .mv-text-area {
    padding-top: 13%;
  }
}
@media screen and (min-height: 900px) {
  #page.index.in.top .mv-text-area {
    padding-top: 17%;
  }
}
@media screen and (min-width: 767px) {
  #page.index.in.top .first {
    width: 100%;
    margin-top: 0;
  }
  #page.index.in.top .first.active {
    background-image: url(../img/top/top_first-pc.jpg);
  }
  #page.index.in.top .mv-text-area {
    padding-top: 10%;
    max-width: 1000px;
    width: 100%;
    margin: 0 auto;
  }
  #page.index.in.top .company-page-title {
    text-align: left;
    font-size: 4rem;
    letter-spacing: 0.22em;
    line-height: 1.712;
    margin-bottom: 20px;
  }
  #page.index.in.top .company-page-title.show span:nth-child(1) {
    -webkit-transition-delay: 0.1s;
            transition-delay: 0.1s;
  }
  #page.index.in.top .company-page-title.show span:nth-child(2) {
    -webkit-transition-delay: 0.3s;
            transition-delay: 0.3s;
  }
  #page.index.in.top .company-page-title.show span:nth-child(3) {
    -webkit-transition-delay: 0.5s;
            transition-delay: 0.5s;
  }
  #page.index.in.top .company-page-title.show span:nth-child(4) {
    -webkit-transition-delay: 0.7s;
            transition-delay: 0.7s;
  }
  #page.index.in.top .company-page-title.show span:nth-child(5) {
    -webkit-transition-delay: 0.9s;
            transition-delay: 0.9s;
  }
  #page.index.in.top .company-page-title.show span:nth-child(6) {
    -webkit-transition-delay: 1.1s;
            transition-delay: 1.1s;
  }
  #page.index.in.top .company-page-title.show span:nth-child(7) {
    -webkit-transition-delay: 1.3s;
            transition-delay: 1.3s;
  }
  #page.index.in.top .company-page-title.show span:nth-child(8) {
    -webkit-transition-delay: 1.5s;
            transition-delay: 1.5s;
  }
  #page.index.in.top .company-page-title.show span:nth-child(9) {
    -webkit-transition-delay: 1.7s;
            transition-delay: 1.7s;
  }
}
@media (min-width: 767px) and (max-width: 1000px) and (min-height: 500px) and (max-height: 750px) {
  #page.index.in.top .first {
    height: calc(150vh - 154px);
  }
}
@media (min-width: 1000px) and (max-width: 1200px) and (min-height: 500px) and (max-height: 600px) {
  #page.index.in.top .first {
    height: calc(150vh - 154px);
  }
}
@media (min-width: 1000px) and (max-width: 1200px) and (min-height: 601px) and (max-height: 750px) {
  #page.index.in.top .first {
    height: calc(160vh - 154px);
  }
}
@media screen and (min-width: 1200px) {
  #page.index.in.top .first {
    height: calc(130vh - 154px);
  }
}
@media screen and (min-width: 1400px) {
  #page.index.in.top .first {
    height: calc(140vh - 154px);
  }
}
@media screen and (min-width: 1600px) {
  #page.index.in.top .first {
    height: calc(150vh - 154px);
  }
}
@media screen and (min-width: 1750px) {
  #page.index.in.top .first {
    height: calc(160vh - 154px);
  }
}
@media screen and (min-width: 1950px) {
  #page.index.in.top .first {
    height: calc(170vh - 154px);
  }
}
@media screen and (min-width: 2050px) {
  #page.index.in.top .first {
    height: calc(180vh - 154px);
  }
}
@media screen and (min-width: 2150px) {
  #page.index.in.top .first {
    height: calc(185vh - 154px);
  }
}
#page.index.in.top .second-area {
  padding: 40px 20px 0;
}
#page.index.in.top .company-mv-text {
  font-size: 1.6rem;
  letter-spacing: 0.03em;
  font-weight: 400;
  line-height: 2.1875;
  text-align: justify;
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease; /* フェードインアニメーション */
}
#page.index.in.top .company-mv-text.show {
  opacity: 1; /* 表示 */
}
#page.index.in.top .company-mv-text span {
  display: block; /* 各行をブロック表示 */
  opacity: 0; /* 初期状態は非表示 */
  -webkit-transition: opacity 1s ease;
  transition: opacity 1s ease; /* 各行のフェードイン */
}
#page.index.in.top .company-mv-text span.pc-span-first {
  opacity: 1;
}
#page.index.in.top .sp-second-position.show .company-mv-text span.sp-span-first {
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
  opacity: 1;
}
#page.index.in.top .sp-second-position.show .company-mv-text span.sp-span-second {
  -webkit-transition-delay: 1s;
          transition-delay: 1s;
  opacity: 1;
}
#page.index.in.top .sp-second-position.show .company-mv-text span.sp-span-third {
  -webkit-transition-delay: 1.5s;
          transition-delay: 1.5s;
  opacity: 1;
}
#page.index.in.top .sp-second-position.show .company-mv-text span.sp-span-four {
  -webkit-transition-delay: 2s;
          transition-delay: 2s;
  opacity: 1;
}
#page.index.in.top .sp-second-position.show .company-mv-text span.sp-span-five {
  -webkit-transition-delay: 2.5s;
          transition-delay: 2.5s;
  opacity: 1;
}
#page.index.in.top .sp-second-position.show .company-mv-text span.sp-span-six {
  -webkit-transition-delay: 3s;
          transition-delay: 3s;
  opacity: 1;
}
@media screen and (min-width: 767px) {
  #page.index.in.top .second-area {
    padding: 0px;
  }
  #page.index.in.top .company-mv-text.show span.sp-span-first, #page.index.in.top .company-mv-text.show span.sp-span-second {
    display: inline-block;
    opacity: 1;
  }
  #page.index.in.top .company-mv-text.show span.pc-span-first {
    -webkit-transition-delay: 0.1s;
            transition-delay: 0.1s;
    opacity: 1;
  }
  #page.index.in.top .company-mv-text.show span.sp-span-third {
    -webkit-transition-delay: 0.4s;
            transition-delay: 0.4s;
    opacity: 1;
  }
  #page.index.in.top .company-mv-text.show span.sp-span-four {
    -webkit-transition-delay: 0.7s;
            transition-delay: 0.7s;
    opacity: 1;
  }
  #page.index.in.top .company-mv-text.show span.sp-span-five {
    -webkit-transition-delay: 1s;
            transition-delay: 1s;
    opacity: 1;
  }
  #page.index.in.top .company-mv-text.show span.sp-span-six {
    -webkit-transition-delay: 1.3s;
            transition-delay: 1.3s;
    opacity: 1;
  }
}
#page.index.in.top .company-area {
  padding-top: 55px;
}
#page.index.in.top .company-area-flex-contens {
  display: block;
  margin-bottom: 52px;
  color: #333;
}
#page.index.in.top .company-flex-contens-en-title {
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 2.3492857143;
  font-size: 1.4rem;
  margin-bottom: 5px;
}
#page.index.in.top .company-flex-contens-ja-title {
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.0364285714;
  font-size: 2.8rem;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  margin-bottom: 23px;
}
#page.index.in.top .company-flex-contens-iamge {
  margin-bottom: 15px;
  overflow: hidden;
  width: 100%;
  border-radius: 7px;
}
#page.index.in.top .company-flex-contens-iamge img {
  -webkit-transition: 1s all;
  transition: 1s all;
}
#page.index.in.top .company-flex-contens-text {
  font-size: 1.5rem;
  letter-spacing: 0.14em;
  line-height: 1.7333333333;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  margin-bottom: 8px;
  text-align: justify;
}
#page.index.in.top .company-flex-contens-arrow-text {
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: 0.08em;
  line-height: 2.3553333333;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  border-bottom: 1px solid #b3b3b3;
  background-image: url(../img/top/arrow-icon.png);
  background-repeat: no-repeat;
  background-size: 24px 24px;
  background-position: right center;
}
#page.index.in.top .company-flex-contens-arrow-text span {
  color: transparent;
  background: -webkit-gradient(linear, left top, right top, color-stop(50%, #b9a48b), color-stop(50%, #333)) 100%;
  background: linear-gradient(to right, #b9a48b 50%, #333 50%) 100%;
  -webkit-background-clip: text;
          background-clip: text;
  background-size: 200% 100%;
  -webkit-transition: background-position 0.3s;
  transition: background-position 0.3s;
  -webkit-transition: 0.5s all;
  transition: 0.5s all;
}
@media (hover: hover) {
  #page.index.in.top .company-area-flex-contens:hover .company-flex-contens-iamge {
    border-radius: 7px;
  }
  #page.index.in.top .company-area-flex-contens:hover .company-flex-contens-iamge img {
    -webkit-transform: scale(1.2, 1.2);
            transform: scale(1.2, 1.2);
    border-radius: 7px;
  }
  #page.index.in.top .company-area-flex-contens:hover .company-flex-contens-arrow-text span {
    background-position: 0 100%;
    border-color: #b9a48b;
  }
}
@media screen and (min-width: 767px) {
  #page.index.in.top .company-area-flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  #page.index.in.top .company-area-flex-contens {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 48%;
            flex: 0 0 48%;
    -webkit-transform: translateY(80px);
            transform: translateY(80px);
    -webkit-transition: all 0.5s ease-in-out;
    transition: all 0.5s ease-in-out; /* スピードとイージングをカスタマイズ */
  }
  #page.index.in.top .company-area-flex-contens:nth-child(2) {
    -webkit-transition: all 1s ease-in-out;
    transition: all 1s ease-in-out; /* スピードとイージングをカスタマイズ */
  }
  #page.index.in.top .company-area-flex-contens.aos-animate {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  #page.index.in.top .company-flex-contens-en-title {
    font-size: 1.6rem;
    letter-spacing: 0.06em;
    line-height: 2.96625;
    margin-bottom: 0;
  }
  #page.index.in.top .company-flex-contens-ja-title {
    font-size: 3rem;
    letter-spacing: -0.04em;
    line-height: 1.2320588235;
  }
  #page.index.in.top .company-flex-contens-iamge {
    margin-bottom: 15px;
    max-width: 480px;
    height: 250px;
    overflow: hidden;
  }
  #page.index.in.top .company-flex-contens-text {
    font-size: 1.6rem;
    letter-spacing: 0em;
    line-height: 1.875;
    margin-bottom: 20px;
  }
  #page.index.in.top .company-flex-contens-arrow-text {
    font-size: 1.6rem;
    letter-spacing: 0.08em;
    line-height: 2.346875;
    border-bottom: none;
    background-image: none;
  }
  #page.index.in.top .company-flex-contens-arrow-text span {
    border-bottom: 1px solid #b3b3b3;
    padding-bottom: 5px;
    position: relative;
  }
  #page.index.in.top .company-flex-contens-arrow-text span::after {
    content: "";
    display: block;
    background-image: url(../img/top/arrow-icon.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 26px;
    height: 26px;
    position: absolute;
    top: 0;
    bottom: 0;
    right: -36px;
    margin: auto;
  }
}
@media screen and (min-width: 820px) {
  #page.index.in.top .company-flex-contens-ja-title {
    font-size: 3.4rem;
  }
}
#page.index.in.top .business-area {
  width: 100%;
}
#page.index.in.top .contens-area-en-title {
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 2.3492857143;
  font-size: 1.4rem;
  margin-bottom: 5px;
  position: relative;
  z-index: 1;
}
#page.index.in.top .contens-area-title {
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.0364285714;
  font-size: 2.8rem;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  margin-bottom: 23px;
  position: relative;
  z-index: 1;
}
#page.index.in.top .business-area-box {
  width: 100%;
  overflow-x: hidden;
  position: relative;
  padding-top: 50px;
  margin-bottom: 15px;
}
#page.index.in.top .business-mv {
  height: 345px;
}
#page.index.in.top .business-mv-loop {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content; /* 子要素に応じて幅を自動調整 */
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
#page.index.in.top .business-mv-loop-list {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: auto;
}
#page.index.in.top .business-mv-loop-list img {
  height: 392px;
}
#page.index.in.top .business-area-text {
  font-size: 1.5rem;
  letter-spacing: 0.06em;
  line-height: 1.7333333333;
  font-weight: 400;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  margin-bottom: 23px;
  text-align: justify;
}
#page.index.in.top .contens-area-arrow-text {
  display: block;
  font-size: 1.5rem;
  color: #333;
  letter-spacing: 0.08em;
  line-height: 2.3506666667;
  font-weight: 400;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  border-bottom: 1px solid #b3b3b3;
  background-image: url(../img/top/arrow-icon.png);
  background-repeat: no-repeat;
  background-size: 24px 24px;
  background-position: right center;
  padding-bottom: 5px;
}
#page.index.in.top .contens-area-arrow-text span {
  color: transparent;
  background: -webkit-gradient(linear, left top, right top, color-stop(50%, #b9a48b), color-stop(50%, #333)) 100%;
  background: linear-gradient(to right, #b9a48b 50%, #333 50%) 100%;
  -webkit-background-clip: text;
          background-clip: text;
  background-size: 200% 100%;
  -webkit-transition: background-position 0.3s;
  transition: background-position 0.3s;
  -webkit-transition: 0.5s all;
  transition: 0.5s all;
}
@media (hover: hover) {
  #page.index.in.top .contens-area-arrow-text:hover span {
    background-position: 0 100%;
    border-color: #b9a48b;
  }
}
@media screen and (min-width: 767px) {
  #page.index.in.top .business-area-box {
    padding-top: 0;
  }
  #page.index.in.top .business-mv {
    height: 764px;
  }
  #page.index.in.top .business-mv-loop-list img {
    height: 764px;
  }
  #page.index.in.top .pc-business-link-box {
    position: relative;
    z-index: 1;
  }
  #page.index.in.top .pc-business-text-area {
    position: relative;
    z-index: 1;
  }
  #page.index.in.top .contens-area-en-title.business-top-margin {
    padding-top: 105px;
  }
  #page.index.in.top .pc-business-flex-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding-right: 38px;
  }
  #page.index.in.top .contens-area-arrow-text {
    background-image: none;
    border-bottom: none;
    font-size: 1.7rem;
    line-height: 2.2088235294;
  }
  #page.index.in.top .contens-area-arrow-text span {
    border-bottom: 1px solid #b3b3b3;
    padding-bottom: 5px;
    position: relative;
  }
  #page.index.in.top .contens-area-arrow-text span::after {
    content: "";
    display: block;
    background-image: url(../img/top/arrow-icon.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 26px;
    height: 26px;
    position: absolute;
    top: 0;
    bottom: 0;
    right: -36px;
    margin: auto;
  }
  #page.index.in.top .business-area-text {
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 1.875;
  }
}
#page.index.in.top .message-area {
  padding-top: 75px;
}
#page.index.in.top .message-area-flex-image {
  margin-top: 28px;
  margin-bottom: 20px;
}
#page.index.in.top .message-area-top-text {
  font-size: 1.5rem;
  font-weight: 400;
  color: #0c0c0c;
  letter-spacing: 0.14em;
  line-height: 1.8666666667;
  margin-bottom: 50px;
}
#page.index.in.top .message-area-top-name-text {
  font-size: 1.5rem;
  letter-spacing: 0.14em;
  line-height: 1.8666666667;
  font-weight: 400;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  text-align: justify;
}
#page.index.in.top .message-area-top-name {
  width: 35%;
  min-width: 117px;
  margin-left: auto;
  margin-bottom: 40px;
}
#page.index.in.top .message-area-top-name-text {
  font-size: 1.2rem;
  letter-spacing: 0.06em;
  line-height: 2.6666666667;
  font-weight: 400;
  text-align: center;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
#page.index.in.top .message-contens-ul {
  margin-top: 122px;
}
#page.index.in.top .message-contens-list {
  margin-bottom: 65px;
}
#page.index.in.top .message-contens-list-title {
  font-size: 2.5rem;
  letter-spacing: 0.05em;
  line-height: 1.1608;
  font-weight: 400;
  text-align: center;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
#page.index.in.top .message-contens-list-text {
  font-size: 1.5rem;
  letter-spacing: 0.03em;
  line-height: 1.8666666667;
  font-weight: 400;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  text-align: justify;
  margin-bottom: 23px;
}
#page.index.in.top .message-contens-list-iamge {
  width: 96.8%;
  margin: 0 auto 20px;
  display: block;
}
#page.index.in.top .message-contens-list-link {
  display: block;
  font-size: 1.5rem;
  color: #333;
  letter-spacing: 0.08em;
  line-height: 2.3506666667;
  font-weight: 400;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  border-bottom: 1px solid #b3b3b3;
  background-image: url(../img/top/arrow-icon.png);
  background-repeat: no-repeat;
  background-size: 24px 24px;
  background-position: right center;
  padding-bottom: 5px;
}
#page.index.in.top .message-contens-list-link span {
  color: transparent;
  background: -webkit-gradient(linear, left top, right top, color-stop(50%, #b9a48b), color-stop(50%, #333)) 100%;
  background: linear-gradient(to right, #b9a48b 50%, #333 50%) 100%;
  -webkit-background-clip: text;
          background-clip: text;
  background-size: 200% 100%;
  -webkit-transition: background-position 0.3s;
  transition: background-position 0.3s;
  -webkit-transition: 0.5s all;
  transition: 0.5s all;
}
@media (hover: hover) {
  #page.index.in.top .message-contens-list-link:hover span {
    background-position: 0 100%;
    border-color: #b9a48b;
  }
}
@media screen and (min-width: 767px) {
  #page.index.in.top .message-area-flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  #page.index.in.top .message-area-flex-image {
    margin: 0;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 50%;
            flex: 0 0 50%;
  }
  #page.index.in.top .message-area-flex-text {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 44.6%;
            flex: 0 0 44.6%;
  }
  #page.index.in.top .message-area-flex-column {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  #page.index.in.top .message-area-top-text {
    font-size: 1.6rem;
    line-height: 2;
    margin-bottom: 35px;
  }
  #page.index.in.top .message-area-top-name {
    width: 100%;
    max-width: 136px;
    margin-bottom: 0;
  }
  #page.index.in.top .message-area-link {
    margin-bottom: 70px;
  }
  #page.index.in.top .message-area-top-name-text {
    font-size: 1.4rem;
    line-height: 2.6957142857;
  }
  #page.index.in.top .message-contens-ul {
    width: 80%;
    margin: 122px auto 115px;
  }
  #page.index.in.top .message-contens-list-title {
    font-size: 2.1rem;
    letter-spacing: 0.06em;
    line-height: 1.7619047619;
  }
  #page.index.in.top .message-contens-list-iamge {
    width: 73.6%;
    margin-top: 20px;
  }
  #page.index.in.top .message-contens-list-text {
    font-size: 1.6rem;
    letter-spacing: 0.06em;
    line-height: 1.5;
  }
  #page.index.in.top .message-contens-list-link {
    font-size: 1.6rem;
    border-bottom: none;
    background-image: none;
  }
  #page.index.in.top .message-contens-list-link span {
    border-bottom: 1px solid #b3b3b3;
    padding-bottom: 5px;
    position: relative;
  }
  #page.index.in.top .message-contens-list-link span::after {
    content: "";
    display: block;
    background-image: url(../img/top/arrow-icon.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 26px;
    height: 26px;
    position: absolute;
    top: 0;
    bottom: 0;
    right: -36px;
    margin: auto;
  }
}
@media screen and (min-width: 880px) {
  #page.index.in.top .message-area-top-text {
    margin-bottom: 78px;
  }
  #page.index.in.top .message-area-link {
    margin-bottom: 140px;
  }
  #page.index.in.top .message-contens-ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: 100%;
  }
  #page.index.in.top .message-contens-list {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 27.2%;
            flex: 0 0 27.2%;
    position: relative;
    opacity: 0;
    margin-bottom: 0;
    -webkit-transform: translateY(80px);
            transform: translateY(80px);
    -webkit-transition: all 0.5s ease-in-out;
    transition: all 0.5s ease-in-out; /* スピードとイージングをカスタマイズ */
  }
  #page.index.in.top .message-contens-list::after {
    content: "";
    display: block;
    background-color: #b3b3b3;
    width: 1px;
    height: 100%;
    position: absolute;
    right: -43px;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  #page.index.in.top .message-contens-list:nth-child(2) {
    -webkit-transition: all 1s ease-in-out;
    transition: all 1s ease-in-out;
  }
  #page.index.in.top .message-contens-list:last-child {
    -webkit-transition: all 1.5s ease-in-out;
    transition: all 1.5s ease-in-out;
  }
  #page.index.in.top .message-contens-list:last-child::after {
    display: none;
  }
  #page.index.in.top .message-contens-list.aos-animate {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
#page.index.in.top .news-area {
  padding-bottom: 65px;
}
#page.index.in.top .news-area-ul {
  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;
}
#page.index.in.top .news-area-list {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 47.78%;
          flex: 0 0 47.78%;
  margin-bottom: 28px;
}
#page.index.in.top .news-area-link {
  display: block;
}
#page.index.in.top .news-area-article-image {
  border-radius: 7px;
  display: block;
  margin-bottom: 7px;
}
#page.index.in.top .news-area-article-image img {
  border-radius: 7px;
  -o-object-fit: cover;
     object-fit: cover;
  height: 106px;
  width: 100%;
  -webkit-transition: 1s all;
  transition: 1s all;
}
#page.index.in.top .news-area-article-info {
  display: block;
}
#page.index.in.top .news-area-article-day {
  font-size: 1.2rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 0.985;
  color: #0c0c0c;
  margin-bottom: 8px;
}
#page.index.in.top .news-area-article-category {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: #0c0c0c;
  background-color: #efefef;
  border-radius: 15px;
  padding: 1px 14px;
}
#page.index.in.top .news-area-article-title {
  font-size: 1.4rem;
  color: #0c0c0c;
  font-weight: 400;
  letter-spacing: 0.04em;
  line-height: 1.5714285714;
  margin-top: 7px;
}
@media (hover: hover) {
  #page.index.in.top .news-area-link:hover .news-area-article-image img {
    -webkit-transform: scale(1.2, 1.2);
            transform: scale(1.2, 1.2);
  }
}
@media screen and (min-width: 767px) {
  #page.index.in.top .pc-news-flex-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding-right: 38px;
    margin-bottom: 30px;
  }
  #page.index.in.top .news-area-list {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 22.8%;
            flex: 0 0 22.8%;
    opacity: 0;
    -webkit-transform: translateY(80px);
            transform: translateY(80px);
    -webkit-transition: all 0.5s ease-in-out;
    transition: all 0.5s ease-in-out; /* スピードとイージングをカスタマイズ */
  }
  #page.index.in.top .news-area-list:nth-child(2) {
    -webkit-transition: all 1s ease-in-out;
    transition: all 1s ease-in-out; /* スピードとイージングをカスタマイズ */
  }
  #page.index.in.top .news-area-list:nth-child(3) {
    -webkit-transition: all 1.5s ease-in-out;
    transition: all 1.5s ease-in-out; /* スピードとイージングをカスタマイズ */
  }
  #page.index.in.top .news-area-list:nth-child(4) {
    -webkit-transition: all 2s ease-in-out;
    transition: all 2s ease-in-out; /* スピードとイージングをカスタマイズ */
  }
  #page.index.in.top .news-area-list.aos-animate {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  #page.index.in.top .news-area-article-image {
    margin-bottom: 9px;
    height: 152px;
    max-width: 228px;
    overflow: hidden;
  }
  #page.index.in.top .news-area-article-image img {
    -o-object-fit: cover;
       object-fit: cover;
    max-width: 228px;
    height: 152px;
    width: 100%;
  }
  #page.index.in.top .news-area-article-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  #page.index.in.top .news-area-article-day {
    font-size: 14px;
    line-height: 1.2228571429;
    margin-bottom: 0;
    margin-right: 10px;
  }
  #page.index.in.top .news-area-article-title {
    font-size: 1.5rem;
    letter-spacing: 0.06em;
    line-height: 1.4666666667;
    margin-top: 11px;
  }
}
#page.index.in.top .recruit-bnr-area {
  padding-bottom: 87px;
}
#page.index.in.top .recruit-bnr-img {
  margin-bottom: 22px;
}
#page.index.in.top .recruit-bnr-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  font-size: 2.4rem;
  letter-spacing: 0.14em;
  line-height: 1.2091666667;
  font-weight: 400;
  margin-bottom: 20px;
}
#page.index.in.top .recruit-bnr-title-icon {
  width: 14px;
  height: 14px;
  margin-bottom: 3px;
  margin-left: 12px;
}
#page.index.in.top .recruit-bnr-box-text {
  text-align: justify;
  font-size: 1.5rem;
  letter-spacing: 0.06em;
  line-height: 1.7333333333;
}
@media screen and (min-width: 767px) {
  #page.index.in.top .recruit-bnr-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    background-color: #faf5e7;
    border-radius: 9px;
  }
  #page.index.in.top .recruit-bnr-img {
    margin-bottom: 0;
    width: 53%;
  }
  #page.index.in.top .recruit-bnr-text-area {
    padding: 0 35px;
    width: 47%;
  }
  #page.index.in.top .recruit-bnr-title {
    font-size: 2.6rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  #page.index.in.top .recruit-bnr-title-icon {
    margin-bottom: 0;
  }
  #page.index.in.top .recruit-bnr-box-text {
    font-size: 1.6rem;
    letter-spacing: 0.12em;
    line-height: 1.875;
  }
}