* {
  font-family: "Zen Kaku Gothic New", sans-serif;
}

body {
  color: #666;
}

a {
  width: inherit;
  height: inherit;
  display: inline-block;
}

img {
  width: 100%;
  height: auto;
  display: block;
}

.hp_spNone {
  display: none !important;
}

/*----------- header -----------*/
.ly_header {
  padding: 1.5625vw 2.03125vw;
  background: #fff;
}

.bl_header_logo {
  width: 36.5625vw;
}

/*----------- fv -----------*/
.ly_fv {
  background: url(../img/sp_fv_background.jpg) no-repeat center/cover;
  padding: 2.8125vw 0 6.25vw;
}

.bl_fv_ttl {
  width: 65.625vw;
  margin-left: 4.6875vw;
}

.bl_fv_catch {
  width: 62.5vw;
  margin: 6.875vw 0 0;
}

.bl_fv_btn {
  margin: 6.25vw auto 0;
}

/*----------- el_btn -----------*/
.el_btnWrap {
  width: 71.875vw;
}

.el_btn + .el_btn {
  margin-top: 3.125vw;
}
.el_btn a {
  display: block;
}

/*----------- about -----------*/
.ly_about {
  background: url(../img/sp_about_background.jpg) no-repeat center/cover;
  padding: 6.5625vw 0 12.96875vw;
  position: relative;
}
.ly_about::before {
  content: "";
  background: url(../img/sp_about_section-divider.png) no-repeat center/contain;
  width: 0.9375vw;
  height: 15.9375vw;
  display: inline-block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 50%);
}

.bl_about_main {
  width: 90.15625vw;
  margin: 0 auto;
}

/*----------- worries -----------*/
.ly_worries {
  padding: 10.9375vw 0 11.71875vw;
  background: #f2f2f2;
}

