@charset "UTF-8";
.fv {
  background: linear-gradient(101deg, rgb(0, 100, 194), rgb(143, 244, 200));
  height: 620px;
  position: relative;
  padding-top: 250px;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .fv {
    height: 60vh;
  }
}
.fv__img {
  mix-blend-mode: multiply;
  position: absolute;
  display: block;
  right: 0;
  margin-top: -250px;
  pointer-events: none;
}
@media screen and (max-width: 768px) {
  .fv__img {
    margin-top: 0;
    bottom: 0;
    width: 140%;
    right: -10vw;
  }
}
.fv__copy {
  color: #fff;
  font-size: 40px;
  line-height: 1.8;
  font-weight: 600;
  margin-top: 30px;
  padding-left: 100px;
  z-index: 3;
  position: relative;
}
@media screen and (max-width: 768px) {
  .fv__copy {
    padding-left: 20px;
    font-size: 8vw;
    line-height: 1.6;
    margin-top: -90px;
  }
}
.fv__en {
  font-family: "Montserrat", sans-serif;
  font-size: 120px;
  opacity: 0.3;
  color: #fff;
  font-weight: 700;
  line-height: 0.9;
  position: absolute;
  bottom: 0;
  white-space: nowrap;
}
@media screen and (max-width: 768px) {
  .fv__en {
    font-size: 15vw;
  }
}
.fv__en--01 {
  transform: translateY(-90px);
  display: inline-block;
  padding-left: 100vw;
  white-space: nowrap;
  animation: scrollCatchCopy 20s linear infinite;
  bottom: 60px;
}
.fv__en--02 {
  display: inline-block;
  padding-left: 100vw;
  white-space: nowrap;
  animation: scrollCatchCopy-re 50s linear infinite;
  bottom: 0;
}

@keyframes scrollCatchCopy {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}
@keyframes scrollCatchCopy-re {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0);
  }
}
.info {
  text-align: center;
  max-width: 1200px;
  padding: 0 20px;
  width: 100%;
  margin: 0 auto;
  padding: 60px;
}
@media screen and (max-width: 768px) {
  .info {
    padding: 4vw;
  }
}
.info h2 {
  font-size: 22px;
  font-weight: 600;
  color: #68BDF3;
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .info h2 {
    margin-bottom: 2.6666666667vw;
  }
}
.info .info__list {
  text-align: left;
  border-radius: 10px;
  font-size: 16px;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .info .info__list {
    font-size: 3.7333333333vw;
    margin-bottom: 5.3333333333vw;
  }
}
@media screen and (max-width: 768px) {
  .info .info__list li a {
    padding-top: 2.6666666667vw;
  }
}
.info .info__list a {
  display: flex;
  flex-wrap: wrap;
  background: rgba(255, 255, 255, 0.8);
  transition: 0.3s;
}
.info .info__list a:hover {
  color: #fff;
  background: rgba(104, 189, 243, 0.8);
}
@media screen and (max-width: 768px) {
  .info .info__list a {
    display: block;
  }
}
.info .info__list time {
  padding: 20px;
  width: 20%;
  border-bottom: 1px solid #eee;
  font-weight: 400;
}
.info .info__list time:last-of-type {
  border-bottom: none;
}
@media screen and (max-width: 768px) {
  .info .info__list time {
    padding: 0vw 5.3333333333vw 2.6666666667vw 5.3333333333vw;
    margin-top: 5.3333333333vw;
    transform: translateY(20px);
  }
}
.info .info__list p {
  padding: 20px;
  width: 80%;
  border-bottom: 1px solid #eee;
  font-weight: 400;
}
.info .info__list p:last-of-type {
  border-bottom: none;
}
@media screen and (max-width: 768px) {
  .info .info__list p {
    padding: 0vw 5.3333333333vw 2.6666666667vw 5.3333333333vw;
  }
}

