@charset "UTF-8";
/* ======================== */
/*         fv           */
/* ======================== */
.p-fv {
  height: auto;
  background-image: url("../img/top/fv_pc.png");
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
}
@media screen and (min-width: 1367px) {
  .p-fv {
    background-image: url("../img/top/fv_pc_1920.png");
    background-size: 1920px 100%;
  }
}
@media screen and (max-width: 750px) {
  .p-fv {
    background-image: url("../img/top/fv_sp.png");
  }
}

.p-fv__padding {
  padding: 3.125rem 1.875rem;
}
@media screen and (max-width: 750px) {
  .p-fv__padding {
    padding-inline: min(28px, 3.7333333333vw);
    padding-bottom: min(70px, 9.3333333333vw);
  }
}

.p-fv__inner {
  height: 100%;
  display: flex;
  align-items: center;
}

.p-fv__content {
  padding-top: min(150px, 10.980966325vw);
}
@media screen and (max-width: 750px) {
  .p-fv__content {
    padding-top: min(686px, 91.4666666667vw);
    transform: none;
  }
}

.p-fv__title {
  display: grid;
  gap: min(23px, 1.6837481698vw);
  font-weight: 700;
  line-height: 1.1;
}
@media screen and (max-width: 750px) {
  .p-fv__title {
    gap: min(20px, 2.6666666667vw);
  }
}

.p-fv__title-line {
  display: inline-block;
  width: -moz-fit-content;
  width: fit-content;
  padding: min(10px, 0.7320644217vw) min(14px, 1.0248901903vw);
  background: #FFFFFF;
  color: #002AC7;
  font-size: min(2.9282576867vw, 40px);
}
@media screen and (max-width: 750px) {
  .p-fv__title-line {
    padding: min(6px, 0.8vw) min(12px, 1.6vw);
    font-size: min(6.6666666667vw, 50px);
    white-space: nowrap;
  }
}

.p-fv__lead {
  margin-top: min(20px, 1.4641288433vw);
  color: #FFFFFF;
  font-size: min(1.4641288433vw, 20px);
  line-height: 1.9;
  position: relative;
  padding-left: min(1.317715959vw, 18px);
}
.p-fv__lead::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.2em;
  width: min(0.1464128843vw, 2px);
  height: 90%;
  background-color: #FFFFFF;
}
@media screen and (max-width: 750px) {
  .p-fv__lead::before {
    width: min(0.5333333333vw, 4px);
  }
}
@media screen and (max-width: 750px) {
  .p-fv__lead {
    margin-top: min(14px, 1.8666666667vw);
    font-size: min(3.2vw, 24px);
    padding-left: min(2.6666666667vw, 20px);
  }
}

.p-fv__badges {
  margin-top: min(25px, 1.8301610542vw);
  margin-bottom: min(96px, 7.027818448vw);
  display: block;
}
@media screen and (max-width: 750px) {
  .p-fv__badges {
    margin-top: min(20px, 2.6666666667vw);
    margin-bottom: 0;
  }
}

.p-fv__badges img {
  width: min(562px, 41.1420204978vw);
  height: auto;
  display: block;
}
@media screen and (max-width: 750px) {
  .p-fv__badges img {
    width: min(690px, 92vw);
  }
}

/* ======================== */
/*         concept           */
/* ======================== */
/* concept本文 */
.p-concept__padding {
  position: relative;
  z-index: 2;
}

.p-concept__content {
  max-width: 1200px;
  margin-inline: auto;
}

.p-concept__texts {
  position: relative;
  margin-top: min(54px, 3.953147877vw);
  margin-bottom: min(182px, 13.3235724744vw);
  text-align: center;
  font-size: min(1.0248901903vw, 14px);
  line-height: 2.5;
}
@media screen and (max-width: 750px) {
  .p-concept__texts {
    margin-top: min(65px, 8.6666666667vw);
    margin-bottom: min(162px, 21.6vw);
    font-size: min(3.2vw, 24px);
  }
}

.p-concept__em {
  color: #002AC7;
  font-weight: 700;
}

/* 左右イラスト(1920枠基準でabsolute) */
.p-concept__illust {
  position: absolute;
  height: auto;
  z-index: 1;
  pointer-events: none;
}

.p-concept__illust--left {
  left: 0;
  top: min(20px, 1.4641288433vw);
  width: min(257px, 18.8140556369vw);
}
@media screen and (max-width: 750px) {
  .p-concept__illust--left {
    top: auto;
    bottom: max(-162px, -21.6vw);
    width: min(154px, 20.5333333333vw);
  }
}

.p-concept__illust--right {
  top: min(69px, 5.0512445095vw);
  right: 0;
  width: min(357px, 26.1346998536vw);
}
@media screen and (max-width: 750px) {
  .p-concept__illust--right {
    top: auto;
    bottom: max(-162px, -21.6vw);
    width: min(228px, 30.4vw);
  }
}

.p-concept .c-section-heading__line {
  padding-right: 0;
}

/* ======================== */
/*         reason           */
/* ======================== */
.p-reason .p-reason__padding {
  padding-bottom: min(81px, 5.9297218155vw);
}
@media screen and (max-width: 750px) {
  .p-reason .p-reason__padding {
    padding-bottom: min(87px, 11.6vw);
  }
}

.c-section-heading__lead {
  margin-top: min(33px, 2.4158125915vw);
  text-align: center;
  line-height: 2.5;
  font-size: min(1.0248901903vw, 14px);
}
@media screen and (max-width: 750px) {
  .c-section-heading__lead {
    margin-top: 14px;
    font-size: min(3.2vw, 24px);
  }
}

.c-section1920--reason {
  background: #FFFFFF;
}

