@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes vibration {
  0% {
    transform: translate(0) rotate(0deg);
  }
  21% {
    transform: translate(0) rotate(0deg);
  }
  22% {
    transform: translate(0) rotate(-2deg);
  }
  23% {
    transform: translateY(-0.1rem) rotate(0deg);
  }
  24% {
    transform: translateY(-0.1rem) rotate(2deg);
  }
  25% {
    transform: translate(0.1rem) rotate(-1deg);
  }
  26% {
    transform: translateY(0.1rem) rotate(0deg);
  }
  27% {
    transform: translate(0) rotate(2deg);
  }
  28% {
    transform: translate(0) rotate(0deg);
  }
  100% {
    transform: translate(0) rotate(0deg);
  }
}
@keyframes clatter {
  0%, 50% {
    transform: rotate(0deg);
  }
  62.5%, 87.5% {
    transform: rotate(1deg) translateY(-3px);
  }
  75%, 100% {
    transform: rotate(0deg);
  }
}
.top-mv {
  position: relative;
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
  padding-top: min(109px, 7.5694444444vw);
  padding-bottom: min(111px, 7.7083333333vw);
}
@media (max-width: 1280px) {
  .top-mv {
    padding-top: 96.8888888889px;
    padding-bottom: 98.6666666667px;
  }
}
@media (max-width: 428px) {
  .top-mv {
    padding-top: 0;
    padding-bottom: 0;
  }
}

.top-mv_ttl {
  width: 25.3472222222%;
  margin-left: 8.2638888889%;
  opacity: 0;
  transform: translateX(-80px);
  transition: 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
  transition-delay: 0.4s;
}
@media (max-width: 428px) {
  .top-mv_ttl {
    width: 255px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 18px;
    transform: translateY(60px);
  }
}
.is_show .top-mv_ttl {
  opacity: 1;
  transform: none;
}
.top-mv_ttl--img {
  display: block;
  width: 100%;
}

.top-mv_catch {
  width: 38.4722222222%;
  margin-top: min(295px, 20.4861111111vw);
  margin-left: auto;
  margin-right: min(238px, 16.5277777778vw);
  opacity: 0;
  transform: translateY(40px);
  transition: 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
  transition-delay: 0.6s;
}
@media (max-width: 1280px) {
  .top-mv_catch {
    margin-top: 262.2222222222px;
    margin-right: 211.5555555556px;
  }
}
@media (max-width: 428px) {
  .top-mv_catch {
    width: 359px;
    margin: 32px auto 0;
  }
}
.is_show .top-mv_catch {
  opacity: 1;
  transform: translateX(0);
}
.top-mv_catch--img {
  display: block;
  width: 100%;
}

@media (max-width: 428px) {
  .top-mv_photo {
    width: calc(100% - 30px);
    aspect-ratio: 345/286;
    margin-left: auto;
    margin-right: auto;
    position: relative;
  }
}
.top-mv_photo--img {
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  position: absolute;
  opacity: 0;
  transition: 0.6s;
  transform: translateY(40px);
}
.is_show .top-mv_photo--img {
  opacity: 1;
  transform: translateY(0);
}
.top-mv_photo--img:first-of-type {
  width: 61.1111111111%;
  aspect-ratio: 1760/1020;
  background-image: url(../../img/top-mv-photo-img01.webp);
  top: 0;
  right: 3.4722222222%;
}
@media (max-width: 428px) {
  .top-mv_photo--img:first-of-type {
    width: 92.4637681159%;
    right: 0;
  }
}
.top-mv_photo--img:last-of-type {
  width: 35.4166666667%;
  aspect-ratio: 510/380;
  background-image: url(../../img/top-mv-photo-img02.webp);
  top: min(354px, 24.5833333333vw);
  left: 6.1805555556%;
  transition-delay: 0.15s;
}
@media (max-width: 1280px) {
  .top-mv_photo--img:last-of-type {
    top: 314.6666666667px;
  }
}
@media (max-width: 428px) {
  .top-mv_photo--img:last-of-type {
    width: 52.1739130435%;
    top: calc(0.4376811594 * (100vw - 30px));
    left: 0;
  }
}