.bl_worries_ttl {
  width: 78.125vw;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.bl_worries_list {
  background: url(../img/sp_worries_background.png) no-repeat center/contain;
  width: 90.625vw;
  height: 135.15625vw;
  margin: -7.03125vw auto 0;
  padding: 13.28125vw 4.6875vw 0 3.4375vw;
}

.bl_worries_item {
  height: 26.5625vw;
  position: relative;
}
.bl_worries_item + .bl_worries_item {
  margin-top: 3.125vw;
}

.bl_worries_body {
  position: absolute;
  top: 4.0625vw;
  left: 23.125vw;
  padding-right: 1.5625vw;
}

.bl_worries_catch {
  display: inline;
  font-size: 4.21875vw;
  font-weight: bold;
  letter-spacing: -0.03em;
  color: #12376c;
  line-height: 1.4814814815;
  background: linear-gradient(transparent calc(100% - 1.71875vw), #ffffcc calc(100% - 1.71875vw));
}

.bl_worries_txt {
  font-size: 3.59375vw;
  line-height: 1.652173913;
  letter-spacing: -0.03em;
  color: #336699;
  margin-top: 0.9375vw;
}

/*----------- strengths -----------*/
.ly_strengths {
  background: url(../img/sp_strengths_background.jpg) no-repeat center top/cover;
  padding: 9.375vw 0;
}

.bl_strengths_ttl {
  width: 80.625vw;
  margin: 0 auto;
}

.bl_strengths_list {
  width: 90.46875vw;
  margin: 7.8125vw auto 0;
}

.bl_strengths_item {
  height: 41.25vw;
  position: relative;
  z-index: 1;
  padding: 5.3125vw 4.6875vw 4.6875vw 39.0625vw;
}
.bl_strengths_item + .bl_strengths_item {
  margin-top: 3.90625vw;
}

.bl_strengths_img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
}
.bl_strengths_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.bl_strengths_itemTtl {
  font-size: 4.0625vw;
  font-weight: 700;
  line-height: 1.9230769231;
  color: #ffffcc;
  background: #3273cc;
  border-radius: 50vmax;
  text-align: center;
}

.bl_strengths_itemWrapper {
  text-align: center;
  margin-top: 2.34375vw;
}

.bl_strengths_itemTxt {
  font-size: 3.75vw;
  line-height: 1.3333333333;
  color: #336699;
}
.bl_strengths_itemTxt span {
  font-weight: bold;
  display: inline-block;
  background: #feedea;
  padding: 0 0.46875vw;
  border-radius: 0.78125vw;
  margin: 0.46875vw 0;
  letter-spacing: -0.03em;
}

/*----------- service -----------*/
.ly_service {
  background: url(../img/sp_service_background.jpg) no-repeat center/cover;
  padding: 12.1875vw 0 13.59375vw;
}

.bl_service_ttl {
  text-align: center;
  width: 67.34375vw;
  margin: 0 auto;
}

.bl_service_slider {
  margin-top: 6.5625vw;
}

.bl_service_list {
  display: block;
}

.bl_service_slide {
  padding: 0 6.25vw;
}

.bl_service_item {
  height: 41.25vw;
  background: url(../img/sp_service_list_background.png) no-repeat center/100% 100%;
  padding: 4.375vw 3.90625vw 4.375vw 9.375vw;
}

.bl_service_body {
  width: 100%;
}

.bl_service_head {
  display: flex;
  align-items: center;
  gap: 2.34375vw;
}

.bl_service_icon {
  width: 12.5vw;
  flex-shrink: 0;
}

.bl_service_itemTtl {
  font-size: 4.6875vw;
  font-weight: 700;
  line-height: 1.5333333333;
  color: #12376c;
}

.bl_service_tagList {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25vw;
  margin-top: 1.25vw;
}

.bl_service_tag {
  font-size: 3.59375vw;
  line-height: 1;
  color: #336699;
  background: #dce9fb;
  padding: 0.78125vw 1.5625vw;
  letter-spacing: 0.05em;
  border-radius: 0.78125vw;
}

.bl_service_slider .splide__pagination {
  bottom: -6.25vw;
}
.bl_service_slider .splide__pagination__page {
  width: 2.1875vw;
  height: 2.1875vw;
  background: #b3cbd5;
  opacity: 1;
  margin-left: 2.34375vw;
  margin-right: 2.34375vw;
}
.bl_service_slider .splide__pagination__page.is-active {
  background: #5092eb;
  transform: scale(1);
}
.bl_service_slider .splide__arrows {
  display: block;
}
.bl_service_slider .splide__arrow {
  width: 10.9375vw;
  height: 47.5vw;
  background: url(../img/sp_service_arrow.png) no-repeat center/contain;
  opacity: 1;
  border-radius: 0;
  top: 43%;
  transform: translateY(-50%);
}
.bl_service_slider .splide__arrow svg {
  display: none;
}
.bl_service_slider .splide__arrow--prev {
  left: 0;
}
.bl_service_slider .splide__arrow--next {
  transform: translateY(-50%) scaleX(-1);
  right: 0;
}

/*----------- price -----------*/
.ly_price {
  padding: 9.375vw 0;
  background: #f2f2f2;
}

.bl_price_ttl {
  width: 78.59375vw;
  margin: 0 auto;
}

.bl_price_box {
  margin: 6.25vw 0 0 5vw;
  background: #fff;
  border-radius: 2.34375vw 0 0 2.34375vw;
  padding: 6.25vw 0 9.6875vw;
}

.bl_price_tableWrap {
  position: relative;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding: 1.5625vw 0 0 4.375vw;
}

.bl_price_table {
  width: 168.75vw;
  flex-shrink: 0;
}

.bl_price_hint {
  position: absolute;
  top: 0;
  left: 0.3125vw;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  background: rgba(255, 255, 255, 0.3);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  z-index: 10;
  transition: opacity 1s;
}
.bl_price_hint img {
  width: 60.15625vw;
  position: fixed;
  top: 25vw;
  left: 14.6875vw;
}
.bl_price_hint.is_hidden {
  opacity: 0;
  pointer-events: none;
}

.bl_price_txt {
  font-size: 3.4375vw;
  line-height: 1.3636363636;
  margin-top: 4.6875vw;
  padding: 0 3.90625vw 0 8.125vw;
  text-indent: -1em;
}
.bl_price_txt + .bl_price_txt {
  margin-top: 0;
}

.bl_price_btn {
  margin: 7.1875vw 0 0 9.0625vw;
}

/*----------- flow -----------*/
.ly_flow {
  background: url(../img/sp_flow_background.png) no-repeat center/cover;
  padding: 9.375vw 0;
}

.bl_flow_ttl {
  width: 35.15625vw;
  margin: 0 auto;
}

.bl_flow_list {
  width: 90.46875vw;
  margin: 7.8125vw auto 0;
}

.bl_flow_item {
  position: relative;
}

.bl_flow_conts {
  position: absolute;
  top: 6.25vw;
  left: 39.0625vw;
  padding-right: 4.6875vw;
}

.bl_flow_itemTtl {
  font-size: 4.0625vw;
  font-weight: 500;
  color: #ffffcc;
  background: #3273cc;
  border-radius: 50vmax;
  text-align: center;
  padding: 0.9375vw;
  letter-spacing: -0.03em;
}

.bl_flow_itemTxt {
  font-size: 3.75vw;
  line-height: 1.5833333333;
  margin: 2.5vw -0.78125vw 0 0;
  letter-spacing: -0.03em;
}

/*----------- faq -----------*/
.ly_faq {
  padding: 12.5vw 0 9.375vw;
  background: #f2f2f2;
}

.bl_faq_ttl {
  width: 38.75vw;
  margin: 0 auto;
}

.bl_faq_list {
  width: 90.625vw;
  margin: 8.28125vw auto 0;
}

.bl_faq_item + .bl_faq_item {
  margin-top: 3.125vw;
}

.bl_faq_q {
  min-height: 17.1875vw;
  display: flex;
  align-items: center;
  background: #5092eb;
  border-radius: 1.25vw;
  padding: 2.65625vw 9.375vw 3.125vw 14.6875vw;
  position: relative;
  font-size: 4.0625vw;
  font-weight: 700;
  line-height: 1.3846153846;
  letter-spacing: 0.06em;
  color: #fff;
}
.bl_faq_q:hover {
  opacity: 0.8;
}
.bl_faq_q::before {
  content: "";
  width: 8.125vw;
  aspect-ratio: 1/1;
  background: url(../img/sp_faq_Qicon.png) no-repeat center/contain;
  position: absolute;
  left: 3.125vw;
  top: 50%;
  transform: translateY(-50%);
}
.bl_faq_q::after {
  content: "";
  width: 3.90625vw;
  aspect-ratio: 1/1;
  background: url(../img/sp_faq_open.png) no-repeat center/contain;
  position: absolute;
  right: 3.125vw;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.3s;
}
.bl_faq_q.open::after {
  background: url(../img/sp_faq_close.png) no-repeat center/contain;
}

.bl_faq_conts {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s;
}

.bl_faq_contsInner {
  margin-top: 2.8125vw;
  padding: 3.4375vw 7.8125vw;
  background: #fff;
  border-radius: 1.25vw;
}

.bl_faq_a {
  font-size: 3.75vw;
  line-height: 1.5833333333;
  letter-spacing: 0.06em;
  color: #333;
}

.bl_faq_btn {
  margin: 9.375vw auto 0;
}

/*----------- footer -----------*/
.bl_footer_main {
  padding: 7.03125vw 3.4375vw 6.25vw;
}

.bl_footer_logo {
  width: 49.21875vw;
  margin: 0 auto;
}

.bl_footer_info {
  color: #12376c;
  font-size: 3.4375vw;
  font-weight: 500;
  line-height: 1.8181818182;
  margin-top: 4.6875vw;
  letter-spacing: -0.03em;
}

.bl_footer_copyright {
  background: #12376c;
  text-align: center;
}
.bl_footer_copyright small {
  color: #5092eb;
  font-size: 2.34375vw;
  font-weight: 500;
  line-height: 7.8125vw;
  letter-spacing: 0.08em;
}

/*----------- fixed -----------*/
.ly_fixed {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 99;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  opacity: 0;
  pointer-events: none;
  transition: 0.3s;
}

.bl_fixed_btnWrap {
  display: flex;
  gap: 0.46875vw;
}

.bl_fixed_btn {
  width: 47.8125vw;
}
.bl_fixed_btn a {
  display: block;
}
/*# sourceMappingURL=top_sp.css.map */
