/*tit_area
-----------------------------------------------------------------------------*/
.tit_area {
  color: #009fac;
}
.tit_area .subtit {
  letter-spacing: 0.1em;
  position: relative;
}
.tit_area .subtit::before {
  content: "";
  display: block;
  background-color: #009fac;
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 0;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
}
.tit_area .sec_tit {
  letter-spacing: 0.1em;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .tit_area {
    margin-bottom: 3.75rem;
  }
  .tit_area .subtit {
    font-size: 0.9375rem;
    padding-left: 4.5625rem;
    margin-bottom: 2.4375rem;
  }
  .tit_area .subtit::before {
    width: 3.125rem;
    height: 0.09375rem;
  }
  .tit_area .sec_tit {
    font-size: 2.1875rem;
  }
}
@media only screen and (max-width: 767px) {
  .tit_area {
    margin-bottom: 11.2vw;
    margin-left: 10.6666666667vw;
  }
  .tit_area .subtit {
    font-size: 0.8214285714rem;
    padding-left: 9.7333333333vw;
    margin-bottom: 4.9333333333vw;
  }
  .tit_area .subtit::before {
    width: 6.6666666667vw;
    height: 0.2vw;
  }
  .tit_area .sec_tit {
    font-size: 1.7857142857rem;
  }
}

/*anc_btn_wrap
-----------------------------------------------------------------------------*/
.anc_btn_wrap {
  position: absolute;
  z-index: 100;
}
.anc_btn_wrap.fixed {
  position: fixed;
  bottom: 0;
}
.anc_btn_wrap .anc_btn {
  -webkit-transition: all 0.6s cubic-bezier(0.66, 0.01, 0.67, 0.71) 0s;
  -ms-transition: all 0.6s cubic-bezier(0.66, 0.01, 0.67, 0.71) 0s;
  transition: all 0.6s cubic-bezier(0.66, 0.01, 0.67, 0.71) 0s;
  opacity: 0;
  -webkit-transform: translate(0, 100%) rotate(0deg) scale(1, 1) skew(0deg, 0deg);
  -ms-transform: translate(0, 100%) rotate(0deg) scale(1, 1) skew(0deg, 0deg);
  transform: translate(0, 100%) rotate(0deg) scale(1, 1) skew(0deg, 0deg);
  height: 100%;
  border-radius: 50%;
  display: block;
  text-align: center;
  background: #ffa489;
}
.anc_btn_wrap .anc_btn .btn_txt {
  color: #fff;
  letter-spacing: 0.1em;
  display: inline-block;
  position: relative;
  font-weight: 500;
}
.anc_btn_wrap .anc_btn .btn_txt strong {
  letter-spacing: 0.1em;
}
.anc_btn_wrap .anc_btn .btn_txt small {
  display: inline-block;
  margin: 0 -0.5em;
}
.anc_btn_wrap .anc_btn .btn_txt::after {
  content: "";
  display: block;
  background-color: #fff;
  position: absolute;
  left: 50%;
  z-index: 0;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
}
.anc_btn_wrap.active .anc_btn {
  opacity: 1;
  -webkit-transform: translate(0, 0) rotate(0deg) scale(1, 1) skew(0deg, 0deg);
  -ms-transform: translate(0, 0) rotate(0deg) scale(1, 1) skew(0deg, 0deg);
  transform: translate(0, 0) rotate(0deg) scale(1, 1) skew(0deg, 0deg);
}
@media print, screen and (min-width: 768px) {
  .anc_btn_wrap {
    right: 1.4375rem;
    width: 15.4375rem;
    height: 15.4375rem;
    bottom: -14.1875rem;
    margin-bottom: 1.4375rem;
  }
  .anc_btn_wrap .anc_btn {
    padding-top: 2.6875rem;
    box-shadow: 7px 7px 20px 0px rgba(0, 0, 0, 0.35);
  }
  .anc_btn_wrap .anc_btn .btn_txt {
    font-size: 1.5625rem;
    line-height: 1.2;
    margin-top: calc(0px - (((1em*1.2) - 1em)/2));
  }
  .anc_btn_wrap .anc_btn .btn_txt:last-child {
    margin-bottom: calc(0px - (((1em*1.2) - 1em)/2));
  }
  .anc_btn_wrap .anc_btn .btn_txt:not(:last-child) {
    margin-bottom: calc(1.6875rem - (((1em*1.2) - 1em)/2));
  }
  .anc_btn_wrap .anc_btn .btn_txt strong {
    font-size: 2.375rem;
  }
  .anc_btn_wrap .anc_btn .btn_txt small {
    font-size: 0.9375rem;
  }
  .anc_btn_wrap .anc_btn .btn_txt::after {
    height: 0.1875rem;
    bottom: -0.625rem;
  }
  .anc_btn_wrap .anc_btn .btn_txt:first-of-type::after {
    width: 11.5625rem;
  }
  .anc_btn_wrap .anc_btn .btn_txt:last-of-type::after {
    width: 6.25rem;
  }
  .anc_btn_wrap .anc_btn:hover {
    -webkit-transform: translate(0, 0) rotate(0deg) scale(1.1, 1.1) skew(0deg, 0deg);
    -ms-transform: translate(0, 0) rotate(0deg) scale(1.1, 1.1) skew(0deg, 0deg);
    transform: translate(0, 0) rotate(0deg) scale(1.1, 1.1) skew(0deg, 0deg);
  }
}
@media only screen and (max-width: 767px) {
  .anc_btn_wrap {
    right: 4.4vw;
    width: 32.9333333333vw;
    height: 32.9333333333vw;
    bottom: -22.2666666667vw;
    margin-bottom: 4.4vw;
  }
  .anc_btn_wrap .anc_btn {
    padding-top: 5.7333333333vw;
    box-shadow: 7px 7px 20px 0px rgba(0, 0, 0, 0.35);
  }
  .anc_btn_wrap .anc_btn .btn_txt {
    font-size: 0.8928571429rem;
    line-height: 1.2;
    margin-top: calc(0px - (((1em*1.2) - 1em)/2));
  }
  .anc_btn_wrap .anc_btn .btn_txt:last-child {
    margin-bottom: calc(0px - (((1em*1.2) - 1em)/2));
  }
  .anc_btn_wrap .anc_btn .btn_txt:not(:last-child) {
    margin-bottom: calc(3.6vw - (((1em*1.2) - 1em)/2));
  }
  .anc_btn_wrap .anc_btn .btn_txt strong {
    font-size: 1.3571428571rem;
  }
  .anc_btn_wrap .anc_btn .btn_txt small {
    font-size: 0.5357142857rem;
  }
  .anc_btn_wrap .anc_btn .btn_txt::after {
    height: 0.4vw;
    bottom: -1.3333333333vw;
  }
  .anc_btn_wrap .anc_btn .btn_txt:first-of-type::after {
    width: 24.6666666667vw;
  }
  .anc_btn_wrap .anc_btn .btn_txt:last-of-type::after {
    width: 13.3333333333vw;
  }
}