.top-mv_deco--img {
  display: block;
  position: absolute;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
.top-mv_deco--img:first-of-type {
  width: 28.125%;
  aspect-ratio: 405/112;
  background-image: url(../../img/icon/icon-green-deco01.svg);
  top: min(277px, 19.2361111111vw);
  left: -9.6527777778%;
}
@media (max-width: 1280px) {
  .top-mv_deco--img:first-of-type {
    top: 246.2222222222px;
  }
}
@media (max-width: 428px) {
  .top-mv_deco--img:first-of-type {
    content: none;
  }
}
.top-mv_deco--img:last-of-type {
  width: 14.6527777778%;
  aspect-ratio: 422/334;
  background-image: url(../../img/top-mv-deco-img.webp);
  top: min(552px, 38.3333333333vw);
  right: 1.25%;
  animation: vibration 5s infinite 0.2s cubic-bezier(0.4, 0, 1, 1.3);
}
@media (max-width: 1280px) {
  .top-mv_deco--img:last-of-type {
    top: 490.6666666667px;
  }
}
@media (max-width: 428px) {
  .top-mv_deco--img:last-of-type {
    width: 38.8405797101%;
    top: calc(0.5275362319 * (100vw - 30px));
    right: 0;
  }
}
.is_show .top-mv_deco--img:last-of-type {
  opacity: 1;
  transform: none;
}

.top-lead {
  background-color: #fff;
  position: relative;
  padding-bottom: 130px;
  position: relative;
}
@media (max-width: 428px) {
  .top-lead {
    padding-top: 129px;
    padding-bottom: 143px;
  }
}
.top-lead:before {
  content: "";
  display: block;
  width: 100%;
  aspect-ratio: 1440/153;
  background-image: url(../../img/top-lead.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
@media (max-width: 428px) {
  .top-lead:before {
    content: none;
  }
}
.top-lead--txt {
  margin: 9px auto;
  text-align: center;
  font-weight: 700;
  line-height: 1.6;
  font-size: 32px;
}
@media (max-width: 428px) {
  .top-lead--txt {
    margin-top: 0;
    font-size: 24px;
    line-height: 2;
  }
}
.top-lead--strong {
  background: linear-gradient(transparent 65%, #FFEF6A 35%);
}

.top-lead_deco--img:before {
  content: "";
  display: block;
  position: absolute;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
.top-lead_deco--img:after {
  content: "";
  display: block;
  position: absolute;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
.top-lead_deco--img:first-of-type:before {
  background-image: url(../../img/icon/icon-green-deco02.svg);
  width: 445px;
  aspect-ratio: 445/238;
  top: 197px;
  left: calc(50% - 758px);
}
@media (max-width: 428px) {
  .top-lead_deco--img:first-of-type:before {
    width: 185px;
    top: 274px;
    left: -54px;
  }
}
.top-lead_deco--img:first-of-type:after {
  animation: clatter 2s cubic-bezier(0.19, 1, 0.22, 1) infinite;
  background-image: url(../../img/top-lead-deco-img-after01.webp);
  width: 134px;
  aspect-ratio: 268/350;
  top: 131px;
  left: calc(50% - 516px);
}
@media (max-width: 428px) {
  .top-lead_deco--img:first-of-type:after {
    width: 83px;
    top: 22px;
    left: 24px;
  }
}
.top-lead_deco--img:last-of-type:before {
  background-image: url(../../img/icon/icon-green-deco03.svg);
  width: 346px;
  aspect-ratio: 346/200;
  top: -49px;
  left: calc(50% + 299px);
}
@media (max-width: 428px) {
  .top-lead_deco--img:last-of-type:before {
    width: 173px;
    top: 15px;
    left: auto;
    right: -67px;
  }
}
.top-lead_deco--img:last-of-type:after {
  animation: clatter 2s cubic-bezier(0.19, 1, 0.22, 1) 1s infinite;
  background-image: url(../../img/top-lead-deco-img-after02.webp);
  width: 309px;
  aspect-ratio: 618/392;
  top: 152px;
  left: calc(50% + 296px);
}
@media (max-width: 428px) {
  .top-lead_deco--img:last-of-type:after {
    width: 195px;
    top: 280px;
    left: auto;
    right: 20px;
  }
}

.top-how {
  background-color: #fff;
  padding-bottom: 130px;
  position: relative;
}
@media (max-width: 428px) {
  .top-how {
    padding-bottom: 60px;
  }
}
.top-how:before {
  content: "";
  display: block;
  width: 387px;
  aspect-ratio: 387/107;
  background-image: url(../../img/icon/icon-green-deco04.svg);
  background-position: 50% 50%;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 23px;
  left: calc(50% + 283px);
}
@media (max-width: 428px) {
  .top-how:before {
    content: none;
  }
}
.top-how:after {
  content: "";
  display: block;
  width: 346px;
  aspect-ratio: 346/200;
  background-image: url(../../img/icon/icon-green-deco03.svg);
  background-position: 50% 50%;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  bottom: 23px;
  left: calc(50% - 668px);
}
@media (max-width: 428px) {
  .top-how:after {
    content: none;
  }
}
.top-how--inner {
  border-radius: 30px;
  background-color: rgba(211, 236, 215, 0.9);
  padding: 60px 65px;
  box-sizing: border-box;
  position: relative;
  z-index: 100;
}
@media (max-width: 428px) {
  .top-how--inner {
    padding: 40px 15px;
  }
}
.top-how--link {
  color: #fff;
  font-weight: 700;
  font-size: 18px;
  width: 320px;
  height: 60px;
  border-radius: 60px;
  background-color: #0E7EC3;
  margin: 60px auto 0;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
@media (max-width: 428px) {
  .top-how--link {
    width: 100%;
    height: 60px;
    margin-top: 40px;
  }
}
.top-how--link:after {
  content: "";
  display: block;
  background-image: url(../../img/icon/icon-arrow-white.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  width: 11px;
  aspect-ratio: 11/17;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 23px;
  transition: 0.3s;
}
@media (max-width: 428px) {
  .top-how--link:after {
    width: 9px;
    right: 16px;
  }
}
.top-how--link:hover:after {
  right: 16px;
}
@media (max-width: 428px) {
  .top-how--link:hover:after {
    right: 16px;
  }
}

.top-how_ttl {
  text-align: center;
}
.top-how_ttl--main {
  color: #0E7EC3;
  font-weight: 700;
  font-size: 55px;
  display: block;
}
@media (max-width: 428px) {
  .top-how_ttl--main {
    font-size: 32px;
  }
}
.top-how_ttl--sub {
  font-weight: 700;
  font-size: 22px;
  color: #5BBF53;
  display: block;
  margin-top: 15px;
}
@media (max-width: 428px) {
  .top-how_ttl--sub {
    font-size: 15px;
    margin-top: 13px;
  }
}

.top-how_list {
  margin-top: 34px;
}
@media (max-width: 428px) {
  .top-how_list {
    margin-top: 30px;
  }
}
.top-how_list--item {
  background-color: #fff;
  border-radius: 20px;
  margin-top: 53px;
  padding: 30px 50px;
  box-sizing: border-box;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  position: relative;
}
@media (max-width: 428px) {
  .top-how_list--item {
    margin-top: 44px;
    padding: 46px 20px 24px;
    display: block;
  }
}
.top-how_list--item:before {
  content: "";
  display: block;
  width: 126px;
  aspect-ratio: 130/130;
  border-radius: 50%;
  border: 4px solid #0E7EC3;
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
@media (max-width: 428px) {
  .top-how_list--item:before {
    width: 97px;
    border-width: 3px;
    position: absolute;
    top: 24px;
    left: 20px;
  }
}
.top-how_list--item:after {
  content: "";
  display: block;
  background-color: #0E7EC3;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  width: 24px;
  aspect-ratio: 26/18;
  position: absolute;
  bottom: -36px;
  left: 50%;
  transform: translateX(-50%);
}
@media (max-width: 428px) {
  .top-how_list--item:after {
    bottom: -32px;
  }
}
.top-how_list--item:first-of-type {
  margin-top: 0;
}
.top-how_list--item:first-of-type:before {
  background-image: url(../../img/top-how-list-item01.svg);
  background-size: 72px auto;
}
@media (max-width: 428px) {
  .top-how_list--item:first-of-type:before {
    background-size: 51px auto;
  }
}
.top-how_list--item:nth-of-type(2):before {
  background-image: url(../../img/top-how-list-item02.svg);
  background-size: 40px auto;
}
@media (max-width: 428px) {
  .top-how_list--item:nth-of-type(2):before {
    background-size: 29px auto;
  }
}
.top-how_list--item:nth-of-type(3):before {
  background-image: url(../../img/top-how-list-item03.svg);
  background-size: 61px auto;
}
@media (max-width: 428px) {
  .top-how_list--item:nth-of-type(3):before {
    background-size: 43px auto;
  }
}
.top-how_list--item:last-of-type:before {
  background-image: url(../../img/top-how-list-item04.svg);
  background-size: 61px auto;
}
@media (max-width: 428px) {
  .top-how_list--item:last-of-type:before {
    background-size: 43px auto;
  }
}
.top-how_list--item:last-of-type:after {
  content: none;
}
.top-how_list--inner {
  width: 520px;
}
@media (max-width: 428px) {
  .top-how_list--inner {
    width: 100%;
  }
}
.top-how_list--step {
  color: #5BBF53;
  font-weight: 700;
  font-size: 16px;
}
@media (max-width: 428px) {
  .top-how_list--step {
    margin-left: 120px;
  }
}
.top-how_list--ttl {
  font-size: 30px;
  font-weight: 700;
  margin-top: 10px;
}
@media (max-width: 428px) {
  .top-how_list--ttl {
    margin-left: 120px;
  }
}
.top-how_list--desc {
  font-size: 16px;
  line-height: 1.8;
  letter-spacing: 0.04em;
  margin-top: 10px;
}
@media (max-width: 428px) {
  .top-how_list--desc {
    margin-top: 38px;
  }
}

.top-price {
  background-color: #fff;
  padding-bottom: 130px;
}
@media (max-width: 428px) {
  .top-price {
    padding-bottom: 60px;
  }
}
.top-price--desc {
  font-weight: 700;
  font-size: 20px;
  margin-top: 32px;
  text-align: center;
}
@media (max-width: 428px) {
  .top-price--desc {
    font-size: 24px;
    line-height: 1.45;
    margin-top: 20px;
  }
}
.top-price--model_ttl {
  font-weight: 700;
  font-size: 32px;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  margin-top: 55px;
  position: relative;
  display: flex;
  align-items: center;
}
@media (max-width: 428px) {
  .top-price--model_ttl {
    font-size: 26px;
    margin-top: 40px;
  }
}
.top-price--model_ttl:before {
  content: "";
  display: block;
  width: 8px;
  aspect-ratio: 8/39;
  background-image: url(../../img/icon/icon-parentheses.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 50% 50%;
  margin-right: 10px;
}
@media (max-width: 428px) {
  .top-price--model_ttl:before {
    margin-right: 7px;
  }
}
.top-price--model_ttl:after {
  content: "";
  display: block;
  width: 8px;
  aspect-ratio: 8/39;
  background-image: url(../../img/icon/icon-parentheses.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 50% 50%;
  margin-left: 10px;
  transform: scale(-1, 1);
}
@media (max-width: 428px) {
  .top-price--model_ttl:after {
    margin-left: 7px;
  }
}

.top-price_ttl {
  text-align: center;
}
.top-price_ttl--main {
  display: block;
  font-weight: 700;
  font-size: 55px;
}
@media (max-width: 428px) {
  .top-price_ttl--main {
    font-size: 32px;
  }
}
.top-price_ttl--sub {
  font-size: 22px;
  font-weight: 700;
  color: #5BBF53;
  margin-top: 16px;
  display: block;
}
@media (max-width: 428px) {
  .top-price_ttl--sub {
    font-size: 15px;
    margin-top: 13px;
  }
}

.top-price_point {
  display: flex;
  justify-content: space-between;
  margin-top: 55px;
}
@media (max-width: 428px) {
  .top-price_point {
    margin-top: 20px;
    display: block;
  }
}
.top-price_point--item {
  width: 281px;
  aspect-ratio: 285/285;
  border-radius: 50%;
  border: 4px solid #0E7EC3;
  position: relative;
}
@media (max-width: 428px) {
  .top-price_point--item {
    border: none;
    border-radius: 0px;
    width: 100%;
    aspect-ratio: auto;
    padding-left: 98px;
    box-sizing: border-box;
    padding-top: 11px;
    padding-bottom: 11px;
    min-height: 98px;
    display: flex;
    align-items: center;
  }
}
.top-price_point--item:before {
  content: "";
  display: block;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 428px) {
  .top-price_point--item:before {
    position: absolute;
    top: 11px;
    left: 0;
    border: 2px solid #0E7EC3;
    border-radius: 50%;
    box-sizing: border-box;
  }
}
.top-price_point--item:first-of-type:before {
  background-image: url(../../img/top-price-point-item01.svg);
  width: 69px;
  aspect-ratio: 69/70;
  margin-bottom: 38px;
  margin-top: 36px;
}
@media (max-width: 428px) {
  .top-price_point--item:first-of-type:before {
    width: 90px;
    aspect-ratio: 90/90;
    margin-bottom: 0;
    margin-top: 0;
    background-size: 50px auto;
  }
}
@media (max-width: 428px) {
  .top-price_point--item:nth-of-type(2) {
    padding-bottom: 22px;
  }
}
.top-price_point--item:nth-of-type(2):before {
  background-image: url(../../img/top-price-point-item02.svg);
  width: 66px;
  aspect-ratio: 66/63;
  margin-bottom: 38px;
  margin-top: 42px;
}
@media (max-width: 428px) {
  .top-price_point--item:nth-of-type(2):before {
    width: 90px;
    aspect-ratio: 90/90;
    margin-bottom: 0;
    margin-top: 0;
    background-size: 50px auto;
  }
}
.top-price_point--item:last-of-type:before {
  background-image: url(../../img/top-price-point-item03.svg);
  width: 61px;
  aspect-ratio: 61/65;
  margin-bottom: 37px;
  margin-top: 44px;
}
@media (max-width: 428px) {
  .top-price_point--item:last-of-type:before {
    width: 90px;
    aspect-ratio: 90/90;
    margin-bottom: 0;
    margin-top: 0;
    background-size: 42px auto;
  }
}
.top-price_point--txt {
  font-size: 25px;
  font-weight: 700;
  text-align: center;
  line-height: 1.2;
}
@media (max-width: 428px) {
  .top-price_point--txt {
    font-size: 27px;
    text-align: left;
  }
}
.top-price_point--strong {
  color: #0E7EC3;
  font-size: 28px;
}
@media (max-width: 428px) {
  .top-price_point--strong {
    font-size: 30px;
  }
}
.top-price_point--num {
  font-size: 30px;
}
@media (max-width: 428px) {
  .top-price_point--num {
    font-size: 33px;
  }
}
.top-price_point--small {
  font-size: 22px;
}
@media (max-width: 428px) {
  .top-price_point--small {
    font-size: 25px;
  }
}
.top-price_point--note {
  font-weight: 700;
  font-size: 16px;
  margin-top: 14px;
  text-align: center;
}
@media (max-width: 428px) {
  .top-price_point--note {
    font-size: 19px;
    margin-top: 5px;
    margin-left: -1em;
  }
}
.top-price_point--serif {
  font-weight: 700;
  line-height: 1.15;
  text-align: center;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #FFEF6A;
  border-radius: 50%;
  width: 94px;
  aspect-ratio: 94/94;
  position: absolute;
  top: -5px;
  left: 20px;
}
@media (max-width: 428px) {
  .top-price_point--serif {
    font-size: 13px;
    width: 63px;
    left: 278px;
    top: -16px;
  }
}

.top-price_model {
  margin-top: 25px;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 428px) {
  .top-price_model {
    margin-top: 20px;
    display: block;
  }
}
.top-price_model--item {
  width: 285px;
  border: 3px solid #0E7EC3;
  border-radius: 20px;
  overflow: hidden;
  box-sizing: border-box;
}
@media (max-width: 428px) {
  .top-price_model--item {
    width: 100%;
    border-radius: 17px;
    margin-top: 13px;
  }
}
.top-price_model--item:after {
  content: "";
  display: block;
  width: 100%;
  height: 238px;
  background-position: 50% 50%, 50% 50%;
  background-repeat: no-repeat, no-repeat;
}
@media (max-width: 428px) {
  .top-price_model--item:after {
    height: 145px;
  }
}
@media (max-width: 428px) {
  .top-price_model--item:first-of-type {
    margin-top: 0;
  }
}
.top-price_model--item:first-of-type:after {
  background-image: url(../../img/top-price-model-item01.svg), url(../../img/icon/icon-stripe-green.svg);
  background-size: 172px auto, cover;
}
@media (max-width: 428px) {
  .top-price_model--item:first-of-type:after {
    background-image: url(../../img/top-price-model-item-sp01.svg), url(../../img/icon/icon-stripe-green.svg);
    background-size: 316px auto, cover;
  }
}
.top-price_model--item:nth-of-type(2):after {
  background-image: url(../../img/top-price-model-item02.svg), url(../../img/icon/icon-stripe-green.svg);
  background-size: 180px auto, cover;
}
@media (max-width: 428px) {
  .top-price_model--item:nth-of-type(2):after {
    background-image: url(../../img/top-price-model-item-sp03.svg), url(../../img/icon/icon-stripe-green.svg);
    background-size: 321px auto, cover;
  }
}
.top-price_model--item:last-of-type:after {
  background-image: url(../../img/top-price-model-item03.svg), url(../../img/icon/icon-stripe-green.svg);
  background-size: 169px auto, cover;
}
@media (max-width: 428px) {
  .top-price_model--item:last-of-type:after {
    background-image: url(../../img/top-price-model-item-sp03.svg), url(../../img/icon/icon-stripe-green.svg);
    background-size: 310px auto, cover;
  }
}
.top-price_model--txt {
  color: #fff;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0.08em;
  background-color: #0E7EC3;
  height: 62px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.top-cta {
  background-color: #5EB457;
  position: relative;
}
.top-cta--inner {
  padding-top: 80px;
  padding-bottom: 80px;
}
@media (max-width: 428px) {
  .top-cta--inner {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

.top-cta_list {
  display: flex;
  justify-content: center;
}
@media (max-width: 428px) {
  .top-cta_list {
    display: block;
  }
}
.top-cta_list--item {
  width: 412px;
  margin-right: 20px;
}
@media (max-width: 428px) {
  .top-cta_list--item {
    width: 100%;
    margin-right: 0;
  }
}
.top-cta_list--item:last-of-type {
  margin-right: 0;
}
@media (max-width: 428px) {
  .top-cta_list--item:last-of-type {
    margin-top: 20px;
  }
}
.top-cta_list--link {
  width: 100%;
  height: 100px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: 700;
  position: relative;
  box-sizing: border-box;
}
@media (max-width: 428px) {
  .top-cta_list--link {
    height: 80px;
    font-size: 20px;
  }
}
.top-cta_list--link:before {
  content: "";
  display: block;
  width: 50px;
  aspect-ratio: 50/50;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 15px;
  border-radius: 50%;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}
@media (max-width: 428px) {
  .top-cta_list--link:before {
    left: 16px;
  }
}
.top-cta_list--link:after {
  content: "";
  display: block;
  width: 11px;
  aspect-ratio: 11/17;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 30px;
  transition: 0.3s;
}
@media (max-width: 428px) {
  .top-cta_list--link:after {
    right: 14px;
  }
}
.top-cta_list--link:hover:after {
  right: 24px;
}
@media (max-width: 428px) {
  .top-cta_list--link:hover:after {
    right: 14px;
  }
}
.top-cta_list--link-contact {
  background-color: #fff;
  color: #5BBF53;
}
@media (max-width: 428px) {
  .top-cta_list--link-contact {
    padding-left: 29px;
  }
}
.top-cta_list--link-contact:before {
  background-color: #5BBF53;
  background-image: url(../../img/icon/icon-yen.svg);
  background-size: 19px auto;
}
.top-cta_list--link-contact:after {
  background-image: url(../../img/icon/icon-arrow-green.svg);
}
.top-cta_list--link-search {
  background-color: #FFE82D;
}
@media (max-width: 428px) {
  .top-cta_list--link-search {
    padding-left: 25px;
  }
}
.top-cta_list--link-search:before {
  background-color: #fff;
  background-image: url(../../img/icon/icon-search.svg);
  background-size: 27px auto;
}
.top-cta_list--link-search:after {
  background-image: url(../../img/icon/icon-arrow-black.svg);
}

.top-cta_deco--img:before {
  content: "";
  display: block;
  background-position: 50% 50%;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  background-image: url(../../img/icon/icon-green-deco03.svg);
  width: 346px;
  aspect-ratio: 346/200;
}
@media (max-width: 428px) {
  .top-cta_deco--img:before {
    width: 173px;
  }
}
.top-cta_deco--img:after {
  content: "";
  display: block;
  background-position: 50% 50%;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
}
.top-cta_deco--img:first-of-type:before {
  left: calc(50% - 875px);
  bottom: -109px;
}
@media (max-width: 428px) {
  .top-cta_deco--img:first-of-type:before {
    left: -106px;
    bottom: -43px;
    aspect-ratio: 173/100;
    background-image: url(../../img/icon/icon-green-deco05.svg);
  }
}
.top-cta_deco--img:first-of-type:after {
  background-image: url(../../img/icon/icon-wave2.svg);
  width: 95px;
  aspect-ratio: 95/42;
  left: calc(50% - 731px);
  top: 46px;
}
@media (max-width: 428px) {
  .top-cta_deco--img:first-of-type:after {
    left: -26px;
    top: 8px;
    width: 83px;
    aspect-ratio: 83/42;
  }
}
.top-cta_deco--img:last-of-type:before {
  left: calc(50% + 439px);
  top: -141px;
}
@media (max-width: 428px) {
  .top-cta_deco--img:last-of-type:before {
    left: auto;
    right: -72px;
    top: -69px;
  }
}
.top-cta_deco--img:last-of-type:after {
  background-image: url(../../img/icon/icon-wave.svg);
  left: calc(50% + 602px);
  top: 134px;
  width: 96px;
  aspect-ratio: 96/29;
}
@media (max-width: 428px) {
  .top-cta_deco--img:last-of-type:after {
    left: auto;
    top: 259px;
    width: 94px;
    right: -22px;
  }
}

.top-recommend {
  padding-top: 100px;
  padding-bottom: 113px;
}
@media (max-width: 428px) {
  .top-recommend {
    background-color: #F9F8F3;
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

.top-recommend_ttl--note {
  display: block;
  font-size: 24px;
  line-height: 1.2083333333;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 428px) {
  .top-recommend_ttl--note {
    font-size: 20px;
    line-height: 1.45;
    padding-left: 12px;
  }
}
.top-recommend_ttl--note:after {
  content: "";
  display: block;
  background-position: 50% 50%;
  background-size: contain;
  background-repeat: no-repeat;
  background-image: url(../../img/top-recommend-ttl-note.svg);
  width: 279px;
  aspect-ratio: 279/11;
  margin: 8px auto 0;
}
@media (max-width: 428px) {
  .top-recommend_ttl--note:after {
    background-image: url(../../img/top-recommend-ttl-note-sp.svg);
    width: 235px;
    aspect-ratio: 235/11;
    margin-top: -2px;
  }
}
.top-recommend_ttl--main {
  color: #0E7EC3;
  font-weight: 700;
  font-size: 55px;
  margin: 4px auto 0;
  display: block;
  width: fit-content;
  position: relative;
}
@media (max-width: 428px) {
  .top-recommend_ttl--main {
    font-size: 38px;
    line-height: 1.35;
    text-align: center;
    margin-top: -6px;
  }
}
.top-recommend_ttl--main:after {
  content: "";
  display: block;
  width: 48px;
  aspect-ratio: 48/51;
  position: absolute;
  top: -26px;
  right: -22px;
  background-position: 50% 50%;
  background-size: contain;
  background-repeat: no-repeat;
  background-image: url(../../img/icon/icon-attention-blue.svg);
}
@media (max-width: 428px) {
  .top-recommend_ttl--main:after {
    width: 29px;
    aspect-ratio: 29/28;
    top: auto;
    left: auto;
    right: -12px;
    bottom: 33px;
    background-image: url(../../img/icon/icon-attention-blue2.svg);
  }
}
.top-recommend_ttl--sub {
  display: block;
  color: #5BBF53;
  font-size: 22px;
  font-weight: 700;
  margin-top: 16px;
  text-align: center;
}
@media (max-width: 428px) {
  .top-recommend_ttl--sub {
    font-size: 15px;
    margin-top: 10px;
    padding-right: 15px;
  }
}

.top-recommend_list {
  margin-top: 68px;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 428px) {
  .top-recommend_list {
    margin-top: 39px;
    display: block;
  }
}
.top-recommend_list--group {
  width: 440px;
}
@media (max-width: 428px) {
  .top-recommend_list--group {
    width: 100%;
  }
}
.top-recommend_list--group:first-of-type .top-recommend_list--term {
  background-color: #5BBF53;
}
.top-recommend_list--group:first-of-type .top-recommend_class:before {
  background-image: url(../../img/top-recommend-class01.webp);
}
.top-recommend_list--group:first-of-type .top-recommend_class--txt {
  background-color: #D7EEDB;
}
.top-recommend_list--group:first-of-type .top-recommend_class--means {
  border: 2px solid #5BBF53;
  color: #5BBF53;
}
.top-recommend_list--group:first-of-type .top-recommend_price--period {
  color: #5BBF53;
}
.top-recommend_list--group:first-of-type .top-recommend_price--num {
  color: #5BBF53;
}
.top-recommend_list--group:first-of-type .top-recommend_list--desc_link {
  background-color: #5BBF53;
}
.top-recommend_list--group:last-of-type {
  transition-delay: 0.15s;
}
@media (max-width: 428px) {
  .top-recommend_list--group:last-of-type {
    margin-top: 50px;
    transition-delay: 0s;
  }
}
.top-recommend_list--group:last-of-type .top-recommend_list--term {
  background-color: #0E7EC3;
}
.top-recommend_list--group:last-of-type .top-recommend_class:before {
  background-image: url(../../img/top-recommend-class02.webp);
}
.top-recommend_list--group:last-of-type .top-recommend_class--txt {
  background-color: #DDF3F2;
}
.top-recommend_list--group:last-of-type .top-recommend_class--means {
  border: 2px solid #0E7EC3;
  color: #0E7EC3;
  margin-right: 10px;
}
@media (max-width: 428px) {
  .top-recommend_list--group:last-of-type .top-recommend_class--means {
    margin-right: 2px;
  }
}
.top-recommend_list--group:last-of-type .top-recommend_price--period {
  color: #0E7EC3;
}
.top-recommend_list--group:last-of-type .top-recommend_price--num {
  color: #0E7EC3;
}
.top-recommend_list--group:last-of-type .top-recommend_list--desc_link {
  background-color: #0E7EC3;
}
.top-recommend_list--term {
  padding: 19px 76px 18px;
  position: relative;
  border-radius: 30px 30px 0px 0px;
}
@media (max-width: 428px) {
  .top-recommend_list--term {
    padding: 15px 0 11px;
    border-radius: 25px 25px 0px 0px;
  }
}
.top-recommend_list--term_txt {
  font-size: 24px;
  font-weight: 700;
  color: #fff;
  line-height: 1.4583333333;
}
@media (max-width: 428px) {
  .top-recommend_list--term_txt {
    text-align: center;
    font-size: 20px;
    line-height: 1.45;
  }
}
.top-recommend_list--term_plan {
  font-weight: 700;
  line-height: 1.2;
  font-size: 20px;
  transform: rotate(-30deg);
  border-radius: 50%;
  background-color: #FFEF6A;
  width: 90px;
  aspect-ratio: 90/90;
  position: absolute;
  top: -48px;
  left: -11px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
@media (max-width: 428px) {
  .top-recommend_list--term_plan {
    font-size: 15px;
    width: 68px;
    top: -42px;
    left: -9px;
  }
}
.top-recommend_list--desc {
  border: 3px dashed #B8B8B8;
  border-top: none;
  background-color: #fff;
  padding: 42px 30px 50px;
  border-radius: 0px 0px 30px 30px;
}
@media (max-width: 428px) {
  .top-recommend_list--desc {
    padding: 33px 23px 39px;
    border-radius: 0px 0px 25px 25px;
  }
}
.top-recommend_list--desc_link {
  width: 320px;
  height: 60px;
  border-radius: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 700;
  font-size: 18px;
  margin: 20px auto 0;
  position: relative;
}
@media (max-width: 428px) {
  .top-recommend_list--desc_link {
    width: 251px;
    height: 47px;
    margin-top: 15px;
    font-size: 16px;
  }
}
.top-recommend_list--desc_link:after {
  content: "";
  display: block;
  background-image: url(../../img/icon/icon-arrow-white.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  width: 11px;
  aspect-ratio: 11/17;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 23px;
  transition: 0.3s;
}
@media (max-width: 428px) {
  .top-recommend_list--desc_link:after {
    width: 8px;
    right: 16px;
  }
}
.top-recommend_list--desc_link:hover:after {
  right: 16px;
}
@media (max-width: 428px) {
  .top-recommend_list--desc_link:hover:after {
    right: 16px;
  }
}

.top-recommend_class {
  border-radius: 10px;
  overflow: hidden;
}
@media (max-width: 428px) {
  .top-recommend_class {
    border-radius: 15px;
  }
}
.top-recommend_class:before {
  content: "";
  display: block;
  width: 100%;
  aspect-ratio: 380/190;
  background-position: 50% 50%;
  background-size: contain;
  background-repeat: no-repeat;
}
.top-recommend_class--txt {
  padding: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 428px) {
  .top-recommend_class--txt {
    padding: 6px;
  }
}
.top-recommend_class--means {
  font-size: 18px;
  font-weight: 700;
  color: #5BBF53;
  background-color: #fff;
  padding: 8px 18px;
  box-sizing: border-box;
  border-radius: 30px;
  margin-right: 16px;
  box-sizing: border-box;
}
@media (max-width: 428px) {
  .top-recommend_class--means {
    font-size: 14px;
    padding: 6px 12px;
    margin-right: 6px;
  }
}
.top-recommend_class--name {
  font-weight: 700;
  font-size: 18px;
}
@media (max-width: 428px) {
  .top-recommend_class--name {
    font-size: 15px;
  }
}

.top-recommend_price {
  margin-top: 30px;
  text-align: center;
}
@media (max-width: 428px) {
  .top-recommend_price {
    margin-top: 23px;
  }
}
.top-recommend_price--period {
  font-weight: 700;
  font-size: 24px;
  letter-spacing: 0.06em;
}
@media (max-width: 428px) {
  .top-recommend_price--period {
    font-size: 20px;
  }
}
.top-recommend_price--unit {
  font-weight: 700;
  font-size: 20px;
  margin-right: 8px;
}
@media (max-width: 428px) {
  .top-recommend_price--unit {
    font-size: 16px;
    margin-right: 4px;
  }
}
.top-recommend_price--num {
  font-weight: 700;
  font-size: 40px;
}
@media (max-width: 428px) {
  .top-recommend_price--num {
    font-size: 32px;
  }
}
.top-recommend_price--yen {
  font-size: 26px;
  letter-spacing: -0.25em;
  font-weight: 700;
}
@media (max-width: 428px) {
  .top-recommend_price--yen {
    font-size: 20px;
  }
}
.top-recommend_price--exclamation {
  font-size: 40px;
  font-weight: 700;
}
@media (max-width: 428px) {
  .top-recommend_price--exclamation {
    font-size: 32px;
  }
}

.top-spot {
  background-color: #5EB457;
  position: relative;
}
.top-spot:before {
  content: "";
  display: block;
  width: 204px;
  aspect-ratio: 408/290;
  background-image: url(../../img/top-spot01.webp);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  position: absolute;
  top: 21px;
  left: calc(50% - 691px);
  animation: clatter 2s cubic-bezier(0.19, 1, 0.22, 1) infinite;
}
@media (max-width: 428px) {
  .top-spot:before {
    width: 118px;
    top: -42px;
    left: 15px;
  }
}
.top-spot:after {
  content: "";
  display: block;
  width: 206px;
  aspect-ratio: 412/306;
  background-image: url(../../img/top-spot02.webp);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  position: absolute;
  bottom: 21px;
  left: calc(50% + 477px);
  z-index: 100;
  animation: clatter 2s cubic-bezier(0.19, 1, 0.22, 1) 1s infinite;
}
@media (max-width: 428px) {
  .top-spot:after {
    width: 122px;
    bottom: -44px;
    left: auto;
    right: 9px;
  }
}
.top-spot--inner {
  padding: 62px 0;
}
@media (max-width: 428px) {
  .top-spot--inner {
    padding-top: 55px;
    padding-bottom: 55px;
  }
}

.top-spot_ttl--note {
  width: 272px;
  height: 45px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #0E7EC3;
  font-size: 20px;
  font-weight: 700;
  margin-left: auto;
  margin-right: auto;
  background-image: url(../../img/top-spot-ttl-note.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  padding-bottom: 5px;
  box-sizing: border-box;
}
.top-spot_ttl--main {
  color: #fff;
  font-weight: 700;
  font-size: 40px;
  letter-spacing: 0.03em;
  text-align: center;
  margin-top: 6px;
  display: block;
}
@media (max-width: 428px) {
  .top-spot_ttl--main {
    font-size: 36px;
    line-height: 1.25;
    margin-top: 10px;
  }
}

.top-spot_link {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background-color: #0E7EC3;
  width: 445px;
  height: 78px;
  border-radius: 10px;
  margin: 36px auto 0;
  position: relative;
}
@media (max-width: 428px) {
  .top-spot_link {
    width: 100%;
    margin-top: 54px;
  }
}
.top-spot_link:after {
  content: "";
  display: block;
  background-image: url(../../img/icon/icon-arrow-white.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  width: 11px;
  aspect-ratio: 11/17;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 18px;
  transition: 0.3s;
}
.top-spot_link:hover:after {
  right: 12px;
}
@media (max-width: 428px) {
  .top-spot_link:hover:after {
    right: 18px;
  }
}
.top-spot_link--note {
  color: #FFE82D;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.3;
  display: flex;
  justify-content: center;
  align-items: center;
}
.top-spot_link--note:before {
  content: "";
  display: block;
  width: 15px;
  height: 2px;
  background-color: #FFE82D;
  transform: rotate(-113.2deg);
  margin-right: 1px;
}
.top-spot_link--note:after {
  content: "";
  display: block;
  width: 15px;
  height: 2px;
  background-color: #FFE82D;
  transform: rotate(113.2deg);
  margin-left: 1px;
}
.top-spot_link--main {
  color: #fff;
  font-weight: 700;
  font-size: 24px;
  margin-top: 5px;
}

.top-faq {
  padding-top: 130px;
  padding-bottom: 130px;
  background-color: #fff;
  position: relative;
}
@media (max-width: 428px) {
  .top-faq {
    padding-top: 44px;
    padding-bottom: 60px;
  }
}
.top-faq:before {
  content: "";
  display: block;
  background-image: url(../../img/icon/icon-green-deco06.svg);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  width: 345px;
  aspect-ratio: 345/199;
  position: absolute;
  top: -76px;
  left: calc(50% - 735px);
}
@media (max-width: 428px) {
  .top-faq:before {
    content: none;
  }
}
.top-faq:after {
  content: "";
  display: block;
  background-image: url(../../img/icon/icon-green-deco03.svg);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  width: 345px;
  aspect-ratio: 346/200;
  position: absolute;
  top: 332px;
  left: calc(50% + 425px);
}
@media (max-width: 428px) {
  .top-faq:after {
    content: none;
  }
}
.top-faq--inner {
  position: relative;
  z-index: 100;
}
.top-faq--inner:before {
  content: "";
  display: block;
  background-image: url(../../img/icon/icon-green-deco04.svg);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  width: 387px;
  aspect-ratio: 387/107;
  position: absolute;
  top: 777px;
  left: calc(50% - 758px);
}
@media (max-width: 428px) {
  .top-faq--inner:before {
    content: none;
  }
}
.top-faq--wrap {
  border: 3px solid #0E7EC3;
  padding: 40px 40px 60px;
  background-color: #F9F8F3;
  border-radius: 0 0 30px 30px;
  position: relative;
}
@media (max-width: 428px) {
  .top-faq--wrap {
    border-width: 2px;
    padding: 15px;
  }
}
.top-faq--link {
  width: 320px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #0E7EC3;
  margin: 40px auto 0;
  border-radius: 10px;
  color: #fff;
  font-weight: 700;
  font-size: 18px;
  position: relative;
}
@media (max-width: 428px) {
  .top-faq--link {
    width: 100%;
  }
}
.top-faq--link:after {
  content: "";
  display: block;
  background-image: url(../../img/icon/icon-arrow-white.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  width: 11px;
  aspect-ratio: 11/17;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 18px;
  transition: 0.3s;
}
.top-faq--link:hover:after {
  right: 12px;
}
@media (max-width: 428px) {
  .top-faq--link:hover:after {
    right: 18px;
  }
}

.top-faq_ttl {
  background-color: #0E7EC3;
  padding-top: 25px;
  padding-bottom: 25px;
  border-radius: 30px 30px 0 0;
}
@media (max-width: 428px) {
  .top-faq_ttl {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}
.top-faq_ttl--note {
  color: #fff;
  font-size: 24px;
  font-weight: 700;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.5;
  display: block;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 428px) {
  .top-faq_ttl--note {
    font-size: 20px;
    line-height: 1.45;
  }
}
.top-faq_ttl--note:before {
  content: "";
  display: block;
  width: 23px;
  height: 2px;
  background-color: #0E7EC3;
  transform: rotate(70.02deg);
  background-color: #fff;
}
@media (max-width: 428px) {
  .top-faq_ttl--note:before {
    width: 20px;
  }
}
.top-faq_ttl--note:after {
  content: "";
  display: block;
  width: 23px;
  height: 2px;
  background-color: #0E7EC3;
  transform: rotate(-70.02deg);
  background-color: #fff;
}
@media (max-width: 428px) {
  .top-faq_ttl--note:after {
    width: 20px;
  }
}
.top-faq_ttl--main {
  font-weight: 700;
  font-size: 40px;
  color: #fff;
  display: block;
  width: fit-content;
  margin: 13px auto 0;
}
@media (max-width: 428px) {
  .top-faq_ttl--main {
    font-size: 24px;
    margin-top: 17px;
  }
}
.top-faq_ttl--strong {
  position: relative;
  display: inline-block;
}
.top-faq_ttl--strong:before {
  content: "";
  display: block;
  border-radius: 50%;
  background-color: #fff;
  width: 9px;
  aspect-ratio: 9/9;
  position: absolute;
  top: -10px;
  left: 16px;
}
@media (max-width: 428px) {
  .top-faq_ttl--strong:before {
    width: 5px;
    top: -8px;
    left: 9px;
  }
}
.top-faq_ttl--strong:after {
  content: "";
  display: block;
  border-radius: 50%;
  background-color: #fff;
  width: 9px;
  aspect-ratio: 9/9;
  position: absolute;
  top: -10px;
  left: 55px;
}
@media (max-width: 428px) {
  .top-faq_ttl--strong:after {
    width: 5px;
    top: -8px;
    left: 33px;
  }
}

.top-faq_check {
  background-color: #fff;
  border-radius: 10px;
  padding: 30px 0 30px 84px;
  box-sizing: border-box;
}
@media (max-width: 428px) {
  .top-faq_check {
    padding: 20px 15px;
  }
}
.top-faq_check--group {
  margin-top: 39px;
  padding-left: 30px;
  position: relative;
}
@media (max-width: 428px) {
  .top-faq_check--group {
    margin-top: 10px;
    padding-left: 24px;
  }
}
.top-faq_check--group:first-of-type {
  margin-top: 0;
}
.top-faq_check--group:before {
  content: "";
  display: block;
  width: 22px;
  aspect-ratio: 22/22;
  border-radius: 50%;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url(../../img/icon/icon-check-blue.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
@media (max-width: 428px) {
  .top-faq_check--group:before {
    width: 16px;
    top: 2px;
  }
}
.top-faq_check--term {
  font-size: 24px;
  font-weight: 700;
}
@media (max-width: 428px) {
  .top-faq_check--term {
    font-size: 18px;
    line-height: 1.35;
  }
}
.top-faq_check--strong {
  color: #0E7EC3;
}
.top-faq_check--desc {
  font-size: 16px;
  line-height: 1.4375;
  margin-top: 7px;
}
@media (max-width: 428px) {
  .top-faq_check--desc {
    margin-top: 6px;
  }
}

.top-faq_qa {
  margin-top: 50px;
  position: relative;
}
@media (max-width: 428px) {
  .top-faq_qa {
    margin-top: 62px;
  }
}
.top-faq_qa:before {
  content: "";
  display: block;
  width: 128px;
  aspect-ratio: 256/266;
  background-image: url(../../img/top-faq-qa.webp);
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  position: absolute;
  top: -133px;
  right: 0;
}
@media (max-width: 428px) {
  .top-faq_qa:before {
    width: 95px;
    top: -100px;
  }
}
.top-faq_qa--group {
  margin-top: 32px;
}
@media (max-width: 428px) {
  .top-faq_qa--group {
    margin-top: 24px;
  }
}
.top-faq_qa--group:first-of-type {
  margin-top: 0;
}
.top-faq_qa--link {
  background-color: #fff;
  border-radius: 10px;
  box-sizing: border-box;
  padding: 16px 64px 16px 84px;
  display: flex;
  align-items: center;
  position: relative;
}
@media (max-width: 428px) {
  .top-faq_qa--link {
    padding: 16px 48px 16px 68px;
  }
}
.top-faq_qa--link:before {
  content: "";
  width: 36px;
  aspect-ratio: 36/36;
  position: absolute;
  top: 16px;
  left: 24px;
  background-image: url(../../img/icon/icon-question.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
@media (max-width: 428px) {
  .top-faq_qa--link:before {
    left: 16px;
  }
}
.top-faq_qa--link:after {
  content: "";
  width: 16px;
  aspect-ratio: 16/16;
  position: absolute;
  top: 26px;
  right: 24px;
  background-image: url(../../img/icon/icon-plus-blue.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
@media (max-width: 428px) {
  .top-faq_qa--link:after {
    right: 16px;
  }
}
.is_open .top-faq_qa--link:after {
  background-image: url(../../img/icon/icon-minus-blue.svg);
}
.top-faq_qa--term_txt {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.5;
}
@media (max-width: 428px) {
  .top-faq_qa--term_txt {
    font-size: 18px;
    line-height: 1.4444444444;
  }
}
.top-faq_qa--desc {
  padding-left: 86px;
  position: relative;
  transition: 0.3s;
}
@media (max-width: 428px) {
  .top-faq_qa--desc {
    padding-left: 68px;
  }
}
.top-faq_qa--desc:before {
  content: "";
  width: 36px;
  aspect-ratio: 36/36;
  position: absolute;
  top: 20px;
  left: 24px;
  background-image: url(../../img/icon/icon-answer.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
@media (max-width: 428px) {
  .top-faq_qa--desc:before {
    left: 16px;
  }
}
.top-faq_qa--desc_txt {
  padding-top: 24px;
  font-size: 16px;
  line-height: 1.4375;
}
.top-faq_qa--desc_link {
  text-decoration: underline;
  color: #0E7EC3;
}

.top-station {
  background-color: #fff;
}
.top-station--inner {
  padding-top: 27px;
  height: 376px;
  box-sizing: border-box;
  background-image: url(../../img/top-station-inner01.svg);
  background-size: cover;
  position: relative;
}
@media (max-width: 428px) {
  .top-station--inner {
    padding-top: 30px;
    height: 391px;
    background-image: url(../../img/top-station-inner-sp01.svg);
  }
}
.top-station--inner:before {
  content: "";
  display: block;
  width: 189px;
  aspect-ratio: 378/380;
  background-image: url(../../img/top-station-inner02.webp);
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: contain;
  position: absolute;
  top: 156px;
  left: 50%;
  transform: translateX(-50%);
}
@media (max-width: 428px) {
  .top-station--inner:before {
    width: 141px;
    top: 249px;
  }
}
.top-station--txt {
  font-weight: 600;
  font-size: 20px;
  display: flex;
  justify-content: center;
  box-sizing: border-box;
  position: absolute;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: contain;
  transition: 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
  opacity: 0;
}
@media (max-width: 428px) {
  .top-station--txt {
    font-size: 16px;
  }
}
.is_show .top-station--txt {
  opacity: 1;
}
.top-station--txt:first-of-type {
  width: 323px;
  height: 122px;
  padding-top: 45px;
  background-image: url(../../img/top-station-txt01.svg);
  top: 27px;
  left: 50%;
  transform: translate(-50%, 60px);
}
@media (max-width: 428px) {
  .top-station--txt:first-of-type {
    width: 242px;
    height: 91px;
    top: 103px;
    left: calc(50% - 57px);
    transform: translateY(60px);
    padding-top: 31px;
    background-image: url(../../img/top-station-txt-sp01.svg);
    transition-delay: 0.15s;
  }
}
.is_show .top-station--txt:first-of-type {
  transform: translate(-50%, 0);
}
@media (max-width: 428px) {
  .is_show .top-station--txt:first-of-type {
    transform: translateY(0);
  }
}
.top-station--txt:nth-of-type(2) {
  width: 241px;
  height: 115px;
  padding-top: 40px;
  background-image: url(../../img/top-station-txt02.svg);
  top: 126px;
  left: calc(50% - 426px);
  transform: translateY(60px);
  transition-delay: 0.15s;
}
@media (max-width: 428px) {
  .top-station--txt:nth-of-type(2) {
    width: 181px;
    height: 86px;
    padding-top: 30px;
    top: 30px;
    left: calc(50% - 181px);
    background-image: url(../../img/top-station-txt-sp02.svg);
    transition-delay: 0s;
  }
}
.is_show .top-station--txt:nth-of-type(2) {
  transform: translateY(0);
}
.top-station--txt:last-of-type {
  width: 250px;
  height: 110px;
  padding-top: 42px;
  background-image: url(../../img/top-station-txt03.svg);
  top: 121px;
  left: calc(50% + 195px);
  transform: translateY(60px);
  transition-delay: 0.3s;
}
@media (max-width: 428px) {
  .top-station--txt:last-of-type {
    width: 188px;
    height: 82px;
    padding-top: 32px;
    top: 170px;
    left: calc(50% - 179px);
    background-image: url(../../img/top-station-txt-sp03.svg);
  }
}
.is_show .top-station--txt:last-of-type {
  transform: translateY(0);
}

.top-station_link {
  height: 233px;
  background-image: url(../../img/top-station-link.svg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50% 0px;
  margin-top: -73px;
  position: relative;
  box-sizing: border-box;
  padding-top: 97px;
}
@media (max-width: 428px) {
  .top-station_link {
    margin-top: -51px;
    padding-top: 87px;
    padding-bottom: 70px;
    height: auto;
    background-image: url(../../img/top-station-link-sp.svg);
  }
}
.top-station_link--btn {
  color: #fff;
  font-size: 24px;
  font-weight: 700;
  background-color: #0E7EC3;
  border-radius: 10px;
  width: 490px;
  height: 76px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: auto;
  margin-right: auto;
  position: relative;
}
@media (max-width: 428px) {
  .top-station_link--btn {
    width: calc(100% - 30px);
    font-size: 21px;
  }
}
.top-station_link--btn:after {
  content: "";
  display: block;
  background-image: url(../../img/icon/icon-arrow-white.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  width: 11px;
  aspect-ratio: 11/17;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 18px;
  transition: 0.3s;
}
.top-station_link--btn:hover:after {
  right: 12px;
}
@media (max-width: 428px) {
  .top-station_link--btn:hover:after {
    right: 18px;
  }
}

.top-station_deco--img:before {
  content: "";
  display: block;
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  position: absolute;
}
.top-station_deco--img:after {
  content: "";
  display: block;
  position: absolute;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
}
.top-station_deco--img:first-of-type:before {
  background-image: url(../../img/icon/icon-green-deco03.svg);
  width: 346px;
  aspect-ratio: 346/200;
  top: 118px;
  left: calc(50% - 751px);
}
@media (max-width: 428px) {
  .top-station_deco--img:first-of-type:before {
    width: 173px;
    top: 167px;
    left: -77px;
    background-image: url(../../img/icon/icon-green-deco06.svg);
    aspect-ratio: 345/199;
  }
}
.top-station_deco--img:first-of-type:after {
  background-image: url(../../img/icon/icon-wave4.svg);
  width: 95px;
  aspect-ratio: 95/42;
  top: 73px;
  left: calc(50% - 681px);
}
@media (max-width: 428px) {
  .top-station_deco--img:first-of-type:after {
    width: 70px;
    top: 31px;
    left: 7px;
  }
}
.top-station_deco--img:last-of-type:before {
  content: "";
  display: block;
  width: 387px;
  aspect-ratio: 387/107;
  background-image: url(../../img/icon/icon-green-deco04.svg);
  background-position: 50% 50%;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: -20px;
  left: calc(50% + 475px);
}
@media (max-width: 428px) {
  .top-station_deco--img:last-of-type:before {
    background-image: url(../../img/icon/icon-green-deco03.svg);
    width: 172px;
    aspect-ratio: 346/200;
    top: -41px;
    left: auto;
    right: -78px;
  }
}
.top-station_deco--img:last-of-type:after {
  background-image: url(../../img/icon/icon-wave3.svg);
  width: 96px;
  aspect-ratio: 96/29;
  top: 138px;
  left: calc(50% + 445px);
}
@media (max-width: 428px) {
  .top-station_deco--img:last-of-type:after {
    width: 46px;
    top: 197px;
    left: auto;
    right: 15px;
  }
}

.top-sharing {
  background-color: #F9F8F3;
}
.top-sharing--inner {
  padding-top: 78px;
  padding-bottom: 90px;
}
@media (max-width: 428px) {
  .top-sharing--inner {
    padding-top: 60px;
    padding-bottom: 40px;
  }
}

.top-sharing--note {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.5;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 428px) {
  .top-sharing--note {
    font-size: 20px;
    line-height: 1.45;
  }
}
.top-sharing--note:before {
  content: "";
  display: block;
  width: 31px;
  aspect-ratio: 31/44;
  background-image: url(../../img/icon/icon-hand.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  margin-right: 16px;
  margin-top: -10px;
}
@media (max-width: 428px) {
  .top-sharing--note:before {
    width: 24px;
    margin-right: 4px;
    margin-top: -12px;
  }
}
.top-sharing--note:after {
  content: "";
  display: block;
  width: 31px;
  aspect-ratio: 31/44;
  background-image: url(../../img/icon/icon-hand.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  margin-right: 16px;
  margin-top: -10px;
  transform: scale(-1, 1);
}
@media (max-width: 428px) {
  .top-sharing--note:after {
    width: 24px;
    margin-left: -8px;
    margin-top: -12px;
  }
}
.top-sharing--main {
  font-size: 55px;
  font-weight: 700;
  text-align: center;
  margin-top: 14px;
  display: block;
}
@media (max-width: 428px) {
  .top-sharing--main {
    font-size: 38px;
    line-height: 1.35;
    margin-top: 5px;
  }
}
.top-sharing--sub {
  color: #5BBF53;
  display: block;
  font-weight: 700;
  font-size: 22px;
  margin-top: 16px;
  text-align: center;
}
@media (max-width: 428px) {
  .top-sharing--sub {
    font-size: 15px;
    margin-top: 10px;
  }
}

.top-sharing_list {
  margin-top: 60px;
}
@media (max-width: 428px) {
  .top-sharing_list {
    margin-top: 40px;
  }
}
.top-sharing_list--item {
  margin-top: 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}
@media (max-width: 428px) {
  .top-sharing_list--item {
    display: block;
  }
}
.top-sharing_list--item:after {
  content: "";
  display: block;
  width: 415px;
  aspect-ratio: 415/290;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 50% 50%;
}
@media (max-width: 428px) {
  .top-sharing_list--item:after {
    width: 100%;
    margin-top: 16px;
  }
}
.top-sharing_list--item:first-of-type {
  margin-top: 0;
}
.top-sharing_list--item:first-of-type:after {
  background-image: url(../../img/top-sharing-list-group01.webp);
}
.top-sharing_list--item:last-of-type {
  flex-direction: row-reverse;
}
.top-sharing_list--item:last-of-type:after {
  background-image: url(../../img/top-sharing-list-group02.webp);
}
.top-sharing_list--wrap {
  width: 415px;
}
@media (max-width: 428px) {
  .top-sharing_list--wrap {
    width: 100%;
  }
}
.top-sharing_list--ttl {
  color: #0E7EC3;
  font-weight: 700;
  font-size: 32px;
  line-height: 1.4;
}
@media (max-width: 428px) {
  .top-sharing_list--ttl {
    font-size: 24px;
    text-align: center;
  }
}
.top-sharing_list--desc {
  font-size: 16px;
  line-height: 1.6;
  margin-top: 20px;
}
@media (max-width: 428px) {
  .top-sharing_list--desc {
    text-align: center;
    margin-top: 8px;
  }
}

.top-news {
  background-color: #fff;
  padding-bottom: 130px;
  position: relative;
}
@media (max-width: 428px) {
  .top-news {
    padding-bottom: 100px;
  }
}
.top-news:before {
  content: "";
  display: block;
  width: 100%;
  aspect-ratio: 1440/153;
  background-image: url(../../img/top-news01.svg);
  background-size: auto 100%;
  background-repeat: no-repeat;
  background-position: 50% 100%;
}
@media (max-width: 428px) {
  .top-news:before {
    aspect-ratio: 375/91;
    background-image: url(../../img/top-news-sp01.svg);
  }
}
.top-news:after {
  content: "";
  display: block;
  width: 211px;
  aspect-ratio: 422/334;
  background-image: url(../../img/top-news02.webp);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 50% 50%;
  position: absolute;
  top: -4.7222222222%;
  left: calc(50% - 620px);
  animation: vibration 5s infinite cubic-bezier(0.4, 0, 1, 1.3);
}
@media (max-width: 428px) {
  .top-news:after {
    width: 130px;
    top: -20px;
    left: 0;
  }
}
.top-news--inner {
  padding-top: 21px;
}
.top-news--link {
  width: 320px;
  height: 60px;
  border-radius: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background-color: #0E7EC3;
  font-size: 18px;
  font-weight: 700;
  margin: 60px auto 0;
  position: relative;
}
@media (max-width: 428px) {
  .top-news--link {
    margin-top: 40px;
  }
}
.top-news--link:after {
  content: "";
  display: block;
  background-image: url(../../img/icon/icon-arrow-white.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  width: 11px;
  aspect-ratio: 11/17;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 18px;
  transition: 0.3s;
}
.top-news--link:hover:after {
  right: 12px;
}
@media (max-width: 428px) {
  .top-news--link:hover:after {
    right: 18px;
  }
}

.top-news_ttl--main {
  display: block;
  font-size: 55px;
  font-weight: 700;
  text-align: center;
}
@media (max-width: 428px) {
  .top-news_ttl--main {
    font-size: 38px;
  }
}
.top-news_ttl--sub {
  display: block;
  color: #5BBF53;
  font-size: 22px;
  font-weight: 700;
  margin-top: 16px;
  text-align: center;
}
@media (max-width: 428px) {
  .top-news_ttl--sub {
    font-size: 15px;
    margin-top: 10px;
  }
}

.top-news_list {
  margin-top: 40px;
}
.top-news_list--item {
  border-bottom: 2px dashed #ddd;
}
.top-news_list--item:first-of-type .top-news_list--link {
  padding-top: 0;
}
.top-news_list--link {
  padding-top: 32px;
  padding-bottom: 32px;
  padding-left: 24px;
  padding-right: 53px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  position: relative;
}
@media (max-width: 428px) {
  .top-news_list--link {
    flex-wrap: wrap;
    padding: 24px 29px 24px 0;
  }
}
.top-news_list--link:after {
  content: "";
  display: block;
  width: 8px;
  aspect-ratio: 8/11;
  background-image: url(../../img/icon/icon-arrow-blue.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  position: absolute;
  bottom: 40px;
  right: 24px;
  transition: 0.3s;
}
@media (max-width: 428px) {
  .top-news_list--link:after {
    right: 0;
    bottom: 50%;
    transform: translateY(50%);
  }
}
.top-news_list--link:hover:after {
  right: 16px;
}
@media (max-width: 428px) {
  .top-news_list--link:hover:after {
    right: 0;
  }
}
.top-news_list--date {
  color: #777;
  font-size: 13px;
  letter-spacing: 0.04em;
  margin-right: 32px;
}
@media (max-width: 428px) {
  .top-news_list--date {
    margin-right: 10px;
  }
}
.top-news_list--cat {
  width: 132px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #0E7EC3;
  color: #fff;
  border-radius: 16px;
  font-size: 14px;
  letter-spacing: 0.04em;
  margin-right: 16px;
}
@media (max-width: 428px) {
  .top-news_list--cat {
    width: auto;
    padding-left: 22px;
    padding-right: 22px;
    height: 22px;
    font-size: 13px;
    margin-right: 0;
  }
}
.top-news_list--ttl {
  width: 527px;
  font-size: 16px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 400;
}
@media (max-width: 428px) {
  .top-news_list--ttl {
    width: 100%;
    margin-top: 8px;
    line-height: 1.8;
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
  }
}
.top-news_list--empty {
  font-size: 16px;
  line-height: 1.6;
}

/*# sourceMappingURL=top.css.map */