/* ここで共通値 */
.p-reason {
  --peek: 200px;
  --point-line-height: 1.6;
  --point-font-size: min(50px, calc(50 / 1366 * 100vw));
  --point-row: calc(var(--point-font-size) * var(--point-line-height));
  --stack-gap-12: calc(var(--point-row) + 12px);
}
@media screen and (max-width: 750px) {
  .p-reason {
    --point-font-size: min(70px, calc(70 / 750 * 100vw));
  }
}

/* stickyスタックのスクロール量を確保(3枚) */
.p-reason__cards {
  position: relative;
  height: 300svh;
  color: #FFFFFF;
  background: transparent;
}

/* カード共通 */
.p-reason-card {
  position: sticky;
  top: 0;
  height: 100svh;
  overflow: hidden;
  transform: translateY(var(--offset));
}

/* 重なり順(01奥→03手前) */
.p-reason-card--01 {
  --offset: 0px;
  z-index: 1;
  background: #002AC7;
}
.p-reason-card--01 .p-reason-card__media img {
  width: min(147px, 10.7613469985vw);
  height: auto;
  display: block;
}
@media screen and (max-width: 750px) {
  .p-reason-card--01 .p-reason-card__media img {
    width: min(226px, 30.1333333333vw);
    margin: 0 auto;
  }
}

.p-reason-card--02 {
  --offset: var(--stack-gap-12);
  z-index: 2;
  background: #001E8F;
}
.p-reason-card--02 .p-reason-card__media img {
  width: min(130px, 9.5168374817vw);
  height: auto;
  display: block;
}
@media screen and (max-width: 750px) {
  .p-reason-card--02 .p-reason-card__media img {
    width: min(181px, 24.1333333333vw);
    margin: 0 auto;
  }
}

.p-reason-card--03 {
  --offset: calc(var(--stack-gap-12) + var(--stack-gap-12));
  z-index: 3;
  background: #001257;
}
.p-reason-card--03 .p-reason-card__media img {
  width: min(173px, 12.6647144949vw);
  height: auto;
  display: block;
}
@media screen and (max-width: 750px) {
  .p-reason-card--03 .p-reason-card__media img {
    width: min(235px, 31.3333333333vw);
    margin: 0 auto;
  }
}

/* カード内レイアウト(PC 2カラム) */
.p-reason-card__inner {
  height: 100%;
  max-width: min(1000px, 73.2064421669vw);
  display: flex;
  flex-direction: column;
  gap: min(16px, 1.1713030747vw);
}
@media screen and (max-width: 750px) {
  .p-reason-card__inner {
    gap: min(44px, 5.8666666667vw);
    max-width: min(685px, 91.3333333333vw);
  }
}

.p-reason-card__grid {
  display: flex;
  align-items: center;
  gap: min(238px, 17.4231332357vw);
}
@media screen and (max-width: 750px) {
  .p-reason-card__grid {
    flex-direction: column-reverse;
    align-items: flex-start;
    gap: min(40px, 5.3333333333vw);
  }
}

.p-reason-card__body {
  width: min(550px, 40.2635431918vw);
  letter-spacing: 0.1em;
}
@media screen and (max-width: 750px) {
  .p-reason-card__body {
    width: 100%;
  }
}

/* タイポ(仮。後で合わせる) */
.p-reason-card__point {
  font-weight: 700;
  letter-spacing: 0.06em;
  font-size: min(1.4641288433vw, 20px);
}
@media screen and (max-width: 750px) {
  .p-reason-card__point {
    font-size: min(4vw, 30px);
  }
}

.p-reason-card__num {
  font-size: min(50px, 3.6603221083vw);
}
@media screen and (max-width: 750px) {
  .p-reason-card__num {
    font-size: min(70px, 9.3333333333vw);
  }
}

.p-reason-card__slash {
  font-size: min(1.4641288433vw, 20px);
}
@media screen and (max-width: 750px) {
  .p-reason-card__slash {
    font-size: min(4vw, 30px);
  }
}

.p-reason-card__title {
  font-size: min(1.756954612vw, 24px);
  font-weight: 700;
}
@media screen and (max-width: 750px) {
  .p-reason-card__title {
    font-size: min(5.3333333333vw, 40px);
  }
}

.p-reason-card__text {
  margin-top: 20px;
  font-size: min(1.0248901903vw, 14px);
  line-height: 2.5;
}
.p-reason-card__text .bold {
  font-weight: 700;
}
@media screen and (max-width: 750px) {
  .p-reason-card__text {
    font-size: min(3.2vw, 24px);
  }
}

@media screen and (max-width: 750px) {
  .p-reason-card__media {
    width: 100%;
    text-align: center;
  }
}

/* ======================== */
/*         service           */
/* ======================== */
/* 全体背景(必要なら) */
.c-section1920--service {
  background: #FFFFFF;
  margin-top: min(184px, 13.4699853587vw);
}
@media screen and (max-width: 750px) {
  .c-section1920--service {
    margin-top: min(247px, 32.9333333333vw);
  }
}

.p-service__inner {
  max-width: min(1200px, 87.8477306003vw);
  margin: 0 auto;
}

/* ========== top ========== */
.p-service__top {
  display: grid;
  grid-template-columns: min(525px, 38.4333821376vw) min(300px, 21.9619326501vw);
  -moz-column-gap: min(148px, 10.8345534407vw);
       column-gap: min(148px, 10.8345534407vw);
  align-items: center;
  justify-content: center;
  grid-template-areas: "heading media" "text    media";
}
@media screen and (max-width: 750px) {
  .p-service__top {
    grid-template-columns: 1fr;
    -moz-column-gap: 0;
         column-gap: 0;
    row-gap: 20px;
    grid-template-areas: "heading" "media" "text";
  }
}
.p-service__top .p-service__heading {
  grid-area: heading;
  text-align: left;
}
@media screen and (max-width: 750px) {
  .p-service__top .p-service__heading {
    text-align: center;
  }
}
.p-service__top .c-section-heading__line {
  margin-inline: inherit;
}
@media screen and (max-width: 750px) {
  .p-service__top .c-section-heading__line {
    margin-inline: auto;
  }
}

