@charset "UTF-8";

body {
  font-family: 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'Yu Gothic', YuGothic, Verdana, Helvetica, 'ＭＳ Ｐゴシック', sans-serif;
  background: #fff;
  color: #202020;
  text-rendering: optimizeSpeed;
  letter-spacing: 0.015em;
  overflow-x: hidden;
}

/* リキッドレイアウト対応 */
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 {
  margin-bottom: 60px;
  font-size: 36px;
  text-align: center;
  line-height: 1.5;
}

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

.mv {
  background: url(../images/main.png) no-repeat center center;
  background-size: cover;
  padding: 145px 0 164px;
}

@media screen and (max-width: 640px) {
  .mv {
    padding: 60px 0;
  }
}

.mv .lead {
  max-width: 1040px;
  font-size: 20px;
  font-weight: 500;
  color: #fff;
  padding: 0 40px;
  margin: 0 auto 20px;
}

@media screen and (max-width: 640px) {
  .mv .lead {
    font-size: 16px;
  }
}

.mv .ttl {
  max-width: 1040px;
  font-size: 44px;
  font-weight: 700;
  color: #fff;
  padding: 0 40px;
  margin: 0 auto;
}

@media screen and (max-width: 640px) {
  .mv .ttl {
    font-size: 30px;
  }
}

.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(../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;
}

.partner-contents .partner .items .item:not(:first-child) {
  margin-top: 40px;
}

@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 {
  display: inline-block;
  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(../images/attention_bg.png) no-repeat center center;
  background-size: cover;
  padding: 60px 40px;
  margin: 0 auto 100px;
}

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

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

/* パートナー個別ページ */

