@media screen and (max-width: 700px) {
  #sc .header__sns--sp {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }

  #sc .header__sns--sp a {
    display: block;
  }

  #sc .header__sns--sp a img {
    width: 50px;
  }
}

#sc .btn {
  width: 350px;
  font-size: clamp(14px, 1.5vw, 18px);
  max-width: 80%;
  font-weight: 700;
  color: #fff;
  background: #C8161D;
  border: 3px solid #C8161D;
}

@media screen and (max-width: 767px) {
  #sc .btn {
    height: 60px;
    line-height: 50px;
    font-size: clamp(14px, 5.5vw, 18px);
  }
}

.section__titleImg {
  width: 75px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1rem;
}

@media (max-width: 768px) {
  .section__titleImg {
    margin-bottom: 2rem;
  }
}

/* メインビジュアル */
.key {
  background: url(../img/sc/mv.webp) no-repeat center right/cover;
  margin-top: clamp(80px, 7vw, 117px);
  padding: 60px 0;
  text-align: center;
}

.key__visual {
  position: relative;
  width: 100%;
  max-width: 1920px;
  height: auto;
}

.overlay__logo {
  width: clamp(475px, 33vw, 630px);
  margin-top: 14px;
}

/* main-visualのSP版 */
@media screen and (max-width: 768px) {
  .key {
    background: url(../img/sc/mv-sp.webp) no-repeat center center/cover;
    margin-top: 80px;
    position: relative;
    padding-top: clamp(85px, 22vw, 180px);
    padding-bottom: clamp(85px, 22vw, 180px);
  }

  .overlay__logo {
    margin-top: 0;
    width: clamp(320px, 70vw, 430px);
    position: absolute;
    top: 60%;
    left: 50%;
    transform: translateX(-50%);
  }
}

/* メインビジュアル */
/* soeechlink */
.speech {
  background-image: url("../img/sl/pic_bg.webp");
  background-size: cover;
  background-position: center;
  text-align: center;
  background-color: #f8f8f8;
}

.speech__container {
  position: relative;
  padding: 45px 0 80px;
}

.speech__wrapper {
  position: relative;
  z-index: 1;
}

.speech__text {
  text-align: center;
  font-size: clamp(30px, 3.2vw, 60px);
  line-height: 1.3;
  font-weight: bold;
}

.speech__img {
  margin-top: clamp(2rem, 4vw, 3rem);
  display: block;
  width: 60vw;
  margin-left: auto;
  margin-right: auto;
}

.speech__sub {
  margin-top: 0;
}

.speech__sub p {
  font-size: 18px;
  letter-spacing: -0.1rem;
  font-weight: 500;
}

@media screen and (max-width: 768px) {
  .speech {
    background-image: url("../img/sl/sp_pic_bg.webp");
    background-size: cover;
    background-position: center;
    text-align: center;
    background-color: #F0F0F0;
  }

  .speech__container {
    padding-left: 30px;
    padding-right: 30px;
    padding-bottom: 10px;
    padding-top: clamp(140px, 30vw, 160px);
  }

  .speech__text {
    font-size: clamp(18px, 4vw, 30px);
  }

  .speech__img {
    width: 100%;
    margin-top: clamp(2rem, 4vw, 3rem);
  }

  .speech__sub {
    margin-top: 20px;
  }

  .speech__sub p {
    text-align: justify;
    font-size: clamp(13px, 4.5vw, 16px);
    width: 98%;
    margin-left: auto;
    margin-right: auto;
  }
}

.sp {
  display: none;
}

/* Speech Link 3 つの特長 */
.features {
  background-color: #F0F0F0;
  padding: 95px 0px 180px;
}

.features__box {
  text-align: center;
  margin: 0 auto;
  width: 90%;
  max-width: 1010px;
}

.features__title {
  padding-bottom: 7px;
  font-size: 36px;
  text-align: center;
  font-weight: 700;
  border-bottom: 5px solid #64BFAA;
}

.features__subtitle {
  margin-top: 25px;
  letter-spacing: -0.08rem;
  font-size: 18px;
  font-weight: bold;
}

.features__container {
  display: flex;
  margin-top: 57px;
  align-items: stretch;
  justify-content: center;
  gap: 23px;
  flex-wrap: wrap;
}