.p-service__text {
  grid-area: text;
  margin-top: max(-50px, -3.6603221083vw);
}
@media screen and (max-width: 750px) {
  .p-service__text {
    margin-top: min(77px, 10.2666666667vw);
  }
}

.p-service__media {
  grid-area: media;
  margin: 0 auto;
}
@media screen and (max-width: 750px) {
  .p-service__media {
    margin-top: min(88px, 11.7333333333vw);
  }
}

.p-service__media img {
  width: min(280px, 20.4978038067vw);
  height: auto;
  display: block;
}
@media screen and (max-width: 750px) {
  .p-service__media img {
    width: min(550px, 73.3333333333vw);
  }
}

/* テキストの見え方(カンプ寄せはここで詰める) */
.p-service__desc {
  line-height: 2.5;
  font-size: min(1.0248901903vw, 14px);
  letter-spacing: 0.1em;
}
@media screen and (max-width: 750px) {
  .p-service__desc {
    font-size: min(3.2vw, 24px);
    line-height: 2;
  }
}

/* ========== points ========== */
.p-service__points {
  margin-top: min(91px, 6.6617862372vw);
  text-align: center;
}
@media screen and (max-width: 750px) {
  .p-service__points {
    margin-top: min(90px, 12vw);
  }
}

.p-service__points-inner {
  display: flex;
  gap: min(24px, 1.756954612vw);
}
@media screen and (max-width: 750px) {
  .p-service__points-inner {
    flex-direction: column;
    gap: min(47px, 6.2666666667vw);
  }
}

.p-service-point {
  display: flex;
  flex-direction: column;
  width: calc((100% - min(24px, 1.756954612vw) * 2) / 3);
  background: #FAFBFF;
  padding-block: min(40px, 2.9282576867vw);
  padding-inline: min(30px, 2.196193265vw);
}
@media screen and (max-width: 750px) {
  .p-service-point {
    width: 100%;
    padding-block: min(80px, 10.6666666667vw);
    padding-inline: min(28px, 3.7333333333vw);
  }
}

.p-service-point__label {
  letter-spacing: 0.06em;
  color: #002AC7;
  font-weight: 700;
  font-size: min(1.4641288433vw, 20px);
  position: relative;
  display: inline-block;
  padding-bottom: 4px;
}
.p-service-point__label::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: 16px;
  height: 1px;
  background: #002AC7;
}
@media screen and (max-width: 750px) {
  .p-service-point__label {
    padding-bottom: 6px;
    font-size: min(4vw, 30px);
  }
  .p-service-point__label::after {
    width: min(4.6666666667vw, 35px);
  }
}

.p-service-point__title {
  font-weight: 700;
  font-size: min(1.4641288433vw, 20px);
  margin-top: 10px;
  line-height: 1.5;
  color: #002AC7;
}
@media screen and (max-width: 750px) {
  .p-service-point__title {
    font-size: min(5.3333333333vw, 40px);
  }
}

.p-service-point__media {
  margin-top: min(40px, 2.9282576867vw);
}
@media screen and (max-width: 750px) {
  .p-service-point__media {
    margin-top: min(40px, 5.3333333333vw);
  }
}

.p-service-point__media-03 {
  margin-top: min(20px, 1.4641288433vw);
}
@media screen and (max-width: 750px) {
  .p-service-point__media-03 {
    margin-top: min(40px, 5.3333333333vw);
  }
}

.p-service-point__media img {
  width: 100%;
  height: auto;
  display: block;
}

.p-service-point__text {
  text-align: left;
  margin-top: min(18px, 1.317715959vw);
  line-height: 2.5;
  font-size: min(1.0248901903vw, 14px);
}
@media screen and (max-width: 750px) {
  .p-service-point__text {
    font-size: min(3.2vw, 24px);
    margin-top: min(33px, 4.4vw);
  }
}

/* 注釈（共通） */
.c-note {
  margin-top: min(12px, 0.8784773069vw);
  text-align: right;
  line-height: 1.6;
  font-size: min(0.8052703836vw, 11px);
}
@media screen and (max-width: 750px) {
  .c-note {
    margin-top: min(16px, 2.1333333333vw);
    font-size: min(2.4vw, 18px);
  }
}

.p-service-point .c-note {
  margin-top: auto;
}

.p-service-point__more {
  margin-top: auto;
  align-self: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: min(167px, 12.2254758419vw);
  height: min(39px, 2.8550512445vw);
  border-radius: 9999px;
  border: 0;
  background: #002AC7;
  color: #FFFFFF;
  letter-spacing: 0.06em;
  cursor: pointer;
  font-size: min(1.0248901903vw, 14px);
}
@media screen and (max-width: 750px) {
  .p-service-point__more {
    margin-top: min(39px, 5.2vw);
    width: min(407px, 54.2666666667vw);
    height: min(68px, 9.0666666667vw);
    font-size: min(4vw, 30px);
    color: #002AC7;
    border: 1px solid #002AC7;
    background: #FFFFFF;
  }
}

/* ========== modal ========== */
.c-modal {
  position: fixed;
  inset: 0;
  z-index: 1005;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px;
}
@media screen and (max-width: 750px) {
  .c-modal {
    padding: 20px;
  }
}

.c-modal.is-open {
  opacity: 1;
  pointer-events: auto;
}

.c-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
}

