@charset "UTF-8";
.cfg_wrap {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック Medium", "Yu Gothic Medium", "メイリオ", Meiryo, sans-serif;
  color: #333;
  line-height: 1;
}
.cfg_wrap div, .cfg_wrap span, .cfg_wrap iframe, .cfg_wrap h1, .cfg_wrap h2, .cfg_wrap h3, .cfg_wrap h4, .cfg_wrap h5, .cfg_wrap h6, .cfg_wrap p, .cfg_wrap img, .cfg_wrap small, .cfg_wrap strong, .cfg_wrap b, .cfg_wrap dl, .cfg_wrap dt, .cfg_wrap dd, .cfg_wrap ol, .cfg_wrap ul, .cfg_wrap li,
.cfg_wrap form, .cfg_wrap label, .cfg_wrap legend, .cfg_wrap table, .cfg_wrap tbody, .cfg_wrap tfoot, .cfg_wrap thead, .cfg_wrap tr, .cfg_wrap th, .cfg_wrap td, .cfg_wrap footer, .cfg_wrap header, .cfg_wrap menu, .cfg_wrap nav, .cfg_wrap section, .cfg_wrap video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: bottom;
  background: transparent;
}
.cfg_wrap ul li {
  list-style: none;
}
.cfg_wrap a {
  margin: 0;
  padding: 0;
  color: #333;
  text-decoration: none;
  vertical-align: baseline;
}
.cfg_wrap a:hover {
  opacity: 0.7;
}
.cfg_wrap table {
  border-spacing: 0;
}
.cfg_wrap img {
  width: 100%;
}
.cfg_wrap button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0;
  border: none;
  background: transparent;
}
.cfg_wrap .inner {
  max-width: 750px;
  margin: 0 auto;
}
.cfg_wrap .rel {
  position: relative;
}
.cfg_wrap .float_area {
  width: 100%;
  padding: 10px 0;
  background: rgba(255, 255, 255, 0.8);
  position: fixed;
  left: 0;
  bottom: 0;
  z-index: 9999;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .float_area {
    padding: 2.6666666667vw 0;
  }
}
.cfg_wrap .float_area .float_btn {
  zoom: 0.7;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .float_area .float_btn {
    zoom: 1;
  }
}
.cfg_wrap .float_area .float_btn a {
  display: block;
  width: 650px;
  height: 120px;
  margin: 0 auto;
  padding-top: 22px;
  padding-left: 70px;
  border-radius: 60px;
  background: #DC5A75;
  box-sizing: border-box;
  position: relative;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .float_area .float_btn a {
    width: 86.6666666667vw;
    height: 16vw;
    padding-top: 2.9333333333vw;
    padding-left: 9.3333333333vw;
    border-radius: 8vw;
  }
}
.cfg_wrap .float_area .float_btn a::before {
  content: "";
  display: block;
  width: 50px;
  height: 44px;
  background: url(../img/icon_cart.svg) no-repeat top left/100%;
  transform: translateY(-50%);
  position: absolute;
  top: 50%;
  left: 40px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .float_area .float_btn a::before {
    width: 6.6666666667vw;
    height: 5.8666666667vw;
    left: 5.3333333333vw;
  }
}
.cfg_wrap .float_area .float_btn a .free {
  text-align: center;
}
.cfg_wrap .float_area .float_btn a .free span {
  color: #fff;
  font-size: 26px;
  letter-spacing: 0.2em;
  padding: 0 20px;
  position: relative;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .float_area .float_btn a .free span {
    font-size: 3.4666666667vw;
    padding: 0 2.6666666667vw;
  }
}
.cfg_wrap .float_area .float_btn a .free span::before, .cfg_wrap .float_area .float_btn a .free span::after {
  content: "";
  display: block;
  width: 2px;
  height: 22px;
  background: #fff;
  position: absolute;
  bottom: 5px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .float_area .float_btn a .free span::before, .cfg_wrap .float_area .float_btn a .free span::after {
    width: 0.2666666667vw;
    height: 2.9333333333vw;
    bottom: 0.6666666667vw;
  }
}
.cfg_wrap .float_area .float_btn a .free span::before {
  transform: rotate(-25deg);
  left: 0;
}
.cfg_wrap .float_area .float_btn a .free span::after {
  transform: rotate(25deg);
  right: 0;
}
.cfg_wrap .float_area .float_btn a .text {
  color: #fff;
  font-size: 26px;
  line-height: 1;
  text-align: center;
  letter-spacing: 0.1em;
  margin-top: 10px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .float_area .float_btn a .text {
    font-size: 3.4666666667vw;
    margin-top: 1.3333333333vw;
  }
}
.cfg_wrap .float_area .float_btn a .text strong {
  font-size: 34px;
  font-weight: 400;
  vertical-align: -2px;
  letter-spacing: 0.19em;
  margin-left: 3px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .float_area .float_btn a .text strong {
    font-size: 4.5333333333vw;
    vertical-align: -0.2666666667vw;
    margin-left: 0.4vw;
  }
}
.cfg_wrap .fv {
  background: url("../img/fv_bg.jpg") no-repeat top center;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .fv {
    background-size: 266.6666666667vw auto;
  }
}
.cfg_wrap .fv .inner .fv_text {
  position: absolute;
  left: 50px;
  bottom: 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .fv .inner .fv_text {
    left: 6.6666666667vw;
  }
}
.cfg_wrap .fv .inner .fv_text span {
  display: inline-block;
  color: #5DB24B;
  font-size: 28px;
  line-height: 48px;
  letter-spacing: 0.22em;
  height: 50px;
  padding: 0 22px;
  border-radius: 30px;
  background: #fff;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .fv .inner .fv_text span {
    font-size: 3.7333333333vw;
    line-height: 6.4vw;
    height: 6.6666666667vw;
    padding: 0 2.9333333333vw;
    border-radius: 4vw;
  }
}
.cfg_wrap .fv .inner .fv_text span:first-child {
  margin-bottom: 10px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .fv .inner .fv_text span:first-child {
    margin-bottom: 1.3333333333vw;
  }
}
.cfg_wrap .worries {
  background: url("../img/worries_bg.png") no-repeat top center;
  height: 2300px;
  margin: -164px 0;
  position: relative;
  z-index: 999;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries {
    background-size: 266.6666666667vw auto;
    height: 306.6666666667vw;
    margin: -21.8666666667vw 0;
  }
}
.cfg_wrap .worries .inner .worries_list_box {
  padding: 430px 0 80px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box {
    padding: 57.3333333333vw 0 10.6666666667vw;
  }
}
.cfg_wrap .worries .inner .worries_list_box .tit {
  color: #4D4D4D;
  font-size: 50px;
  text-align: center;
  font-weight: 400;
  letter-spacing: 0.28em;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box .tit {
    font-size: 6.6666666667vw;
  }
}
.cfg_wrap .worries .inner .worries_list_box .tit strong {
  font-size: 53px;
  font-weight: 700;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box .tit strong {
    font-size: 7.0666666667vw;
  }
}
.cfg_wrap .worries .inner .worries_list_box .worries_list_box_in {
  height: 800px;
  margin-top: 37px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box .worries_list_box_in {
    height: 106.6666666667vw;
    margin-top: 4.9333333333vw;
  }
}
.cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .top_text {
  color: #fff;
  font-size: 40px;
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.28em;
  padding: 70px 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .top_text {
    font-size: 5.3333333333vw;
    padding: 9.3333333333vw 0;
  }
}
.cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .top_text span {
  padding-left: 10px;
  margin-right: 10px;
  background: linear-gradient(transparent 12%, #4D4D4D 12% 97%, transparent 97%);
  position: relative;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .top_text span {
    padding-left: 1.3333333333vw;
    margin-right: 1.3333333333vw;
  }
}
.cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .top_text span::before {
  content: "";
  display: block;
  width: 194px;
  height: 1px;
  margin: 0 auto;
  background: #fff;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -8px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .top_text span::before {
    width: 25.8666666667vw;
    bottom: -1.0666666667vw;
  }
}
.cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .worries_list {
  margin-left: 90px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .worries_list {
    margin-left: 12vw;
  }
}
.cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .worries_list li {
  color: #fff;
  font-size: 28px;
  line-height: 1.75;
  letter-spacing: 0.1em;
  padding-left: 50px;
  position: relative;
}
.cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .worries_list li:not(:first-child) {
  margin-top: 40px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .worries_list li:not(:first-child) {
    margin-top: 5.3333333333vw;
  }
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .worries_list li {
    font-size: 3.7333333333vw;
    padding-left: 6.6666666667vw;
  }
}
.cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .worries_list li::before {
  content: "";
  display: block;
  width: 27px;
  height: 27px;
  background: url(../img/worries_icon_check.svg) no-repeat top left/100%;
  position: absolute;
  top: 13px;
  left: 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .worries_list li::before {
    width: 3.6vw;
    height: 3.6vw;
    top: 1.7333333333vw;
  }
}
.cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .worries_list li span {
  color: #4D4D4D;
  font-weight: 500;
  margin-right: 10px;
  padding: 0 5px;
  background: linear-gradient(transparent 12%, #fff 12% 97%, transparent 97%);
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box .worries_list_box_in .worries_list li span {
    margin-right: 1.3333333333vw;
    padding: 0 0.6666666667vw;
  }
}
.cfg_wrap .worries .inner .worries_list_box .bot_text {
  color: #fff;
  font-size: 26px;
  text-align: center;
  letter-spacing: 0.12em;
  margin: 20px 0 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_list_box .bot_text {
    font-size: 3.4666666667vw;
    margin: 2.6666666667vw 0 0;
  }
}
.cfg_wrap .worries .inner .worries_cause .top_text {
  color: #B98278;
  font-size: 40px;
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.28em;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_cause .top_text {
    font-size: 5.3333333333vw;
  }
}
.cfg_wrap .worries .inner .worries_cause .top_text span {
  color: #fff;
  margin-right: 10px;
  padding: 0 10px;
  background: linear-gradient(transparent 12%, #4D4D4D 12% 100%, transparent 100%);
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_cause .top_text span {
    margin-right: 1.3333333333vw;
    padding: 0 1.3333333333vw;
  }
}
.cfg_wrap .worries .inner .worries_cause .box1 {
  display: flex;
  justify-content: center;
  gap: 30px;
  margin: 40px 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_cause .box1 {
    gap: 4vw;
    margin: 5.3333333333vw 0;
  }
}
.cfg_wrap .worries .inner .worries_cause .box1 .img {
  width: 180px;
  margin-top: 10px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_cause .box1 .img {
    width: 24vw;
    margin-top: 1.3333333333vw;
  }
}
.cfg_wrap .worries .inner .worries_cause .box1 .text {
  color: #4D4D4D;
  font-size: 26px;
  line-height: 2;
  letter-spacing: 0.12em;
  width: 415px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_cause .box1 .text {
    font-size: 3.4666666667vw;
    width: 55.3333333333vw;
  }
}
.cfg_wrap .worries .inner .worries_cause .box2 {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 670px;
  height: 220px;
  margin: 0 auto;
  border: 11px solid #fff;
  border-radius: 150px;
  background: rgba(255, 255, 255, 0.7);
  box-sizing: border-box;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_cause .box2 {
    width: 89.3333333333vw;
    height: 29.3333333333vw;
    border-width: 1.4666666667vw;
    border-radius: 20vw;
  }
}
.cfg_wrap .worries .inner .worries_cause .box2 p {
  color: #4D4D4D;
  font-size: 30px;
  line-height: 50px;
  text-align: center;
  letter-spacing: 0.28em;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .worries .inner .worries_cause .box2 p {
    font-size: 4vw;
    line-height: 6.6666666667vw;
  }
}
.cfg_wrap .worries .inner .worries_cause .box2 p strong {
  color: #5DB24B;
  font-size: 120%;
  font-weight: 700;
}
.cfg_wrap .about {
  background: url("../img/about_bg.jpg") no-repeat top center;
  height: 2104px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .about {
    background-size: 266.6666666667vw auto;
    height: 280.5333333333vw;
  }
}
.cfg_wrap .about .inner .about_tit {
  font-size: 40px;
  line-height: 1.4;
  text-align: center;
  font-weight: 400;
  letter-spacing: 0.08em;
  margin-bottom: 432px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .about .inner .about_tit {
    font-size: 5.3333333333vw;
    margin-bottom: 57.6vw;
  }
}
.cfg_wrap .about .inner .about_tit strong {
  font-size: 60px;
  font-weight: 700;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .about .inner .about_tit strong {
    font-size: 8vw;
  }
}
.cfg_wrap .about .inner .about_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 152px 18px;
  margin-bottom: 70px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .about .inner .about_list {
    gap: 20.2666666667vw 2.4vw;
    margin-bottom: 9.3333333333vw;
  }
}
.cfg_wrap .about .inner .about_list li {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 332px;
  height: 205px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .about .inner .about_list li {
    width: 44.2666666667vw;
    height: 27.3333333333vw;
  }
}
.cfg_wrap .about .inner .about_list li:nth-child(2) p strong {
  color: #FFDA66;
}
.cfg_wrap .about .inner .about_list li p {
  color: #fff;
  font-size: 30px;
  line-height: 48px;
  text-align: center;
  letter-spacing: 0.14em;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .about .inner .about_list li p {
    font-size: 4vw;
    line-height: 6.4vw;
  }
}
.cfg_wrap .about .inner .about_list li p strong {
  color: #FFFF96;
  font-size: 130%;
  font-weight: 700;
}
.cfg_wrap .about .inner .about_text {
  font-size: 26px;
  line-height: 2;
  text-align: center;
  letter-spacing: 0.18em;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .about .inner .about_text {
    font-size: 3.4666666667vw;
  }
}
.cfg_wrap .top_offer {
  background: url("../img/top_offer_bg.jpg") no-repeat top center;
  height: 940px;
  padding-top: 70px;
  box-sizing: border-box;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .top_offer {
    background-size: 266.6666666667vw auto;
    height: 125.3333333333vw;
    padding-top: 9.3333333333vw;
  }
}
.cfg_wrap .offer01 {
  width: 670px;
  margin: 0 auto;
  padding-bottom: 50px;
  background: #fff;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer01 {
    width: 89.3333333333vw;
    padding-bottom: 6.6666666667vw;
  }
}
.cfg_wrap .offer01 .tit {
  color: #fff;
  font-size: 40px;
  line-height: 78px;
  text-align: center;
  font-weight: 400;
  letter-spacing: 0.22em;
  height: 80px;
  background: #E66F7E;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer01 .tit {
    font-size: 5.3333333333vw;
    line-height: 10.4vw;
    height: 10.6666666667vw;
  }
}
.cfg_wrap .offer01 .name {
  color: #4D4D4D;
  font-size: 28px;
  letter-spacing: 0.12em;
  position: absolute;
  top: 53px;
  left: 30px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer01 .name {
    font-size: 3.7333333333vw;
    top: 7.0666666667vw;
    left: 4vw;
  }
}
.cfg_wrap .offer01 .free {
  color: #5DB24B;
  font-size: 26px;
  line-height: 58px;
  text-align: center;
  letter-spacing: 0.12em;
  width: 600px;
  height: 60px;
  margin: 0 auto;
  background: #D4F4DD;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer01 .free {
    font-size: 3.4666666667vw;
    line-height: 7.7333333333vw;
    width: 80vw;
    height: 8vw;
  }
}
.cfg_wrap .offer01 .free strong {
  font-size: 37px;
  font-weight: 700;
  vertical-align: -3px;
  margin-left: 10px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer01 .free strong {
    font-size: 4.9333333333vw;
    vertical-align: -0.4vw;
    margin-left: 1.3333333333vw;
  }
}
.cfg_wrap .offer01 .campaign {
  color: #5DB24B;
  font-size: 28px;
  text-align: center;
  letter-spacing: 0.22em;
  margin: 40px 0 20px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer01 .campaign {
    font-size: 3.7333333333vw;
    margin: 5.3333333333vw 0 2.6666666667vw;
  }
}
.cfg_wrap .offer01 .offer_btn a {
  display: block;
  width: 560px;
  height: 120px;
  margin: 0 auto;
  padding-top: 40px;
  padding-left: 175px;
  border-radius: 60px;
  background: #DC5A75;
  box-sizing: border-box;
  position: relative;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer01 .offer_btn a {
    width: 74.6666666667vw;
    height: 16vw;
    padding-top: 5.3333333333vw;
    padding-left: 23.3333333333vw;
    border-radius: 8vw;
  }
}
.cfg_wrap .offer01 .offer_btn a::before {
  content: "";
  display: block;
  width: 60px;
  height: 52px;
  background: url(../img/icon_cart.svg) no-repeat top left/100%;
  transform: translateY(-50%);
  position: absolute;
  top: 50%;
  left: 75px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer01 .offer_btn a::before {
    width: 8vw;
    height: 6.9333333333vw;
    left: 10vw;
  }
}
.cfg_wrap .offer01 .offer_btn a span {
  color: #fff;
  font-size: 36px;
  letter-spacing: 0.19em;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer01 .offer_btn a span {
    font-size: 4.8vw;
  }
}
.cfg_wrap .theme {
  background: url("../img/theme_bg.jpg") no-repeat top center;
  height: 4040px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme {
    background-size: 266.6666666667vw auto;
    height: 538.6666666667vw;
  }
}
.cfg_wrap .theme .inner .theme_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list {
    gap: 2.6666666667vw;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box {
  width: 330px;
  height: 800px;
  border-radius: 20px;
  position: relative;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box {
    width: 44vw;
    height: 106.6666666667vw;
    border-radius: 2.6666666667vw;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .tit {
  color: #fff;
  font-size: 33px;
  text-align: center;
  font-weight: 500;
  letter-spacing: 0.1em;
  height: 150px;
  padding-top: 30px;
  border-radius: 20px 20px 0 0;
  box-sizing: border-box;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .tit {
    font-size: 4.4vw;
    height: 20vw;
    padding-top: 4vw;
    border-radius: 2.6666666667vw 2.6666666667vw 0 0;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .img {
  width: 220px;
  margin: -70px auto 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .img {
    width: 29.3333333333vw;
    margin: -9.3333333333vw auto 0;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .reco_list {
  width: 260px;
  margin: 0 auto;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .reco_list {
    width: 34.6666666667vw;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .reco_list li:nth-child(1) {
  padding: 10px 0 27px;
  border-bottom: 2px dotted rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .reco_list li:nth-child(1) {
    padding: 1.3333333333vw 0 3.6vw;
    border-bottom-width: 0.2666666667vw;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .reco_list li:nth-child(2) {
  padding: 27px 0 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .reco_list li:nth-child(2) {
    padding: 3.6vw 0 0;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .reco_list li p {
  font-size: 26px;
  line-height: 1.38;
  letter-spacing: 0.05em;
  padding-left: 33px;
  position: relative;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .reco_list li p {
    font-size: 3.4666666667vw;
    padding-left: 4.4vw;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .reco_list li p::before {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background: url(../img/theme_icon_check.svg) no-repeat top left/100%;
  position: absolute;
  top: 10px;
  left: 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .reco_list li p::before {
    width: 2.6666666667vw;
    height: 2.6666666667vw;
    top: 1.3333333333vw;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .open_modal {
  display: block;
  font-size: 26px;
  line-height: 90px;
  text-align: center;
  letter-spacing: 0.06em;
  width: 260px;
  height: 90px;
  margin: 0 auto;
  padding-right: 15px;
  border-radius: 50px;
  background: #fff;
  cursor: pointer;
  box-sizing: border-box;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 50px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .open_modal {
    font-size: 3.4666666667vw;
    line-height: 12vw;
    width: 34.6666666667vw;
    height: 12vw;
    padding-right: 2vw;
    border-radius: 6.6666666667vw;
    bottom: 6.6666666667vw;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .open_modal::before {
  content: "";
  display: block;
  border: 13px solid transparent;
  box-sizing: border-box;
  transform: translateY(-50%);
  position: absolute;
  top: 50%;
  right: 5px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .open_modal::before {
    border-width: 1.7333333333vw;
    right: 0.6666666667vw;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .open_modal:hover {
  opacity: 0.8;
}
.cfg_wrap .theme .inner .theme_list .theme_box .modal {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 99999;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.6);
}
.cfg_wrap .theme .inner .theme_list .theme_box .modal .modal_content {
  max-width: 650px;
  max-height: 90vh;
  overflow-y: auto;
  margin: 50px auto;
  box-sizing: border-box;
  position: relative;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .modal .modal_content {
    max-width: 86.6666666667vw;
    margin: 6.6666666667vw auto 0;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .modal .modal_content .close {
  width: 140px;
  cursor: pointer;
  position: absolute;
  top: 0;
  right: 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .modal .modal_content .close {
    width: 18.6666666667vw;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .modal .modal_content h4 {
  color: #fff;
  font-size: 30px;
  line-height: 58px;
  text-align: center;
  letter-spacing: 0.15em;
  width: 550px;
  height: 60px;
  margin: 145px auto 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .modal .modal_content h4 {
    font-size: 4vw;
    line-height: 7.7333333333vw;
    width: 73.3333333333vw;
    height: 8vw;
    margin: 19.3333333333vw auto 0;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .modal .modal_content .modal_list {
  font-size: 26px;
  line-height: 2;
  letter-spacing: 0.05em;
  margin: 40px 0 55px 50px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .modal .modal_content .modal_list {
    font-size: 3.4666666667vw;
    margin: 5.3333333333vw 0 7.3333333333vw 6.6666666667vw;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box .modal .modal_content .modal_img {
  filter: drop-shadow(10px 10px 10px rgba(0, 0, 0, 0.15));
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box .modal .modal_content .modal_img {
    filter: drop-shadow(1.3333333333vw 1.3333333333vw 1.3333333333vw rgba(0, 0, 0, 0.15));
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box.box01 {
  background: #FFBE83;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box01 .tit {
  background: #FFA357;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box01 .open_modal {
  color: #FFA357;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box01 .open_modal::before {
  border-left: 13px solid #FFA357;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box.box01 .open_modal::before {
    border-left: 1.7333333333vw solid #FFA357;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box.box01 .modal .modal_content {
  background: #FFF0E0;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box01 .modal .modal_content h4 {
  background: #FFA357;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box02 {
  background: #FFC2D9;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box02 .tit {
  background: #F484A9;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box02 .open_modal {
  color: #F484A9;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box02 .open_modal::before {
  border-left: 13px solid #F484A9;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box.box02 .open_modal::before {
    border-left: 1.7333333333vw solid #F484A9;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box.box02 .modal .modal_content {
  background: #FCE9ED;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box02 .modal .modal_content h4 {
  background: #F484A9;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box03 {
  background: #E2D0FC;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box03 .tit {
  background: #B38AE2;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box03 .open_modal {
  color: #B38AE2;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box03 .open_modal::before {
  border-left: 13px solid #B38AE2;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box.box03 .open_modal::before {
    border-left: 1.7333333333vw solid #B38AE2;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box.box03 .modal .modal_content {
  background: #F2EBF7;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box03 .modal .modal_content h4 {
  background: #B38AE2;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box04 {
  background: #FFBDAE;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box04 .tit {
  background: #EF9381;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box04 .open_modal {
  color: #EF9381;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box04 .open_modal::before {
  border-left: 13px solid #EF9381;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box.box04 .open_modal::before {
    border-left: 1.7333333333vw solid #EF9381;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box.box04 .modal .modal_content {
  background: #FCECE7;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box04 .modal .modal_content h4 {
  background: #EF9381;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box05 {
  background: #CBF4C1;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box05 .tit {
  background: #5DB24B;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box05 .open_modal {
  color: #67C98F;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box05 .open_modal::before {
  border-left: 13px solid #67C98F;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box.box05 .open_modal::before {
    border-left: 1.7333333333vw solid #67C98F;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box.box05 .modal .modal_content {
  background: #EFFFEB;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box05 .modal .modal_content h4 {
  background: #5DB24B;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box06 {
  background: #BDE9F4;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box06 .tit {
  background: #68D2DD;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box06 .open_modal {
  color: #68D2DD;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box06 .open_modal::before {
  border-left: 13px solid #68D2DD;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box.box06 .open_modal::before {
    border-left: 1.7333333333vw solid #68D2DD;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box.box06 .modal .modal_content {
  background: #E5F4F9;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box06 .modal .modal_content h4 {
  background: #68D2DD;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box07 {
  height: 760px;
  background: #C9F4EB;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box.box07 {
    height: 101.3333333333vw;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box.box07 .tit {
  background: #5BCEB8;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box07 .open_modal {
  color: #5BCEB8;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box07 .open_modal::before {
  border-left: 13px solid #5BCEB8;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .theme .inner .theme_list .theme_box.box07 .open_modal::before {
    border-left: 1.7333333333vw solid #5BCEB8;
  }
}
.cfg_wrap .theme .inner .theme_list .theme_box.box07 .modal .modal_content {
  background: #E7F9F6;
}
.cfg_wrap .theme .inner .theme_list .theme_box.box07 .modal .modal_content h4 {
  background: #5BCEB8;
}
.cfg_wrap .point_top {
  background: url("../img/point_top_bg.jpg") no-repeat top center;
  height: 830px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point_top {
    background-size: 266.6666666667vw auto;
    height: 110.6666666667vw;
  }
}
.cfg_wrap .point_top .inner {
  position: relative;
}
.cfg_wrap .point_top .inner .top_text {
  color: #fff;
  font-size: 35px;
  text-align: center;
  letter-spacing: 0.2em;
  position: absolute;
  top: 145px;
  left: 0;
  right: 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point_top .inner .top_text {
    font-size: 4.6666666667vw;
    top: 19.3333333333vw;
  }
}
.cfg_wrap .point_top .inner .text {
  color: #4D4D4D;
  font-size: 26px;
  line-height: 2;
  text-align: center;
  letter-spacing: 0.12em;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point_top .inner .text {
    font-size: 3.4666666667vw;
  }
}
.cfg_wrap div[class^=point0] .inner .tit_icon {
  width: 180px;
  margin: 0 auto;
}
@media screen and (max-width: 750px) {
  .cfg_wrap div[class^=point0] .inner .tit_icon {
    width: 24vw;
  }
}
.cfg_wrap div[class^=point0] .inner .point_tit {
  color: #4D4D4D;
  font-size: 50px;
  line-height: 70px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.08em;
  margin: 35px 0 50px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap div[class^=point0] .inner .point_tit {
    font-size: 6.6666666667vw;
    line-height: 9.3333333333vw;
    margin: 4.6666666667vw 0 6.6666666667vw;
  }
}
.cfg_wrap div[class^=point0] .inner .point_tit span {
  font-size: 85%;
  font-weight: 500;
}
.cfg_wrap div[class^=point0] .inner .top_text {
  font-size: 26px;
  line-height: 2;
  text-align: center;
  letter-spacing: 0.12em;
}
@media screen and (max-width: 750px) {
  .cfg_wrap div[class^=point0] .inner .top_text {
    font-size: 3.4666666667vw;
  }
}
.cfg_wrap .point01 {
  background: url("../img/point01_bg.jpg") no-repeat top center;
  height: 3231px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point01 {
    background-size: 266.6666666667vw auto;
    height: 430.8vw;
  }
}
.cfg_wrap .point01 .inner .img01 {
  margin-top: 5px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point01 .inner .img01 {
    margin-top: 0.6666666667vw;
  }
}
.cfg_wrap .point01 .inner .bot_img {
  width: 426px;
  position: absolute;
  right: 375px;
  bottom: 16px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point01 .inner .bot_img {
    width: 56.8vw;
    right: 50vw;
    bottom: 2.1333333333vw;
  }
}
.cfg_wrap .point02 {
  background: url("../img/point02_bg.jpg") no-repeat top center;
  height: 1713px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point02 {
    background-size: 266.6666666667vw auto;
    height: 228.4vw;
  }
}
.cfg_wrap .point02 .inner .g_text {
  color: #5DB24B;
  font-size: 26px;
  line-height: 2;
  text-align: center;
  font-weight: 700;
  letter-spacing: 0.12em;
  margin: 20px 0 25px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point02 .inner .g_text {
    font-size: 3.4666666667vw;
    margin: 2.6666666667vw 0 3.3333333333vw;
  }
}
.cfg_wrap .point02 .inner p[class^=text0] {
  color: #fff;
  font-size: 26px;
  line-height: 1.15;
  text-align: center;
  letter-spacing: 0.14em;
  position: absolute;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point02 .inner p[class^=text0] {
    font-size: 3.4666666667vw;
  }
}
.cfg_wrap .point02 .inner .text01 {
  text-shadow: 0 0 10px #EEAB97, 0 0 10px #EEAB97, 0 0 10px #EEAB97, 0 0 10px #EEAB97, 0 0 10px #EEAB97, 0 0 10px #EEAB97;
  top: 234px;
  left: 82px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point02 .inner .text01 {
    text-shadow: 0 0 1.3333333333vw #EEAB97, 0 0 1.3333333333vw #EEAB97, 0 0 1.3333333333vw #EEAB97, 0 0 1.3333333333vw #EEAB97, 0 0 1.3333333333vw #EEAB97, 0 0 1.3333333333vw #EEAB97;
    top: 31.2vw;
    left: 10.9333333333vw;
  }
}
.cfg_wrap .point02 .inner .text02 {
  text-shadow: 0 0 10px #53BDE6, 0 0 10px #53BDE6, 0 0 10px #53BDE6, 0 0 10px #53BDE6, 0 0 10px #53BDE6, 0 0 10px #53BDE6;
  top: 72px;
  left: 285px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point02 .inner .text02 {
    text-shadow: 0 0 1.3333333333vw #53BDE6, 0 0 1.3333333333vw #53BDE6, 0 0 1.3333333333vw #53BDE6, 0 0 1.3333333333vw #53BDE6, 0 0 1.3333333333vw #53BDE6, 0 0 1.3333333333vw #53BDE6;
    top: 9.6vw;
    left: 38vw;
  }
}
.cfg_wrap .point02 .inner .text03 {
  text-shadow: 0 0 10px #ECCB33, 0 0 10px #ECCB33, 0 0 10px #ECCB33, 0 0 10px #ECCB33, 0 0 10px #ECCB33, 0 0 10px #ECCB33;
  top: 255px;
  left: 518px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point02 .inner .text03 {
    text-shadow: 0 0 1.3333333333vw #ECCB33, 0 0 1.3333333333vw #ECCB33, 0 0 1.3333333333vw #ECCB33, 0 0 1.3333333333vw #ECCB33, 0 0 1.3333333333vw #ECCB33, 0 0 1.3333333333vw #ECCB33;
    top: 34vw;
    left: 69.0666666667vw;
  }
}
.cfg_wrap .point02 .inner .text_area {
  width: 560px;
  margin: 0 auto;
  position: absolute;
  top: 133px;
  left: 0;
  right: 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point02 .inner .text_area {
    width: 74.6666666667vw;
    top: 17.7333333333vw;
  }
}
.cfg_wrap .point02 .inner .text_area .tit {
  text-align: center;
  margin-bottom: 30px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point02 .inner .text_area .tit {
    margin-bottom: 4vw;
  }
}
.cfg_wrap .point02 .inner .text_area .tit strong {
  color: #fff;
  font-size: 37px;
  line-height: 1.62;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 0 10px;
  background: linear-gradient(transparent 12%, #DC5A75 12% 100%, transparent 100%);
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point02 .inner .text_area .tit strong {
    font-size: 4.9333333333vw;
    padding: 0 1.3333333333vw;
  }
}
.cfg_wrap .point02 .inner .text_area .tit strong span {
  font-size: 85%;
  font-weight: 500;
  vertical-align: 2px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point02 .inner .text_area .tit strong span {
    vertical-align: 0.2666666667vw;
  }
}
.cfg_wrap .point02 .inner .text_area .text {
  font-size: 26px;
  line-height: 2;
  letter-spacing: 0.06em;
  width: 310px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point02 .inner .text_area .text {
    font-size: 3.4666666667vw;
    width: 41.3333333333vw;
  }
}
.cfg_wrap .point03 {
  background: url("../img/point03_bg.jpg") no-repeat top center;
  height: 3286px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point03 {
    background-size: 266.6666666667vw auto;
    height: 438.1333333333vw;
  }
}
.cfg_wrap .point03 .inner .point03_box {
  width: 600px;
  margin: 0 auto;
  padding-bottom: 50px;
  border-radius: 20px;
  background: #C5EDB0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point03 .inner .point03_box {
    width: 80vw;
    padding-bottom: 6.6666666667vw;
    border-radius: 2.6666666667vw;
  }
}
.cfg_wrap .point03 .inner .point03_box.box01 {
  margin: 65px auto 60px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point03 .inner .point03_box.box01 {
    margin: 8.6666666667vw auto 8vw;
  }
}
.cfg_wrap .point03 .inner .point03_box h3 {
  color: #fff;
  font-size: 32px;
  line-height: 1.4;
  text-align: center;
  letter-spacing: 0.2em;
  padding: 20px 0;
  border-radius: 20px 20px 0 0;
  background: #5DB24B;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point03 .inner .point03_box h3 {
    font-size: 4.2666666667vw;
    padding: 2.6666666667vw 0;
    border-radius: 2.6666666667vw 2.6666666667vw 0 0;
  }
}
.cfg_wrap .point03 .inner .point03_box .text {
  color: #4D4D4D;
  font-size: 26px;
  line-height: 2;
  text-align: center;
  letter-spacing: 0.1em;
  margin: 30px 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point03 .inner .point03_box .text {
    font-size: 3.4666666667vw;
    margin: 4vw 0;
  }
}
.cfg_wrap .point03 .inner .point03_box .img {
  width: 470px;
  margin: 0 auto;
  filter: drop-shadow(10px 10px 10px rgba(148, 202, 170, 0.3));
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point03 .inner .point03_box .img {
    width: 62.6666666667vw;
  }
}
.cfg_wrap .point03 .inner .bot_text_area {
  margin-top: 140px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point03 .inner .bot_text_area {
    margin-top: 18.6666666667vw;
  }
}
.cfg_wrap .point03 .inner .bot_text_area .text01 {
  font-size: 26px;
  text-align: center;
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point03 .inner .bot_text_area .text01 {
    font-size: 3.4666666667vw;
    margin-bottom: 1.3333333333vw;
  }
}
.cfg_wrap .point03 .inner .bot_text_area .text02 {
  text-align: center;
}
.cfg_wrap .point03 .inner .bot_text_area .text02 strong {
  color: #fff;
  font-size: 32px;
  line-height: 2.12;
  font-weight: 400;
  letter-spacing: 0.1em;
  padding: 3px 35px 8px;
  background: #5DB24B;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point03 .inner .bot_text_area .text02 strong {
    font-size: 4.2666666667vw;
    padding: 0.4vw 4.6666666667vw 1.0666666667vw;
  }
}
.cfg_wrap .point03 .inner .bot_text_area .text03 {
  text-align: center;
  margin-top: 25px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point03 .inner .bot_text_area .text03 {
    margin-top: 3.3333333333vw;
  }
}
.cfg_wrap .point03 .inner .bot_text_area .text03 span {
  font-size: 26px;
  line-height: 2;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding-bottom: 10px;
  background-image: linear-gradient(to right, #4D4D4D, #4D4D4D 2px, transparent 2px);
  background-size: 8px 2px;
  background-position: left bottom;
  background-repeat: repeat-x;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .point03 .inner .bot_text_area .text03 span {
    font-size: 3.4666666667vw;
    padding-bottom: 1.3333333333vw;
    background-size: 1.0666666667vw 0.2666666667vw;
  }
}
.cfg_wrap .step {
  background: url("../img/step_bg.jpg") no-repeat top center;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .step {
    background-size: 266.6666666667vw auto;
  }
}
.cfg_wrap .step .inner .text_area {
  position: absolute;
  top: 160px;
  left: 75px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .step .inner .text_area {
    top: 21.3333333333vw;
    left: 10vw;
  }
}
.cfg_wrap .step .inner .text_area .text01 {
  color: #5DB24B;
  font-size: 30px;
  line-height: 48px;
  text-align: center;
  letter-spacing: 0.2em;
  width: 130px;
  height: 50px;
  border-radius: 30px;
  background: #fff;
  border: 2px solid #5DB24B;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .step .inner .text_area .text01 {
    font-size: 4vw;
    line-height: 6.4vw;
    width: 17.3333333333vw;
    height: 6.6666666667vw;
    border-radius: 4vw;
    border-width: 0.2666666667vw;
  }
}
.cfg_wrap .step .inner .text_area .text02 {
  font-size: 36px;
  line-height: 1.38;
  letter-spacing: 0.1em;
  margin: 10px 0 25px 20px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .step .inner .text_area .text02 {
    font-size: 4.8vw;
    margin: 1.3333333333vw 0 3.3333333333vw 2.6666666667vw;
  }
}
.cfg_wrap .step .inner .text_area .text03 {
  font-size: 26px;
  line-height: 2;
  letter-spacing: 0.1em;
  width: 560px;
  margin-left: 20px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .step .inner .text_area .text03 {
    font-size: 3.4666666667vw;
    width: 74.6666666667vw;
    margin-left: 2.6666666667vw;
  }
}
.cfg_wrap .step .inner .text_area2 {
  width: 670px;
  margin: 0 auto;
  position: absolute;
  top: 5px;
  left: 0;
  right: 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .step .inner .text_area2 {
    width: 89.3333333333vw;
    top: 0.6666666667vw;
  }
}
.cfg_wrap .step .inner .text_area2 .tit {
  color: #4D4D4D;
  font-size: 26px;
  text-align: center;
  letter-spacing: 0.12em;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .step .inner .text_area2 .tit {
    font-size: 3.4666666667vw;
  }
}
.cfg_wrap .step .inner .text_area2 .list {
  display: flex;
  justify-content: center;
  gap: 50px;
  margin: 35px 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .step .inner .text_area2 .list {
    gap: 6.6666666667vw;
    margin: 4.6666666667vw 0;
  }
}
.cfg_wrap .step .inner .text_area2 .list li {
  padding-left: 50px;
  position: relative;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .step .inner .text_area2 .list li {
    padding-left: 6.6666666667vw;
  }
}
.cfg_wrap .step .inner .text_area2 .list li::before {
  content: "";
  width: 35px;
  height: 35px;
  background: url(../img/step_icon_check.svg) no-repeat top left/100%;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .step .inner .text_area2 .list li::before {
    width: 4.6666666667vw;
    height: 4.6666666667vw;
  }
}
.cfg_wrap .step .inner .text_area2 .list li strong {
  color: #5DB24B;
  font-size: 33px;
  font-weight: 500;
  letter-spacing: 0.12em;
  background: linear-gradient(transparent 12%, #FFFFC8 12% 100%, transparent 100%);
}
@media screen and (max-width: 750px) {
  .cfg_wrap .step .inner .text_area2 .list li strong {
    font-size: 4.4vw;
  }
}
.cfg_wrap .step .inner .text_area2 .text {
  color: #4D4D4D;
  font-size: 26px;
  text-align: center;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .step .inner .text_area2 .text {
    font-size: 3.4666666667vw;
  }
}
.cfg_wrap .offer {
  background: url("../img/offer_bg.jpg") no-repeat top center;
  padding-bottom: 110px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer {
    background-size: 266.6666666667vw auto;
    padding-bottom: 14.6666666667vw;
  }
}
.cfg_wrap .offer .inner .top_text {
  width: 245px;
  position: absolute;
  left: 50px;
  bottom: -26px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .top_text {
    width: 32.6666666667vw;
    left: 6.6666666667vw;
    bottom: -3.4666666667vw;
  }
}
.cfg_wrap .offer .inner .offer_tit {
  color: #fff;
  font-size: 40px;
  line-height: 1.8;
  font-weight: 400;
  text-align: center;
  letter-spacing: 0.22em;
  margin: 24px 0 40px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_tit {
    font-size: 5.3333333333vw;
    margin: 3.2vw 0 5.3333333333vw;
  }
}
.cfg_wrap .offer .inner .offer_tit img {
  width: 317px;
  vertical-align: -14px;
  margin: 0 22px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_tit img {
    width: 42.2666666667vw;
    vertical-align: -1.8666666667vw;
    margin: 0 2.9333333333vw;
  }
}
.cfg_wrap .offer .inner .offer_box {
  width: 670px;
  margin: 65px auto 0;
  padding-bottom: 70px;
  background: #fff;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box {
    width: 89.3333333333vw;
    margin: 8.6666666667vw auto 0;
    padding-bottom: 9.3333333333vw;
  }
}
.cfg_wrap .offer .inner .offer_box .tit {
  color: #fff;
  font-size: 40px;
  line-height: 78px;
  text-align: center;
  font-weight: 400;
  letter-spacing: 0.22em;
  height: 80px;
  background: #E7BE00;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .tit {
    font-size: 5.3333333333vw;
    line-height: 10.4vw;
    height: 10.6666666667vw;
  }
}
.cfg_wrap .offer .inner .offer_box .name {
  color: #4D4D4D;
  font-size: 31px;
  text-align: center;
  letter-spacing: 0.12em;
  position: absolute;
  top: 60px;
  left: 0;
  right: 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .name {
    font-size: 4.1333333333vw;
    top: 8vw;
  }
}
.cfg_wrap .offer .inner .offer_box .ribbon_text {
  color: #fff;
  font-size: 30px;
  text-align: center;
  letter-spacing: 0.28em;
  position: absolute;
  top: 13px;
  left: 0;
  right: 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .ribbon_text {
    font-size: 4vw;
    top: 1.7333333333vw;
  }
}
.cfg_wrap .offer .inner .offer_box .min_text {
  color: #666;
  font-size: 20px;
  text-align: center;
  letter-spacing: 0.04em;
  margin: 15px 0 45px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .min_text {
    font-size: 2.6666666667vw;
    margin: 2vw 0 6vw;
  }
}
.cfg_wrap .offer .inner .offer_box .total_text {
  text-align: center;
  margin: 35px 0 12px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .total_text {
    margin: 4.6666666667vw 0 1.6vw;
  }
}
.cfg_wrap .offer .inner .offer_box .total_text span {
  color: #4D4D4D;
  font-size: 26px;
  letter-spacing: 0.12em;
  padding: 0 35px;
  position: relative;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .total_text span {
    font-size: 3.4666666667vw;
    padding: 0 4.6666666667vw;
  }
}
.cfg_wrap .offer .inner .offer_box .total_text span::before, .cfg_wrap .offer .inner .offer_box .total_text span::after {
  content: "";
  display: block;
  width: 2px;
  height: 36px;
  background: #4D4D4D;
  position: absolute;
  top: 5px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .total_text span::before, .cfg_wrap .offer .inner .offer_box .total_text span::after {
    width: 0.2666666667vw;
    height: 4.8vw;
    top: 0.6666666667vw;
  }
}
.cfg_wrap .offer .inner .offer_box .total_text span::before {
  transform: rotate(-40deg);
  left: 0;
}
.cfg_wrap .offer .inner .offer_box .total_text span::after {
  transform: rotate(40deg);
  right: 0;
}
.cfg_wrap .offer .inner .offer_box .kome {
  color: #666;
  font-size: 20px;
  line-height: 1.7;
  letter-spacing: 0.04em;
  width: 600px;
  margin: 0 auto;
  padding: 0 0 45px 20px;
  border-bottom: 3px solid #F2F2F2;
  box-sizing: border-box;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .kome {
    font-size: 2.6666666667vw;
    width: 80vw;
    padding: 0 0 6vw 2.6666666667vw;
    border-bottom-width: 0.4vw;
  }
}
.cfg_wrap .offer .inner .offer_box .offer03 {
  width: 614px;
  margin: 80px auto 47px;
  border: 3px solid #E47998;
  background: #FEF6F8;
  position: relative;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .offer03 {
    width: 81.8666666667vw;
    margin: 10.6666666667vw auto 6.2666666667vw;
    border-width: 0.4vw;
  }
}
.cfg_wrap .offer .inner .offer_box .offer03 .ribbon {
  color: #FFFF96;
  font-size: 30px;
  letter-spacing: 0.28em;
  width: 400px;
  height: 60px;
  margin: 0 auto;
  padding: 13px 0 0 100px;
  background: url(../img/offer03_tit_ribbon.png) no-repeat top left/100%;
  box-sizing: border-box;
  position: absolute;
  top: -33px;
  left: 0;
  right: 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .offer03 .ribbon {
    font-size: 4vw;
    width: 53.3333333333vw;
    height: 8vw;
    padding: 1.7333333333vw 0 0 13.3333333333vw;
    top: -4.4vw;
  }
}
.cfg_wrap .offer .inner .offer_box .offer03 .course_box {
  padding: 47px 0 20px;
  background: #FBE4E9;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .offer03 .course_box {
    padding: 6.2666666667vw 0 2.6666666667vw;
  }
}
.cfg_wrap .offer .inner .offer_box .offer03 .kome {
  border-bottom: none;
}
.cfg_wrap .offer .inner .offer_box .offer05 {
  margin: 47px 0;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .offer05 {
    margin: 6.2666666667vw 0;
  }
}
.cfg_wrap .offer .inner .offer_box .offer_line {
  width: 600px;
  margin: 0 auto 50px;
  border-bottom: 3px solid #F2F2F2;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .offer_line {
    width: 80vw;
    margin: 0 auto 6.6666666667vw;
    border-bottom-width: 0.4vw;
  }
}
.cfg_wrap .offer .inner .offer_box .free {
  color: #5DB24B;
  font-size: 26px;
  line-height: 58px;
  text-align: center;
  letter-spacing: 0.12em;
  width: 600px;
  height: 60px;
  margin: 0 auto;
  background: #D4F4DD;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .free {
    font-size: 3.4666666667vw;
    line-height: 7.7333333333vw;
    width: 80vw;
    height: 8vw;
  }
}
.cfg_wrap .offer .inner .offer_box .free strong {
  font-size: 37px;
  font-weight: 700;
  vertical-align: -3px;
  margin-left: 10px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .free strong {
    font-size: 4.9333333333vw;
    vertical-align: -0.4vw;
    margin-left: 1.3333333333vw;
  }
}
.cfg_wrap .offer .inner .offer_box .campaign {
  color: #DC5A75;
  font-size: 28px;
  text-align: center;
  letter-spacing: 0.22em;
  margin: 40px 0 20px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .campaign {
    font-size: 3.7333333333vw;
    margin: 5.3333333333vw 0 2.6666666667vw;
  }
}
.cfg_wrap .offer .inner .offer_box .offer_btn a {
  display: block;
  text-align: center;
  width: 560px;
  height: 120px;
  margin: 0 auto;
  padding-top: 15px;
  padding-left: 70px;
  border-radius: 60px;
  background: #DC5A75;
  box-sizing: border-box;
  position: relative;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .offer_btn a {
    width: 74.6666666667vw;
    height: 16vw;
    padding-top: 2vw;
    padding-left: 9.3333333333vw;
    border-radius: 8vw;
  }
}
.cfg_wrap .offer .inner .offer_box .offer_btn a::before {
  content: "";
  display: block;
  width: 60px;
  height: 52px;
  background: url(../img/icon_cart.svg) no-repeat top left/100%;
  transform: translateY(-50%);
  position: absolute;
  top: 50%;
  left: 45px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .offer_btn a::before {
    width: 8vw;
    height: 6.9333333333vw;
    left: 6vw;
  }
}
.cfg_wrap .offer .inner .offer_box .offer_btn a span {
  color: #fff;
  font-size: 28px;
  line-height: 1.4;
  letter-spacing: 0.19em;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .offer_btn a span {
    font-size: 3.7333333333vw;
  }
}
.cfg_wrap .offer .inner .offer_box .offer_btn a span strong {
  font-size: 36px;
  font-weight: 400;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .offer .inner .offer_box .offer_btn a span strong {
    font-size: 4.8vw;
  }
}
.cfg_wrap .form_area {
  background: #F3FDE8;
}
.cfg_wrap .form_area .inner .form_tit {
  color: #4D4D4D;
  font-size: 40px;
  text-align: center;
  font-weight: 400;
  letter-spacing: 0.28em;
  padding: 30px 0 80px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .form_area .inner .form_tit {
    font-size: 5.3333333333vw;
    padding: 4vw 0 10.6666666667vw;
  }
}
.cfg_wrap .footer {
  padding-top: 120px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .footer {
    padding-top: 16vw;
  }
}
.cfg_wrap .footer .inner .foot_logo {
  width: 200px;
  margin: 0 0 55px 55px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .footer .inner .foot_logo {
    width: 26.6666666667vw;
    margin: 0 0 7.3333333333vw 7.3333333333vw;
  }
}
.cfg_wrap .footer .inner .foot_table {
  margin-left: 50px;
  padding-bottom: 30px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .footer .inner .foot_table {
    margin-left: 6.6666666667vw;
    padding-bottom: 4vw;
  }
}
.cfg_wrap .footer .inner .foot_table th,
.cfg_wrap .footer .inner .foot_table td {
  color: #4D4D4D;
  font-size: 22px;
  text-align: left;
  vertical-align: top;
  font-weight: 400;
  line-height: 1.45;
  letter-spacing: 0.1em;
  padding-bottom: 30px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .footer .inner .foot_table th,
  .cfg_wrap .footer .inner .foot_table td {
    font-size: 2.9333333333vw;
    padding-bottom: 4vw;
  }
}
.cfg_wrap .footer .inner .foot_table th {
  width: 170px;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .footer .inner .foot_table th {
    width: 22.6666666667vw;
  }
}
.cfg_wrap .footer .copy {
  text-align: center;
  padding: 25px 0;
  background: #333;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .footer .copy {
    padding: 3.3333333333vw 0;
  }
}
.cfg_wrap .footer .copy small {
  color: #fff;
  font-size: 20px;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 750px) {
  .cfg_wrap .footer .copy small {
    font-size: 2.6666666667vw;
  }
}/*# sourceMappingURL=style.css.map */