@charset "UTF-8";

/* リキッドレイアウト対応 */
html {
  font-size: 16px;
}

@media (max-width: 375px) {
  html {
    font-size: 4.2666666667vw;
  }
}

/* ホバー */
a {
  text-decoration: none;
  color: inherit;
}

*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

/* Remove default padding */
ul,
ol {
  list-style: none;
  padding: 0;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

/* Set core root defaults */
html {
  scroll-behavior: smooth;
}

/* Make images easier to work with */
.partner-contents img,
.partner-detail img {
  max-width: 100%;
  display: block;
  width: 100%;
}

.is-sp {
  display: none;
}

@media screen and (max-width: 640px) {
  .is-sp {
    display: block;
  }
}

.section-ttl {
  font-size: 32px;
  font-weight: 600;
  text-align: center;
  line-height: 54.4px;
  color: #333333;
  margin-bottom: 64px;
}

@media screen and (max-width: 640px) {
  .section-ttl {
    font-size: 23px;
    margin-bottom: 20px;
  }
}

.partner-contents .merit {
  max-width: 1040px;
  padding: 0 40px;
  margin: 80px auto;
}

@media screen and (max-width: 640px) {
  .partner-contents .merit {
    padding: 0 20px;
  }
}

.partner-contents .merit .section-ttl span {
  color: #01C1FF;
}

.partner-contents .merit ul {
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 640px) {
  .partner-contents .merit ul {
    display: block;
  }
}

.partner-contents .merit ul li {
  width: 29%;
  margin-right: 6%;
}

@media screen and (max-width: 640px) {
  .partner-contents .merit ul li {
    width: 80%;
    margin: 0 auto 40px;
  }
}

@media screen and (min-width: 641px) {
  .partner-contents .merit ul li:last-child {
    margin-right: 0;
  }
}

.partner-contents .merit ul li img {
  aspect-ratio: 280 / 250;
  object-fit: cover;
  margin-bottom: 25px;
}

.partner-contents .merit ul li img:nth-child(1) {
  object-position: 72%;
}

.partner-contents .merit ul li img:nth-child(2) {
  object-position: 60%;
}

.partner-contents .merit ul li img:nth-child(3) {
  object-position: 80%;
}

@media screen and (max-width: 640px) {
  .partner-contents .merit ul li img {
    margin-bottom: 15px;
  }
}

.partner-contents .merit ul li .ttl {
  font-size: 22px;
  text-align: center;
  font-weight: 700;
  margin-bottom: 15px;
}

@media screen and (max-width: 640px) {
  .partner-contents .merit ul li .ttl {
    font-size: 20px;
    margin-bottom: 10px;
  }
}

.partner-contents .merit ul li .txt {
  line-height: 1.7;
}

.worries {
  background-color: #F3F8FC;
  padding: 80px 0;
}

.worries .section-ttl {
  text-align: center;
  color: #444;
}

.worries .items {
  display: flex;
  flex-wrap: wrap;
  max-width: 1040px;
  padding: 0 40px;
  margin: 0 auto;
}

@media screen and (max-width: 640px) {
  .worries .items {
    display: block;
    padding: 0 20px;
  }
}

.worries .items .item {
  width: 31.5%;
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  color: #fff;
  background: url(../../web-development/images/worries_label.svg) no-repeat center center;
  background-size: contain;
  padding: 26px 0;
  margin-right: 2.6%;
}

@media screen and (max-width: 960px) {
  .worries .items .item {
    width: 48%;
    margin-bottom: 15px;
  }
}

@media screen and (max-width: 640px) {
  .worries .items .item {
    width: 80%;
    margin: 0 auto 15px;
  }
}

@media screen and (min-width: 961px) {

  .worries .items .item:nth-child(3),
  .worries .items .item:nth-child(6) {
    margin-right: 0;
  }
}

@media screen and (max-width: 960px) and (min-width: 641px) {
  .worries .items .item:nth-child(odd) {
    margin-right: 4%;
  }

  .worries .items .item:nth-child(even) {
    margin-right: 0;
  }
}

.rule {
  margin: 100px 0 120px;
}

.rule ul {
  position: relative;
  display: inline-block;
  max-width: 1040px;
  left: 50%;
  transform: translateX(-50%);
  padding: 0 40px;
  margin: 0 auto;
}

.rule ul li {
  position: relative;
  display: block;
  font-size: 18px;
  margin-bottom: 20px;
}

.rule ul li:last-child {
  margin-bottom: 0;
}

.rule ul li::before {
  position: absolute;
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 0 5px 8px;
  border-color: transparent transparent transparent #1E79FA;
  top: 10px;
  left: -20px;
}

.partner-contents .partner {
  max-width: 1040px;
  padding: 0 40px;
  margin: 0 auto 120px;
}

@media screen and (max-width: 640px) {
  .partner-contents .partner {
    padding: 0 20px;
  }
}

.partner-contents .partner .items .item {
  display: flex;
  align-items: center;
  background-color: #fff;
  border-radius: 50px;
  box-shadow: 0px 2px 61px 0px rgba(17, 51, 139, 0.1);
  padding: 60px;
}

@media screen and (max-width: 960px) {
  .partner-contents .partner .items .item {
    display: block;
  }
}

@media screen and (max-width: 640px) {
  .partner-contents .partner .items .item {
    padding: 40px;
  }
}

.partner-contents .partner .items .item img {
  max-width: 180px;
  margin-right: 50px;
}

@media screen and (max-width: 960px) {
  .partner-contents .partner .items .item img {
    margin: 0 auto 40px;
  }
}

.partner-contents .partner .items .item .txt_box .tag_area {
  display: flex;
  margin-bottom: 20px;
}

.partner-contents .partner .items .item .txt_box .tag_area .tag {
  font-size: 12px;
  font-weight: 500;
  color: #fff;
  background-color: #1E79FA;
  border-radius: 50px;
  padding: 2px 13px;
  margin-right: 4px;
}

.partner-contents .partner .items .item .txt_box .ttl {
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 15px;
}

.partner-contents .partner .items .item .txt_box .txt {
  line-height: 1.7;
  margin-bottom: 15px;
}

.partner-contents .partner .items .item .txt_box .coupon_wrap {
  display: flex;
  margin-bottom: 25px;
}

.partner-contents .partner .items .item .txt_box .coupon_wrap .label {
  font-size: 14px;
  color: #fff;
  background-color: #FFA135;
  border-radius: 15px 0 0 15px;
  padding: 5px 16px;
  white-space: nowrap;
}

.partner-contents .partner .items .item .txt_box .coupon_wrap .detail {
  font-size: 12px;
  color: #444;
  border: 1px solid #FFA135;
  border-radius: 0 15px 15px 0;
  padding: 5px 10px;
}

.partner-contents .partner .items .item .txt_box .btn {
  font-size: 16px;
  font-weight: 600;
  color: #1E79FA;
  border: 2px solid #1E79FA;
  border-radius: 5px;
  padding: 10px 45px;
  transition: .3s;
}

@media screen and (max-width: 960px) {
  .partner-contents .partner .items .item .txt_box .btn {
    position: relative;
    display: inline-block;
    left: 50%;
    transform: translateX(-50%);
  }
}

.partner-contents .partner .items .item .txt_box .btn:hover {
  background-color: #1E79FA;
  color: #fff;
}

.partner-contents .faq {
  max-width: 1040px;
  padding: 0 40px;
  margin: 0 auto 70px;
}

@media screen and (max-width: 640px) {
  .partner-contents .faq {
    padding: 0 20px;
  }
}

.partner-contents .faq .section-ttl {
  margin-bottom: 60px;
}

@media screen and (max-width: 960px) {
  .partner-contents .faq .section-ttl {
    margin-bottom: 25px;
  }
}

.partner-contents .faq ul li {
  border-bottom: 1px solid #ccc;
  padding: 30px 0 30px 20px;
}

@media screen and (max-width: 960px) {
  .partner-contents .faq ul li {
    padding: 15px 0 15px 20px;
  }
}

.partner-contents .faq ul li:first-child {
  padding-top: 0;
}

.partner-contents .faq ul li:last-child {
  border-bottom: none;
}

.partner-contents .faq ul li .question {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 10px;
}

@media screen and (max-width: 960px) {
  .partner-contents .faq ul li .question {
    font-size: 16px;
  }
}

.partner-contents .faq ul li .question span {
  font-size: 24px;
  font-weight: 700;
  color: #1E79FA;
  margin-right: 18px;
}

@media screen and (max-width: 960px) {
  .partner-contents .faq ul li .question span {
    font-size: 20px;
  }
}

.partner-contents .faq ul li .answer {
  font-size: 18px;
}

@media screen and (max-width: 960px) {
  .partner-contents .faq ul li .answer {
    font-size: 16px;
  }
}

.partner-contents .faq ul li .answer span {
  font-size: 24px;
  font-weight: 700;
  color: #01C1FF;
  margin-right: 18px;
}

@media screen and (max-width: 960px) {
  .partner-contents .faq ul li .answer span {
    font-size: 20px;
  }
}

.partner-contents .attention {
  max-width: 1040px;
  width: 100%;
  text-align: center;
  background: url(../../web-development/images/attention_bg.png) no-repeat center center;
  background-size: cover;
  padding: 60px 40px;
  margin: 0 auto;
}

@media screen and (max-width: 640px) {
  .partner-contents .attention {
    padding: 40px 20px;
  }
}

.partner-contents .attention .txt {
  font-size: 18px;
  text-align: center;
  line-height: 1.6;
}

/* パートナー個別ページ */
.mv {
  background: url(../../web-development/images/main.png) no-repeat center center;
  background-size: cover;
  padding: 45px 40px;
  .lead {
    margin: 0 auto 8px;
    max-width: 1100px;
    font-size: 20px;
    font-weight: 500;
    line-height: 2;
    color: #fff;
  }
  .ttl {
    margin: 0 auto;
    max-width: 1100px;
    font-size: 44px;
    font-weight: 600;
    line-height: 1.5;
    color: #fff;
  }
  @media screen and (max-width: 640px) {
    padding: 28px 0;
    .lead {
      margin: 0 auto 4px;
      padding: 0 20px;
      font-size: 13px;
      line-height: 1.6;
    }
    .ttl {
      padding: 0 20px;
      font-size: 24px;
      word-break: keep-all;
    }
  }
}

/* partner-detail: 下層ページ */
.partner-detail {

  /* intro: サービス説明 */
  .intro {
    margin: 0;
    padding: 40px;
    .item {
      margin: 0 auto;
      width: 100%;
      max-width: 1200px;
      display: flex;
      align-items: center;
      img {
        margin-right: 100px;
        width: 28%;
        max-width: 300px;
      }
      .txt_box {
        .name {
          margin-bottom: 32px;
          font-size: 36px;
          font-weight: 600;
          line-height: 1.5;
        }
        .ttl {
          margin-bottom: 12px;
          font-size: 22px;
          font-weight: 600;
          line-height: 1.5;
        }
        .txt {
          font-size: 16px;
          line-height: 2;
        }
        .link {
          display: inline-block;
          margin-top: 20px;
          color: rgba(56, 138, 255, 1);
          font-size: 16px;
          font-weight: 400;
          text-decoration: underline;
        }
      }
    }
    @media screen and (max-width: 640px) {
      padding: 40px 20px;
      .item {
        display: block;
        img {
          width: 60%;
          margin: 0 auto 40px;
        }
        .txt_box {
          .name {
            margin-bottom: 32px;
            font-size: 24px;
          }
          .ttl {
            font-size: 20px;
            line-height: 1.6;
          }
          .txt {
            font-size: 14px;
          }
          .url {
            font-size: 14px;
          }
        }
      }
    }
  }
}

/*feature start */
.partner-detail .feature {
  padding: 80px 0px;
  margin: 0 auto;
  background-color: #F3F8FC;
}

.partner-detail .feature .section-ttl span {
  color: #01C1FF;
}

.partner-detail .feature .card-wrap {
  display: flex;
  margin: 64px auto 0;
  width: 100%;
  max-width: 1040px;
  gap: 50px;

  .card-column {
    display: flex;
    flex-direction: column;
    margin-right: auto;
    margin: 0 auto;
  }

  .card-box {
    display: flex;
    flex-direction: column;
    gap: 24px;
    width: 100%;
    max-width: 300px;
  }

  .card-icon {
    margin: 30px;
    > img {
      width: 75px;
      height: 75px;
      margin: auto;
    }
  }

  .ttl {
    color: #333;
    font-size: 21px;
    font-weight: 600;
    line-height: 35.7px;
    text-align: center;
  }

  .txt {
    color: #333;
    font-size: 16px;
    font-weight: 300;
    line-height: 28.8px;
    text-align: left;
  }
}

@media screen and (max-width: 640px) {
  .partner-detail .feature .card-wrap {
    flex-direction: column;
    align-items: center;
  }
}


/*service start */
.partner-detail .service {
  padding: 80px 0px;
  margin: 0 auto;
  background-color: #ffffff;
}

.partner-detail .service .row-wrap {
    display: flex;
    margin: 0 auto 80px;
    width: 100%;
    max-width: 1040px;
    gap: 100px;

  .desc {
    flex: 1 1 440px;
  }

  .step {
    width: 53px;
    margin-bottom: 20px;
  }

  .step p{
    padding-left: 2px;
    color: #0071FF;
    font-size: 15px;
    font-weight: 700;
    line-height: 24.9px;
    text-align: center;
    letter-spacing: 8%;
  }

  .num_box {
    display: flex;
    width: 53px;
    height: 53px;
    background-color: #0071FF;
    border-radius: 50%;
    margin-top: 8px;
    justify-content: center;
    align-items: center;
  }

  .num {
    color: #ffffff;
    font-size: 27px;
    font-weight: 800;
  }

  .ttl {
    width: 350px;
    position: relative;
    font-size: 24px;
    font-weight: 600;
    line-height: 40.8px;
    color: #333333;
    margin-bottom: 25px;
  }

  .txt {
    position: relative;
    font-size: 16px;
    font-weight: 300;
    line-height: 28.8px;
    color: #000000;
    margin-bottom: 25px;
  }

  .step-icon {
    flex: 0 0 500px;
    border-radius: 10px;
    box-shadow: 0 0 19px -4px rgba(17, 51, 139, 0.2);
    background-color: #fff;
    padding: 8px;
  }
}

@media screen and (max-width: 640px) {
  .partner-detail .service .row-wrap {
    flex-direction: column;
    align-items: center;
    gap: 20px;
    margin: 0 16px;
    width: calc(100% - 32px);

    .desc {
      flex: 1 1 auto;
    }
    .step-icon {
      flex: 0 0 auto;
      margin-bottom: 60px;
    }
  }
}

/* register: 申し込みCTA */
.register {
  margin: 0 !important;
  padding: 60px 40px;
  background: url(../../web-development/images/main.png) no-repeat center center;
  background-size: cover;
  &.-sakura-setting{
    .txt{
      margin: 28px 0 0;
    }
  }
  .ttl {
    margin-bottom: 25px;
    font-size: 36px;
    font-weight: 600;
    text-align: center;
    color: #fff;
    word-break: keep-all;
  }
  .txt {
    margin-bottom: 32px;
    font-size: 16px;
    line-height: 2;
    text-align: center;
    color: #fff;
  }
  .memo {
    margin-top: 20px;
    font-size: 16px;
    line-height: 2;
    text-align: center;
    color: #fff;
  }
  .btn {
    position: relative;
    display: inline-block;
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    background-color: #FFA135;
    border: 2px solid #FFA135;
    border-radius: 5px;
    left: 50%;
    transform: translateX(-50%);
    padding: 16px 72px;
    transition: .3s;
    &:not(.-disabled):hover {
      color: #FFA135;
      background-color: #fff;
      border: 2px solid #FFA135;
    }
    &.-disabled{
      padding: 16px 20px;
      background: #DEDEDE;
      color: #388AFF;
      text-align: center;
      border: none;
      word-break: keep-all;
    }
  }
  @media screen and (max-width: 640px) {
    padding: 60px 20px;
    .ttl {
      font-size: 28px;
    }
    .txt {
      margin-bottom: 28px;
      font-size: 14px;
      line-height: 2;
      text-align: left;
    }
    .memo {
      margin-top: 20px;
      font-size: 14px;
      line-height: 2;
      text-align: left;
    }
    .btn {
      padding: 16px 20px;
      display: flex;
      justify-content: center;
      font-size: 18px;
    }
  }
}