.c-modal__panel {
  position: relative;
  width: min(760px, 55.6368960469vw);
  max-height: calc(100vh - 80px);
  overflow: auto;
}
@media screen and (max-width: 750px) {
  .c-modal__panel {
    width: min(690px, 92vw);
    max-height: calc(100vh - 40px);
    width: 92vw;
  }
}

.c-modal__picture img {
  width: 100%;
  height: auto;
  display: block;
}

/* 画像右上× */
.c-modal__close {
  position: absolute;
  z-index: 5;
  top: 10px;
  right: 10px;
  width: 44px;
  height: 44px;
  border: 0;
  background: transparent;
  cursor: pointer;
}
@media screen and (max-width: 750px) {
  .c-modal__close {
    width: 20px;
    height: 20px;
  }
}

.c-modal__close::before,
.c-modal__close::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 26px;
  height: 2px;
  background: #111111;
}
@media screen and (max-width: 750px) {
  .c-modal__close::before,
  .c-modal__close::after {
    width: 20px;
    height: 1px;
  }
}

.c-modal__close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.c-modal__close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

/* ======================== */
/*         solution           */
/* ======================== */
/* section(1920止めは c-section1920 側想定) */
.c-section1920--solution {
  background: #FAFBFF;
}
.c-section1920--solution .c-poc--right {
  top: 0;
  right: 0;
  left: auto;
}
.c-section1920--solution .p-solution__padding {
  padding-top: min(90px, 12vw);
}

/* cards wrapper */
.p-solution__cards {
  width: min(1047px, 76.6471449488vw);
  max-width: 100%;
  margin-inline: auto;
  margin-top: min(85px, 6.2225475842vw);
  display: flex;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 750px) {
  .p-solution__cards {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: min(85px, 11.3333333333vw);
    margin-top: min(75px, 10vw);
  }
}

/* card */
.p-solution-card {
  width: min(250px, 18.3016105417vw);
  text-align: center;
}
@media screen and (max-width: 750px) {
  .p-solution-card {
    width: 100%;
    text-align: center;
  }
}

.p-solution-card__icon {
  margin: 0 auto;
  margin-bottom: 12px;
  height: min(100px, 7.3206442167vw);
}
@media screen and (max-width: 750px) {
  .p-solution-card__icon {
    margin-inline: auto;
    height: auto;
  }
}

.p-solution-card__icon-01 {
  width: min(91px, 6.6617862372vw);
}
@media screen and (max-width: 750px) {
  .p-solution-card__icon-01 {
    width: min(207px, 27.6vw);
  }
}

.p-solution-card__icon-02 {
  width: min(99px, 7.2474377745vw);
}
@media screen and (max-width: 750px) {
  .p-solution-card__icon-02 {
    width: min(216px, 28.8vw);
  }
}

.p-solution-card__icon-03 {
  width: min(104px, 7.6134699854vw);
}
@media screen and (max-width: 750px) {
  .p-solution-card__icon-03 {
    width: min(225px, 30vw);
  }
}

.p-solution-card__icon img {
  width: 100%;
  height: auto;
  display: block;
}

.p-solution-card__title {
  font-size: min(1.756954612vw, 24px);
  font-weight: 700;
  line-height: 1.4;
  color: #002AC7;
}
@media screen and (max-width: 750px) {
  .p-solution-card__title {
    font-size: min(4vw, 30px);
  }
}

.p-solution-card__text {
  margin-top: 14px;
  line-height: 2.5;
  font-size: min(1.0248901903vw, 14px);
  text-align: left;
  letter-spacing: 0em;
}
@media screen and (max-width: 750px) {
  .p-solution-card__text {
    font-size: min(3.2vw, 24px);
    letter-spacing: 0.1em;
    line-height: 2;
  }
}

/* cost lead */
.p-solution__cost-lead {
  margin-top: min(80px, 5.8565153734vw);
  text-align: center;
  font-weight: 700;
  font-size: min(2.196193265vw, 30px);
  color: #002AC7;
}
@media screen and (max-width: 750px) {
  .p-solution__cost-lead {
    margin-top: min(78px, 10.4vw);
    font-size: min(5.3333333333vw, 40px);
  }
}

/* figs */
.p-solution__figs {
  margin-top: min(59px, 4.3191800878vw);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: min(46px, 3.3674963397vw);
}
@media screen and (max-width: 750px) {
  .p-solution__figs {
    margin-top: min(59px, 7.8666666667vw);
    flex-direction: column;
    gap: min(97px, 12.9333333333vw);
    align-items: center;
  }
}

.p-solution-fig--wide {
  width: min(761px, 55.710102489vw);
}
@media screen and (max-width: 750px) {
  .p-solution-fig--wide {
    width: 100%;
  }
}

.p-solution-fig--narrow {
  width: min(392px, 28.6969253294vw);
  margin-bottom: min(25px, 1.8301610542vw);
}
@media screen and (max-width: 750px) {
  .p-solution-fig--narrow {
    width: 100%;
  }
}

.p-solution-fig img {
  width: 100%;
  height: auto;
  display: block;
}

/* ======================== */
/*         plan           */
/* ======================== */
.c-section1920--plan {
  background: #FAFBFF;
}

.p-plan__lead {
  text-align: center;
  font-weight: 700;
  font-size: min(2.196193265vw, 30px);
  color: #002AC7;
  letter-spacing: 0.08em;
  margin-top: min(62px, 4.5387994143vw);
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 750px) {
  .p-plan__lead {
    margin-top: min(32px, 4.2666666667vw);
    font-size: min(5.3333333333vw, 40px);
  }
}

.p-plan-steps {
  margin-top: min(28px, 2.0497803807vw);
  display: flex;
}
@media screen and (max-width: 750px) {
  .p-plan-steps {
    flex-direction: column;
    margin-top: min(47px, 6.2666666667vw);
  }
}

