@charset "utf-8";

/* 共通  */
.sp {
  display: none;
}

.large-container {
  max-width: 1366px;
}

.container {
  max-width: 1186px;
}

.inner {
  max-width: 1026px;
}

/* 共通  */
.c-link {
  width: 40rem;
}

.c-heading h2 {
  font-size: 3.2rem;
}

.c-heading p {
  font-size: 1.7rem;
}

main {
  padding-top: 6.4rem;
}



/*------------------------------ 追従バナー ------------------------------*/
#fixed-banner {
  right: 3rem;
  bottom: 3rem;
}



/*------------------------------ ヘッダー ------------------------------*/
header .large-container {
  max-width: 1240px;
}

header .large-container .logo-nav {
  align-items: center;
  gap: 0 3.4rem;
}

@media screen and (max-width: 1000px) {
  header .large-container .logo-nav {
    gap: 0 2rem;
  }
}

@media screen and (max-width: 1000px) {
  header .large-container .logo-nav .logo a img {
    width: 11rem;
  }
}

header .large-container .logo-nav nav ul {
  gap: 0 2rem;
}

header .large-container .logo-nav nav ul li a {
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: 0.02em;
  line-height: 1.572;
  display: flex;
}

@media screen and (max-width: 1000px) {
  header .large-container .logo-nav nav ul li a {
    font-size: 1.2rem;
  }
}

header .large-container .registration {
  width: 14rem;
  height: 3.6rem;
}

@media screen and (max-width: 1000px) {
  header .large-container .registration {
    width: 9.6rem;
    height: 4.6rem;
    border-radius: .4rem;
  }

}



/* ファーストビュー  */
#top .fv .fv-bg {
  position: absolute;
  content: "";
  top: 0;
  width: 50%;
  height: 100%;
  z-index: -1;
}

#top .fv .fv-bg.bg-left {
  left: 0;
  background-color: var(--c-orange);
}

#top .fv .fv-bg.bg-right {
  right: 0;
  background-color: var(--c-navy);
}

#top .fv .contents {
  top: 11.6rem;
  left: 55%;
}

@media screen and (max-width: 1500px) {
  #top .fv .contents {
    left: auto;
    right: 6%;
  }
}

@media screen and (max-width: 1000px) {
  #top .fv .contents {
    right: 0;
  }
}

#top .fv .contents h2 {
  font-size: 6.4rem;
  margin-bottom: 2rem;
}

#top .fv .contents p {
  margin-bottom: 4.8rem;
  font-size: 2.2rem;
}

#top .fv .contents .img {
  margin-bottom: 2rem;
}

#top .fv .timer-wrap {
  bottom: 4rem;
  left: 6.8rem;
}

#top .fv .large-container {
  top: 0;
  left: -20rem;
  width: 159.7rem;
  height: 70.4rem;
  max-width: none;
}

#top .fv .large-container .orange-triangle {
  position: absolute;
  top: 0;
  left: 0;
}

#top .fv .large-container .navy-triangle {
  position: absolute;
  top: 0;
  right: 16rem;
  z-index: 1;
}

#top .fv .large-container .navy-square {
  position: absolute;
  top: 0;
  left: calc(100% - 16rem);
  width: 39.1rem;
  height: 70.4rem;
  background-color: var(--c-navy);
}

#top .fv .large-container .orange-deco {
  position: absolute;
  top: 0;
  left: -3rem;
}

#top .fv .large-container .orange-deco {
  position: absolute;
  top: 0;
  left: -3rem;
}

#top .fv .large-container .navy-deco-bottom {
  position: absolute;
  bottom: 0;
  left: 79rem;
  z-index: 1;
}

#top .fv .large-container .navy-deco-top {
  position: absolute;
  top: -26rem;
  left: 124rem;
  z-index: 1;
  width: 64.8rem;
}

#top .fv .large-container .person {
  top: 0;
  left: 23.1rem;
}

#top .fv .large-container .person .img {
  width: 65.7rem;
  height: 70.4rem;
}



/* お悩み */
#top .worries {
  padding-top: 4.5rem;
}

#top .worries .inner {
  padding-bottom: 1rem;
  /* ↑問題ない？ */
}

#top .worries .inner .emphasis-top {
  font-size: 3.2rem;
  line-height: 1.067;
}

#top .worries .inner .emphasis-bottom {
  font-size: 3.2rem;
  line-height: 1.067;
  margin-bottom: 3.4rem;
}

@media screen and (max-width: 1000px) {
  #top .worries .inner .emphasis-bottom {
    margin-bottom: 0;
  }
}

#top .worries .inner .emphasis-bottom span {
  font-size: 4.5rem;
}

