.wrap_title {
  line-height: 1.2;
}
.wrap_title .sup {
  display: block;
  font-size: 3.2rem;
  font-family: var(--font-mont);
  font-weight: bold;
}
.wrap_title .title {
  display: block;
  font-size: 9.6rem;
  font-weight: bold;
  color: var(--blue-text);
}
@media screen and (max-width: 640px) {
  .wrap_title {
    line-height: 1.4;
  }
  .wrap_title .sup {
    font-size: 5.33vw;
  }
  .wrap_title .title {
    font-size: 11.7vw;
  }
}

section:not(#visual), #footer {
  position: relative;
  z-index: 2;
}

#header:before {
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0) 100%);
}
#header .logo {
  background-image: url(../img/logo_white.png);
}
#header .btn_menu:before, #header .btn_menu:after {
  background: #fff;
}
#header #menu a {
  color: #fff;
}
@media screen and (max-width: 768px) {
  #header.narrow .logo {
    background-image: url(../img/logo.png);
  }
  #header.narrow .btn_menu:before, #header.narrow .btn_menu:after {
    background: rgba(0, 0, 0, 0.9);
  }
}

#visual {
  position: relative;
  height: 300vh;
  background: #38A0DB;
  overflow: hidden;
  line-height: 1.2;
}
#visual:before {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url(../img/sky.jpg) bottom center/cover;
  opacity: 0.7;
  content: "";
}
#visual .cloud1 {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 100vh;
  margin-right: -45rem;
  background: url(../img/cloud1.png) no-repeat right top;
}
#visual .cloud2 {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 100vh;
  margin-left: -18.5rem;
  background: url(../img/cloud2.png) no-repeat left bottom;
}
#visual [class^=wrap_title] {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  text-align: center;
  color: #fff;
  font-weight: bold;
  z-index: 1;
}
#visual [class^=wrap_title] span {
  display: block;
  height: 0;
  overflow: hidden;
  transition: 0.5s 0.3s;
  transform: translateY(100%);
}
#visual .sup {
  margin-bottom: 4rem;
  font-size: 4.6rem;
}
#visual .title {
  font-size: 11rem;
}
#visual.section1 .wrap_title1 span {
  height: 1.2em;
  transform: translateY(0);
}
#visual.section2 .wrap_title2 span, #visual.normal .wrap_title2 span {
  height: 1.2em;
  transform: translateY(0);
}
#visual.normal .wrap_title2 {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 200vh;
  left: 0;
  right: 0;
  bottom: 0;
  transform: unset;
}
@media screen and (max-width: 768px) {
  #visual .sup {
    margin-bottom: 3.6vw;
    font-size: 4.16vw;
  }
  #visual .title {
    font-size: 10vw;
  }
}