.p-plan-step {
  position: relative;
  flex: 1;
  padding-block: min(26px, 1.9033674963vw);
  padding-inline: min(20px, 1.4641288433vw);
  color: #FFFFFF;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (max-width: 750px) {
  .p-plan-step {
    padding-block: min(79px, 10.5333333333vw);
    padding-inline: min(20px, 2.6666666667vw);
  }
}

.p-plan-step--01 {
  background: #002AC7;
}

.p-plan-step--02 {
  background: #0D2E7A;
}

.p-plan-step--03 {
  background: #0E2357;
}

/* =========================
   PC: ▶︎ (01 → 02 / 02 → 03)
========================= */
.p-plan-step--01::after,
.p-plan-step--02::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(100%, -50%);
  width: min(30px, 2.196193265vw);
  height: min(40px, 2.9282576867vw);
  background: inherit;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  z-index: 2;
}
@media screen and (max-width: 750px) {
  .p-plan-step--01::after,
  .p-plan-step--02::after {
    /* SPでは一旦リセット */
    top: auto;
    right: auto;
    transform: none;
    width: auto;
    height: auto;
    clip-path: none;
  }
}

/* =========================
   SP: ▼ (01の下 / 02の下)
========================= */
@media screen and (max-width: 750px) {
  .p-plan-step--01::after,
  .p-plan-step--02::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 100%);
    width: min(35px, 4.6666666667vw);
    height: min(28px, 3.7333333333vw);
    background: inherit;
    clip-path: polygon(0 0, 50% 100%, 100% 0);
    z-index: 2;
  }
}
.p-plan-step__head {
  display: flex;
  align-items: center;
  gap: 12px;
}
@media screen and (max-width: 750px) {
  .p-plan-step__head {
    justify-content: center;
  }
}

.p-plan-step__num {
  font-family: Arial, "Helvetica Neue", Helvetica, "Noto Sans JP", sans-serif;
  font-size: min(4.39238653vw, 60px);
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 750px) {
  .p-plan-step__num {
    font-size: min(10.6666666667vw, 80px);
  }
}

.p-plan-step__month {
  font-family: Arial, "Helvetica Neue", Helvetica, "Noto Sans JP", sans-serif;
  font-size: min(1.0980966325vw, 15px);
  font-weight: 700;
}
@media screen and (max-width: 750px) {
  .p-plan-step__month {
    font-size: min(2.6666666667vw, 20px);
  }
}

.p-plan-step__title {
  font-size: min(1.317715959vw, 18px);
  font-weight: 700;
}
@media screen and (max-width: 750px) {
  .p-plan-step__title {
    font-size: min(4vw, 30px);
  }
}

.p-plan-step__icon {
  margin-top: min(30px, 2.196193265vw);
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 750px) {
  .p-plan-step__icon {
    margin-top: min(30px, 4vw);
  }
}

.p-plan-step__iconImg {
  display: block;
  height: auto;
}

.p-plan-step__iconImg--01 {
  width: min(85px, 6.2225475842vw);
}
@media screen and (max-width: 750px) {
  .p-plan-step__iconImg--01 {
    width: min(196px, 26.1333333333vw);
  }
}

.p-plan-step__iconImg--02 {
  width: min(72px, 5.270863836vw);
  margin-bottom: min(11px, 0.8052708638vw);
}
@media screen and (max-width: 750px) {
  .p-plan-step__iconImg--02 {
    width: min(176px, 23.4666666667vw);
  }
}

.p-plan-step__iconImg--03 {
  width: min(83px, 6.0761346999vw);
}
@media screen and (max-width: 750px) {
  .p-plan-step__iconImg--03 {
    width: min(195px, 26vw);
  }
}

.p-plan-step__list {
  margin-top: 18px;
  margin-inline: auto;
  display: inline-block;
  text-align: left;
}
@media screen and (max-width: 750px) {
  .p-plan-step__list {
    margin-top: min(30px, 4vw);
  }
}

.p-plan-step__item {
  font-size: 12px;
  line-height: 2.5;
}
@media screen and (max-width: 750px) {
  .p-plan-step__item {
    font-size: min(3.2vw, 24px);
  }
}

.p-plan__block--menu .p-plan__lead {
  margin-top: min(104px, 7.6134699854vw);
}
@media screen and (max-width: 750px) {
  .p-plan__block--menu .p-plan__lead {
    margin-top: min(87px, 11.6vw);
  }
}

.p-plan-menu {
  margin-top: min(30px, 2.196193265vw);
  display: flex;
  gap: 10px;
}
@media screen and (max-width: 750px) {
  .p-plan-menu {
    flex-direction: column;
    gap: min(50px, 6.6666666667vw);
    margin-top: min(53px, 7.0666666667vw);
  }
}

.p-plan-menu-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: #FFFFFF;
  padding-block: min(30px, 2.196193265vw);
  padding-inline: min(15px, 1.0980966325vw);
  width: 25%;
}
@media screen and (max-width: 750px) {
  .p-plan-menu-card {
    padding-block: min(89px, 11.8666666667vw);
    padding-inline: min(20px, 2.6666666667vw);
    width: 100%;
  }
}

.p-plan-menu-card__num {
  text-align: center;
  font-family: Arial, "Helvetica Neue", Helvetica, "Noto Sans JP", sans-serif;
  font-size: min(3.2942898975vw, 45px);
  font-weight: 700;
  color: #002AC7;
  line-height: 1;
}
@media screen and (max-width: 750px) {
  .p-plan-menu-card__num {
    font-size: min(10.6666666667vw, 80px);
  }
}

.p-plan-menu-card__title {
  text-align: center;
  margin-top: 6px;
  font-size: min(1.317715959vw, 18px);
  font-weight: 700;
  color: #002AC7;
  line-height: 1.4;
}
@media screen and (max-width: 750px) {
  .p-plan-menu-card__title {
    font-size: min(4vw, 30px);
  }
}