#top .worries .inner ul {
  padding: 1.5rem 3.5rem 1.5rem 1.5rem;
  width: fit-content;
}

@media screen and (max-width: 1000px) {
  #top .worries .inner ul {
    transform: translateY(-4rem);
  }
}

#top .worries .inner ul li {
  align-items: center;
}

#top .worries .inner ul li:not(:last-of-type) {
  margin-bottom: 1.1rem;
}

#top .worries .inner ul li p {
  font-size: 2.2rem;
  line-height: 1.73;
}

#top .worries .inner .worries-img {
  position: absolute;
  right: -11rem;
  bottom: -8rem;
  z-index: 1;
}

@media screen and (max-width: 1000px) {
  #top .worries .inner .worries-img {
    position: static;
  }
}

/* 解決 */
#top .solution {
  padding: 0 0 5.3rem;
}

#top .solution .bg-dot {
  background-size: 2.5rem 2.5rem;
}

#top .solution .bg-dot1 {
  width: 35rem;
  height: 35rem;
  left: 4.5rem;
  bottom: -4.5rem;
}

@media screen and (max-width: 1365px) {
  #top .solution .bg-dot1 {
    left: -4.5rem;
  }
}

#top .solution .bg-dot2 {
  width: 14rem;
  height: 14rem;
  right: 9rem;
  bottom: -4.5rem;
}

@media screen and (max-width: 1365px) {
  #top .solution .bg-dot2 {
    display: none;
  }
}

#top .solution .large-container .on-solution {
  height: 10.2rem;
  margin-bottom: 3.69rem;
}

#top .solution .large-container .on-solution .bg-dot3 {
  width: 20rem;
  height: 20rem;
  top: 5rem;
  right: 18%;
}

@media screen and (max-width: 1365px) {
  #top .solution .large-container .on-solution .bg-dot3 {
    right: 5%;
  }
}

#top .solution .large-container .contents .emphasis-top {
  font-size: 3.6rem;
  margin-bottom: 1.8rem;
}

#top .solution .large-container .contents .emphasis-top span {
  font-size: 4.5rem;
  line-height: 1.184;
}

#top .solution .large-container .contents .emphasis-top span:first-of-type {
  margin-right: 1.2rem;
  background: linear-gradient(transparent 80%, #FFED89 20%) 0 -.6rem;
}

#top .solution .large-container .contents .emphasis-top span:last-of-type {
  margin: 0 .8rem;
}

#top .solution .large-container .contents .emphasis-bottom {
  font-size: 2.2rem;
  margin-bottom: 4rem;
}



/* スカイサイドとは？  */
#top .overview {
  padding: 10rem 0 4.2rem;
}

#top .overview .bg-border {
  position: absolute;
  content: "";
  top: 13.8rem;
  left: 6rem;
  width: 20rem;
  height: .3rem;
  background-color: #E2F4FF;
  transform-origin: left top;
  transform: rotate(315deg);
  border-radius: .2rem;
  z-index: -2;
}

#top .overview .bg-circle {
  top: 4.8rem;
  left: -3.2rem;
}

#top .overview .bg-large-circle {
  top: 28.2rem;
  right: -10.7rem;
}

#top .overview .inner .txt-img {
  margin-bottom: 10rem;
}

#top .overview .inner .bg-txt {
  top: 22.6rem;
  left: -13rem;
  font-size: 23.1rem;
}

@media screen and (max-width: 1250px) {
  #top .overview .inner .bg-txt {
    top: 22.6rem;
    left: -5%;
    font-size: clamp(12rem, 18vw, 23.1rem);
  }
}

#top .overview .inner .c-heading {
  margin-bottom: 7rem;
}

#top .overview .inner .txt-img .txt {
  width: 50%;
}

#top .overview .inner .txt-img .txt p {
  font-size: 2rem;
}

@media screen and (max-width: 1000px) {
  #top .overview .inner .txt-img .txt p {
    font-size: 1.8rem;
  }
}

@media screen and (max-width: 900px) {
  #top .overview .inner .txt-img .txt p {
    font-size: 1.6rem;
  }
}

#top .overview .inner .txt-img .txt p:not(:last-of-type) {
  margin-bottom: 2rem;
}

#top .overview .inner .txt-img .img {
  width: 50%;
}

#top .overview .inner .txt-img .img img {
  top: -8.9rem;
  left: -1.7rem;
}



/* スカイサイドが選ばれる4つの理由  */
#top .benefit {
  padding: 10rem 0 8rem;
}

#top .benefit .c-heading {
  margin-bottom: 10.5rem;
}

#top .benefit .inner .reason {
  gap: 6.5rem 10%;
  margin-bottom: 7rem;
}

#top .benefit .inner .reason .each-reason {
  width: 45%;
  position: relative;
}