.feature {
  flex: 1;
  padding: 50px 2rem 50px;
  border: 4px solid #64BFAA;
  text-align: left;
  background-color: #fff;
}

.feature__item {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
}

.feature__header {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
}

.feature__number {
  font-size: clamp(30px, 4vw, 63px);
  color: #fff;
  background: #64BFAA;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 0.8rem 1.5rem;
  border-radius: 10px;
  letter-spacing: -0.08rem;
}

.feature__number01 {
  letter-spacing: 0.1rem;
  padding: 1rem 1.2rem 1.5rem;
}

.feature__title {
  font-size: clamp(15px, 1.3vw, 18px);
  text-align: justify;
  font-weight: bold;
  color: #333;
  line-height: 28px;
  letter-spacing: 0.08rem;
}

.feature__title span {
  letter-spacing: -0.3rem;
}

.feature__description {
  margin: 18px 2px 0;
  font-size: 14px;
  letter-spacing: -0.08rem;
  color: #666;
  font-weight: 500;
  line-height: 1.8;
  text-align: justify;
}

.feature__img {
  margin-top: 30px;
}

@media screen and (max-width: 960px) {
  .feature__title {
    letter-spacing: 0;
  }
}

@media screen and (max-width: 768px) {
  .features {
    padding: 80px 0px 50px;
  }

  .features__title {
    font-size: clamp(22px, 4vw, 26px);
  }

  .features__subtitle {
    font-size: 14px;
  }

  .features__container {
    margin-top: 36px;
    flex-direction: column;
    gap: 35px;
  }

  .feature {
    padding: 14px 15px 30px;
  }

  .feature__number {
    font-size: 50px;
  }

  .feature__title {
    font-size: clamp(20px, 3vw, 22px);
    letter-spacing: -0.02rem;
  }

  .feature__title span {
    letter-spacing: -0.02rem;
  }

  .feature__description {
    letter-spacing: 0;
  }
}

/* Speech Link 3 つの特長 */
/* お知らせ部分 */
.notice {
  padding: 80px 0;
  width: 90%;
  margin: 0 auto;
  max-width: 1010px;
}

.notice__title {
  padding-bottom: 7px;
  font-size: 36px;
  text-align: center;
  font-weight: 700;
  border-bottom: 5px solid #64BFAA;
}

.notice__container {
  margin-top: 25px;
}

.notice__item {
  display: block;
  margin-top: 25px;
  padding-bottom: 10px;
  border-bottom: 1px solid #000000;
}

.notice__item:not(:first-child) {
  margin-top: 25px;
}

.date {
  font-size: 18px;
  color: #777777;
  text-align: left;
}

.notice__item--title {
  margin-top: 10px;
  font-size: 18px;
  font-weight: bold;
  text-align: left;
}

.notice__button {
  margin-top: 40px;
  text-align: center;
}

.notice__btn {
  letter-spacing: 0;
  color: #4f6999;
  border: 2px solid #4f6999;
}

.notice__btn:hover {
  background: #88A3D4;
}



@media screen and (max-width: 768px) {
  .notice {
    padding: 50px 0;
  }

  .notice__container {
    margin: 25px 20px 0;
  }

  .notice__block {
    padding: 0 20px;
  }

  .notice__title {
    font-size: clamp(22px, 4vw, 26px);
  }

  .notice__item--title {
    font-size: 15px;
  }

  .date {
    font-size: 13px;
  }

}

/* お知らせ部分 */
/* こんな方におすすめです部分 */
.recommendation {
  padding: 95px 0px 125px;
  text-align: center;
  background-color: #fff;
}

.recommendation__box {
  text-align: center;
  margin: 0 auto;
  width: 90%;
  max-width: 1010px;
}

.recommendation__title {
  padding-bottom: 14px;
  font-size: 36px;
  font-weight: bold;
  border-bottom: 5px solid #64BFAA;
}

.recommendation__description {
  margin-top: 20px;
  font-size: 18px;
  font-weight: bold;
}

.recommendation__text {
  margin-top: 50px;
  font-size: clamp(14px, 1.3vw, 16px);
  font-weight: 500;
  text-align: justify;
  line-height: 2.4;
  letter-spacing: -0.1rem;
}