.p-plan-menu-card__icon {
  margin-top: min(30px, 2.196193265vw);
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 750px) {
  .p-plan-menu-card__icon {
    margin-top: min(44px, 5.8666666667vw);
  }
}

.p-plan-menu-card__iconImg {
  display: block;
  min-height: min(60px, 4.39238653vw);
  height: auto;
}

.p-plan-menu-card__iconImg--01 {
  width: min(76px, 5.5636896047vw);
}
@media screen and (max-width: 750px) {
  .p-plan-menu-card__iconImg--01 {
    width: min(246px, 32.8vw);
  }
}

.p-plan-menu-card__iconImg--02 {
  width: min(59px, 4.3191800878vw);
}
@media screen and (max-width: 750px) {
  .p-plan-menu-card__iconImg--02 {
    width: min(190px, 25.3333333333vw);
  }
}

.p-plan-menu-card__iconImg--03 {
  width: min(63px, 4.6120058565vw);
}
@media screen and (max-width: 750px) {
  .p-plan-menu-card__iconImg--03 {
    width: min(191px, 25.4666666667vw);
  }
}

.p-plan-menu-card__iconImg--04 {
  width: min(75px, 5.4904831625vw);
}
@media screen and (max-width: 750px) {
  .p-plan-menu-card__iconImg--04 {
    width: min(225px, 30vw);
  }
}

.p-plan-menu-card__list {
  margin-top: min(30px, 2.196193265vw);
  display: inline-block;
  text-align: left;
}
@media screen and (max-width: 750px) {
  .p-plan-menu-card__list {
    margin-top: min(35px, 4.6666666667vw);
  }
}

.p-plan-menu-card__item {
  font-size: min(0.878477306vw, 12px);
  line-height: 2.5;
  letter-spacing: 0em;
}
@media screen and (max-width: 750px) {
  .p-plan-menu-card__item {
    font-size: min(3.2vw, 24px);
  }
}

.p-plan-menu-card__item-sm {
  font-size: 8px;
  line-height: 1.5;
}
@media screen and (max-width: 750px) {
  .p-plan-menu-card__item-sm {
    font-size: min(1.8666666667vw, 14px);
  }
}

/* =========================
   パッケージ全体
========================= */
.p-plan__block--package .p-plan__lead {
  margin-top: min(83px, 6.0761346999vw);
}
@media screen and (max-width: 750px) {
  .p-plan__block--package .p-plan__lead {
    margin-top: min(93px, 12.4vw);
  }
}
.p-plan__block--package .p-plan__note {
  font-size: min(1.0248901903vw, 14px);
  text-align: center;
  line-height: 2;
}
@media screen and (max-width: 750px) {
  .p-plan__block--package .p-plan__note {
    font-size: min(3.2vw, 24px);
  }
}

.p-plan-package {
  margin-top: min(28px, 2.0497803807vw);
  display: flex;
}
@media screen and (max-width: 750px) {
  .p-plan-package {
    flex-direction: column;
    margin-top: min(49px, 6.5333333333vw);
  }
}

.p-plan-package-main {
  width: min(361px, 26.4275256223vw);
  background: #002AC7;
  color: #FFFFFF;
  padding-block: min(25px, 1.8301610542vw);
  padding-inline: min(25px, 1.8301610542vw);
  text-align: center;
}
@media screen and (max-width: 750px) {
  .p-plan-package-main {
    width: 100%;
    padding-block: min(96px, 12.8vw);
    padding-inline: min(20px, 2.6666666667vw);
  }
}

.p-plan-package-main__label {
  font-size: min(1.0248901903vw, 14px);
  font-weight: 700;
  letter-spacing: 0.1em;
  position: relative;
  padding-bottom: 8px;
}
@media screen and (max-width: 750px) {
  .p-plan-package-main__label {
    font-size: min(4vw, 30px);
  }
}

.p-plan-package-main__label::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: 16px;
  height: 1px;
  background: #FFFFFF;
}

.p-plan-package-main__price {
  margin-top: 10px;
  font-size: min(3.2942898975vw, 45px);
  font-weight: 700;
  line-height: 1.2;
}
@media screen and (max-width: 750px) {
  .p-plan-package-main__price {
    font-size: min(10.6666666667vw, 80px);
  }
}

.p-plan-package-main__tax {
  font-size: 12px;
  margin-left: 4px;
}
@media screen and (max-width: 750px) {
  .p-plan-package-main__tax {
    font-size: min(3.2vw, 24px);
  }
}

.p-plan-package-main__sub {
  margin-top: 6px;
  font-size: 14px;
}
@media screen and (max-width: 750px) {
  .p-plan-package-main__sub {
    font-size: min(3.2vw, 24px);
  }
}

.p-plan-package-main__sm {
  font-size: 12px;
}
@media screen and (max-width: 750px) {
  .p-plan-package-main__sm {
    font-size: min(3.2vw, 24px);
  }
}

.p-plan-package-main__icon {
  margin-top: 18px;
  width: min(64px, 4.6852122987vw);
  height: auto;
  margin-inline: auto;
}
@media screen and (max-width: 750px) {
  .p-plan-package-main__icon {
    width: min(172px, 22.9333333333vw);
  }
}

.p-plan-package-main__all {
  margin-top: 14px;
  font-size: 14px;
  font-weight: 700;
}
@media screen and (max-width: 750px) {
  .p-plan-package-main__all {
    font-size: min(4vw, 30px);
  }
}

.p-plan-package-main__desc {
  font-size: min(1.0248901903vw, 14px);
  line-height: 1.8;
}
@media screen and (max-width: 750px) {
  .p-plan-package-main__desc {
    font-size: min(3.2vw, 24px);
  }
}