#top .benefit .inner .reason .each-reason .number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 7rem;
  height: 7rem;
  border-radius: 9999px;
  color: #fff;
  font-weight: 700;
  font-size: 3.7rem;
  font-family: "Noto Sans", sans-serif;
  position: absolute;
  top: -3.5rem;
  left: -3.5rem;
}

#top .benefit .inner .reason .each-reason .number {
  background-color: var(--c-orange);
}

#top .benefit .inner .reason .each-reason .img {
  margin-bottom: 1.8rem;
}

#top .benefit .inner .reason .each-reason h3 {
  font-size: 2.2rem;
  margin-bottom: 1.4rem;
}



/* パイロット一覧  */
#top .pilots {
  padding: 10rem 0 8rem;
}

#top .pilots .bg-dot:first-of-type {
  top: 42.8rem;
  left: -7.8rem;
}

#top .pilots .bg-dot:nth-of-type(2) {
  top: 11.2rem;
  right: 6.8rem;
}

#top .pilots .large-container {
  max-width: none;
}

#top .pilots .large-container .c-heading {
  margin-bottom: 7rem;
}

#top .pilots .large-container .swiper {
  margin-bottom: 12rem;
}

#top .pilots .large-container .swiper .swiper-button-prev {
  width: 6rem;
  height: 6rem;
  left: 9rem;
}

@media screen and (max-width: 1000px) {
  #top .pilots .large-container .swiper .swiper-button-prev {
    opacity: .8;
    left: 2rem;
  }
}

#top .pilots .large-container .swiper .swiper-button-prev::before {
  width: 1.2rem;
  height: 1.2rem;
}

#top .pilots .large-container .swiper .swiper-button-next {
  width: 6rem;
  height: 6rem;
  right: 9rem;
}

@media screen and (max-width: 1000px) {
  #top .pilots .large-container .swiper .swiper-button-next {
    opacity: .8;
    right: 2rem;
  }
}

#top .pilots .large-container .swiper .swiper-button-next::before {
  width: 1.2rem;
  height: 1.2rem;
}

#top .pilots .large-container .swiper .swiper-wrapper .swiper-slide a .contents h3 {
  margin-bottom: 1.6rem;
}

#top .pilots .large-container .swiper .swiper-wrapper .swiper-slide a .contents h4 {
  margin-bottom: .8rem;
}

#top .pilots .large-container .swiper .swiper-wrapper .swiper-slide a .contents .term-wrapper p {
  font-size: 1.4rem;
}

#top .pilots .large-container .swiper-pagination {
  bottom: 13rem;
}



/* 人気のカテゴリ  */
#top .categories .large-container {
  padding: 7.1rem 0 8.9rem;
}

#top .categories .large-container .c-heading {
  margin-bottom: 7rem;
}

#top .categories .large-container .category-wrap {
  gap: 1.6rem 1.4rem;
  margin-bottom: 7rem;
  max-width: 1026px;
}

#top .categories .large-container .category-wrap a {
  font-size: 1.8rem;
  padding: .8rem 2.4rem;
}



/* 利用者の声  */
#top .voices {
  padding: 10rem 0 8rem;
}

#top .voices .inner .c-heading {
  margin-bottom: 7rem;
}

#top .voices .inner .voice-wrap {
  gap: 0 3.5%;
  transform: none !important;
}

#top .voices .inner .voice-wrap .each-voice {
  height: auto;
  width: 31% !important;
  margin-right: 0 !important;
}

#top .voices .inner .voice-wrap .each-voice h3 {
  font-size: 2.2rem;
  margin-bottom: 2rem;
}

@media screen and (max-width: 1000px) {
  #top .voices .inner .voice-wrap .each-voice h3 {
    font-size: 2rem;
  }
}

#top .voices .inner .voice-wrap .each-voice p {
  padding: 1.8rem;
  margin-bottom: 3rem;
}



/* 仕事を受注する流れ  */
#top .flow {
  padding: 10rem 0 8rem;
}

#top .flow .flow-bg {
  position: absolute;
  content: "";
  top: 0;
  width: 50%;
  height: 100%;
  z-index: -1;
}

#top .flow .flow-bg.bg-left {
  left: 0;
}

#top .flow .flow-bg.bg-right {
  right: 0;
}

#top .flow .flow-bg.bg-left {
  background-color: #FFFCE6;
}

#top .flow .flow-bg.bg-right {
  background-color: #FFFAD0;
}

#top .flow .inner .flow-wrap {
  position: relative;
  top: -10rem;
  z-index: -1;
}

@media screen and (max-width: 1000px) {
  #top .flow .inner .flow-wrap {
    top: 2.8rem;
  }
}