.recommendation__content {
  margin-top: 60px;
  padding: 40px 107px;
  background-color: #64BFAA;
  border-radius: 35px;
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
}

.recommendation__content--inner {
  padding: 45px 50px;
  background-color: #ffffff;
  width: 100%;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
}

.recommendation__content--inner ul {
  text-align: left;
}

.recommendation__content--inner ul li {
  font-weight: 700;
  font-size: clamp(15px, 1.4vw, 19px);
  letter-spacing: -0.08rem;
}

.recommendation__content--inner ul li:not(:first-child) {
  margin-top: 20px;
}

@media screen and (max-width: 768px) {
  .recommendation {
    padding: 80px 0px 50px;
  }

  .recommendation__title {
    font-size: clamp(22px, 4vw, 26px);
  }

  .recommendation__description {
    font-size: 16px;
  }

  .recommendation__text {
    margin-top: 20px;
    line-height: 2;
  }

  .recommendation__content {
    padding: 40px 15px;
    border-radius: 20px;
    margin-top: 45px;
  }

  .recommendation__content--inner {
    padding: 30px 15px;
  }

  .recommendation__content--inner ul li {
    letter-spacing: 0;
  }

  .recommendation__content--inner ul li:not(:first-child) {
    margin-top: 10px;
  }
}

/* こんな方におすすめです部分 */
/* 利用者さまの声 */
.voice {
  margin: 0px auto;
  background-color: #F0F0F0;
  padding: 95px 0px 180px;
}

.voice__box {
  text-align: center;
  margin: 0 auto;
  width: 90%;
  max-width: 1010px;
}

.voice__title {
  padding-bottom: 14px;
  font-size: 36px;
  font-weight: bold;
  border-bottom: 5px solid #64BFAA;
}

.voice__description {
  margin-top: 20px;
  font-size: 18px;
  font-weight: bold;
}

.voice__container {
  display: flex;
  margin-top: 57px;
  align-items: stretch;
  justify-content: center;
  gap: 23px;
}

.voice__item {
  border: 4px solid #90928F;
  background-color: #fff;
}

.voice__item.family-voice {
  border: 4px solid #66BF97;
}

.voice__header {
  border: 4px solid #90928F;
  text-align: center;
  color: #fff;
  font-weight: 700;
  font-size: clamp(16px, 1.6vw, 19px);
  background-color: #90928F;
}

.voice__header.family-voice {
  border: 4px solid #66BF97;
  background-color: #66BF97;
}

.voice__body {
  padding: 15px 18px 50px;
  text-align: justify;
}

.voice__body--title {
  font-size: clamp(14px, 1.6vw, 23px);
  font-weight: 700;
  text-align: justify;
  line-height: 1.2;
}

.voice__body--description {
  margin-top: 20px;
  font-size: 14px;
  font-weight: 500;
}

.voice__body--img {
  margin-top: 30px;
}

.voice__body--img .img img {
  height: clamp(150px, 20vw, 230px);
  object-fit: cover;
}


.voice__body--img .caption {
  text-align: right;
  font-weight: 700;
  font-size: clamp(14px, 1.3vw, 17px);
}

.voice__button {
  margin-top: 40px;
}

@media screen and (max-width: 768px) {
  .voice {
    padding: 80px 0px 50px;
  }

  .voice__title {
    font-size: clamp(22px, 4vw, 26px);
  }

  .voice__container {
    margin-top: 36px;
    flex-direction: column;
    gap: 35px;
  }

  .voice__header {
    font-size: clamp(16px, 2.5vw, 19px);
  }

  .voice__body {
    padding: 25px 18px 25px;
  }

  .voice__body--title {
    font-size: clamp(16px, 4.8vw, 23px);
  }

  .voice__body--img {
    width: 100%;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
  }

  .voice__body--img .img img {
    height: clamp(280px, 47vw, 360px);
    object-fit: cover;
  }

  .voice__body--img .caption {
    font-size: clamp(16px, 2.3vw, 17px);
  }

  .voice__body--description {
    letter-spacing: -0.08rem;
  }
}