.p-plan-package-main__note {
  margin-top: 6px;
  font-size: 8px;
}
@media screen and (max-width: 750px) {
  .p-plan-package-main__note {
    font-size: min(1.8666666667vw, 14px);
  }
}

/* =========================
   右：3枚カードまとめ
========================= */
.p-plan-package-sub {
  flex: 1;
  display: flex;
  background: #FFFFFF;
  padding-block: min(26px, 1.9033674963vw);
}
@media screen and (max-width: 750px) {
  .p-plan-package-sub {
    flex-direction: column;
    padding-block: 0;
  }
}

/* =========================
   右側カード共通
========================= */
.p-plan-package-card {
  flex: 1;
  padding-inline: min(40px, 2.9282576867vw);
  position: relative;
  text-align: center;
}
@media screen and (max-width: 750px) {
  .p-plan-package-card {
    padding-inline: min(20px, 2.6666666667vw);
    padding-block: min(90px, 12vw);
  }
}

.p-plan-package-card__title {
  font-size: min(1.756954612vw, 24px);
  font-weight: 700;
  color: #002AC7;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 750px) {
  .p-plan-package-card__title {
    font-size: min(6.6666666667vw, 50px);
  }
}

.p-plan-package-card__icon {
  margin-top: min(28px, 2.0497803807vw);
  height: auto;
}
.p-plan-package-card__icon .p-plan-package-card__iconImg {
  margin-inline: auto;
}

.p-plan-package-card__iconImg--01 {
  width: min(80px, 5.8565153734vw);
}
@media screen and (max-width: 750px) {
  .p-plan-package-card__iconImg--01 {
    width: min(174px, 23.2vw);
  }
}

.p-plan-package-card__iconImg--02 {
  width: min(84px, 6.149341142vw);
}
@media screen and (max-width: 750px) {
  .p-plan-package-card__iconImg--02 {
    width: min(184px, 24.5333333333vw);
  }
}

.p-plan-package-card__iconImg--03 {
  width: min(82px, 6.0029282577vw);
}
@media screen and (max-width: 750px) {
  .p-plan-package-card__iconImg--03 {
    width: min(192px, 25.6vw);
  }
}

.p-plan-package-card__list {
  margin-top: 18px;
  display: inline-block;
  text-align: left;
}

.p-plan-package-card__item {
  font-size: min(0.878477306vw, 12px);
  line-height: 2.5;
  white-space: nowrap;
}
@media screen and (max-width: 750px) {
  .p-plan-package-card__item {
    font-size: min(3.2vw, 24px);
  }
}

/* =========================
   PC：カード間の縦線(境界線)
========================= */
.p-plan-package-card + .p-plan-package-card {
  border-left: 1px solid #979797;
}
@media screen and (max-width: 750px) {
  .p-plan-package-card + .p-plan-package-card {
    border-left: none;
  }
}

/* =========================
   SP：padding分短い横線
========================= */
@media screen and (max-width: 750px) {
  .p-plan-package-card + .p-plan-package-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 18px;
    right: 18px;
    height: 1px;
    background: #979797;
  }
}
/* ======================== */
/*         FAQ           */
/* ======================== */
.c-section1920--faq {
  background: #FAFBFF;
}

.p-faq__content {
  width: min(886px, 64.8609077599vw);
  margin-inline: auto;
  margin-top: min(56px, 4.0995607613vw);
}
@media screen and (max-width: 750px) {
  .p-faq__content {
    width: 100%;
    margin-top: min(96px, 12.8vw);
  }
}

.p-faq-group + .p-faq-group {
  margin-top: min(43px, 3.1478770132vw);
}
@media screen and (max-width: 750px) {
  .p-faq-group + .p-faq-group {
    margin-top: min(92px, 12.2666666667vw);
  }
}

.p-faq-group__title {
  text-align: center;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin-bottom: 22px;
  color: #002AC7;
  font-size: min(1.756954612vw, 24px);
}
@media screen and (max-width: 750px) {
  .p-faq-group__title {
    margin-bottom: 18px;
    font-size: min(4vw, 30px);
  }
}

/* item */
.p-faq-item {
  font-size: min(1.0248901903vw, 14px);
  letter-spacing: 0.1em;
}
@media screen and (max-width: 750px) {
  .p-faq-item {
    font-size: min(3.2vw, 24px);
  }
}

/* question button */
.p-faq-item__q {
  width: 100%;
  padding-block: min(20px, 1.4641288433vw);
  display: flex;
  align-items: center;
  gap: 14px;
  background: transparent;
  border: 0;
  text-align: left;
  cursor: pointer;
}
@media screen and (max-width: 750px) {
  .p-faq-item__q {
    padding-block: min(2.6666666667vw, 20px);
    gap: 12px;
  }
}

/* Q/A circle */
.p-faq-item__mark {
  font-family: Arial, "Helvetica Neue", Helvetica, "Noto Sans JP", sans-serif;
  width: 28px;
  height: 28px;
  border-radius: 9999px;
  background: #002AC7;
  color: #FFFFFF;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  flex: 0 0 auto;
}
@media screen and (max-width: 750px) {
  .p-faq-item__mark {
    width: min(5.0666666667vw, 38px);
    height: min(5.0666666667vw, 38px);
  }
}

.p-faq-item__mark--a {
  background: #FAFBFF;
  color: #002AC7;
}

/* q text */
.p-faq-item__qText {
  flex: 1;
  line-height: 1.9;
}

/* plus/minus */
.p-faq-item__plus {
  width: 18px;
  height: 18px;
  position: relative;
  flex: 0 0 auto;
  margin-right: 8px;
}
@media screen and (max-width: 750px) {
  .p-faq-item__plus {
    width: min(4.8vw, 36px);
    height: min(4.8vw, 36px);
  }
}

