@charset "utf-8";
/*---------------- index_mv_mess --------------------*/
/*----------------
	mv
--------------------*/

#index_mv .mv_img {
  min-height: 490px;
  width: 100%;
  object-fit: cover;
  object-position: 56%;
}

#index_mv {
  position: relative;
}

#index_mv .mv_img {
  height: 100vh;
  margin: auto;
  max-height: 100%;
  max-width: 100%;
  object-fit: cover;
  width: 100%;
  min-height: 40vw;
}

.mv_side_label {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  writing-mode: vertical-rl;
  text-orientation: mixed;

  font-size: 16px;
  letter-spacing: 0.25em;
  color: #fff;
  z-index: 5;
  pointer-events: none;
  user-select: none;
  white-space: nowrap;
}

@media (max-width: 767px) {
	#index_mv .mv.sp_size .slick-slide:nth-child(4) .mv_img{
		object-position: 41% 50%;
	}
	
  .mv_side_label {
    display: none;
  }
}

#index_mv {
  position: relative;
  min-height: 100vh;
  isolation: isolate;
  overflow: clip;
}

#index_mv .mv {
  opacity: 0;
  visibility: hidden;
}

#index_mv .mv.slick-initialized {
  opacity: 1;
  visibility: visible;
  transition: opacity .35s ease;
}

#index_mv .mv {
  position: fixed;
  inset: 0;
  z-index: -1;
  width: 100%;
  height: 100vh;
  pointer-events: none;
  overflow: hidden;
}

#index_mv .mv::before,
#index_mv .mv.sp_size::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(36,118,172,.45), rgba(36,118,172,.0) 30%);  
  z-index: 1;
  pointer-events: none;
}

#index_mv .mv::after,
#index_mv .mv.sp_size::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  /*background: #2476AC; */
  background: #5f99bf; 
  opacity: var(--mv-overlay-alpha, .35); 
  mix-blend-mode: multiply;
}

#index_mv .mv .mv_img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: translate3d(0, var(--mv-parallax, 0px), 0) scale(var(--mv-scale, 1.06));
  filter: blur(var(--mv-blur, 0px));
  will-change: transform, filter;
  transition: filter .12s linear, transform .12s linear;
  transform: scale(1.06);
}

#index_mv .mv .slick-active .mv_img {
  animation: mvZoom 11.5s ease-out forwards;
}

#index_mv .mv .slick-slide.is-zoom .mv_img {
  transform: scale(1.12);
}

#index_mv .mv.is-init .mv_img {
  transition: none;
}

@keyframes mvZoom {
  from {
    transform: scale(1.06);
  }

  to {
    transform: scale(1.12);
  }
}

#index_mv .mv .slick-slide {
  backface-visibility: hidden;
}


.mv_recruit_book {
  position: fixed;
  right: 30px;
  bottom: 34px;
  width: 280px;
  padding: 27px 31px;
  border-radius: 8px;
  background: #266AEA;
  color: #fff;
  text-decoration: none;
  box-shadow: 0px 0px 16px rgba(0, 80, 230, 0.35);
  z-index: 6;
  display: grid;
  gap: 6px;
  transition: transform .6s ease, filter .3s ease, opacity .8s ease;
  text-align: center;
}

.mv_recruit_book:hover {
  transform: translateY(-2px);
  filter: brightness(1.03);
}

.mv_recruit_book__en {
  font-size: 16px;
  letter-spacing: .08em;
  opacity: .9;
}

.mv_recruit_book__ttl {
  font-size: 24px;
  letter-spacing: .04em;
  line-height: 1.1;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  /* gap: 10px; */
  justify-content: space-evenly;
  padding: 14px 0 11px;
}

.mv_recruit_book__ttl::after {
  content: "";
  width: 16.5px;
  height: 11.5px;
  display: inline-block;
  flex: 0 0 auto;
  background: url("../../../img/icon_file_w.svg") no-repeat center / contain;
}

.mv_recruit_book__jp {
  font-size: 16px;
  letter-spacing: .12em;
}

@media (max-width: 767px) {
  .mv_recruit_book {
	  display: none;
  }

  .mv_recruit_book__ttl {
    font-size: 20px;
  }
}

/*----------------
	message
--------------------*/

/* =========================
   Top Message
========================= */

.top-message {
  position: relative;
  overflow: hidden;
}

.top-message__inner {
  max-width: 1350px;
  margin: 0 auto;
  padding: clamp(200px, 40vw, 600px) 20px clamp(500px, 45vw, 690px);
  position: relative;
}

.top-message .top_ttl h2,
.top-message .top_ttl h2::after {
  color: #fff;
}

.top-message__content {
  max-width: 675px;
  position: relative;
  z-index: 2;
}

.top-message__text {
  font-size: 1.6rem;
  line-height: 2.05;
  color: #fff;
}

.top-message__text p {
  margin: 0 0 14px;
}

.top-message__text p:last-child {
  margin-bottom: 0;
}

.top-message__media {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
}

.top-message__img {
  position: absolute;
  margin: 0;
  border-radius: 0;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .08);
  background: #fff;
}

.top-message__img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.top-message__img--tl {
  width: clamp(220px, 22vw, 320px);
  aspect-ratio: 4/3;
  left: 20px;
  top: clamp(83px, 17vw, 290px);
}

.top-message__img--tr {
  width: clamp(200px, 20vw, 300px);
  aspect-ratio: 4/3;
  right: clamp(14px, 4vw, 70px);
  top: clamp(20px, 10vw, 220px);
}

.top-message__img--rm {
  width: clamp(420px, 38vw, 620px);
  aspect-ratio: 4/3;
  right: clamp(-120px, -8vw, 0px);
  top: 50%;
  transform: translateY(-20%);
}

.top-message__img--bl {
  width: clamp(320px, 30vw, 460px);
  aspect-ratio: 4/3;
  left: clamp(-200px, -10vw, 0px);
  bottom: clamp(40px, 10vw, 180px);
}

.top-message__watermark {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  user-select: none;
}

.top-message__marquee {
  display: flex;
  width: max-content;
  white-space: nowrap;
  gap: clamp(40px, 6vw, 120px);
  animation: topMessageMarquee 22s linear infinite;
  will-change: transform;
}

.top-message__marquee span {
  font-size: clamp(64px, 10vw, 160px);
  line-height: 1;
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, .28);
  font-family: "Times New Roman", "Georgia", serif;
}

.mv_recruit_book.is-hidden{
  opacity: 0;
  pointer-events: none;
}

@keyframes topMessageMarquee {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

@media screen and (max-width:1700px) {}

@media screen and (max-width:1500px) {}

@media screen and (max-width:1300px) {}

@media screen and (max-width:767px) {
	 .mv_catch{
    width: 70vw;       
    max-width: 240px;  
  }
  .mv_catch img{
    width: 100%;
    height: auto;
    display: block;
  }
	
  .top-message__inner {
    padding-bottom: 80px;
  }

  .top-message__media {
    position: static;
    inset: auto;
    pointer-events: auto;
    margin-top: 28px;
  }

  .top-message__img {
    position: static;
    width: 100% !important;
    max-width: 620px;
    aspect-ratio: 16/9;
    transform: none !important;
    margin: 0 0 14px;
  }

  .top-message__watermark {
    font-size: clamp(44px, 12vw, 96px);
    opacity: .9;
  }
}