/* 利用者さまの声 */
/* 利用料金のご案内 */
.price {
  padding: 90px 0px 170px;
}

.price__section {
  margin: 0 auto;
  width: 90%;
  max-width: 1010px;
}

.price__title {
  text-align: center;
  padding-bottom: 14px;
  font-size: 36px;
  font-weight: bold;
  border-bottom: 5px solid #64BFAA;
}

.price__subtitle {
  margin-top: 20px;
  letter-spacing: -0.1rem;
  text-align: center;
  font-size: clamp(12px, 1.2vw, 18px);
  font-weight: bold;
}

.price__table,
.price__table--child {
  margin-top: 50px;
}

.price__table table,
.price__table--child table {
  width: 100%;
  border-collapse: collapse;
  border: 4px solid #231815;
  font-size: 16px;
}

.price__table table th,
.price__table--child table th {
  padding: 12px 8px;
  text-align: center;
  border: 1px solid #231815;
  vertical-align: middle;
}

.price__table table td,
.price__table--child table td {
  padding: 12px 8px;
  text-align: right;
  border: 1px solid #231815;
  vertical-align: middle;
}

.price__table table .width40,
.price__table--child table .width40 {
  width: 40%;
}

.price__table table .width20,
.price__table--child table .width20 {
  width: 20%;
}

.price__table table .width15,
.price__table--child table .width15 {
  width: 15%;
}

.price__table table th,
.price__table--child table th {
  background-color: #E0F0EB;
  font-size: clamp(14px, 1.3vw, 18px);
  font-weight: 500;
  border: 4px solid #231815;
}

.price__table table th p,
.price__table--child table th p {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.price__table table th .big,
.price__table--child table th .big {
  font-size: clamp(40px, 5.3vw, 77px);
  display: block;
  font-weight: bold;
  font-weight: bold;
}

.price__table table th .mid,
.price__table--child table th .mid {
  font-size: clamp(20px, 2.6vw, 29px);
  display: inline-block;
  margin-left: 2px;
  font-weight: bold;
}

.price__table table td p,
.price__table--child table td p {
  text-align: right;
  display: flex;
  justify-content: flex-end;
  align-items: baseline;
  width: 77%;
  margin-left: auto;
  margin-right: auto;
  font-size: clamp(12px, 1.3vw, 18px);
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
}

.price__table table .table-num,
.price__table--child table .table-num {
  font-weight: bold;
  font-size: clamp(26px, 4.1vw, 40px);
  margin-right: 0.5rem;
}

.price__table table .price-flex,
.price__table--child table .price-flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 3rem;
}

.price__table table .border-none,
.price__table--child table .border-none {
  border-left: none;
  border-right: none;
}

.price__table table .flex,
.price__table--child table .flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 3rem;
  width: clamp(135px, 15vw, 180px);
}

.price__table table .flex .table-price,
.price__table--child table .flex .table-price {
  text-align: right;
  display: flex;
  justify-content: flex-end;
  align-items: baseline;
  margin-left: auto;
  font-size: 12px;
  font-weight: 500;
  line-height: 1;
}

.price__table table .flex .table-arrow,
.price__table--child table .flex .table-arrow {
  font-size: clamp(20px, 1.6vw, 30px);
  font-weight: 500;
}

.price__table table .price-mid,
.price__table--child table .price-mid {
  font-size: clamp(20px, 3vw, 28px);
  font-weight: 700;
}

.price__table table .price-big,
.price__table--child table .price-big {
  color: #C8161D;
  font-size: clamp(26px, 3.3vw, 46px);
  font-weight: bold;
  padding-right: 5px;
  display: inline-block;
}

.price__table table .img,
.price__table--child table .img {
  width: 80%;
  margin-left: auto;
  margin-right: auto;
}

.price__table tr,
.price__table--child tr {
  background: #fff;
}

.price__table tr:nth-of-type(2),
.price__table tr:nth-of-type(5),
.price__table--child tr:nth-of-type(2),
.price__table--child tr:nth-of-type(5) {
  background-color: #E0F0EB;
}

.price__table tr:nth-of-type(3),
.price__table--child tr:nth-of-type(3) {
  border-bottom: 4px solid #231815;
}