.p-faq-item__plus::before,
.p-faq-item__plus::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 18px;
  height: 1px;
  background: #111111;
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 750px) {
  .p-faq-item__plus::before,
  .p-faq-item__plus::after {
    width: min(4.8vw, 36px);
  }
}

.p-faq-item__plus::after {
  width: 1px;
  height: 18px;
}
@media screen and (max-width: 750px) {
  .p-faq-item__plus::after {
    height: min(4.8vw, 36px);
  }
}

/* answer panel */
.p-faq-item__a {
  height: 0;
  overflow: hidden;
  transition: height 0.28s ease;
}

.p-faq-item__aInner {
  display: flex;
  gap: 14px;
  padding-block: min(20px, 1.4641288433vw);
  border-top: 1px solid #BCBCBC;
  align-items: baseline;
}
@media screen and (max-width: 750px) {
  .p-faq-item__aInner {
    gap: 12px;
    padding-block: min(18px, 2.4vw);
    margin-bottom: min(52px, 6.9333333333vw);
  }
}

.p-faq-item__aText {
  margin: 0;
  line-height: 2;
  width: 85%;
}

/* open state */
.p-faq-item.is-open .p-faq-item__plus::after {
  display: none;
}

/* ======================== */
/*         company           */
/* ======================== */
.c-section1920--company {
  background: #FFFFFF;
}
.c-section1920--company .p-company__padding {
  padding-top: min(121px, 8.8579795022vw);
  padding-bottom: min(143px, 10.4685212299vw);
}
@media screen and (max-width: 750px) {
  .c-section1920--company .p-company__padding {
    padding-top: min(123px, 16.4vw);
    padding-bottom: min(150px, 20vw);
  }
}

/* table wrapper */
.p-company__table {
  width: min(690px, 50.5124450952vw);
  max-width: 100%;
  margin-inline: auto;
  margin-top: min(60px, 4.39238653vw);
}
@media screen and (max-width: 750px) {
  .p-company__table {
    margin-top: min(37px, 4.9333333333vw);
    width: 100%;
  }
}

/* dl */
.p-company-dl__row {
  display: flex;
  gap: min(28px, 2.0497803807vw);
  padding-block: min(20px, 1.4641288433vw);
  border-bottom: 1px solid #B6B6B6;
  white-space: nowrap;
  font-size: min(1.0248901903vw, 14px);
  align-items: center;
}
.p-company-dl__row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
@media screen and (max-width: 750px) {
  .p-company-dl__row {
    gap: min(35px, 4.6666666667vw);
    padding-block: min(35px, 4.6666666667vw);
    font-size: min(3.2vw, 24px);
  }
}

.p-company-dl__term {
  width: 85px;
  flex: 0 0 auto;
  font-weight: 400;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 750px) {
  .p-company-dl__term {
    width: min(155px, 20.6666666667vw);
  }
}

.p-company-dl__desc {
  flex: 1;
  margin: 0;
  line-height: 2.2;
}

/* ======================== */
/*         contact           */
/* ======================== */
.c-section1920--contact {
  background: #FAFBFF;
}
.c-section1920--contact .p-contact__padding {
  padding-top: min(86px, 6.2957540264vw);
  padding-bottom: min(100px, 7.3206442167vw);
}
@media screen and (max-width: 750px) {
  .c-section1920--contact .p-contact__padding {
    padding-top: min(96px, 12.8vw);
    padding-bottom: min(100px, 13.3333333333vw);
  }
}

/* lead */
.p-contact__lead {
  margin-top: min(49px, 3.5871156662vw);
  text-align: center;
  line-height: 2.2;
  font-size: min(1.0248901903vw, 14px);
}
@media screen and (max-width: 750px) {
  .p-contact__lead {
    margin-top: min(30px, 4vw);
    font-size: min(3.2vw, 24px);
  }
}

/* actions */
.p-contact__actions {
  margin-top: min(41px, 3.0014641288vw);
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 750px) {
  .p-contact__actions {
    gap: min(30px, 4vw);
    margin-top: min(42px, 5.6vw);
  }
}
.p-contact__actions .c-pill-btn {
  gap: 11px;
}
@media screen and (max-width: 750px) {
  .p-contact__actions .c-pill-btn {
    gap: min(20px, 2.6666666667vw);
  }
}
.p-contact__actions .c-pill-btn--mail {
  color: #FFFFFF;
  background: #002AC7;
  width: min(367px, 26.8667642753vw);
  height: min(60px, 4.39238653vw);
}
@media screen and (max-width: 750px) {
  .p-contact__actions .c-pill-btn--mail {
    width: min(630px, 84vw);
    height: min(90px, 12vw);
  }
}
.p-contact__actions .c-pill-btn--mail .c-pill-btn__icon {
  width: min(29px, 2.1229868228vw);
}
@media screen and (max-width: 750px) {
  .p-contact__actions .c-pill-btn--mail .c-pill-btn__icon {
    width: min(52px, 6.9333333333vw);
  }
}
.p-contact__actions .c-pill-btn__text {
  font-size: min(1.4641288433vw, 20px);
}
@media screen and (max-width: 750px) {
  .p-contact__actions .c-pill-btn__text {
    font-size: min(5.3333333333vw, 40px);
  }
}

/* ======================== */
/*   下からフェードイン      */
/* ======================== */
.js-fade-up {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.js-fade-up.is-show {
  opacity: 1;
  transform: translateY(0);
}

/* ======================== */
/*         追従ボタン           */
/* ======================== */
.js-fv-end {
  height: 1px;
}

.p-float-contact {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translate(-50%, 10px);
  z-index: 1000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s, transform 0.3s;
}

.p-float-contact.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0);
}