/*balloon
-----------------------------------------------------------------------------*/
.balloon {
  text-align: center;
  font-weight: bold;
  background-image: url("../img/top/balloon_bg.svg");
  background-size: 100% 100%;
  margin: auto;
}
@media print, screen and (min-width: 768px) {
  .balloon {
    font-size: 1.75rem;
    letter-spacing: 0.098em;
    width: 34.0625rem;
    padding: 1.875rem 0 4.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .balloon {
    font-size: 1.2rem;
    letter-spacing: 0.1em;
    width: 87.22968vw;
    padding: 4.9333333333vw 0 11.6vw;
  }
}

/*mv
-----------------------------------------------------------------------------*/
#mv {
  position: relative;
}
#mv .mv_slider {
  width: 100%;
}
#mv .mv_slider div[class^="slide_item0"] {
  position: relative;
}
#mv .mv_slider .img02, #mv .mv_slider .img03 {
  position: absolute;
}
#mv .mv_slider .slide_img {
  position: relative;
}
#mv .mv_slider .bg01 .img01 {
  background: #99d8de;
}
#mv .mv_slider .bg02 .img01 {
  background: #ffa489;
}
#mv .mv_slider .bg03 .img01 {
  background: #fff;
}
#mv .scroll_btn span {
  -webkit-transform: scale(1, -1);
  -ms-transform: scale(1, -1);
  transform: scale(1, -1);
}
@media print, screen and (min-width: 768px) {
  #mv .mv_slider .slide_item01 .img02 {
    width: 12.0714285714%;
    bottom: 46.677471637%;
    right: 1.7142857143%;
  }
  #mv .mv_slider .slide_item02 .img02 {
    width: 13.2857142857%;
    bottom: 47.1636952998%;
    right: 1.5%;
  }
  #mv .mv_slider .img03 {
    bottom: 0;
    right: -3.8571428571%;
    width: 24.6428571429%;
  }
  #mv .mv_slider .slide_img {
    width: 93.3333333333%;
    padding-bottom: 4.6666666667%;
  }
  #mv .scroll_btn_wrap {
    top: 50%;
    -webkit-transform: translate(0, -50%) rotate(0deg) scale(1, -1) skew(0deg, 0deg);
    -ms-transform: translate(0, -50%) rotate(0deg) scale(1, -1) skew(0deg, 0deg);
    transform: translate(0, -50%) rotate(0deg) scale(1, -1) skew(0deg, 0deg);
  }
  #mv .scroll_btn {
    position: relative;
    padding-bottom: 4.6875rem;
  }
  #mv .scroll_btn span {
    padding-top: 0.75rem;
  }
  #mv .scroll_btn::before, #mv .scroll_btn::after {
    content: "";
    display: block;
    width: 1px;
    position: absolute;
    left: 50%;
    z-index: 0;
    -webkit-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
  }
  #mv .scroll_btn::before {
    height: 4.6875rem;
    background-color: #5db9c2;
    bottom: 0;
  }
  #mv .scroll_btn::after {
    height: 2.3125rem;
    background-color: #fff;
    bottom: 2.375rem;
    -webkit-animation: scroll_animepc_mv 1.6s ease-in-out 0s infinite reverse forwards;
    -ms-animation: scroll_animepc_mv 1.6s ease-in-out 0s infinite reverse forwards;
    animation: scroll_animepc_mv 1.6s ease-in-out 0s infinite reverse forwards;
  }
  @keyframes scroll_animepc_mv {
    0% {
      height: 0;
      bottom: 4.6875rem;
    }
    70% {
      height: 3.75rem;
    }
    80% {
      bottom: 0;
    }
    100% {
      height: 0;
      bottom: 0;
    }
  }
}
@media only screen and (max-width: 767px) {
  #mv .mv_slider .slide_item01 .img02 {
    width: 30.0196133333vw;
    bottom: 4.92324vw;
    left: 5.61812vw;
  }
  #mv .mv_slider .slide_item02 .img02 {
    width: 33.4638vw;
    bottom: 5.9828133333vw;
    left: 4.70188vw;
  }
  #mv .mv_slider .img03 {
    bottom: 6.0098933333vw;
    right: 8.0769466667vw;
    width: 53.3333333333vw;
  }
  #mv .mv_slider .slide_img {
    width: 100%;
  }
  #mv .scroll_btn_wrap {
    right: 2.912vw;
    bottom: 5.7493333333vw;
    -webkit-transform: translate(0, 0) rotate(0deg) scale(1, -1) skew(0deg, 0deg);
    -ms-transform: translate(0, 0) rotate(0deg) scale(1, -1) skew(0deg, 0deg);
    transform: translate(0, 0) rotate(0deg) scale(1, -1) skew(0deg, 0deg);
    color: #fff;
  }
  #mv .scroll_btn {
    position: relative;
    padding-bottom: 12vw;
  }
  #mv .scroll_btn span {
    padding-top: 2.4vw;
  }
  #mv .scroll_btn::before, #mv .scroll_btn::after {
    content: "";
    display: block;
    width: 1px;
    position: absolute;
    left: 50%;
    z-index: 0;
    -webkit-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
  }
  #mv .scroll_btn::before {
    height: 12vw;
    background-color: #fff;
    bottom: 0;
  }
  #mv .scroll_btn::after {
    height: 4.9333333333vw;
    background-color: #5db9c2;
    bottom: 7.0666666667vw;
    -webkit-animation: scroll_animesp_mv 1.6s ease-in-out 0s infinite reverse forwards;
    -ms-animation: scroll_animesp_mv 1.6s ease-in-out 0s infinite reverse forwards;
    animation: scroll_animesp_mv 1.6s ease-in-out 0s infinite reverse forwards;
  }
  @keyframes scroll_animesp_mv {
    0% {
      height: 0;
      bottom: 12vw;
    }
    70% {
      height: 9.6vw;
    }
    80% {
      bottom: 0;
    }
    100% {
      height: 0;
      bottom: 0;
    }
  }
}