.price__table--child #table-child {
  border-color: #64BFAA;
}

.price__table--child #table-child th,
.price__table--child #table-child td {
  border-color: #64BFAA;
}

.price__table--child #table-child th {
  background: #FFFCDB;
  border-color: #64BFAA;
}

.price__table--child #table-child tr:nth-of-type(2) {
  background-color: #FFFCDB;
}

.price__table--child #table-child tr:nth-of-type(3) {
  border-color: #64BFAA;
}

.price__table--child #table-child .child-img {
  width: 60%;
  margin-left: auto;
  margin-right: auto;
}

.price__table--child #table-child .child-flex {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  flex-wrap: wrap;
}

.price__attention {
  margin-top: 30px;
}

.price__attention p {
  font-size: clamp(12px, 1.3vw, 14px);
  line-height: 2;
}

.price__button {
  margin-top: 80px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .price {
    padding: 80px 0px 50px;
  }

  .price__title {
    font-size: clamp(22px, 4vw, 26px);
  }

  .price__subtitle {
    font-size: 14px;
  }

  .price__table td.width40,
  .price__table--child td.width40 {
    width: 30%;
  }

  .price__table td.width20,
  .price__table--child td.width20 {
    width: 30%;
  }

  .price__table td .width15,
  .price__table--child td.width15 {
    width: 5%;
  }

  .price__table table th p,
  .price__table--child table th p {
    flex-wrap: wrap;
    align-items: baseline;
  }

  .price__table table th .big,
  .price__table--child table th .big {
    font-size: clamp(28px, 5.3vw, 40px);
  }

  .price__table table th .mid,
  .price__table--child table th .mid {
    font-size: clamp(16px, 2.6vw, 20px);
  }

  .price__table table .table-num,
  .price__table--child table .table-num {
    margin-right: 0.2rem;
  }

  .price__table table td,
  .price__table--child table td {
    text-align: left;
    padding: 12px 3px;
    font-size: 14px;
  }

  .price__table table td p,
  .price__table--child table td p {
    width: auto;
  }

  .price__table table .price-flex,
  .price__table--child table .price-flex {
    gap: 0;
    align-items: flex-start;
    flex-direction: column;
  }

  .price__table table .flex,
  .price__table--child table .flex {
    gap: 5px;
    width: auto;
  }

  .price__table table .flex .table-arrow,
  .price__table--child table .flex .table-arrow {
    font-size: clamp(15px, 1.6vw, 30px);
  }

  .price__table table .price-big,
  .price__table--child table .price-big {
    font-size: clamp(20px, 5.3vw, 40px);
    padding-right: 2px;
    margin-top: -0.5rem;
  }

  .price__table table .price-mid,
  .price__table--child table .price-mid {
    font-size: clamp(14px, 4vw, 28px);
    text-align: left;
  }

  .price__table table .img,
  .price__table--child table .img {
    width: 100%;
  }

  .price__table table th,
  .price__table--child table th {
    font-size: clamp(11px, 1.3vw, 14px);
  }

  .price__table--child #table-child .child-img {
    width: 100%;
  }

  .price__button {
    margin-top: 40px;
  }
}

/* 利用料金のご案内 */
/* youtube */
.youtube {
  padding: 90px 0px 170px;
  background: #F0F0F0;
}

.youtube__section {
  margin: 0 auto;
  width: 90%;
  max-width: 1010px;
}

.youtube__title {
  text-align: center;
  padding-bottom: 14px;
  font-size: 36px;
  font-weight: bold;
  border-bottom: 5px solid #64BFAA;
}

.youtube__subtitle {
  margin-top: 20px;
  letter-spacing: -0.1rem;
  text-align: center;
  font-size: 18px;
  font-weight: bold;
}

.youtube__content {
  margin-top: 50px;
  padding-bottom: 60px;
}

@media (max-width: 768px) {
  .youtube__content {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 0;
  }
}

.swiper .swiper-button-next,
.swiper .swiper-button-prev {
  bottom: 0px;
  top: auto;
  color: #333;
}

.swiper .swiper-button-next {
  right: 30px;
}

.swiper .swiper-button-prev {
  left: 30px;
}

