body {
  margin: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  font-size: 1em;
}

img {
  display: block;
  max-width: 100%;
}

a {
  text-decoration: none;
}

i {
  font-style: normal;
}

ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

p {
  margin: 0;
}

input,
input[type=submit] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

dl,
dd {
  margin: 0;
}

em {
  font-style: normal;
}

* {
  box-sizing: border-box;
}

html {
  font-size: 0.2666666667vw;
}

body {
  position: relative;
  color: #333;
  line-height: 1.8;
  font-family: "Noto Sans JP", sans-serif;
}

input {
  display: block;
  font-size: 16rem;
}

textarea {
  font-size: 16rem;
}

a * {
  pointer-events: none;
}

sup {
  font-size: 0.5em;
}

@media (min-width: 769px) {
  html {
    font-size: 1px;
  }
  section {
    margin: auto;
    max-width: 1100px;
  }
}
@media (min-width: 769px) {
  .l-main {
    margin: auto;
    max-width: 1440px;
  }
}
@media screen and (min-width: 769px) {
  .l-footer .l-container {
    max-width: unset;
  }
}

.l-container {
  margin: auto;
  padding: 0 15rem;
  max-width: 768px;
  box-sizing: content-box;
}

@media (min-width: 769px) {
  .l-container {
    margin: auto;
    max-width: 600rem;
  }
}
.c-cta {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  padding: 0 12rem;
  margin: auto;
  max-width: 375rem;
  height: 120rem;
  font-size: 46rem;
  color: #fff;
  line-height: 1;
  border: solid 2rem #d20c5d;
  border-width: 2rem 2rem 4rem;
  background-color: #f4287b;
  border-radius: 5rem;
}
.c-cta::before {
  content: "\f879";
  position: absolute;
  left: 12rem;
  bottom: 24rem;
  font-size: 0.8695652em;
  font-weight: 900;
  font-family: "Font Awesome 5 Free";
}
.c-cta::after {
  content: "";
  position: absolute;
  right: 12rem;
  bottom: 38rem;
  width: 8rem;
  height: 8rem;
  border: solid 3rem #fff;
  border-width: 3rem 3rem 0 0;
  transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
}
.c-cta__text {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: -2rem;
  width: 240rem;
  height: 36rem;
  font-size: 0.347826em;
  font-weight: bold;
  color: #0d42a9;
  background-color: #fde9f1;
  border-radius: 20rem;
}
.c-cta__text::before, .c-cta__text::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 20rem;
  height: 1rem;
  background-color: #0d42a9;
}
.c-cta__text::before {
  left: calc((100% - 10em) / 2 - 20rem);
  transform: rotate(45deg);
}
.c-cta__text::after {
  right: calc((100% - 10em) / 2 - 20rem);
  transform: rotate(-45deg);
}
.c-cta__tel {
  font-size: 1em;
  font-weight: 500;
  margin: 3rem 0 5rem;
  letter-spacing: -1.01rem;
  transform: translateX(16rem);
  font-family: "Oswald", sans-serif;
}
.c-cta__hour {
  font-size: 0.326086em;
  font-weight: bold;
  transform: translateX(16rem);
}
@media screen and (min-width: 769px) {
  .c-cta {
    max-width: unset;
    width: 420rem;
  }
  .c-cta::before {
    left: 42rem;
  }
  .c-cta::after {
    right: 32rem;
  }
  .c-cta__text {
    font-size: 0.347826em;
    line-height: 1;
  }
}

.c-footer__link {
  display: flex;
  gap: 15rem;
  flex-direction: column;
  padding: 40rem 0 30rem;
}
.c-footer__link-item {
  font-size: 16rem;
  color: #525252;
}
@media screen and (min-width: 769px) {
  .c-footer__link {
    gap: 24rem;
    flex-direction: row;
    justify-content: center;
  }
}

.c-footer-form__link {
  position: relative;
  padding-right: 12rem;
  font-size: 12rem;
  color: #333;
  line-height: 1;
}
.c-footer-form__link:not(:last-child) {
  margin-right: 16rem;
}
.c-footer-form__link::after {
  content: "";
  position: absolute;
  top: 2rem;
  right: 0;
  bottom: 0;
  display: block;
  margin: auto;
  width: 4rem;
  height: 4rem;
  border: solid #333;
  border-width: 2rem 2rem 0 0;
  transform: rotate(45deg);
}
.c-footer-form__link-wrap {
  padding: 12rem 0;
  text-align: center;
  background-color: #eaecef;
}
.c-footer-form__copy {
  font-size: 10rem;
  color: #fff;
}
.c-footer-form__copy-wrap {
  padding: 10rem 0;
  text-align: center;
  background-color: #333;
}

.c-footer__copy {
  font-size: 10rem;
  color: #fff;
}
.c-footer__copy-wrap {
  padding: 10rem 0;
  text-align: center;
  background-color: #333;
}

.c-header-form {
  padding: 16rem 0;
  background-color: #1094f1;
}
.c-header-form__logo {
  max-width: 160rem;
}

.c-note {
  padding-left: 1em;
  text-indent: -1em;
  font-size: 10rem;
  line-height: normal;
}
.c-note-num {
  padding-left: 2em;
  text-indent: -2em;
}
@media screen and (min-width: 769px) {
  .c-note {
    font-size: 12rem;
  }
}

.c-input {
  padding: 0 14rem;
  width: 100%;
  height: 50rem;
  border: solid 1px #bcbcbc;
  border-radius: 4rem;
  box-sizing: border-box;
}
.c-input::-moz-placeholder {
  color: #999;
  font-size: 14rem;
}
.c-input::placeholder {
  color: #999;
  font-size: 14rem;
}

.c-step {
  padding: 16rem 0;
  background-color: #f2f2f2;
}
.c-step__wrap {
  display: flex;
  align-items: center;
  gap: 12rem;
}
.c-step__title {
  font-size: 12rem;
  font-weight: bold;
}
.c-step-indicator {
  display: flex;
  align-items: center;
  gap: 15rem;
  font-size: 12rem;
}
.c-step-indicator__item {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4.5rem;
  width: 70rem;
  height: 30rem;
  background-color: #ccc;
  counter-increment: step;
}
.c-step-indicator__item::before {
  content: counter(step);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12rem;
  width: 16rem;
  height: 16rem;
  font-weight: 500;
  border-radius: 4rem;
  background-color: #fff;
  -webkit-border-radius: 4rem;
  -moz-border-radius: 4rem;
  -ms-border-radius: 4rem;
  -o-border-radius: 4rem;
}
.c-step-indicator__item::after {
  position: absolute;
  top: 0;
  left: 100%;
  bottom: 0;
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 15px solid transparent;
  border-bottom: 15px solid transparent;
  border-left: 8px solid #ccc;
  border-right: 0;
}
.c-step-indicator__item--active {
  color: #fff;
  background-color: #1094f1;
}
.c-step-indicator__item--active::before {
  color: #1094f1;
}
.c-step-indicator__item--active::after {
  border-left: 8px solid #1094f1;
}
@media (min-width: 769px) {
  .c-step {
    max-width: unset;
  }
}