/*sec_wrap00
-----------------------------------------------------------------------------*/
@media only screen and (max-width: 767px) {
  .sec_wrap00 {
    position: relative;
    padding-bottom: 37.0666666667vw;
  }
}

/*intro
-----------------------------------------------------------------------------*/
#intro .question_area {
  position: relative;
}
#intro .question_area::after, #intro .question_area::before {
  content: "";
  display: block;
  background-size: 100% 100%;
  position: absolute;
}
#intro .question_area::before {
  background-image: url("../img/top/question_area_left.svg");
}
#intro .question_area::after {
  background-image: url("../img/top/question_area_right.svg");
}
#intro .question_area p {
  position: absolute;
}
#intro .question_area.scrollListAll > *:not(.scrollActive) {
  opacity: 0;
  -webkit-transform: translate(0, 20%) rotate(0deg) scale(0.8, 0.8) skew(0deg, 0deg);
  -ms-transform: translate(0, 20%) rotate(0deg) scale(0.8, 0.8) skew(0deg, 0deg);
  transform: translate(0, 20%) rotate(0deg) scale(0.8, 0.8) skew(0deg, 0deg);
}
#intro .question_area.scrollListAll > *.scrollActive {
  opacity: 1;
  -webkit-transform: translate(0, 0) rotate(0deg) scale(1, 1) skew(0deg, 0deg);
  -ms-transform: translate(0, 0) rotate(0deg) scale(1, 1) skew(0deg, 0deg);
  transform: translate(0, 0) rotate(0deg) scale(1, 1) skew(0deg, 0deg);
}
#intro .txt_area {
  text-align: center;
}
#intro .txt_area .intro_tit {
  font-weight: bold;
  letter-spacing: 0.1em;
  color: #009fac;
}
#intro .txt_area .txt {
  letter-spacing: 0.1em;
  font-weight: 500;
}
#intro .txt_area .subtit {
  font-weight: bold;
  letter-spacing: 0.1em;
  color: #009fac;
}
#intro .txt_area .subtit strong {
  background: linear-gradient(180deg, transparent 92%, #009fac 8%);
}
@media print, screen and (min-width: 768px) {
  #intro {
    position: relative;
    padding-bottom: 9.375rem;
  }
  #intro .question_area {
    padding-top: 52.0833333333%;
    height: 0;
  }
  #intro .question_area::before {
    width: 14.0998333333%;
    height: 31.63456%;
    left: -2.7404166667%;
    top: 3.380112%;
  }
  #intro .question_area::after {
    width: 12.6100583333%;
    height: 30.59688%;
    right: -2.3484833333%;
    top: 8.55232%;
  }
  #intro .question_area .q01 {
    width: 22.5833333333%;
    top: 9.84144%;
    left: 10.1249666667%;
  }
  #intro .question_area .q02 {
    width: 23.0689666667%;
    top: 11.962192%;
    left: 36.489625%;
  }
  #intro .question_area .q03 {
    width: 22.5553%;
    top: 12.698032%;
    right: 12.441475%;
  }
  #intro .question_area .q04 {
    width: 23.01035%;
    top: 53.637472%;
    left: 0;
  }
  #intro .question_area .q05 {
    width: 23.9189%;
    top: 51.91072%;
    left: 26.0148416667%;
  }
  #intro .question_area .q06 {
    width: 22.039125%;
    top: 48.307792%;
    right: 24.2447166667%;
  }
  #intro .question_area .q07 {
    width: 20.2249416667%;
    top: 54.567456%;
    right: 0;
  }
  #intro .txt_area .intro_tit {
    font-size: 2.8125rem;
    margin: 0 -1em 2.3125rem;
  }
  #intro .txt_area .txt {
    font-size: 1rem;
    line-height: 1.75;
    margin-top: calc(0px - (((1em*1.75) - 1em)/2));
    margin-bottom: calc(3.75rem - (((1em*1.75) - 1em)/2));
  }
  #intro .txt_area .subtit {
    font-size: 2.1875rem;
    line-height: 1.8571428571;
    margin-top: calc(0px - (((1em*1.8571428571) - 1em)/2));
    margin-bottom: calc(0px - (((1em*1.8571428571) - 1em)/2));
  }
}
@media only screen and (max-width: 767px) {
  #intro {
    padding-bottom: 21.3333333333vw;
  }
  #intro .question_area {
    height: 99.2vw;
  }
  #intro .question_area::before {
    width: 16.9282266667vw;
    height: 19.7517866667vw;
    left: 5.3354533333vw;
    top: 11.2672933333vw;
  }
  #intro .question_area::after {
    width: 15.15036vw;
    height: 19.10716vw;
    right: 3.9978533333vw;
    top: 12.4511066667vw;
  }
  #intro .question_area .q01 {
    width: 26.99532vw;
    top: 14.09776vw;
    left: 19.86312vw;
  }
  #intro .question_area .q02 {
    width: 27.5302vw;
    top: 15.4151066667vw;
    right: 20.8451866667vw;
  }
  #intro .question_area .q03 {
    width: 26.91716vw;
    top: 40.17432vw;
    left: 7.06644vw;
  }
  #intro .question_area .q04 {
    width: 27.46024vw;
    top: 41.2024vw;
    left: 36.333vw;
  }
  #intro .question_area .q05 {
    width: 28.54456vw;
    top: 40.2292vw;
    right: 4.6734266667vw;
  }
  #intro .question_area .q06 {
    width: 26.3012133333vw;
    bottom: 10.6009466667vw;
    left: 26.24388vw;
  }
  #intro .question_area .q07 {
    width: 24.13624vw;
    bottom: 11.18812vw;
    right: 18.5215333333vw;
  }
  #intro .txt_area .intro_tit {
    font-size: 1.6071428571rem;
    line-height: 1.5555555556;
    margin-top: calc(0px - (((1em*1.5555555556) - 1em)/2));
    margin-bottom: calc(10.5333333333vw - (((1em*1.5555555556) - 1em)/2));
  }
  #intro .txt_area .txt {
    font-size: 1rem;
    line-height: 2.0714285714;
    margin-top: calc(0px - (((1em*2.0714285714) - 1em)/2));
    margin-bottom: calc(11.3333333333vw - (((1em*2.0714285714) - 1em)/2));
  }
  #intro .txt_area .subtit {
    font-size: 1.25rem;
    line-height: 1.8571428571;
    margin-top: calc(0px - (((1em*1.8571428571) - 1em)/2));
    margin-bottom: calc(0px - (((1em*1.8571428571) - 1em)/2));
  }
}