.swiper-head {
  text-align: center;
  background: #64BFAA;
  color: #fff;
  font-weight: 500;
  padding: 2px 0;
  font-size: clamp(14px, 1.3vw, 18px);
}

.youtube-wrap {
  position: relative;
  width: 100%;
  padding-top: 56%;
  border: 2px solid #333;
  border-top: none;
}

.youtube-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.youtube-item {
  max-width: 540px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

.youtube-item:not(:first-child) {
  margin-top: 45px;
}

.youtube-head {
  text-align: center;
  background: #64BFAA;
  color: #fff;
  font-weight: 500;
  padding: 2px 0;
  font-size: clamp(14px, 1.3vw, 18px);
}

.youtube__button {
  margin-top: 50px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .youtube {
    padding: 80px 0px 50px;
  }

  .youtube__title {
    letter-spacing: -0.08rem;
    font-size: clamp(22px, 4vw, 26px);
    line-height: 1.3;
  }

  .youtube__subtitle {
    font-size: 14px;
  }

  .youtube-head {
    font-size: clamp(15px, 4.3vw, 18px);
  }

  .youtube-wrap {
    margin-top: 1rem;
  }

  .youtube__button {
    margin-top: 80px;
  }
}

/* youtube */
/* よくある質問 */
.faq {
  padding: 90px 0px 170px;
}

.faq__section {
  margin: 0 auto;
  width: 90%;
  max-width: 1010px;
}

.faq__title {
  text-align: center;
  padding-bottom: 14px;
  font-size: 36px;
  font-weight: bold;
  border-bottom: 5px solid #64BFAA;
}

.faq__subtitle {
  margin-top: 20px;
  letter-spacing: -0.1rem;
  text-align: center;
  font-size: 18px;
  font-weight: bold;
}

.faq__alert {
  color: #e60012;
  font-size: 16px;
  margin-top: 45px;
}

/* accordion */
.accordion {
  width: 100%;
  padding: 0 0 100px;
  background-color: #ffffff;
}

.accordion__grid {
  margin-top: 60px;
  padding: 80px 75px 0;
}

/* Accordion  */
.accordion__item:not(:first-child) {
  margin-top: 65px;
}

.accordion__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  background-color: #ffffff;
  transition: background-color 0.3s ease;
}

.accordion__header:hover {
  background-color: #ffffff;
}

.accordion__faq--icon {
  font-size: clamp(22px, 2vw, 27px);
  font-family: "Inter", sans-serif;
  color: #64BFAA;
  margin-right: 10px;
}

.accordion__title {
  font-size: 19px;
  font-weight: bold;
}

.accordion__icon {
  position: relative;
  width: 20px;
  height: 20px;
}

.accordion__icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #333;
  transform: translateY(-50%);
  transition: transform 0.3s ease;
}

.accordion__icon::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 2px;
  height: 100%;
  background-color: #333;
  transform: translateX(-50%);
  transition: opacity 0.3s ease;
}

.accordion__content {
  padding-left: 25px;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  background-color: #ffffff;
}

.accordion__text {
  font-size: 16px;
  line-height: 37px;
  font-weight: 500;
}

.accordion__item.active .accordion__content {
  text-align: left;
  margin-top: 17px;
  max-height: 200px;
  opacity: 1;
}

.accordion__item.active .accordion__icon::after {
  opacity: 0;
}

.accordion__item.active .accordion__icon::before {
  transform: translateY(-50%) rotate(90deg);
}

.accordion__texts {
  margin-left: 70px;
  display: flex;
  align-items: flex-start;
}

.faq__button {
  margin-top: 50px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .faq {
    padding: 80px 0px 50px;
  }

  .faq__title {
    font-size: clamp(22px, 4vw, 26px);
  }

  .faq__subtitle {
    font-size: 14px;
  }

  .faq__alert {
    font-size: 12px;
    margin-top: 20px;
  }

  .accordion {
    padding-bottom: 40px;
  }

  .accordion__item:not(:first-child) {
    margin-top: 30px;
  }

  .accordion__faq {
    display: flex;
    align-items: center;
  }

  .accordion__grid {
    padding: 40px 20px;
    margin-top: 40px;
  }

  .accordion__title {
    font-size: 16px;
  }

  .num {
    font-size: 20px;
    line-height: 1.8;
  }

  .accordion__icon {
    width: 15px;
    height: 15px;
  }

  .accordion__text {
    font-size: 13px;
    line-height: 22px;
    width: 90%;
  }

  .accordion__texts {
    margin-left: 0px;
  }

  .faq__button {
    margin-top: 0px;
  }
}