/*intro*/
.intro {
  text-align: center;
  margin-bottom: 80px;
}
.intro h2 {
  color: #0064C2;
  font-weight: 600;
  font-size: 30px;
  margin-bottom: 60px;
}
@media screen and (max-width: 768px) {
  .intro h2 {
    font-size: 4.8vw;
    margin-bottom: 5.3333333333vw;
  }
}
.intro__box {
  display: flex;
  gap: 80px;
  max-width: 1080px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .intro__box {
    display: block;
    margin-bottom: 10.6666666667vw;
  }
}
.intro__box > div {
  width: calc(50% - 40px);
}
@media screen and (max-width: 768px) {
  .intro__box > div {
    width: 90%;
    margin: 0 auto;
  }
}
.intro__item {
  margin-bottom: 60px;
}
.intro__item p {
  text-align: left;
}
.intro__p {
  color: #fff;
  background: #68BDF3;
  text-align: center;
  font-weight: 600;
  border-radius: 50px;
  padding: 15px;
  margin-bottom: 15px;
  text-align: center !important;
}
.intro__p-01 {
  margin-bottom: 20px;
}
.intro__p-02 {
  font-size: 32px;
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .intro__p-02 {
    font-size: 5.3333333333vw;
  }
}
.intro__icon {
  width: 70px;
  height: 120px;
  display: flex;
  align-items: center;
  margin: 0 auto;
}
.intro__icon img {
  width: 100%;
  margin: 0 auto;
  display: block;
}
.intro__out {
  width: 100%;
  background: #ccc;
  padding: 80px;
  color: #fff;
  /* 逆三角形のサイズ指定：幅180px・高さ50px */
  clip-path: polygon(0 0, calc(50% - 90px) 0, 50% 50px, calc(50% + 90px) 0, 100% 0, 100% 100%, 0 100%);
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.3) 1px, transparent 1px), radial-gradient(circle at 50% 100%, rgb(143, 244, 200), rgb(43, 155, 255));
  background-size: 20px 20px, 100%;
}
@media screen and (max-width: 768px) {
  .intro__out {
    padding: 21.3333333333vw 10.6666666667vw 10.6666666667vw;
  }
}

/*strengths*/
.strengths {
  margin-bottom: 100px;
}
@media screen and (max-width: 768px) {
  .strengths {
    margin-bottom: 21.3333333333vw;
  }
}
.strengths__box {
  display: flex;
  gap: 50px;
}
@media screen and (max-width: 768px) {
  .strengths__box {
    display: block;
  }
}
.strengths__box > div {
  width: calc(50% - 25px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 50px;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .strengths__box > div {
    width: 80%;
    padding: 4vw;
  }
}
.strengths__left {
  border-radius: 0 20px 20px 0;
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.3) 1px, transparent 1px), linear-gradient(120deg, rgb(43, 155, 255), rgb(143, 244, 200));
  background-size: 20px 20px, 100%;
}
.strengths__right {
  border-radius: 20px 0 0 20px;
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.3) 1px, transparent 1px), linear-gradient(315deg, rgb(43, 155, 255), rgb(143, 244, 200));
  background-size: 20px 20px, 100%;
}
@media screen and (max-width: 768px) {
  .strengths__right {
    margin-left: auto;
    margin-top: 10px;
  }
}

/*faq*/
.faq {
  margin-bottom: 100px;
}

.details {
  border-top: 1px solid #eee;
  border-left: 1px solid #eee;
  border-right: 1px solid #eee;
  max-width: 1060px;
  margin: 0 auto;
}
.details:last-of-type {
  border-bottom: 1px solid #eee;
}

.details-summary {
  position: relative;
  display: block;
  padding: 20px 20px 20px 40px;
  color: #333;
  font-size: 18px;
  text-align: left;
  background-color: #fff;
  transition: 0.3;
}
@media screen and (max-width: 768px) {
  .details-summary {
    padding: 2.6666666667vw 2.6666666667vw 2.6666666667vw 4vw;
    font-size: 3.4666666667vw;
  }
}
.details-summary::before, .details-summary::after {
  content: "";
  margin: auto;
  position: absolute;
  transition: 0.3;
}
.details-summary::before {
  /* くの字の表示設定 */
  top: 0;
  bottom: 0;
  right: 30px;
  width: 10px;
  /* くの字を山なりに見た時、左側の長さ */
  height: 10px;
  /* くの字を山なりに見た時、右側の長さ */
  border-top: 2px solid #333;
  /* くの字を山なりに見た時、左側の太さと色 */
  border-right: 2px solid #333;
  /* くの字を山なりに見た時、右側の太さと色 */
  transform: rotate(135deg);
  /* くの字の向き */
}
.details-summary:hover {
  cursor: pointer;
  opacity: 0.8;
}
.details-summary.is-active::before {
  transform: rotate(315deg);
}

.details-summary::-webkit-details-marker {
  display: none;
}

.details-content {
  padding: 20px 20px 20px 40px;
  font-size: 18px;
  text-align: left;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .details-content {
    font-size: 3.7333333333vw;
  }
}
.details-content p {
  margin: 0 0 20px;
  text-align: left;
}
.details-content p:last-of-type {
  margin: 0 0 0;
}/*# sourceMappingURL=index.css.map */