#top .flow .inner .flow-wrap .each-flow {
  width: 50%;
}

#top .flow .inner .flow-wrap .each-flow:first-of-type {
  padding-right: 2.3rem;
}

#top .flow .inner .flow-wrap .each-flow:last-of-type {
  padding-left: 2.3rem;
}

#top .flow .inner .flow-wrap .each-flow .img {
  margin-bottom: 1rem;
}

#top .flow .flow-wrap .each-flow .img {
  height: 23.8rem;
}

#top .flow .flow-wrap .each-flow:first-of-type .img {
  text-align: left;
}

#top .flow .inner .flow-wrap .each-flow h3 {
  font-size: 2.2rem;
  margin-bottom: 2.6rem;
}

@media screen and (max-width: 1000px) {
  #top .flow .inner .flow-wrap .each-flow h3 span {
    display: block;
  }
}

#top .flow .inner .flow-wrap .each-flow .step {
  gap: 0 2rem;
  padding: 2.2rem;
}

#top .flow .inner .flow-wrap .each-flow .step:not(:last-of-type) {
  margin-bottom: 7rem;
}

#top .flow .inner .flow-wrap .each-flow .step:not(:last-of-type)::before {
  top: calc(100% + 1rem);
  width: 2.5rem;
  height: 2.5rem;
}

#top .flow .inner .flow-wrap .each-flow .step:not(:last-of-type)::before {
  border-right: .5rem solid var(--c-orange);
  border-bottom: .5rem solid var(--c-orange);
}

#top .flow .inner .flow-wrap .each-flow .step:not(:last-of-type)::after {
  top: calc(100% + 2.5rem);
  width: 2.5rem;
  height: 2.5rem;
}

#top .flow .inner .flow-wrap .each-flow .step:not(:last-of-type)::after {
  border-right: .5rem solid var(--c-orange);
  border-bottom: .5rem solid var(--c-orange);
}

#top .flow .inner .flow-wrap .each-flow .step .contents h4 {
  font-size: 2.2rem;
}

@media screen and (max-width: 1000px) {
  #top .flow .inner .c-link {
    margin-top: 12.8rem;
  }
}



/* 安心してご利用できる仕組み */
#top .safety {
  padding: 10rem 0 4.5rem;
}

#top .safety .container .c-heading {
  margin-bottom: 7rem;
}

#top .safety .container .safety-wrap {
  gap: 5.5rem 10%;
  padding: 3.5rem 5%;
}

#top .safety .container .safety-wrap .each-safety {
  width: 45%;
}

#top .safety .container .safety-wrap .each-safety .img-heading {
  gap: 0 1.8rem;
  margin-bottom: 2rem;
}

#top .safety .container .safety-wrap .each-safety .img-heading h3 {
  font-size: 2.2rem;
}



/* よくある質問 */
#top .faq {
  padding: 10rem 0 8rem;
}

#top .faq .inner .c-heading {
  margin-bottom: 7rem;
}

#top .faq .inner .faq-wrap {
  gap: 1rem 0;
  margin-bottom: 7rem;
}

#top .faq .inner .faq-wrap .each-faq summary {
  align-items: center;
  gap: 0 1.4rem;
  padding: 1.6rem 5.2rem 1.6rem 2.2rem;
}

#top .faq .inner .faq-wrap .each-faq summary span:first-of-type {
  width: 4.3rem;
  height: 4.3rem;
  font-size: 2.4rem;
}

#top .faq .inner .faq-wrap .each-faq summary span:last-of-type {
  font-size: 1.8rem;
  width: calc(100% - 5.7rem);
}

#top .faq .inner .faq-wrap .each-faq summary::before {
  right: 3.5rem;
}

#top .faq .inner .faq-wrap .each-faq summary::after {
  right: 2.6rem;
}

#top .faq .inner .faq-wrap .each-faq p {
  padding: 0 3.6rem;
}

#top .faq .inner .faq-wrap .each-faq[open] p {
  padding: 2.7rem 3.6rem;
}



/*------------------------------ 事前登録------------------------------*/
.sign-up {
  padding: 10rem 0 8rem;
}

.sign-up .start-skyside {
  /* padding: 5.6rem 6.2rem; */
  padding: 5.6rem 6rem;
}

.sign-up .start-skyside .img {
  margin-bottom: 1.8rem;
}

.sign-up .start-skyside p:first-of-type {
  font-size: 3.2rem;
  margin-bottom: 1.6rem;
  line-height: 1.78;
}

.sign-up .start-skyside p:last-of-type {
  margin-bottom: 2.8rem;
}



/*------------------------------ フッター ------------------------------*/
footer {
  padding-top: 3.6rem;
}

footer .container .instagram {
  margin-bottom: 3.6rem;
}