/* よくある質問 */
/* flow */
.flow {
  background: #F0F0F0;
  padding: 90px 0px 170px;
}

.flow__section {
  margin: 0 auto;
  width: 90%;
  max-width: 1010px;
}

.flow__title {
  text-align: center;
  padding-bottom: 14px;
  font-size: 36px;
  font-weight: bold;
  border-bottom: 5px solid #64BFAA;
}

.flow__subtitle {
  margin-top: 20px;
  letter-spacing: -0.1rem;
  text-align: center;
  font-size: 18px;
  font-weight: bold;
}

.flow__content {
  margin-top: 60px;
}

.flow__items {
  width: 700px;
  margin-left: auto;
  margin-right: auto;
  max-width: 100%;
}

.flow__item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 2rem;
  border-top: 2px solid #64BFAA;
  position: relative;
}

.flow__item:not(:last-child) {
  padding-bottom: 45px;
}

.flow__item::after {
  content: "";
  position: absolute;
  bottom: 10%;
  left: 50%;
  transform: translateX(-50%);
  width: clamp(60px, 6vw, 86px);
  height: clamp(20px, 2.2vw, 30px);
  background: url(../../img/sc/flow-arrow.svg) no-repeat center center/contain;
}

.flow__item:last-child::after {
  display: none;
}

.flow__item .left {
  width: clamp(380px, 33vw, 470px);
}

.flow__item .left .head {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 1rem;
}

.flow__item .left .head .num {
  background: #64BFAA;
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(100px, 10vw, 140px);
  line-height: 1;
  font-size: clamp(18px, 1.8vw, 26px);
  font-weight: 500;
  font-family: "Inter", sans-serif;
  gap: 1rem;
  padding: 7px 2px;
}

.flow__item .left .head .num span {
  font-size: clamp(30px, 3.2vw, 60px);
  color: #fff;
}

.flow__item .left .head h3 {
  font-size: clamp(18px, 1.6vw, 20px);
  font-weight: 700;
}

.flow__item .left .body {
  margin-top: 10px;
}

.flow__item .left .body p {
  font-weight: 500;
  letter-spacing: -0.05rem;
  font-size: clamp(12px, 1.3vw, 14px);
}

.flow__item .right {
  width: clamp(160px, 14vw, 200px);
}

.flow__button {
  margin-top: 50px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .flow {
    padding: 80px 0px 50px;
  }

  .flow__title {
    font-size: clamp(22px, 4vw, 26px);
  }

  .flow__subtitle {
    font-size: 14px;
  }

  .flow__item {
    flex-direction: column;
    width: 100%;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
  }

  .flow__item:not(:last-child) {
    padding-bottom: 80px;
  }

  .flow__item .left {
    width: 100%;
  }

  .flow__item .left .body p {
    font-size: 15px;
  }

  .flow__item .right {
    width: 100%;
  }
}

/* flow */
/* contact*/
.contact {
  padding: 90px 0px 170px;
}

.contact__section {
  margin: 0 auto;
  width: 90%;
  max-width: 1010px;
}

.contact__title {
  text-align: center;
  padding-bottom: 14px;
  font-size: 36px;
  font-weight: bold;
  border-bottom: 5px solid #64BFAA;
}

.contact__subtitle {
  margin-top: 20px;
  letter-spacing: -0.1rem;
  text-align: center;
  font-size: 18px;
  font-weight: bold;
}

.contact__content {
  margin-top: 30px;
}

.contact__content p {
  text-align: center;
  font-size: clamp(14px, 1.3vw, 16px);
  line-height: 2.6;
}

.contact__button {
  margin-top: 50px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .contact {
    padding: 80px 0px 50px;
  }

  .contact__title {
    font-size: clamp(22px, 4vw, 26px);
  }

  .contact__subtitle {
    font-size: 16px;
  }

  .contact__content {
    margin-top: 30px;
  }

  .contact__content p {
    text-align: justify;
    line-height: 1.8;
    letter-spacing: -0.08rem;
  }
}