/*relief
-----------------------------------------------------------------------------*/
#relief .graph_box .txt {
  text-align: center;
  font-weight: bold;
}
#relief .subtit {
  letter-spacing: 0.1em;
  color: #009fac;
  font-weight: bold;
  text-align: center;
}
#relief .relief_tit {
  letter-spacing: 0.1em;
  color: #009fac;
  font-weight: bold;
  text-align: center;
}
#relief .relief_tit strong {
  display: inline-block;
  position: relative;
}
@media print, screen and (min-width: 768px) {
  #relief .balloon {
    margin-bottom: 2.3125rem;
  }
  #relief .graph_list {
    -webkit-justify-content: space-between;
    justify-content: space-between;
    margin-bottom: 3.0625rem;
  }
  #relief .graph_box {
    width: 45.25%;
  }
  #relief .graph_box img {
    width: auto;
    height: 21.8125rem;
  }
  #relief .graph_box .txt {
    font-size: 1.5625rem;
    margin-bottom: 1.6875rem;
  }
  #relief .subtit {
    font-size: 2.1875rem;
    margin-bottom: 1.875rem;
  }
  #relief .relief_tit {
    font-size: 2.8125rem;
  }
  #relief .relief_tit strong::after {
    content: "";
    display: block;
    width: 100%;
    height: 3px;
    background-color: #009fac;
    margin-top: 1.25rem;
  }
}
@media only screen and (max-width: 767px) {
  #relief .balloon {
    margin-bottom: 4.8vw;
  }
  #relief .graph_list {
    width: 78.6666666667vw;
    margin: 0 auto 8.5333333333vw;
  }
  #relief .graph_box .txt {
    font-size: 1.0714285714rem;
    margin-bottom: 4.4vw;
  }
  #relief .graph_box:not(:first-child) {
    margin-top: 10.2666666667vw;
  }
  #relief .subtit {
    font-size: 1.25rem;
    line-height: 1.7142857143;
    margin-top: calc(0px - (((1em*1.7142857143) - 1em)/2));
    margin-bottom: calc(7.4666666667vw - (((1em*1.7142857143) - 1em)/2));
  }
  #relief .relief_tit {
    font-size: 1.6071428571rem;
    line-height: 1.5555555556;
    margin-top: calc(0px - (((1em*1.5555555556) - 1em)/2));
    margin-bottom: calc(0px - (((1em*1.5555555556) - 1em)/2));
  }
  #relief .relief_tit strong::after {
    content: "";
    display: block;
    width: 100%;
    height: 2px;
    background-color: #009fac;
    margin-top: 1.3333333333vw;
  }
}