.c-title {
  font-size: 24rem;
  font-weight: bold;
  text-align: center;
  color: #515151;
  line-height: 1;
  font-family: "Noto Sans JP", sans-serif;
}
.c-title__head {
  margin-bottom: 16rem;
  font-size: 1em;
  line-height: 1.2;
}
.c-title__head-sub {
  position: relative;
  padding: 0 10rem;
  font-size: 20rem;
  background: linear-gradient(to left, #2883ff, #175fc2);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 500;
  font-family: "Oswald", sans-serif;
}
.c-title__head-sub::before, .c-title__head-sub::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  display: block;
  margin: auto;
  width: 40rem;
  height: 1rem;
  background: linear-gradient(to left, #2883ff, #175fc2);
}
.c-title__head-sub::before {
  right: 100%;
}
.c-title__head-sub::after {
  left: 100%;
}
@media screen and (min-width: 769px) {
  .c-title__head-sub {
    font-size: 24rem;
  }
}

.c-textarea {
  padding: 8rem 14rem;
  width: 100%;
  height: 160rem;
  border: solid 1px #bcbcbc;
  border-radius: 4rem;
  box-sizing: border-box;
}
.c-textarea::-moz-placeholder {
  color: #999;
}
.c-textarea::placeholder {
  color: #999;
}

.p-areaform {
  padding: 40rem 0;
  background-image: url(../img/area_bg.webp);
  background-size: cover;
  background-repeat: no-repeat;
}
.p-areaform__head {
  position: relative;
  margin-bottom: 18rem;
  font-size: 24rem;
  text-align: center;
  line-height: 1;
  color: #eb5405;
}
.p-areaform__head::before {
  content: "\f044";
  position: relative;
  top: 0;
  left: -10rem;
  bottom: 0;
  margin: auto;
  font-size: 36rem;
  font-weight: 900;
  font-family: "Font Awesome 6 Free";
}
.p-areaform__text {
  font-size: 16rem;
  line-height: normal;
}
.p-areaform__wrap {
  margin-top: 24rem;
  padding: 30rem 15rem;
  background-color: #fff;
}
.p-areaform__wrap .p-form__wrap {
  margin-top: 0;
}
.p-areaform__wrap .p-form__table {
  margin-bottom: 20rem;
}
.p-areaform__wrap .p-form-button__active::after {
  right: 42rem;
}
@media screen and (min-width: 769px) {
  .p-areaform {
    padding: 50rem 0;
    background-image: url(../img/area_bg_pc.webp);
  }
  .p-areaform .l-container {
    width: 480rem;
  }
  .p-areaform__wrap {
    padding: 50rem 32rem;
  }
  .p-areaform__head {
    font-size: 28rem;
  }
  .p-areaform__head::bofore {
    font-size: 40rem;
  }
  .p-areaform .p-form__table {
    margin-bottom: 38rem;
  }
  .p-areaform .p-form__row {
    display: flex;
    align-items: center;
  }
  .p-areaform .p-form__label {
    width: 8em;
    font-size: 14rem;
  }
  .p-areaform .p-form__field {
    flex: 1 1;
  }
  .p-areaform .p-form-button-wrap {
    margin: 0 auto 16rem;
    max-width: 330rem;
  }
  .p-areaform .p-form__note {
    margin: auto;
    width: -moz-fit-content;
    width: fit-content;
  }
  .p-areaform .u-required {
    width: 30rem;
    height: 16rem;
    font-size: 10rem;
  }
}

.p-form {
  margin: 30rem 0 56rem;
}
.p-form__title {
  text-align: center;
  font-size: 20rem;
  font-weight: bold;
}
.p-form__wrap {
  margin-top: 32rem;
}
.p-form__table {
  display: block;
  margin-bottom: 50rem;
}
.p-form__tboby {
  display: block;
}
.p-form__row {
  display: block;
}
.p-form__row:not(:first-child) {
  margin-top: 20rem;
}
.p-form__label {
  display: flex;
  align-items: center;
  gap: 8rem;
  margin-bottom: 4rem;
  font-size: 15rem;
  font-weight: normal;
}
.p-form__field {
  display: block;
  font-size: 16rem;
  word-break: break-all;
}
.p-form__field .ERR {
  font-size: 10rem;
  color: #f00;
  font-weight: bold;
}
.p-form-button {
  display: block;
  width: 100%;
  height: 80rem;
  font-size: 18rem;
  color: #fff;
  font-weight: bold;
  border-radius: 40rem;
  background-color: #eb5405;
  border: unset;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.15), inset -1px -2px 4px 0 rgba(0, 0, 0, 0.2), inset 1px 2px 2px 0 rgba(255, 255, 255, 0.6);
}
.p-form-button:disabled {
  background-color: #ccc;
}
.p-form-button-wrap {
  margin-bottom: 20rem;
  overflow: hidden;
}
.p-form-button__active {
  position: relative;
}
.p-form-button__active::before {
  content: "";
  position: absolute;
  left: 50%;
  right: 0;
  bottom: 38rem;
  display: block;
  margin: auto;
  width: 430rem;
  height: 110rem;
  background-color: #fff;
  opacity: 0.2;
  transform: translateX(-50%);
  border-radius: 50%;
  pointer-events: none;
}
.p-form-button__active::after {
  content: "";
  position: absolute;
  top: 0;
  right: 22rem;
  bottom: 0;
  display: block;
  margin: auto;
  width: 5rem;
  height: 5rem;
  border: solid 3rem #fff;
  border-width: 3rem 3rem 0 0;
  transform: rotate(45deg);
  pointer-events: none;
}
.p-form-button-back {
  padding: 0;
  font-size: 16rem;
  color: #555;
  border: 1rem solid #555;
  border-width: 0 0 1rem;
  background-color: unset;
  line-height: 1;
}
.p-form-button-back-wrap {
  position: relative;
  margin: auto;
  padding: 0 0 0 20rem;
  width: -moz-fit-content;
  width: fit-content;
}
.p-form-button-back-wrap::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  display: block;
  margin: auto;
  width: 12rem;
  height: 12rem;
  background-image: url(../img/form_back_arrow.webp);
  background-size: contain;
}
.p-form__note {
  padding-left: 1em;
  text-indent: -1em;
  font-size: 10rem;
}
.p-form-confirm__head {
  margin-bottom: 12rem;
  font-size: 16rem;
  font-weight: bold;
  line-height: 1;
}
.p-form-confirm .p-form__label {
  padding-bottom: 4rem;
  border-bottom: 1rem solid #bcbcbc;
}
.p-form-confirm .p-form__field {
  line-height: 1;
}
.p-form-complete__info {
  margin-bottom: 36rem;
  text-align: center;
}
.p-form-complete__head {
  padding: 16rem 0;
  font-size: 15rem;
  color: #fff;
  font-weight: bold;
  background-color: #1094f1;
}
.p-form-complete__text {
  margin-bottom: 20rem;
  font-size: 16rem;
}
.p-form-complete__text b {
  color: #eb5405;
  border-bottom: solid 1px #eb5405;
}
.p-form-complete__text-wrap {
  padding: 20rem 16rem 30rem;
  background-color: #e6f3fe;
}
.p-form-complete__tel {
  font-weight: bold;
  font-size: 40rem;
  font-weight: 500;
  color: #eb5405;
  letter-spacing: -1.46rem;
  line-height: 1;
  font-family: "Oswald", sans-serif;
}
.p-form-complete__tel-head {
  margin-bottom: 4rem;
  font-size: 14rem;
  font-weight: normal;
}
.p-form-complete__tel-hour {
  display: block;
  margin-top: 12rem;
  font-size: 12rem;
}
.p-form-complete__content {
  margin-bottom: 50rem;
}
.p-form-complete__content-head {
  margin-bottom: 8rem;
  font-size: 16rem;
}
.p-form-complete__content-wrap {
  padding: 16rem;
  font-size: 14rem;
  border: solid 1rem #ccc;
  border-width: 1rem 0;
}
.p-form-complete__row:not(:first-child) {
  margin-top: 20rem;
}
.p-form-complete__label {
  margin-bottom: 2rem;
  font-weight: bold;
}
.p-form-complete__field {
  word-break: break-all;
}
.p-form__totop {
  position: relative;
  display: block;
  margin: auto;
  padding: 0 0 0 20rem;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 16rem;
  color: #555;
  line-height: 1;
}
.p-form__totop::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  display: block;
  margin: auto;
  width: 12rem;
  height: 12rem;
  background-image: url(../img/form_back_arrow.webp);
  background-size: contain;
}
.p-form__totop span {
  border: 1rem solid #555;
  border-width: 0 0 1rem;
}
@media screen and (min-width: 769px) {
  .p-form {
    margin: 30rem auto 56rem;
  }
}