/* contact*/
/* line*/
.line {
  background: #F0F0F0;
  padding: 90px 0px 170px;
}

.line__section {
  margin: 0 auto;
  width: 90%;
  max-width: 1010px;
}

.line__title {
  text-align: center;
  padding-bottom: 14px;
  font-size: 36px;
  font-weight: bold;
  border-bottom: 5px solid #64BFAA;
}

.line__button {
  margin-top: 50px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .line {
    padding: 80px 0px 50px;
  }

  .line__title {
    font-size: clamp(19px, 4vw, 26px);
  }
}

/* line*/
/*----------------- sc faq -------------------*/
.sc-mv {
  margin-top: clamp(80px, 12vw, 117px);
  height: clamp(340px, 39vw, 592px);
  background: #BDE0D5;
  z-index: 1;
  position: relative;
}

@media (max-width: 768px) {
  .sc-mv {
    height: clamp(340px, 49vw, 360px);
  }
}

.sc-mv::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/bg-deco.webp) no-repeat center center/cover;
  z-index: -1;
}

@media (max-width: 768px) {
  .sc-mv::before {
    background: url(../img/bg-deco_sp.webp) no-repeat center center/cover;
  }
}

.sc-mv__img {
  width: clamp(80px, 8vw, 150px);
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 768px) {
  .sc-mv__img {
    width: clamp(80px, 15vw, 110px);
  }
}

.sc-mv__content {
  text-align: center;
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.sc-mv__content h1 {
  margin-top: 1.5rem;
  font-size: clamp(26px, 3vw, 46px);
  font-weight: 700;
}

@media (max-width: 768px) {
  .sc-mv__content h1 {
    font-size: clamp(20px, 5vw, 26px);
  }
}

.sc-mv__content--bottom {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: clamp(80px, 10vw, 152px);
  background: #F0F0F0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sc-mv__content--bottom p {
  text-align: center;
  font-size: clamp(14px, 1.4vw, 26px);
  font-weight: 500;
}

@media (max-width: 768px) {
  .sc-mv__content--bottom p {
    font-weight: 700;
    font-size: clamp(14px, 2vw, 16px);
  }
}

.sc-faq {
  margin-top: 100px;
}

.sc-faq__title {
  font-size: clamp(16px, 1.6vw, 19px);
  font-weight: 700;
  text-align: center;
  padding-bottom: 10px;
  border-bottom: 1px solid #333333;
}

.faq__content>.accordion .accordion__grid {
  margin-top: 0;
}

.sc-voice {
  margin-top: 100px;
  padding-bottom: 100px;
}

.sc-voice__box {
  padding-top: 50px;
}

.sc-voice__container {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  -moz-column-gap: 3rem;
  column-gap: 3rem;
  row-gap: 100px;
}

.sc-voice__container {
  text-align: center;
  margin: 0 auto;
  width: 90%;
  max-width: 1010px;
}

.background-stripe {
  background-image: repeating-linear-gradient(to bottom, #ffffff, #ffffff calc(700.11px + 31.17 * (100vw - 769px) / 1151), #f0f0f0 calc(700.11px + 31.17 * (100vw - 769px) / 1151), #f0f0f0 calc((700.11px + 31.17 * (100vw - 769px) / 1151) * 2));
}

@media screen and (max-width: 768px) {
  .sc-voice {
    margin-top: 0;
  }

  .sc-voice__box {
    padding-top: 30px;
  }

  .sc-voice__container {
    display: grid;
    grid-template-columns: 1fr;
    -moz-column-gap: 3rem;
    column-gap: 3rem;
    row-gap: 30px;
  }

  .background-stripe {
    background-image: repeating-linear-gradient(to bottom, #ffffff, #ffffff calc(1840.27px + 181.74 * (100vw - 330px) / 438), #f0f0f0 calc(1840.27px + 181.74 * (100vw - 330px) / 438), #f0f0f0 calc((1840.27px + 181.74 * (100vw - 330px) / 438) * 2));
  }
}