.mv {
  background: url(../images/main.png) no-repeat center center;
  background-size: cover;
  padding: 45px 0;
  .lead {
    margin: 0 auto 8px;
    padding: 0 40px;
    max-width: 1100px;
    font-size: 20px;
    font-weight: 500;
    line-height: 2;
    color: #fff;
  }
  .ttl {
    margin: 0 auto;
    padding: 0 40px;
    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 12px;
      padding: 0 20px;
      font-size: 16px;
      line-height: 1.6;
    }
    .ttl {
      padding: 0 20px;
      font-size: 28px;
      word-break: keep-all;
    }
  }
}

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

  /* intro: サービス説明 */
  .intro {
    margin: 0;
    padding: 60px 40px;
    .item {
      margin: 0 auto;
      width: 100%;
      max-width: 1200px;
      display: flex;
      align-items: center;
      img {
        margin-right: 80px;
        width: 28%;
        max-width: 320px;
      }
      .txt_box {
        .name {
          margin-bottom: 32px;
          font-size: 40px;
          font-weight: 600;
          line-height: 1.5;
        }
        .ttl {
          margin-bottom: 20px;
          font-size: 24px;
          font-weight: 600;
          line-height: 1.5;
        }
        .txt {
          font-size: 16px;
          line-height: 2;
        }
      }
    }
    @media screen and (max-width: 640px) {
      padding: 60px 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: 特徴 */
  .feature {
    margin: 0;
    background-color: #F3F8FC;
    padding: 80px 0;
    .section-ttl span {
      color: #01C1FF;
    }
    .wrap {
      background: linear-gradient(to right, #ffffff 0%, #ffffff 50%, #f3f8fc 50%, #f3f8fc 100%);
      margin-bottom: 40px;
      &.reverse {
        background: linear-gradient(to right, #f3f8fc 0%, #f3f8fc 50%, #ffffff 50%, #ffffff 100%);
        .item {
          flex-direction: row-reverse;
          padding: 40px 40px 40px 60px;
          .txt_box {
            margin-right: 0;
            margin-left: 60px;
          }
        }
      }
      &:last-child {
        margin-bottom: 0;
      }
      .item {
        position: relative;
        display: flex;
        align-items: center;
        max-width: 1040px;
        background-color: #fff;
        padding: 40px 60px 40px 40px;
        margin: 0 auto;
        box-sizing: content-box;
        .ttl {
          margin-bottom: 28px;
          padding-left: 20px;
          position: relative;
          font-size: 28px;
          font-weight: 700;
          line-height: 1.6;
          color: #444;
          &::before {
            position: absolute;
            content: "";
            width: 5px;
            height: 100%;
            background-color: #FFA135;
            top: 0;
            left: 0;
          }
        }
        .txt {
          font-size: 16px;
          line-height: 2;
        }
        img {
          width: 46.875%;
        }
      }
    }
    @media screen and (min-width: 801px) {
      .wrap {
        .item {
          .txt_box {
            width: 46.875%;
            margin-right: 60px;
          }
        }
      }
    }
    @media screen and (max-width: 800px) {
      .wrap {
        &.reverse{
          .item{
            padding: 40px 20px;
            .txt_box {
              margin: 0 auto 20px;
            }
          }
        }
        .item {
          display: block;
          padding: 40px;
          margin: 0 20px;
          .txt_box {
            width: 80%;
            margin: 0 auto 20px;
          }
          img {
            width: 80%;
            margin: 0 auto;
          }
        }
      }
    }
    @media screen and (max-width: 640px) {
      .wrap {
        .item {
          padding: 40px 20px;
          .txt_box {
            width: 100%;
            .ttl {
              font-size: 20px;
              padding-left: 16px;
            }
            .txt {
              font-size: 14px;
            }
          }
          img {
            width: 100%;
          }
        }
      }
    }
  }

  /* movie: youtube差し込み */
  .movie {
    margin: 100px 0;
    .section-ttl-sub {
      padding: 7px 11px;
      position: relative;
      display: inline-block;
      font-size: 14px;
      font-weight: 500;
      text-align: center;
      color: #fff;
      background-color: #01C1FF;
      border-radius: 6px;
      left: 50%;
      transform: translateX(-50%);
      &::before {
        position: absolute;
        content: "";
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 5px 3.5px 0 3.5px;
        border-color: #01C1FF transparent transparent transparent;
        bottom: -5px;
        left: 50%;
        transform: translateX(-50%);
      }
    }
    .player {
      max-width: 680px;
      width: 100%;
      aspect-ratio: 680 / 383;
      margin: 0 auto;
      iframe {
        width: 100%;
        height: 100%;
      }
    }
    @media screen and (max-width: 800px) {
      iframe {
        max-width: 100%;
      }
    }
    @media screen and (max-width: 640px) {
      margin: 60px 0;
    }
  }

  /* service: サービス内容 */
  .service {
    margin: 80px auto;
    padding: 0 40px;
    max-width: 1040px;
    img.main {
      margin: 0 auto 80px;
      max-width: 800px;
    }
    .service_info {
      max-width: 680px;
      margin: 0 auto;
      .ttl {
        margin-bottom: 28px;
        font-size: 24px;
        font-weight: 600;
      }
      .sample {
        table {
          margin-bottom: 60px;
          border-collapse: collapse;
          border-spacing: 0;
          th {
            padding: 15px 0;
            font-size: 14px;
            font-weight: 600;
            line-height: 1.5;
            background-color: #F7F7F7;
            border: 1px solid #ccc;
            &:nth-child(1) {
              width: 220px;
            }
            &:nth-child(2) {
              width: 120px;
            }
            &:nth-child(3) {
              width: 342px;
            }
          }
          td {
            font-size: 16px;
            line-height: 2;
            border: 1px solid #ccc;
            padding: 15px 0 15px 20px;
          }
        }
      }
      .support {
        margin-bottom: 60px;
        .txt {
          font-size: 16px;
          line-height: 2;
        }
      }
      .range {
        table {
          border-collapse: collapse;
          border-spacing: 0;
          margin-bottom: 100px;
        }
        th {
          padding: 15px 20px;
          width: 164px;
          font-size: 14px;
          font-weight: 600;
          line-height: 1.5;
          text-align: left;
          background-color: #F7F7F7;
          border: 1px solid #ccc;
        }
        td {
          padding: 15px 20px;
          width: 517px;
          font-size: 16px;
          line-height: 2;
          border: 1px solid #ccc;
        }
      }
    }
    @media screen and (max-width: 640px) {
      padding: 0 20px;
      .service_info {
        .ttl {
          margin-bottom: 20px;
          font-size: 20px;
        }
        .sample {
          table {
            th {
              padding: 16px 12px;
            }
            td {
              padding: 16px 12px;
              font-size: 14px;
              line-height: 1.5;
            }
          }
        }
        .support {
          .txt {
            font-size: 14px;
          }
        }
        .range {
          table {
            margin-bottom: 80px;
          }
          th {
            padding: 16px 12px;
            width: 180px;
            word-break: keep-all;
          }
          td {
            padding: 16px 12px;
            font-size: 14px;
          }
        }
      }
    }
  }

  /* benefit: 特典 */
  .benefit {
    .coupon_wrap {
      margin: 0 auto 100px;
      display: flex;
      align-items: center;
      justify-content: center;
      max-width: 1000px;
      .label {
        padding: 32px 80px;
        flex-shrink: 0;
        font-size: 28px;
        font-weight: 600;
        color: #fff;
        background-color: #FFA135;
        border-radius: 12px 0 0 12px;
      }
      .detail {
        padding: 16px 40px 20px;
        width: 100%;
        font-size: 20px;
        color: #3b3b3b;
        border: 2px solid #FFA135;
        border-radius: 0 10px 10px 0;
        span {
          font-size: 24px;
          font-weight: 700;
        }
        small {
          font-size: 14px;
        }
      }
    }
    @media screen and (max-width: 640px) {
      .coupon_wrap {
        align-items: stretch;
        margin: 0 15px 80px;
        .label {
          padding: 35px 15px;
          display: flex;
          align-items: center;
          font-size: 20px;
          white-space: nowrap;
        }
        .detail {
          padding: 20px 15px;
          font-size: 16px;
          span {
            font-size: 20px;
          }
          small {
            margin-top: 12px;
            display: block;
            font-size: 12px;
            line-height: 1.6;
          }
        }
      }
    }
  }

  /* register: 申し込みCTA */
  .register {
    padding: 60px 40px;
    margin: 0;
    background: url(../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;
      }
    }
  }


  /* さくらのさくっとおまかせ設定 */

  /* merit: メリット */
  .merit {
    margin: 0;
    padding: 80px 40px;
    background-color: #F3F8FC;
    .merit-ul{
      margin: 0 auto;
      width: 100%;
      max-width: 1200px;
      display: flex;
      justify-content: space-between;
      .ul-li{
        width: 30%;
        .ul-li-img{
          position: relative;
          width: 100%;
          &:before{
            content: "";
            display: block;
            padding-top: calc((180 / 316) * 100%);
          }
          img{
            position: absolute;
            top: 0;
            right: 0;
            bottom: 0;
            left: 0;
            width: 100%;
          }
        }
        .ul-li-ttl{
          margin-top: 40px;
          text-align: center;
          font-size: 24px;
          font-weight: 600;
          line-height: 1.6;
        }
        .ul-li-txt{
          margin-top: 20px;
          font-size: 16px;
          line-height: 2;
        }
      }
    }
    @media screen and (max-width: 640px) {
      padding: 60px 20px;
      .merit-ul {
        flex-direction: column;
        .ul-li {
          width: 100%;
          &:not(:first-child){
            margin-top: 40px;
          }
          .ul-li-ttl{
            margin-top: 28px;
            font-size: 20px;
          }
          .ul-li-txt{
            margin-top: 16px;
            font-size: 14px;
          }
        }
      }
    }
  }

  /* plan: 対象プラン */
  .plan {
    margin: 0;
    background-color: #fff;
    padding: 80px 40px;
    .plan-ul {
      margin: 0 auto;
      width: 100%;
      max-width: 1100px;
      display: flex;
      justify-content: space-between;
      .ul-li {
        width: 31%;
        padding: 24px 20px;
        font-size: 22px;
        font-style: normal;
        font-weight: 600;
        line-height: 1.6;
        text-align: center;
        color: #fff;
        background: #FFA135;
        border-radius: 12px;
        box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.10);
      }
    }
    .plan-div {
      margin: 40px auto 0;
      width: 100%;
      max-width: 1100px;
      .plan-div-ttl {
        font-size: 28px;
        font-style: normal;
        font-weight: 600;
        line-height: 2;
      }
      .plan-div-ul {
        margin-top: 12px;
        .ul-li {
          padding-left: 20px;
          position: relative;
          font-size: 16px;
          line-height: 2;
          &:before {
            content: "※";
            position: absolute;
            top: 0;
            left: 0;
          }
        }
      }
    }
    @media screen and (max-width: 640px) {
      padding: 60px 20px;
      .plan-ul{
        flex-direction: column;
        .ul-li{
          margin: 0 auto;
          padding: 20px 24px;
          width: 84%;
          font-size: 18px;
          border-radius: 8px;
          &:not(:first-child){
            margin-top: 12px;
          }
        }
      }
      .plan-div {
        margin: 32px auto 0;
        .plan-div-ttl {
          font-size: 20px;
          line-height: 1.6;
        }
        .plan-div-ul {
          margin-top: 20px;
          .ul-li {
            padding-left: 20px;
            font-size: 14px;
            line-height: 1.8;
            &:not(:first-child){
              margin-top: 4px;
            }
          }
        }
      }
    }
  }

  /* menu: メニュー */
  .menu {
    margin: 0;
    padding: 80px 40px;
    background-color: #F3F8FC;
    .menu-div {
        margin: 0 auto;
        width: 100%;
        max-width: 1100px;
      .menu-div-table {
        border-collapse: collapse;
        border-spacing: 0;
        th {
          padding: 12px 20px;
          font-size: 14px;
          font-weight: 600;
          line-height: 1.6;
          background-color: #F7F7F7;
          border: 1px solid #ccc;
          &:nth-child(1) {
            width: 32%;
          }
          &:nth-child(2),
          &:nth-child(3) {
            width: 14%;
          }
          &:nth-child(4) {
            width: 40%;
          }
        }
        td {
          padding: 12px 20px;
          font-size: 16px;
          font-style: normal;
          line-height: 2;
          border: 1px solid #ccc;
          background: #fff;
          &:first-child {
            font-weight: 600;
            text-align: center;
          }
          &:nth-child(2),
          &:nth-child(3) {
            text-align: center;
          }
          .td_ul {
            .ul_li {
              padding-left: 16px;
              position: relative;
              &:before {
                content: "・";
                position: absolute;
                top: 0;
                left: 0;
              }
              &.-anno:before {
                content: "※";
              }
            }
          }
        }
      }
    }
    @media screen and (max-width: 640px) {
      padding: 60px 0;
      .menu-div {
        width: 100%;
        padding: 0 20px 12px;
        overflow-x: auto;
        .menu-div-table {
          width: 800px;
          th {
            padding: 16px 12px;
          }
          td {
            padding: 16px 12px;
            font-size: 14px;
            line-height: 1.8;
          }
        }
      }
    }
  }

  /* flow: ご利用の流れ */
  .flow{
    margin: 0;
    background-color: #fff;
    padding: 80px 40px;
    .flow-ul {
      margin: 35px auto 0;
      display: flex;
      flex-wrap: wrap;
      max-width: 1100px;
      list-style: none;
      .ul-li {
        position: relative;
        padding: 40px 28px;
        width: 30%;
        height: 350px;
        border-radius: 16px;
        text-decoration: none;
        box-sizing: border-box;
        background-color: #fff;
        box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.1);
        &:nth-of-type(n + 4) {
          margin-top: 40px;
        }
        &:not(:nth-child(3n)){
          margin-right: 5%;
        }
        &:not(:nth-child(3n)):before{
          content: "";
          width: 0;
          height: 0;
          border-left: 20px solid #88B4EC;
          border-top: 20px solid transparent;
          border-bottom: 20px solid transparent;
          position: absolute;
          top: calc(50% - 20px);
          left: 100%;
        }
        &:last-child:before{
          display: none;
        }
        .li-div{
          display: flex;
          flex-direction: column;
          align-items: center;
          .li-div-img{
            position: relative;
            width: 60px;
            &:before{
              content: "";
              display: block;
              padding-top: calc(( 70 / 80 ) * 100%);
            }
            img {
              position: absolute;
              top: 0;
              right: 0;
              left: 0;
              bottom: 0;
              width: 100%;
            }
          }
          .li-div-ttl {
            margin-top: 28px;
            font-size: 16px;
            color: rgba(0, 113, 255, 1);
            font-weight: 700;
          }
          .li-div-txt {
            margin-top: 20px;
            font-size: 16px;
            line-height: 2;
            color: rgba(51, 51, 51, 1);
          }
        }
      }
    }
    @media (max-width: 640px) {
      padding: 60px 20px;
      .flow-ul{
        .ul-li {
          width: 100%;
          height: auto;
          padding: 40px 28px;
          &:nth-of-type(n + 2) {
            margin-top: 32px;
          }
          &:not(:nth-child(3n)){
            margin-right: 0;
          }
          &:not(:last-child):before {
            content: "";
            width: 0;
            height: 0;
            border-left: 20px solid transparent;
            border-right: 20px solid transparent;
            border-top: 20px solid #88B4EC;
            position: absolute;
            top: 100%;
            left: calc(50% - 20px);
          }
          .li-div {
            .li-div-txt {
              font-size: 14px;
            }
          }
        }
      }
    }
  }

  /* notes: 注意事項 */
  .notes {
    margin: 0;
    padding: 80px 40px;
    background: #F3F8FC;
    .notes-ul {
      margin: 0 auto;
      width: 100%;
      max-width: 1100px;
      background: #fff;
      .ul-li {
        padding: 32px 40px;
        &:not(:last-child) {
          border-bottom: 1px solid #DEDEDE;
        }
        .li-txt {
          font-size: 16px;
          line-height: 2;
          .li-txt-link {
            color: #1E79FA;
            text-decoration: underline;
            transition: opacity .3s ease;
            &:hover {
              opacity: .8;
            }
          }
        }
      }
    }
    @media screen and (max-width: 640px) {
      padding: 60px 20px;
      .notes-ul {
        .ul-li {
          padding: 20px 24px;
          .li-txt {
            font-size: 14px;
          }
        }
      }
    }
  }

}