/*sec_wrap
-----------------------------------------------------------------------------*/
.sec_wrap .wrap_sec .inner {
  position: relative;
}
.sec_wrap .wrap_sec .inner::after {
  content: "";
  display: block;
  background-color: #e0f3f5;
  position: absolute;
  bottom: 0;
  z-index: -1;
}
.sec_wrap .box .tit {
  font-weight: bold;
  letter-spacing: 0.1em;
}
.sec_wrap .box .txt {
  letter-spacing: 0.1em;
}
@media print, screen and (min-width: 768px) {
  .sec_wrap {
    padding: 9.375rem 0;
  }
  .sec_wrap .wrap_sec .inner {
    padding-bottom: 3.125rem;
  }
  .sec_wrap .wrap_sec .inner::after {
    width: 100vw;
    height: 88.4548308336%;
  }
  .sec_wrap .wrap_sec:not(:first-of-type) {
    margin-top: 5.3125rem;
  }
  .sec_wrap .wrap_sec:nth-of-type(odd) .inner::after {
    left: 12.75%;
  }
  .sec_wrap .wrap_sec:nth-of-type(even) .inner::after {
    right: 12.75%;
  }
  .sec_wrap .wrap_sec:nth-of-type(even) figure {
    order: 1;
  }
  .sec_wrap .box {
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
  .sec_wrap .box figure {
    width: 47.5%;
  }
  .sec_wrap .box .txt_area {
    width: 47.5%;
  }
  .sec_wrap .box .tit {
    font-size: 1.5625rem;
    line-height: 1.4;
    margin-top: calc(0px - (((1em*1.4) - 1em)/2));
    margin-bottom: calc(2rem - (((1em*1.4) - 1em)/2));
  }
  .sec_wrap .box .txt {
    line-height: 1.875;
    margin-top: calc(0px - (((1em*1.875) - 1em)/2));
    margin-bottom: calc(3.875rem - (((1em*1.875) - 1em)/2));
  }
}
@media only screen and (max-width: 767px) {
  .sec_wrap {
    padding: 0 0 20.4vw;
  }
  .sec_wrap .wrap_sec .inner {
    padding-bottom: 10.6666666667vw;
  }
  .sec_wrap .wrap_sec .inner::after {
    width: 78.6666666667vw;
    height: 94.5333333333%;
  }
  .sec_wrap .wrap_sec:not(:first-of-type) {
    margin-top: 16vw;
  }
  .sec_wrap .wrap_sec:nth-of-type(odd) figure {
    margin-left: auto;
  }
  .sec_wrap .wrap_sec:nth-of-type(odd) .inner::after {
    right: 0;
  }
  .sec_wrap .wrap_sec:nth-of-type(even) .inner::after {
    left: 0;
  }
  .sec_wrap .box figure {
    width: 89.3333333333vw;
    margin-bottom: 10.2666666667vw;
  }
  .sec_wrap .box .txt_area {
    width: 78.6666666667vw;
    margin: auto;
  }
  .sec_wrap .box .tit {
    font-size: 1.1785714286rem;
    line-height: 2.0606060606;
    margin-top: calc(0px - (((1em*2.0606060606) - 1em)/2));
    margin-bottom: calc(5.3333333333vw - (((1em*2.0606060606) - 1em)/2));
  }
  .sec_wrap .box .txt {
    line-height: 2.0714285714;
    margin-top: calc(0px - (((1em*2.0714285714) - 1em)/2));
    margin-bottom: calc(9.6vw - (((1em*2.0714285714) - 1em)/2));
  }
}

/*voice
-----------------------------------------------------------------------------*/
#voice .voice_list .list_tit {
  letter-spacing: 0.05em;
  color: #009fac;
  text-align: center;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  #voice {
    padding-bottom: 9.375rem;
  }
  #voice .balloon {
    margin-bottom: 3.125rem;
  }
  #voice .voice_list li {
    width: 30.8333333333%;
  }
  #voice .voice_list li:not(:nth-child(3n)) {
    margin-right: 3.75%;
  }
  #voice .voice_list li:not(:nth-child(-n +3)) {
    margin-top: 6.5625rem;
  }
  #voice .voice_list figure {
    margin-bottom: 3.125rem;
  }
  #voice .voice_list .list_tit {
    font-size: 1.25rem;
    margin-bottom: 2.125rem;
  }
  #voice .voice_list .txt {
    line-height: 1.875;
    margin-top: calc(0px - (((1em*1.875) - 1em)/2));
    margin-bottom: calc(0px - (((1em*1.875) - 1em)/2));
  }
}
@media only screen and (max-width: 767px) {
  #voice {
    padding-bottom: 26.6666666667vw;
  }
  #voice .balloon {
    margin-bottom: 5.2vw;
  }
  #voice .voice_list {
    width: 78.6666666667vw;
    margin: auto;
  }
  #voice .voice_list li {
    width: 100;
  }
  #voice .voice_list li:not(:first-child) {
    margin-top: 11.8666666667vw;
  }
  #voice .voice_list figure {
    margin-bottom: 6.6666666667vw;
  }
  #voice .voice_list .list_tit {
    font-size: 1.25rem;
    margin-bottom: 6.6666666667vw;
  }
  #voice .voice_list .txt {
    line-height: 2.0714285714;
    margin-top: calc(0px - (((1em*2.0714285714) - 1em)/2));
    margin-bottom: calc(0px - (((1em*2.0714285714) - 1em)/2));
  }
}