.p-flow {
  padding: 40rem 0;
  background-image: url(../img/flow_bg.webp);
  background-repeat: no-repeat;
  background-size: contain;
}
.p-flow__list {
  position: relative;
  display: flex;
  gap: 32rem;
  flex-direction: column;
  margin: 32rem 0;
}
.p-flow__list::after {
  content: "";
  position: absolute;
  top: 130rem;
  left: 37rem;
  bottom: 0;
  width: 1rem;
  height: 390rem;
  border-right: 2rem dashed #D2DDFF;
  z-index: 1;
}
.p-flow__item {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15rem;
}
.p-flow__item:nth-child(1) .p-flow__img img {
  width: 42.4rem;
  transform: translateX(-2rem);
}
.p-flow__item:nth-child(2) .p-flow__img img {
  width: 12rem;
}
.p-flow__item:nth-child(3) .p-flow__img img {
  width: 41rem;
}
.p-flow__img {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 1;
  width: 80rem;
  height: 80rem;
  background-color: #e1f1fe;
  border-radius: 50%;
  z-index: 2;
}
.p-flow__text {
  flex: 1 1;
}
.p-flow__head {
  display: flex;
  gap: 8rem;
  flex-direction: column;
  margin-bottom: 10rem;
  font-size: 20rem;
  font-weight: bold;
  line-height: 1;
}
.p-flow__head-num {
  display: flex;
  gap: 0.5em;
  background: linear-gradient(106deg, #175fc2 1%, #2883ff 13%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: "Oswald", sans-serif;
}
.p-flow__title {
  font-size: 0.8em;
  color: #515151;
}
.p-flow__main {
  font-size: 16rem;
  color: #515151;
}
.p-flow__main:not(:last-child) {
  margin-bottom: 10rem;
}
@media (min-width: 769px) {
  .p-flow {
    padding: 50rem 0;
    background-image: url(../img/flow_bg_pc.webp);
  }
  .p-flow__list {
    gap: 64rem;
  }
  .p-flow__list::after {
    top: 80rem;
  }
}

.p-mv {
  padding-bottom: 40rem;
  background-color: #009aff;
}
.p-mv__pc {
  display: none;
}
.p-mv__wrap {
  margin: 0 auto;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (min-width: 769px) {
  .p-mv {
    padding: 0;
    max-width: 1440px;
    background-color: unset;
  }
  .p-mv__sp {
    display: none;
  }
  .p-mv__pc {
    display: block;
  }
  .p-mv__container {
    position: relative;
    overflow: hidden;
  }
  .p-mv__container::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -356px;
    bottom: -24.7222222222vw;
    margin: auto;
    width: 76.3888888889vw;
    height: 48.6111111111vw;
    border-radius: 50%;
    background-color: #009aff;
  }
  .p-mv__lead {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 12.1527777778vw;
    margin: auto;
    width: 29.1666666667vw;
    z-index: 1;
  }
  .p-mv__cta {
    position: absolute;
    bottom: 2.4305555556vw;
    left: 0;
    right: 0;
    margin: inherit;
    z-index: 10;
  }
  .p-mv .c-cta {
    padding: 0 0.8333333333vw;
    max-width: unset;
    width: 26.0416666667vw;
    height: 8.3333333333vw;
    font-size: 3.1944444444vw;
    border: solid 0.1388888889vw #d20c5d;
    border-width: 0.1388888889vw 0.1388888889vw 0.2777777778vw;
    border-radius: 0.3472222222vw;
  }
  .p-mv .c-cta::before {
    left: 0.8333333333vw;
    bottom: 1.6666666667vw;
  }
  .p-mv .c-cta::after {
    right: 0.8333333333vw;
    bottom: 2.6388888889vw;
    width: 0.5555555556vw;
    height: 0.5555555556vw;
    border: solid 0.2083333333vw #fff;
    border-width: 0.2083333333vw 0.2083333333vw 0 0;
  }
  .p-mv .c-cta__text {
    margin-top: -0.1388888889vw;
    width: 16.6666666667vw;
    height: 2.5vw;
    border-radius: 1.3888888889vw;
  }
  .p-mv .c-cta__text::before, .p-mv .c-cta__text::after {
    width: 1.3888888889vw;
    height: 0.0694444444vw;
  }
  .p-mv .c-cta__text::before {
    left: calc((100% - 10em) / 2 - 1.3888889vw);
    transform: rotate(45deg);
  }
  .p-mv .c-cta__text::after {
    right: calc((100% - 10em) / 2 - 1.3888889vw);
    transform: rotate(-45deg);
  }
  .p-mv .c-cta__tel {
    margin: 0.2083333333vw 0 0.3472222222vw;
    letter-spacing: -0.07013vw;
    transform: translateX(1.1111111111vw);
  }
  .p-mv .c-cta__hour {
    font-size: 0.326086em;
    transform: translateX(1.1111111111vw);
  }
}
@media screen and (min-width: 1440px) {
  .p-mv__container::after {
    content: "";
    bottom: -356px;
    width: 1100px;
    height: 700px;
  }
  .p-mv__lead {
    bottom: 175px;
    width: 420px;
  }
  .p-mv__cta {
    bottom: 35px;
  }
  .p-mv .c-cta {
    padding: 0 12rem;
    max-width: 375rem;
    height: 120rem;
    font-size: 46rem;
    border: solid 2rem #d20c5d;
    border-width: 2rem 2rem 4rem;
    border-radius: 5rem;
  }
  .p-mv .c-cta::before {
    left: 12rem;
    bottom: 24rem;
  }
  .p-mv .c-cta::after {
    right: 12rem;
    bottom: 38rem;
    width: 8rem;
    height: 8rem;
    border: solid 3rem #fff;
    border-width: 3rem 3rem 0 0;
  }
  .p-mv .c-cta__text {
    margin-top: -2rem;
    width: 240rem;
    height: 36rem;
    border-radius: 20rem;
  }
  .p-mv .c-cta__text::before, .p-mv .c-cta__text::after {
    width: 20rem;
    height: 1rem;
  }
  .p-mv .c-cta__text::before {
    left: calc((100% - 10em) / 2 - 20rem);
  }
  .p-mv .c-cta__text::after {
    right: calc((100% - 10em) / 2 - 20rem);
  }
  .p-mv .c-cta__tel {
    margin: 3rem 0 5rem;
    letter-spacing: -1.01rem;
    transform: translateX(16rem);
  }
  .p-mv .c-cta__hour {
    transform: translateX(16rem);
  }
}

.p-qa {
  padding: 40rem 0;
  background-color: #eaecef;
}
.p-qa__head {
  font-family: "Zen Kaku Gothic New", sans-serif;
}
.p-qa__content {
  display: flex;
  gap: 20rem;
  flex-direction: column;
  margin-top: 20rem;
  font-size: 15rem;
}
.p-qa__label {
  position: relative;
  padding: 24rem 30rem 24rem 64rem;
  color: #515151;
  font-weight: bold;
  background-color: #fff;
}
.p-qa__label.is-active::after {
  content: "\f068";
}
.p-qa__label::before {
  content: "Q";
  position: absolute;
  top: 0;
  left: 15rem;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto;
  width: 35rem;
  height: 35rem;
  font-size: 24rem;
  color: #fff;
  font-weight: bold;
  background-color: #0d42a9;
  font-family: "Oswald", sans-serif;
}
.p-qa__label::after {
  content: "+";
  position: absolute;
  top: 0;
  right: 15rem;
  bottom: 0;
  display: inline-block;
  margin: auto;
  height: -moz-fit-content;
  height: fit-content;
  color: #333;
  font-weight: 900;
  font-family: "Font Awesome 6 Free";
}
.p-qa__answer {
  position: relative;
  display: none;
  padding: 24rem 15rem 24rem 50rem;
  color: #fff;
  background-color: #0d42a9;
}
.p-qa__answer::before {
  content: "A.";
  position: absolute;
  top: 0;
  left: 15rem;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto;
  font-size: 24rem;
  color: #fff;
  font-weight: bold;
  font-family: "Oswald", sans-serif;
}
.p-qa__contact:not(:first-child) {
  margin-top: 16rem;
}
.p-qa__note {
  margin-top: 15rem;
  font-size: 12rem;
}
.p-qa__note-item {
  padding-left: 1em;
  text-indent: -1em;
}
@media (min-width: 769px) {
  .p-qa {
    padding: 50rem 0;
  }
}

.p-option {
  padding: 40rem 0;
  background-color: #e6f3fe;
}
.p-option__item {
  padding: 30rem 10rem;
  background-color: #fff;
}
.p-option__item-wrap {
  margin: 20rem 0;
  display: flex;
  gap: 20rem;
  flex-direction: column;
}
.p-option__head {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14rem 0;
  font-size: 18rem;
  color: #fff;
  line-height: 1.2;
  background-image: linear-gradient(96deg, #0d42a9 -3%, #009aff 125%);
  clip-path: polygon(100% 0%, 0% 0%, 0% 100%, 96% 100%, 100% 75%);
}
.p-option__head-recommend {
  position: relative;
}
.p-option__head-recommend::after {
  content: "";
  position: absolute;
  top: -24rem;
  right: -12rem;
  width: 60rem;
  height: 60rem;
  background-image: url(../img/option_recommend.webp);
  background-repeat: no-repeat;
  background-size: contain;
}
.p-option__head-wrap {
  position: relative;
}
.p-option__head-wrap::before {
  content: "";
  position: absolute;
  top: 2rem;
  right: calc(100% + 8rem);
  bottom: 0;
  display: block;
  margin: auto;
  width: 18rem;
  height: 15rem;
  background-image: url(../img/option_check.svg);
}
.p-option__head-column {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-option__head small {
  font-size: 0.7777778em;
}
.p-option__price {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  color: #525252;
}
.p-option__price::after {
  content: "\f101";
  position: absolute;
  top: 18rem;
  left: calc(100% + 10rem);
  display: block;
  font-size: 16rem;
  height: -moz-fit-content;
  height: fit-content;
  color: #f8d8d1;
  font-weight: 900;
  font-family: "Font Awesome 6 Free";
}
.p-option__price-wrap {
  display: flex;
  align-items: center;
  gap: 36rem;
  justify-content: space-between;
  margin: 20rem auto;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 44rem;
  line-height: 1;
  font-weight: bold;
}
.p-option__price-center {
  justify-content: center;
}
.p-option__price-small {
  margin-right: 5rem;
  font-size: 0.454545em;
  writing-mode: vertical-rl;
}
.p-option__price-midium {
  font-size: 0.545454em;
}
.p-option__price-large {
  font-size: 1em;
  font-family: "Oswald", sans-serif;
}
.p-option__value {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  font-size: 0.954545em;
  color: #f24822;
}
.p-option__value-small {
  font-size: 0.7619047em;
}
.p-option__value-large {
  font-size: 1em;
  font-weight: bold;
}
.p-option__info {
  font-size: 16rem;
  color: #333;
}
.p-option__table {
  margin: 20rem -10rem;
  width: 345rem;
  font-size: 18em;
  text-align: center;
  border-collapse: collapse;
}
.p-option__table thead th {
  padding: 6rem 0;
  width: 85rem;
  font-size: 0.6111111em;
  color: #fff;
  font-weight: bold;
  line-height: 1.2;
  border-radius: 5rem 5rem 0 0;
}
.p-option__table thead th:nth-child(2) {
  background-image: linear-gradient(to bottom, #0d42a9, #366fde);
}
.p-option__table thead th:nth-child(3) {
  background-image: linear-gradient(to bottom, #838b8f, #d2d3d8);
}
.p-option__table thead th:nth-child(4) {
  background-image: linear-gradient(to bottom, #cfb644, #eddca2);
}
.p-option__table thead th span {
  display: block;
}
.p-option__table thead th small {
  display: block;
  font-size: 0.9090909em;
}
.p-option__table tbody tr:nth-child(odd) {
  background-color: #f9f9fb;
}
.p-option__table tbody th {
  padding: 18rem 0;
  width: 90rem;
  font-size: 0.8333333em;
  font-weight: normal;
  color: #333;
  line-height: 1.2;
}
.p-option__table tbody th span {
  display: block;
}
.p-option__table tbody th small {
  display: block;
  font-size: 0.6666667em;
}
.p-option__table tbody td {
  border: solid 1rem #d7d6d6;
}
.p-option__table tbody td:nth-child(2) {
  border-width: 0 1rem;
}
.p-option__table tbody td:nth-child(3) {
  border-width: 0 1rem;
}
.p-option__table tbody td:nth-child(4) {
  border-width: 0;
}
.p-option__table tbody td .fa-circle {
  font-size: 1.2em;
  color: #f24822;
}
.p-option__table tbody td .fa-xmark {
  font-size: 0.77777778em;
  color: #bab7b4;
}
.p-option__table-text {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  line-height: 1;
}
.p-option__table-text span {
  font-size: 0.8888888em;
}
.p-option__table-text-wrap {
  display: flex;
  flex-direction: column;
  font-weight: bold;
}
.p-option__table-text-wrap small {
  font-size: 0.5555556em;
}
.p-option__table-text-wrap:last-child {
  margin-top: 5rem;
}

@media (min-width: 769px) {
  .p-option {
    padding: 50rem 0;
  }
  .p-option__table {
    margin: 20rem auto;
  }
  .p-option__item {
    padding: 40rem 32rem;
  }
  .p-option__head {
    margin: auto;
    width: 360rem;
  }
  .p-option__head-recommend::after {
    right: 76rem;
  }
  .p-option__price-wrap {
    font-size: 58rem;
  }
  .p-option__price-small {
    font-size: 0.3448275em;
  }
  .p-option__price-midium {
    font-size: 0.5517241em;
  }
  .p-option__price-large {
    font-size: 0.8275862em;
  }
}
.p-plan {
  padding: 40rem 0;
  background-color: #eaecef;
  background-image: url(../img/plan_bg.webp);
  background-repeat: no-repeat;
  background-size: contain;
}
.p-plan__head span {
  font-size: 36rem;
}
.p-plan__lead {
  margin: 20rem 0;
  color: #525252;
  font-size: 16rem;
}
.p-plan__wrap {
  margin-bottom: 20rem;
  padding: 20rem 15rem;
  background-color: #fff;
}
.p-plan__item {
  margin: 0 auto 20rem;
  max-width: 320rem;
  font-size: 34rem;
  border-radius: 10rem;
  overflow: hidden;
  border: solid 2rem #0d42a9;
}
.p-plan__item-head {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50rem;
  color: #fff;
  font-size: 0.6666667em;
  font-weight: bold;
  background-color: #0d42a9;
}
.p-plan__container {
  position: relative;
  display: flex;
  justify-content: space-between;
  padding: 15rem 12rem;
}
.p-plan__container::before {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 1rem;
  height: 68rem;
  border-left: 2px dashed #0d42a9;
}
.p-plan__container::after {
  content: "+";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto;
  width: 22rem;
  height: 22rem;
  font-size: 14rem;
  color: #fff;
  font-weight: 900;
  border-radius: 50%;
  font-family: "Font Awesome 6 Free";
  background-color: #0d42a9;
}
.p-plan__content {
  width: -moz-fit-content;
  width: fit-content;
}
.p-plan__title {
  display: block;
  margin: 0 auto 5rem;
  width: 130rem;
  font-size: 16rem;
  font-weight: bold;
  color: #0d42a9;
  text-align: center;
  background-image: linear-gradient(to right, #f1da63, #fcefae 50%, #f1da63);
  border-radius: 80rem;
}
.p-plan__price {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  color: #f24822;
  line-height: 1;
  letter-spacing: -1.08rem;
}
.p-plan__price-wrap {
  display: flex;
  flex-direction: column;
  margin-left: 2rem;
}
.p-plan__price-num {
  font-weight: 500;
  font-family: "Oswald", sans-serif;
}
.p-plan__price-icon {
  font-size: 1.25em;
  font-weight: 500;
  font-family: "Oswald", sans-serif;
}
.p-plan__price-small {
  margin-right: 2rem;
  font-size: 0.4444444em;
  font-weight: bold;
  writing-mode: vertical-rl;
}
.p-plan__price-midium {
  font-size: 0.5em;
  font-weight: bold;
}
.p-plan__price-large {
  font-size: 0.6111111em;
  font-weight: bold;
}
.p-plan__table {
  margin-bottom: 20rem;
  width: 100%;
  font-size: 16rem;
  color: #525252;
  border-collapse: collapse;
}
.p-plan__table th {
  height: 55rem;
  width: 36%;
  font-size: 1em;
  font-weight: bold;
  background-color: #eaecef;
  border: solid 1rem #d7d5d2;
}
.p-plan__table td {
  height: 55rem;
  width: 64%;
  font-size: 1em;
  text-align: center;
  border: solid 1rem #d7d5d2;
  line-height: 1.2;
}
.p-plan__table td small {
  display: block;
  font-size: 0.625em;
}
.p-plan__table td span {
  display: block;
  font-size: 0.875em;
}
.p-plan__table td i {
  display: block;
  font-size: 0.8125em;
}
.p-plan__info {
  text-align: left;
  font-size: 16rem;
  line-height: normal;
}
.p-plan__info:not(:last-child) {
  margin-bottom: 8rem;
}
.p-plan__info-wrap {
  padding: 12rem;
}
.p-plan__info dt {
  font-weight: bold;
}
.p-plan__info dd {
  font-size: 14rem;
}
.p-plan__info-note {
  text-align: left;
  font-size: 10rem;
}
@media screen and (min-width: 769px) {
  .p-plan {
    padding: 50rem 0;
    background-image: url(../img/plan_bg_pc.webp);
  }
  .p-plan__wrap {
    padding: 30rem;
  }
  .p-plan__table {
    margin: 0 auto 20rem;
    width: 320rem;
  }
}

.p-point {
  position: relative;
  padding: 40rem 0;
  background-color: #E6F3FE;
  background-image: url(../img/point_bg.webp);
  background-repeat: no-repeat;
  background-size: contain;
}
.p-point__head {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin: 0 auto 8rem;
  width: calc(100% - 26rem);
  height: 80rem;
  font-size: 40rem;
  font-weight: bold;
  color: #0d42a9;
  line-height: 1;
  background-color: #fff302;
  filter: drop-shadow(4px 3px 3px rgba(100, 96, 2, 0.2));
}
.p-point__head::before, .p-point__head::after {
  content: "";
  position: absolute;
  top: 0;
  width: 0;
  height: 0;
  border-style: solid;
}
.p-point__head::before {
  right: 100%;
  border-color: transparent #fff302 transparent transparent;
  border-width: 0 13rem 40rem 0;
}
.p-point__head::after {
  left: 100%;
  border-color: #fff302 transparent transparent transparent;
  border-width: 40rem 13rem 0 0;
}
.p-point__head-icon {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
}
.p-point__head-icon::before, .p-point__head-icon::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 0;
  height: 0;
  border-style: solid;
}
.p-point__head-icon::before {
  right: 100%;
  border-color: transparent transparent #fff302 transparent;
  border-width: 0 0 40rem 13rem;
}
.p-point__head-icon::after {
  left: 100%;
  border-color: transparent transparent transparent #fff302;
  border-width: 40rem 0 0 13rem;
}
.p-point__head-wrap {
  display: flex;
  align-items: center;
}
.p-point__head-wrap span {
  font-size: 0.6em;
}
.p-point__head-logo {
  width: 230rem;
}
.p-point__head-text {
  display: flex;
  align-items: center;
  align-items: baseline;
}
.p-point__head-text span {
  font-size: 0.6em;
}
.p-point__head-text em {
  font-size: 0.7em;
}
.p-point__list {
  position: relative;
  margin: 46rem auto 20rem;
  max-width: 600rem;
  font-size: 19rem;
  counter-reset: step;
}
.p-point__list::before {
  content: "";
  position: absolute;
  top: -94rem;
  right: 8rem;
  display: block;
  width: 88rem;
  height: 104rem;
  background-image: url(../img/point_list.webp);
  background-repeat: no-repeat;
  background-size: contain;
  z-index: 10;
}
.p-point__list-item {
  position: relative;
  padding: 20rem 15rem;
  background-color: #fff;
}
.p-point__list-item:not(:first-child) {
  margin-top: 45rem;
}
.p-point__list-item::before {
  counter-increment: step;
  content: "0" counter(step);
  position: absolute;
  left: 0;
  bottom: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 12rem 0 19rem;
  font-size: 1em;
  width: 50rem;
  height: 25rem;
  color: #fff;
  font-weight: bold;
  font-family: "Oswald", sans-serif;
  background-image: linear-gradient(to bottom, #0d42a9, #1070d3 67%);
  box-sizing: border-box;
}
.p-point__list-item::after {
  content: "";
  position: absolute;
  left: 50rem;
  bottom: 100%;
  width: 7rem;
  height: 26rem;
  background: linear-gradient(to bottom, #0d42a9, #1070d3 67%);
  clip-path: polygon(0% 0%, 0% 100%, 100% 100%);
}
.p-point__list-head {
  margin-bottom: 10rem;
  color: #0d42a9;
  font-weight: bold;
  line-height: 1.2;
}
.p-point__list-text {
  line-height: normal;
  text-align: justify;
  font-size: 0.84210526em;
}
.p-point__wrap {
  margin-top: 40rem;
}
.p-point__item {
  position: relative;
  padding: 42rem 17rem;
  background-image: linear-gradient(156deg, #0d42a9, #3d72da 100%);
  z-index: 0;
}
.p-point__item:not(:first-child) {
  margin-top: 20rem;
}
.p-point__item::before {
  content: "";
  position: absolute;
  inset: 3rem;
  display: block;
  margin: auto;
  background-color: #fff;
  z-index: -1;
}
.p-point__item-head {
  font-size: 24rem;
  color: #0d42a9;
  line-height: 1.3;
  text-align: center;
}
.p-point__item-head-row {
  display: flex;
  align-items: baseline;
  justify-content: center;
  margin: auto;
  width: -moz-fit-content;
  width: fit-content;
}
.p-point__item-head-small {
  font-size: 0.75em;
}
.p-point__item-head-medium {
  font-size: 0.791666em;
}
.p-point__item-head-logo {
  width: 230rem;
  transform: translateY(4rem);
}
.p-point__item-head-price {
  font-weight: 500;
  font-family: "Oswald", sans-serif;
}
.p-point__item-04__head {
  position: relative;
  padding-left: 60rem;
}
.p-point__item-04__head::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  display: block;
  margin: auto;
  width: 55rem;
  height: 55rem;
  background-image: url(../img/point_head_text.webp);
  background-size: contain;
  background-repeat: no-repeat;
}
.p-point__item-text {
  font-size: 16rem;
  text-align: justify;
}
.p-point__item-text:not(:first-child) {
  margin-top: 20rem;
}
.p-point__item-text-wrap {
  margin: 20rem 0;
}
.p-point__item-text sup {
  font-size: 10rem;
}
.p-point__item-04 .p-point__item-head-row:first-child {
  position: relative;
  margin: 0 auto 14rem;
  padding-left: 60rem;
  width: -moz-fit-content;
  width: fit-content;
}
.p-point__item-04 .p-point__item-head-row:first-child::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  display: block;
  margin: auto;
  width: 55rem;
  height: 55rem;
  background-image: url(../img/point_head_text.webp);
  background-size: contain;
  background-repeat: no-repeat;
}
.p-point__item-04 .p-point__item-head-medium {
  font-size: 0.75em;
}
.p-point__num {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 65rem;
  height: 65rem;
  text-align: center;
  font-size: 28rem;
  font-weight: bold;
  color: #fff;
  font-family: "Oswald", sans-serif;
}
.p-point__num::after {
  content: "";
  position: absolute;
  top: -2rem;
  left: 0;
  width: 65rem;
  height: 65rem;
  background: linear-gradient(142deg, #0d42a9 -6%, #3d72da 65%);
  clip-path: polygon(0 0, 100% 0, 0 100%);
  z-index: 1;
}
.p-point__num i {
  position: absolute;
  top: 4rem;
  left: 13rem;
  line-height: 1;
  z-index: 10;
}
.p-point__plan {
  flex: 1 1;
  overflow: hidden;
  border-radius: 5rem;
  border: solid 1px #009aff;
}
.p-point__plan-wrap {
  position: relative;
  display: flex;
  align-items: center;
  gap: 5rem;
  font-size: 36rem;
}
.p-point__plan-label {
  padding: 10rem 0;
  font-size: 0.4444444em;
  color: #fff;
  font-weight: bold;
  text-align: center;
  line-height: 1;
}
.p-point__plan-price {
  display: flex;
  align-items: baseline;
  justify-content: center;
  padding: 4rem 0;
}
.p-point__plan-price-column {
  font-size: 0.4166666em;
  font-weight: bold;
  writing-mode: vertical-rl;
}
.p-point__plan-price-column-small {
  font-size: 0.2222222em;
  font-weight: bold;
  writing-mode: vertical-rl;
}
.p-point__plan-price-num {
  font-size: 1em;
  font-weight: bold;
  line-height: 1;
  font-family: "Oswald", sans-serif;
}
.p-point__plan-price-num small {
  font-size: 0.5em;
}
.p-point__plan-price-text {
  font-size: 0.3333333em;
  font-weight: bold;
}
.p-point__plan-icon {
  position: absolute;
  top: -8rem;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto;
  width: 50rem;
  height: 50rem;
  font-size: 0.2777777em;
  font-weight: bold;
  line-height: 1.2;
  color: #009aff;
  text-align: center;
  border: solid 1px #009aff;
  background-color: #fff;
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
}
.p-point__plan-simple {
  margin: 28rem 0;
}
.p-point__plan-simple .p-point__plan-label {
  background-color: #009aff;
}
.p-point__plan-simple .p-point__plan-price {
  color: #009aff;
}
.p-point__plan-simple .p-point__plan-icon {
  color: #009aff;
  border-color: #009aff;
}
.p-point__plan-relief .p-point__plan-label {
  background-color: #0d42a9;
}
.p-point__plan-relief .p-point__plan-price {
  color: #0d42a9;
}
.p-point__plan-relief .p-point__plan-icon {
  color: #0d42a9;
  border-color: #0d42a9;
}
.p-point__arrow {
  position: relative;
  margin: 48rem auto;
  width: 90rem;
  z-index: 0;
}
.p-point__arrow span {
  position: relative;
  display: block;
  font-size: 16rem;
  font-weight: bold;
  text-align: center;
  color: #0d42a9;
  border-radius: 80rem;
  background-color: #fff;
  border: solid 1rem #0d42a9;
}
.p-point__arrow::after {
  content: "";
  position: absolute;
  inset: 0;
  display: block;
  margin: auto;
  width: 48rem;
  height: 77rem;
  background-image: url(../img/point_arrow.webp);
  background-size: contain;
  background-repeat: no-repeat;
  z-index: -1;
}
.p-point__value {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1 1;
  padding: 0 10rem;
  font-size: 16rem;
  height: 58rem;
  color: #fff;
  font-weight: bold;
  border-radius: 5rem;
  background-image: linear-gradient(110deg, #054dae 3%, #0f73d8 100%);
}
.p-point__value-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10rem;
}
.p-point__value-icon {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 29rem;
  height: 29rem;
  margin: auto;
  font-size: 18rem;
  color: #0d42a9;
  font-weight: bold;
  background-color: #fff;
  border: 1rem solid #0d42a9;
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  -ms-border-radius: 50%;
  -o-border-radius: 50%;
}
.p-point__graph {
  max-width: 400rem;
}
.p-point__graph-02 {
  margin: 16rem auto 20rem;
}
.p-point__graph-04 {
  margin: 20rem auto;
  max-width: 300rem;
}
.p-point__mode {
  flex: 1 1;
  font-size: 26rem;
  border-radius: 5rem;
  border: 1rem solid #333;
  border-radius: 5rem;
  border-width: 0 1rem 1rem 1rem;
}
.p-point__mode-wrap {
  margin: 20rem 0;
  display: flex;
  gap: 15rem;
}
.p-point__mode-img {
  width: 30rem;
}
.p-point__mode-label {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 -1rem;
  width: calc(100% + 2rem);
  height: 30rem;
  font-size: 0.5em;
  font-weight: bold;
  text-align: center;
  color: #fff;
  border-radius: 5rem 5rem 0 0;
}
.p-point__mode-label::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin: auto;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5rem 6rem 0 6rem;
}
.p-point__mode-content {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5rem;
  padding: 16rem 0;
  line-height: 1.2;
}
.p-point__mode-text {
  display: flex;
  flex-direction: column;
}
.p-point__mode-01 .p-point__mode-label {
  background-color: #009aff;
}
.p-point__mode-01 .p-point__mode-label::after {
  border-color: #009aff transparent transparent transparent;
}
.p-point__mode-01 .p-point__mode-content p {
  width: 5em;
  color: #525252;
  font-size: 0.615384em;
  text-align: center;
  font-weight: bold;
}
.p-point__mode-02 .p-point__mode-label {
  background-color: #0d42a9;
}
.p-point__mode-02 .p-point__mode-label::after {
  border-color: #0d42a9 transparent transparent transparent;
}
.p-point__mode-02 .p-point__mode-text p {
  display: flex;
  align-items: baseline;
  color: #525252;
}
.p-point__mode-02 .p-point__mode-text p em {
  font-weight: bold;
  font-family: "Oswald", sans-serif;
  transform: translateY(2rem);
}
.p-point__mode-02 .p-point__mode-text p em i {
  font-size: 0.615384em;
}
.p-point__mode-02 .p-point__mode-text p span {
  font-size: 0.538461em;
  font-weight: bold;
}
.p-point__mode-02 .p-point__mode-text small {
  font-size: 0.42307em;
}
.p-point__check {
  position: relative;
  flex: 1 1;
  padding: 0 0 16rem;
  max-width: 150rem;
  font-size: 13rem;
  background-color: #fff;
  border-radius: 10rem;
}
.p-point__check-wrap {
  display: flex;
  gap: 15rem;
  margin: 20rem auto 0;
  width: -moz-fit-content;
  width: fit-content;
}
.p-point__check-label {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24rem;
  height: 45rem;
  border-radius: 8rem 8rem 0 0;
}
.p-point__check-list {
  position: relative;
  margin-left: 8rem;
  line-height: 1.2;
}
.p-point__check-list li {
  position: relative;
  padding-left: 24rem;
  font-weight: bold;
}
.p-point__check-list li::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  width: 20rem;
  height: 20rem;
  -webkit-mask: url("../img/point_check.svg") no-repeat center;
  mask: url("../img/point_check.svg") no-repeat center;
  -webkit-mask-size: contain;
  mask-size: contain;
}
.p-point__check-list li:not(:first-child) {
  margin-top: 14rem;
}
.p-point__check-fixed {
  border: solid 2rem #a1a1a1;
}
.p-point__check-fixed .p-point__check-label {
  font-size: 15rem;
  color: #fff;
  font-weight: bold;
  text-align: center;
  background-color: #a1a1a1;
}
.p-point__check-fixed .p-point__check-list {
  color: #525252;
}
.p-point__check-fixed .p-point__check-list li::before {
  background-color: #a1a1a1;
}
.p-point__check-ecosma {
  border: solid 2rem #009aff;
  box-shadow: 5rem 5rem 5rem 0 rgba(0, 0, 0, 0.15);
}
.p-point__check-ecosma .p-point__check-label {
  padding: 14rem 8rem;
  background-image: linear-gradient(108deg, #2c61c8 2%, #009aff 102%);
}
.p-point__check-ecosma .p-point__check-label img {
  width: 100%;
  max-width: 132rem;
}
.p-point__check-ecosma .p-point__check-list {
  color: #2b63c9;
}
.p-point__check-ecosma .p-point__check-list li::before {
  background-color: #2b63c9;
}
.p-point__check-ecosma .p-point__check-list li:nth-child(2) {
  display: flex;
  align-items: center;
  height: 2.4em;
}
@media screen and (min-width: 769px) {
  .p-point {
    padding: 50rem 0;
    background-image: url(../img/point_bg_pc.webp);
  }
  .p-point__head {
    margin-bottom: 16rem;
    width: calc(100% - 52rem);
    height: 140rem;
    font-size: 50rem;
  }
  .p-point__head::before {
    border-width: 0 26rem 70rem 0;
  }
  .p-point__head::after {
    border-width: 70rem 26rem 0 0;
  }
  .p-point__head-logo {
    width: 310rem;
  }
  .p-point__head-text strong {
    font-weight: bold;
  }
  .p-point__head-text span {
    font-size: 0.5em;
  }
  .p-point__head-text em {
    font-size: 0.72em;
  }
  .p-point__head-wrap span {
    font-size: 0.5em;
  }
  .p-point__head-icon {
    gap: 10rem;
  }
  .p-point__head-icon::before {
    border-width: 0 0 70rem 26rem;
  }
  .p-point__head-icon::after {
    border-width: 70rem 0 0 26rem;
  }
  .p-point__list {
    margin-top: 76rem;
  }
  .p-point__list::before {
    top: -145rem;
    right: 32rem;
    width: 140rem;
    height: 163rem;
    z-index: 1;
  }
  .p-point__list-item {
    padding: 20rem 32rem;
  }
  .p-point__list-item::before {
    padding-right: 21rem;
    width: 58rem;
  }
  .p-point__list-item::after {
    left: 58rem;
  }
  .p-point__list-item:nth-child(1) {
    z-index: 2;
  }
  .p-point__list-head {
    font-size: 22rem;
  }
  .p-point__item {
    padding: 42rem 32rem;
  }
  .p-point__item-head-small {
    font-size: 0.7916666em;
  }
  .p-point__item-head-medium {
    font-size: 1em;
  }
  .p-point__item .c-note {
    font-size: 12rem;
  }
  .p-point__plan-wrap {
    margin-left: auto;
    margin-right: auto;
    width: 350rem;
  }
  .p-point__value-wrap {
    margin: auto;
    width: 350rem;
  }
  .p-point__mode-wrap {
    margin: 20rem auto;
    width: 350rem;
  }
}

.p-set {
  position: relative;
  padding: 40rem 0;
  background-color: #fffde3;
}
.p-set * {
  position: relative;
  z-index: 10;
}
.p-set::before, .p-set::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  background-repeat: no-repeat;
  background-size: contain;
  z-index: 1;
}
.p-set::before {
  top: 0;
  height: 153rem;
  background-image: url(../img/set_bg_01.webp);
}
.p-set::after {
  bottom: 0;
  height: 145rem;
  background-image: url(../img/set_bg_02.webp);
}
.p-set__head {
  display: flex;
  align-items: center;
  flex-direction: column;
  font-size: 24rem;
  color: #f24822;
  line-height: 1.2;
}
.p-set__lead {
  margin: 20rem 0;
  font-size: 16rem;
  text-align: justify;
}
.p-set__container {
  display: flex;
  gap: 46rem;
  flex-direction: column;
  margin-top: 46rem;
}
.p-set__item {
  position: relative;
  margin-top: 20rem;
  padding: 14rem 20rem 14rem;
  background-color: #fff;
  border-radius: 10rem;
  border: solid 2rem;
}
.p-set__item-last {
  margin-bottom: 20rem;
}
.p-set__item-au {
  border-color: #f24822;
}
.p-set__item-au .p-set__title {
  background-color: #ff9f6c;
}
.p-set__item-au .p-set__title-sub {
  background-color: #f24822;
}
.p-set__item-au .p-set__text-wrap {
  color: #f24822;
}
.p-set__item-au .p-set__text-large {
  color: #f24822;
}
.p-set__item-au .p-set__text-small {
  color: #525252;
}
.p-set__item-au .p-set__link {
  background-color: #f24822;
}
.p-set__item-uq {
  border-color: #f4287b;
}
.p-set__item-uq .p-set__title {
  background-color: #fe8ebc;
}
.p-set__item-uq .p-set__title-sub {
  background-color: #f4287b;
}
.p-set__item-uq .p-set__text-wrap {
  color: #f4287b;
}
.p-set__item-uq .p-set__link {
  background-color: #f4287b;
}
.p-set__title {
  margin-bottom: 10rem;
  padding: 8rem 0;
  color: #fff;
  font-size: 20rem;
  border-radius: 5rem;
  text-align: center;
  line-height: 1;
}
.p-set__title-sub {
  position: absolute;
  left: 16rem;
  bottom: 100%;
  display: block;
  padding: 10rem 0;
  width: 150rem;
  font-size: 11rem;
  color: #fff;
  line-height: 1;
  text-align: center;
  font-weight: bold;
  border-radius: 5rem 5rem 0 0;
}
.p-set__info {
  margin-bottom: 8rem;
  font-size: 16rem;
  font-weight: bold;
  text-align: center;
}
.p-set__text-wrap {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  line-height: 1;
  font-weight: bold;
}
.p-set__text-wrap em {
  font-size: 23rem;
}
.p-set__text-wrap i {
  font-size: 28rem;
}
.p-set__text-small::after {
  content: "\f101";
  position: absolute;
  top: 18rem;
  left: calc(100% + 10rem);
  display: block;
  font-size: 16rem;
  height: -moz-fit-content;
  height: fit-content;
  color: #f8d8d1;
  font-weight: 900;
  font-family: "Font Awesome 6 Free";
}
.p-set__text-small .p-set__column {
  font-size: 18rem;
}
.p-set__text-small .p-set__price {
  font-size: 42rem;
}
.p-set__text-small em {
  font-size: 21rem;
}
.p-set__text-large {
  font-size: 53rem;
  line-height: 1;
}
.p-set__column {
  font-size: 23rem;
  writing-mode: vertical-rl;
}
.p-set__price {
  font-size: 54rem;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  transform: translateY(2rem);
}
.p-set__price small {
  font-size: 0.5185185em;
}
.p-set__link {
  position: relative;
  display: block;
  margin-top: 10rem;
  padding: 12rem 0;
  font-size: 16rem;
  color: #fff;
  text-align: center;
  font-weight: bold;
  border-radius: 80rem;
  line-height: 1;
}
.p-set__link::after {
  content: "";
  position: absolute;
  top: 3rem;
  right: 75rem;
  bottom: 0;
  display: block;
  margin: auto;
  width: 6rem;
  height: 6rem;
  border: solid 2rem #fff;
  border-width: 2rem 2rem 0 0;
  transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
}
.p-set__row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 35rem;
}
.p-set__arrow {
  width: 65rem;
}
.p-set__arrow-wrap {
  display: flex;
  gap: 10rem;
  align-items: center;
  flex-direction: column;
  margin: 20rem 0;
}
.p-set__arrow-wrap span {
  font-size: 24rem;
  line-height: 1;
  color: #f24822;
  font-weight: bold;
}
@media (min-width: 769px) {
  .p-set {
    padding: 50rem 0;
    background-color: #fffde3;
  }
  .p-set::before {
    height: 153rem;
    background-image: url(../img/set_bg_01_pc.webp);
  }
  .p-set::after {
    height: 127rem;
    background-image: url(../img/set_bg_02_pc.webp);
  }
  .p-set__container {
    flex-direction: row;
    gap: 20rem;
  }
  .p-set__info {
    margin-bottom: 0;
  }
  .p-set__item-last {
    margin: 55rem auto 20rem;
    max-width: 345rem;
  }
  .p-set__link::after {
    right: 46rem;
  }
}

.p-type {
  padding: 40rem 0;
  background-color: #eaecef;
  background-image: url(../img/type_bg.webp);
  background-repeat: no-repeat;
  background-size: contain;
}
.p-type__head {
  display: flex;
  gap: 10rem;
  flex-direction: column;
  margin-bottom: 20rem;
  font-size: 46em;
}
.p-type__head-row {
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-type__head-end {
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.p-type__head-logo {
  width: 145rem;
}
.p-type__head-logo-wrap span {
  font-size: 0.347826em;
  color: #333;
}
.p-type__head-text {
  color: #0d42a9;
  line-height: 1;
}
.p-type__head-text span {
  margin: 0 -0.5em;
  font-size: 0.5652173em;
}
.p-type__head-text small {
  font-size: 0.5217391em;
}
.p-type__head-text-large {
  background-image: linear-gradient(135deg, #0d42a9 43%, #079FF8 58%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}
.p-type__head-text-large strong {
  font-size: 1em;
}
.p-type__head-text-large span {
  font-size: 0.6521739em;
}
.p-type__lead {
  font-size: 16rem;
  text-align: justify;
}
.p-type__item {
  padding: 20rem 0;
  background-color: #fff;
}
.p-type__item-wrap {
  display: flex;
  gap: 20rem;
  flex-direction: column;
  margin: 20rem 0;
}
.p-type__title {
  display: flex;
  gap: 4rem;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  margin-bottom: 16rem;
  width: calc(100% - 3rem);
  height: 75rem;
  font-size: 20rem;
  color: #fff;
  font-weight: bold;
  line-height: 1.2;
  background-image: linear-gradient(99deg, #053085 0%, #2859b8 99%);
  border-radius: 0 80rem 80rem 0;
}
.p-type__img {
  margin: auto;
  max-width: 214rem;
}
.p-type__img-wrap {
  display: flex;
  gap: 16rem;
  justify-content: center;
}
.p-type__img-wrap dl {
  display: flex;
  gap: 4rem;
  align-items: center;
  flex-direction: column;
}
.p-type__img-wrap dt {
  font-size: 16rem;
  color: #525252;
}
.p-type__img-wrap dd img {
  width: auto;
  height: 218rem;
}
.p-type__spec {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 1em;
  margin-top: 12rem;
  font-size: 24rem;
  font-weight: bold;
  color: #0d42a9;
  line-height: 1;
}
.p-type__spec span {
  font-size: 0.6666667em;
}
.p-type__spec strong {
  font-size: 1em;
}
.p-type__info {
  margin-top: 20rem;
  padding: 0 15rem;
  font-size: 16rem;
  text-align: justify;
}
.p-type__table {
  width: 100%;
  font-size: 16rem;
  line-height: 1.2;
  text-align: center;
  border-collapse: collapse;
}
.p-type__table th {
  padding: 12rem 0;
  width: 115rem;
  color: #525252;
  font-weight: bold;
  background-color: #eaecef;
  border: solid 1rem #d7d5d2;
}
.p-type__table td {
  padding: 12rem 4rem;
  color: #525252;
  border: solid 1rem #d7d5d2;
}
.p-type__table td small {
  display: block;
  font-size: 0.875em;
}
.p-type__table-wrap {
  padding: 20rem 10rem;
  background-color: #fff;
}
.p-type__table-head {
  margin-bottom: 10rem;
  font-size: 18rem;
  font-weight: bold;
  text-align: center;
  color: #515151;
}
.p-type__table-left {
  text-align: left;
}
@media (min-width: 769px) {
  .p-type {
    padding: 50rem 0;
  }
  .p-type__item {
    padding: 40rem 0;
  }
  .p-type__info {
    padding: 0 32rem;
  }
  .p-type__img-wrap {
    gap: 100rem;
  }
  .p-type__table {
    margin: auto;
    width: 400rem;
  }
  .p-type__table-wrap {
    padding: 40rem 32rem;
  }
  .p-type__table-left {
    margin: auto;
    width: -moz-fit-content;
    width: fit-content;
  }
  .p-type__img {
    max-width: unset;
    width: 280rem;
  }
  .p-type__img-wrap {
    margin-top: 50rem;
  }
}

.p-modal {
  position: fixed;
  inset: 0;
  display: none;
  margin: auto;
  padding: 40rem 0;
  width: calc(100% - 32rem);
  height: -moz-fit-content;
  height: fit-content;
  font-size: 16rem;
  line-height: normal;
  background-color: #fff;
  border-radius: 5rem;
  z-index: 100;
}
.p-modal__close {
  position: absolute;
  top: 16rem;
  right: 16rem;
  width: 16rem;
  height: 16rem;
}
.p-modal__close::before, .p-modal__close::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 2rem;
  background-color: #333;
}
.p-modal__close::before {
  transform: rotate(45deg);
}
.p-modal__close::after {
  transform: rotate(-45deg);
}
.p-modal__logo {
  margin: 0 auto 20rem;
  width: 200rem;
}
.p-modal__text-wrap {
  margin-bottom: 20rem;
}
.p-modal__head {
  margin-bottom: 12rem;
  text-align: center;
}
.p-modal__text {
  font-size: 12rem;
  padding-left: 1em;
  text-indent: -1em;
}
.p-modal__list {
  display: flex;
  gap: 16rem;
  flex-direction: column;
}
.p-modal__button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 70rem;
  color: #fff;
  font-size: 20rem;
  font-weight: bold;
  border-radius: 5rem;
  background-color: #F4287B;
  background-image: linear-gradient(to top, #D20C5D, #F4287B);
  border: 6rem solid #D20C5D;
  border-top-color: #F4287B;
  border-left-color: #F4287B;
  box-shadow: 2.5rem 4.25rem 5rem 0 rgba(7, 4, 4, 0.5);
}
.p-modal__button::before {
  content: "\f879";
  position: absolute;
  top: 0;
  left: 16rem;
  bottom: 0;
  margin: auto;
  height: -moz-fit-content;
  height: fit-content;
  font-weight: 900;
  font-family: "Font Awesome 5 Free";
}
.p-modal__button-other {
  flex-direction: column;
  background-image: linear-gradient(to top, #111, #666);
  border: 6rem solid #111;
  border-top-color: #666;
  border-left-color: #666;
}
.p-modal__button-other::before {
  display: none;
}
.p-modal__button-other small {
  font-size: 10rem;
}
.p-modal__overlay {
  z-index: 99;
  display: none;
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.7490196078);
}

.u-any {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38rem;
  height: 21rem;
  font-size: 13rem;
  color: #fff;
  background-color: #8c8c8c;
}

.u-blue {
  font-weight: bold;
  color: #0d42a9;
}

.u-spnone {
  display: none;
}

@media (min-width: 769px) {
  .u-spnone {
    display: block;
  }
  .u-pcnone {
    display: none;
  }
}
.u-gray {
  font-weight: bold;
  color: #656b6f;
}

.u-gold {
  font-weight: bold;
  color: #b49614;
}

.u-required {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38rem;
  height: 21rem;
  font-size: 13rem;
  color: #fff;
  background-color: #eb5405;
}

.u-margin-t10 {
  margin-top: 10rem;
}

.u-margin-b20 {
  margin-bottom: 20rem;
}

.u-marker {
  background-image: linear-gradient(0deg, #fff702 40%, transparent 0);
}

.u-notel {
  pointer-events: none;
  text-decoration: none;
}

.u-oswald {
  font-family: "Oswald", sans-serif;
}