.component #main .ttl_box .sub_ttl {
  font-family: "SST W20 Condensed Bd";
}

.component #main {
  margin: 7.5rem 0.9375rem 9.375rem;
  letter-spacing: 0.1em;
}
.component #main .ttl_box .ttl img {
  height: 60px;
}
.component #main .ttl_box .sub_ttl {
  color: #8517e5;
  font-size: 0.8125rem;
  letter-spacing: 0.1em;
  text-align: center;
  margin-top: 0.3rem;
}
.component #main .art .art_ttl {
  font-size: 1.4375rem;
  letter-spacing: 0.05em;
  font-family: "SSTJapanese W55 Bold";
  text-align: center;
  margin: 3.125rem 0 2.1875rem;
  line-height: 1;
}
.component #main .art .art_text {
  font-size: 0.8125rem;
  letter-spacing: 0.1em;
}
.component #main .art .art_text .blue_text {
  color: #416eec;
}
.component #main .art .sec {
  margin-top: 4.0625rem;
}
.component #main .art .sec.sec2 {
  margin-top: 1.5625rem;
}
.component #main .art .sec .img_box.img_vertical {
  width: 60%;
  margin: 0 auto;
}
.component #main .art .sec .img_box.img_vertical span {
  padding-top: 200%;
}
.component #main .art .sec .img_box span {
  display: block;
  background-color: #c8c6c6;
  background-repeat: no-repeat;
  background-position: center 0;
  background-size: cover;
  padding-top: 55%;
}
.component #main .art .sec .text_box .sec_ttl {
  margin: 1.25rem 0;
  font-size: 1.25rem;
  font-family: "SSTJapanese W55 Bold";
  line-height: 1;
}
.component #main .art .sec .text_box .sec_ttl.text_center {
  text-align: center;
}
.component #main .art .sec .text_box .sec_ttl.ttl_lines {
  line-height: 1.5;
}
.component #main .art .sec .text_box .sec_ul {
  margin-top: 1.4375rem;
}
.component #main .art .sec .text_box .sec_ul .sec_li {
  position: relative;
  padding-left: 21px;
}
.component #main .art .sec .text_box .sec_ul .sec_li::after {
  content: "";
  background-color: #1d1d1c;
  width: 11px;
  height: 11px;
  display: block;
  border-radius: 50%;
  position: absolute;
  top: 0.35rem;
  left: 2px;
}

.component .scroll_table {
  overflow-x: scroll;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
}
.component .table_wrap {
  margin: 0 0.9375rem;
  border-collapse: collapse;
  width: 750px;
}
.component .table_wrap .table_cont .title {
  background-color: #e8d9ff;
}
.component .table_wrap .table_cont .contents {
  border-bottom: 1px solid #aeaaaa;
}
.component .table_wrap .table_cont th, .component .table_wrap .table_cont td {
  width: 190px;
  height: 63px;
  text-align: left;
  vertical-align: top;
  border-right: 1px solid #aeaaaa;
  padding: 1.25rem 0.375rem;
  font-size: 0.6875rem;
  letter-spacing: 0;
}
.component .table_wrap .table_cont th:last-child, .component .table_wrap .table_cont td:last-child {
  border-right: none;
}
.component .table_wrap .table_cont .check_mark {
  font-size: 0.875rem;
}
.component .table_wrap .table_cont th {
  font-family: "SSTJapanese W55 Bold";
  height: 36px;
}
.component #main .art02 .art_ttl {
  line-height: 1.8;
}
.component #main .art02 .art_text {
  margin-bottom: 3.4375rem;
}

@media screen and (min-width: 768px) {
  .component #main {
    margin: 11.875rem 3.75rem 18.75rem;
  }
  .component #main .ttl_box .ttl img {
    height: 7.5rem;
  }
  .component #main .ttl_box .sub_ttl {
    font-size: 1.625rem;
    letter-spacing: 0.1em;
    margin-top: 0.1rem;
  }
  .component #main .pc_flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
  }
  .component #main .pc_flex .sec {
    width: 46%;
  }
  .component #main .pc_flex .sec .img_box.img_vertical {
    width: 34%;
    margin: 0;
  }
  .component #main .pc_flex .sec .pc_flex_box {
    width: 62%;
  }
  .component #main .art .art_ttl {
    font-size: 2.8125rem;
    margin: 6.25rem 0 4.375rem;
  }
  .component #main .art .art_text {
    font-size: 1.875rem;
    text-align: center;
  }
  .component #main .art .sec {
    margin-top: 4.6875rem;
    font-size: 1.7rem;
  }
  .component #main .art .sec.sec2 {
    margin-top: 1.5625rem;
  }
  .component #main .art .sec .img_box.img_vertical {
    width: 34%;
  }
  .component #main .art .sec .img_box.img_vertical.img09 {
    width: 23%;
    margin-right: 2rem;
  }
  .component #main .art .sec .img_box.img_vertical span {
    padding-top: 200%;
  }
  .component #main .art .sec .img_box span {
    display: block;
    background-color: #c8c6c6;
    background-repeat: no-repeat;
    background-position: center 0;
    background-size: cover;
    padding-top: 55%;
  }
  .component #main .art .sec .text_box .sec_ttl {
    margin: 2.25rem 0;
    font-size: 2.5rem;
  }
  .component #main .art .sec .text_box .sec_ttl.ttl_lines {
    line-height: 1.5;
  }
  .component #main .art .sec .text_box .sec_ul {
    margin-top: 1.75rem;
  }
  .component #main .art .sec .text_box .sec_ul .sec_li {
    padding-left: 2rem;
  }
  .component #main .art .sec .text_box .sec_ul .sec_li::after {
    width: 1rem;
    height: 1rem;
    top: 1.25rem;
    left: 2px;
  }
  .component #main .art .sec .text_box .sec_text.text_width {
    width: 76%;
    margin: 0 auto;
  }
  .component #main .pc_flex2 .sec {
    margin-bottom: 3.125rem;
    width: 66%;
  }
  .component #main .pc_flex2 .sec:nth-last-of-type(odd) {
    width: 33%;
  }
  .component #main .pc_flex2 .sec .text_box .sec_ttl_margin {
    margin: 0 0 1.25rem 0;
  }
  .component #main .pc_flex2 .sec3 {
    width: 45%;
  }
  .component #main .pc_flex2 .sec3:nth-last-of-type(odd) {
    width: 45%;
  }
  .component #main .pc_flex2 .pc_flex3 {
    -webkit-box-pack: start;
    -webkit-justify-content: flex-start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .component .scroll_table {
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .component .scroll_table::-webkit-scrollbar {
    display: none;
  }
  .component .table_wrap {
    margin: 0 auto;
    width: 80%;
  }
  .component .table_wrap .table_cont th, .component .table_wrap .table_cont td {
    width: 25%;
    height: 6.25rem;
    padding: 2.5rem 1.25rem;
    font-size: 1.4375rem;
  }
  .component .table_wrap .table_cont .check_mark {
    font-size: 1.875rem;
  }
  .component .table_wrap .table_cont th {
    height: 4.375rem;
  }
  .component #main .art02 .art_ttl {
    line-height: 1.8;
  }
  .component #main .art02 .art_text {
    margin-bottom: 3.4375rem;
  }
}