/*subscription
-----------------------------------------------------------------------------*/
#subscription {
  position: relative;
}
#subscription .inner {
  color: #fff;
}
#subscription .txt_area {
  text-align: center;
}
#subscription .sec_tit {
  font-weight: bold;
  letter-spacing: 0.1em;
}
#subscription .sec_tit .up_dot {
  display: inline-block;
  position: relative;
}
#subscription .sec_tit .up_dot::after {
  content: "";
  display: block;
  background-color: #fff;
  position: absolute;
  left: 50%;
  top: 0;
  z-index: 0;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  border-radius: 50%;
}
#subscription .bg {
  position: absolute;
  top: 0;
  z-index: -1;
}
@media print, screen and (min-width: 768px) {
  #subscription {
    margin-bottom: 15.625rem;
  }
  #subscription::before {
    content: "";
    display: block;
    width: 50%;
    height: 100%;
    background-color: #b7babe;
    position: absolute;
    left: 0;
    top: 0;
    z-index: -1;
  }
  #subscription .inner {
    max-width: 1400px;
    color: #fff;
    position: relative;
  }
  #subscription .inner::before {
    content: "";
    display: block;
    width: 100%;
    height: 124.3902439024%;
    background-color: #5db9c2;
    position: absolute;
    top: 50%;
    left: 85.7142857143%;
    z-index: -1;
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
  }
  #subscription .txt_area {
    width: 68.5925925926%;
    margin-left: auto;
    margin-right: 7.1428571429%;
    padding: 6.4375rem 0 3.125rem;
  }
  #subscription .sec_tit {
    font-size: 2.1875rem;
    line-height: 1.7;
    margin-top: calc(0px - (((1em*1.7) - 1em)/2));
    margin-bottom: calc(4.6875rem - (((1em*1.7) - 1em)/2));
  }
  #subscription .sec_tit strong {
    font-size: 3.125rem;
  }
  #subscription .sec_tit .up_dot::after {
    width: 0.625rem;
    height: 0.625rem;
  }
  #subscription .btn {
    margin-left: auto;
  }
  #subscription .annexed_box {
    position: absolute;
    width: 26.25rem;
    left: 0;
    top: -3.0625rem;
  }
  #subscription .bg {
    right: 7.1428571429%;
    width: 111.4285714286%;
    height: 100%;
  }
  #subscription .bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 100% 50%;
    font-family: "object-fit:cover; object-position:100% 50%; ";
  }
}
@media only screen and (max-width: 767px) {
  #subscription {
    margin-bottom: 26.6666666667vw;
  }
  #subscription .txt_area {
    width: 100%;
  }
  #subscription .sec_tit {
    font-size: 1.25rem;
    line-height: 1.7;
    margin-top: calc(0px - (((1em*1.7) - 1em)/2));
    margin-bottom: calc(9.0666666667vw - (((1em*1.7) - 1em)/2));
  }
  #subscription .sec_tit strong {
    font-size: 1.7857142857rem;
  }
  #subscription .sec_tit .up_dot::after {
    width: 1.3333333333vw;
    height: 1.3333333333vw;
  }
  #subscription .btn {
    width: 100%;
  }
  #subscription .btn::after {
    right: 7.6610666667vw;
  }
  #subscription .annexed_box {
    width: 59.74948vw;
    margin: auto;
    -webkit-transform: translate(0, -20.1333333333vw);
    -ms-transform: translate(0, -20.1333333333vw);
    transform: translate(0, -20.1333333333vw);
    margin-bottom: -17.4666666667vw;
  }
  #subscription .bg {
    left: 0;
    width: 100%;
    height: 69.3333333333vw;
  }
  #subscription .bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;
    font-family: "object-fit:cover; object-position:50% 50%; ";
  }
}