.about {
  min-height: 60vh;
  margin-top: -14.4rem;
  padding: 20rem 0;
  background: linear-gradient(117deg, #25CEF9 12.49%, #1C4DE2 87.65%);
  color: #fff;
  overflow: hidden;
}
.about:before {
  position: absolute;
  top: -10%;
  right: -10%;
  left: 0;
  bottom: -10%;
  background: url(../img/symbol_bg.png) no-repeat right center/contain;
  opacity: 0.15;
  content: "";
}
.about .wrap_title .title {
  color: #fff;
}
.about .desc {
  margin-top: 8rem;
  font-size: 3.2rem;
}
.about .btn_animate {
  margin-top: 5rem;
}
@media screen and (max-width: 768px) {
  .about .wfix {
    padding: 0 32px;
  }
}
@media screen and (max-width: 580px) {
  .about {
    padding: 120px 0;
  }
  .about .desc {
    margin-top: 8.5vw;
    font-size: 4.8vw;
  }
  .about .desc .block {
    display: inline;
  }
  .about .btn_animate {
    margin-top: 40px;
  }
}

.services {
  padding: 18rem 0;
  overflow: hidden;
}
.services .title_area {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.services .arrows {
  display: flex;
  gap: 1.6rem;
}
.services .arrows button {
  width: 6rem;
  height: 6rem;
  border-radius: 100%;
  background: url(../img/arrow2.png) no-repeat center/contain;
  font-size: 0;
}
.services .arrows .slick-prev {
  transform: rotate(180deg);
}
.services .contents {
  margin-top: 9.2rem;
}
.services .swiper {
  max-width: 90rem;
  margin: 0 auto;
}
.services .swiper .slick-list {
  overflow: visible;
}
.services .swiper .item {
  padding: 0 3rem;
}
.services .swiper img {
  width: 100%;
  height: auto;
  border-radius: 4rem;
}
.services .swiper .conts {
  margin-top: 3rem;
}
.services .swiper .conts .tit {
  display: block;
  font-size: 3.2rem;
  font-weight: 500;
  font-family: var(--font-mont);
  font-weight: bold;
}
.services .swiper .conts .desc {
  font-size: 2rem;
  color: #757575;
}
.services .intro_service {
  position: relative;
  padding: 18rem 0;
  text-align: center;
}
.services .intro_service .lottie-img {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.services .intro_service #animation1 {
  left: 0;
  width: 42rem;
}
.services .intro_service #animation2 {
  right: 8rem;
  width: 26rem;
}
.services .intro_service .title, .services .intro_service .desc {
  position: relative;
  z-index: 1;
}
.services .intro_service .title {
  display: block;
  font-size: 0;
}
.services .intro_service .title .ib {
  font-size: 4.8rem;
  font-weight: bold;
  color: var(--blue-text);
}
.services .intro_service .desc {
  margin: 5.2rem 0;
  font-size: 2.4rem;
}
@media screen and (max-width: 1024px) {
  .services .intro_service #animation1 {
    left: -12%;
  }
  .services .intro_service #animation2 {
    right: calc(-12% + 40px);
  }
}
@media screen and (max-width: 768px) {
  .services {
    padding: 80px 0 0;
  }
  .services .arrows {
    display: none;
  }
  .services .contents {
    margin-top: 40px;
  }
  .services .swiper {
    max-width: calc(100% - 40px);
  }
  .services .swiper .item {
    padding: 0 8px;
  }
  .services .swiper img {
    border-radius: 20px;
  }
  .services .intro_service {
    padding: 120px 20px;
  }
  .services .intro_service #animation1 {
    width: 30vw;
  }
  .services .intro_service #animation2 {
    width: 20vw;
  }
  .services .intro_service .title {
    word-break: keep-all;
  }
  .services .intro_service .desc .block {
    display: inline;
  }
}
@media screen and (max-width: 560px) {
  .services .intro_service {
    padding: 40px 20px;
  }
  .services .intro_service .lottie {
    padding: 40px 0;
  }
  .services .intro_service .lottie-img {
    position: relative;
    top: auto;
    left: auto !important;
    right: auto !important;
    margin: 0 auto;
    transform: unset;
  }
  .services .intro_service #animation1 {
    width: 40vw;
  }
  .services .intro_service #animation2 {
    width: 36vw;
  }
}

.recruit {
  padding-bottom: 18rem;
}
.recruit .contents {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  padding: 16rem 4rem;
  border-radius: 4rem;
  background: url(../img/main_recruit.jpg) center/cover;
}
.recruit .wrap_title {
  width: 50%;
}
.recruit .wrap_title .title {
  font-size: 7.2rem;
}
.recruit .wrap_title .desc {
  line-height: 1.8;
  margin: 6rem 0;
}
@media screen and (max-width: 1024px) {
  .recruit {
    border-radius: 20px;
  }
  .recruit .contents {
    background-position: 35% center;
  }
  .recruit .wrap_title {
    width: auto;
  }
}
@media screen and (max-width: 768px) {
  .recruit .wide:before {
    display: block;
    height: 50vw;
    border-radius: 20px 0 0 20px;
    margin-right: -20px;
    background: url(../img/main_recruit.jpg) center/cover;
    content: "";
  }
  .recruit .contents {
    display: block;
    margin-top: -11vw;
    padding: 0;
    border-radius: 0;
    background: none;
  }
  .recruit .wrap_title {
    text-align: right;
    text-shadow: 0 0 12em #fff;
  }
  .recruit .wrap_title .title {
    font-size: 9vw;
  }
}