/*sec_wrap02
-----------------------------------------------------------------------------*/
.sec_wrap02 {
  position: relative;
  background: #e0f3f5;
}
.sec_wrap02 .wrap02_sec {
  position: relative;
  z-index: 0;
}
.sec_wrap02 .wrap02_sec .txt {
  letter-spacing: 0.1em;
}
.sec_wrap02 .wrap02_sec figure {
  position: absolute;
}
.sec_wrap02 .wrap02_sec::before {
  position: absolute;
  top: 0;
  z-index: -1;
  content: "";
  display: block;
  height: 100%;
  background-color: #fff;
}
@media print, screen and (min-width: 768px) {
  .sec_wrap02 {
    margin-bottom: 15.625rem;
    padding: 6.25rem 0;
  }
  .sec_wrap02 .inner {
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
  .sec_wrap02 .wrap02_sec {
    width: 41.6666666667%;
  }
  .sec_wrap02 .wrap02_sec .txt {
    line-height: 1.875;
    margin-top: calc(0px - (((1em*1.875) - 1em)/2));
    margin-bottom: calc(3.875rem - (((1em*1.875) - 1em)/2));
  }
  .sec_wrap02 .wrap02_sec figure {
    width: 100%;
    left: 0;
  }
  .sec_wrap02 .wrap02_sec::before {
    width: 300%;
  }
  .sec_wrap02 .wrap02_sec:nth-of-type(odd) {
    margin-top: 2.875rem;
  }
  .sec_wrap02 .wrap02_sec:nth-of-type(odd)::before {
    right: 16%;
  }
  .sec_wrap02 .wrap02_sec:nth-of-type(even) {
    margin-bottom: 2.875rem;
  }
  .sec_wrap02 .wrap02_sec:nth-of-type(even)::before {
    left: 16%;
  }
}
@media only screen and (max-width: 767px) {
  .sec_wrap02 {
    margin-bottom: 26.6666666667vw;
    padding: 22vw 0;
  }
  .sec_wrap02 .wrap02_sec .txt {
    margin: auto;
    width: 78.6666666667vw;
    line-height: 2.0714285714;
    margin-top: calc(0px - (((1em*2.0714285714) - 1em)/2));
    margin-bottom: calc(10.6666666667vw - (((1em*2.0714285714) - 1em)/2));
  }
  .sec_wrap02 .wrap02_sec .btn {
    margin-left: 10.6666666667vw;
  }
  .sec_wrap02 .wrap02_sec figure {
    width: 66.6666666667vw;
  }
  .sec_wrap02 .wrap02_sec::before {
    width: 78.6666666667vw;
  }
  .sec_wrap02 .wrap02_sec:nth-of-type(odd)::before {
    left: 0;
  }
  .sec_wrap02 .wrap02_sec:nth-of-type(even)::before {
    right: 0;
  }
}

/*price
-----------------------------------------------------------------------------*/
@media print, screen and (min-width: 768px) {
  #price {
    padding: 9.8125rem 0 5rem;
  }
  #price figure {
    top: -15.3125rem;
  }
}
@media only screen and (max-width: 767px) {
  #price {
    padding: 21.8666666667vw 0 10.6666666667vw;
    margin-bottom: 16vw;
  }
  #price figure {
    top: -32.6666666667vw;
    right: 0;
  }
}

/*penalty
-----------------------------------------------------------------------------*/
@media print, screen and (min-width: 768px) {
  #penalty {
    padding: 5rem 0 10.0625rem;
  }
  #penalty figure {
    bottom: -15.3125rem;
  }
}
@media only screen and (max-width: 767px) {
  #penalty {
    padding: 10.6666666667vw 0 20.6666666667vw;
  }
  #penalty figure {
    bottom: -32.6666666667vw;
  }
}

/*outro
-----------------------------------------------------------------------------*/
#outro {
  text-align: center;
  background-size: cover;
  background-position: center center;
}
#outro .outro_tit {
  font-weight: bold;
  letter-spacing: 0.1em;
  transform-origin: 0 50%;
}
#outro .outro_tit:not(.scrollActive) {
  -webkit-transform: scale(0, 1);
  -ms-transform: scale(0, 1);
  transform: scale(0, 1);
}
#outro .outro_tit.scrollActive {
  -webkit-transform: scale(1, 1);
  -ms-transform: scale(1, 1);
  transform: scale(1, 1);
}
@media print, screen and (min-width: 768px) {
  #outro {
    padding: 9rem 0;
    background-image: url("../img/top/outro_bg.jpg");
  }
  #outro .outro_tit {
    background: #fff;
    display: inline-block;
    font-size: 2.1875rem;
    padding: 1.125rem 1.6875rem;
  }
  #outro .outro_tit:not(:last-of-type) {
    margin-bottom: 1.875rem;
  }
}
@media only screen and (max-width: 767px) {
  #outro {
    padding: 13.3333333333vw 0 12.2666666667vw;
    background-image: url("../img/top/outro_bg_sp.jpg");
  }
  #outro .outro_tit {
    font-size: 1.25rem;
  }
  #outro .outro_tit span {
    background: #fff;
    display: inline-block;
    padding: 2.5333333333vw 3.7333333333vw;
  }
  #outro .outro_tit span:not(:last-of-type) {
    margin: 4vw 0;
  }
}

/*footer
-----------------------------------------------------------------------------*/
@media print, screen and (min-width: 768px) {
  footer {
    margin-top: 9.375rem;
  }
}
@media only screen and (max-width: 767px) {
  footer {
    margin-top: 13.3333333333vw;
  }
}
