@charset "UTF-8";
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
small,
button,
time,
figure {
  border: 0;
  font: inherit;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

html {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

li,
dd {
  list-style-type: none;
}

header,
footer,
nav,
section,
article,
main,
aside,
figure,
figcaption {
  display: block;
}

img {
  border: none;
  vertical-align: bottom;
}

html {
  -webkit-text-size-adjust: 100%; /* iOS Safari用 */
  -moz-text-size-adjust: 100%;
   -ms-text-size-adjust: 100%;
       text-size-adjust: 100%;
}
@media screen and (max-width: 1199px) and (min-width: 768px) {
  html {
    font-size: calc(16 / 1200 * 100vw);
  }
}
@media screen and (max-width: 429px) {
  html {
    font-size: calc(16 / 430 * 100vw);
  }
}

body {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
}

a {
  text-decoration: none;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  color: inherit;
}
@media (hover: hover) {
  a:hover {
    cursor: pointer;
    opacity: 0.7;
  }
}

picture,
img,
a {
  display: inline-block;
}

video,
img,
svg {
  width: 100%;
  height: 100%;
}

button {
  font: inherit;
  color: inherit;
  background: transparent;
  background: none;
  border: none;
}

input,
textarea,
select {
  font: inherit;
}

.l-main {
  min-height: 100vh;
  overflow: hidden;
}

.l-inner {
  position: relative;
  width: 100%;
  max-width: 1200px;
  height: inherit;
  padding: 0 2.5rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .l-inner {
    width: 100%;
    max-width: 632px;
    padding: 0 1rem;
  }
}

.l-inner__narrow {
  max-width: 50rem;
}
@media screen and (max-width: 767px) {
  .l-inner__narrow {
    padding: 0 1rem;
    max-width: 600px;
  }
}

.p-header__btn--orange {
  width: 10.325rem;
  height: 2.275rem;
  border-radius: 0.875rem;
  background: #FF8127;
  color: #FFF;
  font-family: "Inria Sans";
  font-size: 0.9625rem;
  font-weight: 700;
  line-height: 1.05rem;
  text-transform: uppercase;
  display: grid;
  place-items: center;
}
@media screen and (max-width: 767px) {
  .p-header__btn--orange {
    width: 7.375rem;
    height: 1.625rem;
    border-radius: 0.625rem;
    font-size: 0.6875rem;
    line-height: 0.75rem;
  }
}

.p-header__btn--yellow {
  width: 10.325rem;
  height: 2.275rem;
  border-radius: 0.875rem;
  background: #FFC828;
  color: #000;
  font-family: "Inria Sans";
  font-size: 0.9625rem;
  font-weight: 700;
  line-height: 1.05rem;
  text-transform: uppercase;
  display: grid;
  place-items: center;
}
@media screen and (max-width: 767px) {
  .p-header__btn--yellow {
    width: 7.375rem;
    height: 1.625rem;
    border-radius: 0.625rem;
    font-size: 0.6875rem;
    line-height: 0.75rem;
  }
}

.c-btn--orange {
  width: 17.90625rem;
  height: 6.84375rem;
  color: #FFF;
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 1.7120625rem;
  font-weight: 500;
  line-height: 2.0184375rem;
  letter-spacing: 0.12675rem;
  border-radius: 0.9375rem;
  background: #FF8127;
  -webkit-box-shadow: 0 0.75rem 0.75rem 0 rgba(0, 0, 0, 0.25);
          box-shadow: 0 0.75rem 0.75rem 0 rgba(0, 0, 0, 0.25);
  display: grid;
  place-items: center;
}
@media screen and (max-width: 767px) {
  .c-btn--orange {
    width: 11.9375rem;
    height: 4.5625rem;
    font-size: 1.141375rem;
    line-height: 1.345625rem;
    letter-spacing: 0.0845rem;
  }
}

.c-btn--yellow {
  width: 17.90625rem;
  height: 6.84375rem;
  color: #000;
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 1.7120625rem;
  font-weight: 700;
  line-height: 2.0184375rem;
  letter-spacing: 0.12675rem;
  border-radius: 0.9375rem;
  background: #FFC828;
  -webkit-box-shadow: 0 0.75rem 0.75rem 0 rgba(0, 0, 0, 0.25);
          box-shadow: 0 0.75rem 0.75rem 0 rgba(0, 0, 0, 0.25);
  display: grid;
  place-items: center;
}
@media screen and (max-width: 767px) {
  .c-btn--yellow {
    width: 11.9375rem;
    height: 4.5625rem;
    font-size: 1.141375rem;
    line-height: 1.345625rem;
    letter-spacing: 0.0845rem;
  }
}

.c-cta__btn {
  position: fixed;
  left: 50%;
  translate: -50% 110%;
  bottom: calc(env(safe-area-inset-bottom, 0px) + 16px);
  z-index: 10000;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: all 0.7s ease;
  transition: all 0.7s ease;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 1.5rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 767px) {
  .c-cta__btn {
    gap: 1rem;
  }
}

/* 表示時 */
.c-cta__btn.is-visible {
  opacity: 1;
  translate: -50% 0;
  pointer-events: auto;
}

.c-animated__fadeIn {
  translate: 0 20px;
  opacity: 0;
}
.c-animated__fadeIn.js-show {
  translate: 0;
  opacity: 1;
}

.c-environment__title {
  color: #0B308D;
  text-align: center;
  font-family: "Inria Sans";
  font-size: 2.3125rem;
  font-weight: 700;
  line-height: 1.8rem;
  position: relative;
  margin-bottom: 4.25rem;
}
@media screen and (max-width: 767px) {
  .c-environment__title {
    font-size: 1.5625rem;
    line-height: 1.2rem;
    margin-bottom: 2rem;
  }
}
.c-environment__title::after {
  content: "";
  position: absolute;
  width: 70rem;
  height: 0.09375rem;
  background: #0B308D;
  left: 50%;
  translate: -50%;
  bottom: -1.5625rem;
}
@media screen and (max-width: 767px) {
  .c-environment__title::after {
    width: 24.875rem;
    bottom: -1rem;
  }
}

.c-environment__content {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  text-align: center;
  width: 53.25rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .c-environment__content {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
    width: 24.875rem;
  }
}

.c-environment__card {
  -o-object-fit: cover;
     object-fit: cover;
  height: 5.1875rem;
  border-radius: 0.625rem;
  border: 1px solid #0B308D;
  background: -webkit-gradient(linear, left top, left bottom, from(#F0F4FF), to(#E1EAFF));
  background: linear-gradient(180deg, #F0F4FF 0%, #E1EAFF 100%);
  display: grid;
  place-items: center;
  -webkit-box-shadow: 0 0.25rem 0.25rem 0 rgba(0, 0, 0, 0.25);
          box-shadow: 0 0.25rem 0.25rem 0 rgba(0, 0, 0, 0.25);
}
.c-environment__card:nth-child(7) {
  grid-column: span 2;
}
.c-environment__card .text {
  color: #0B308D;
  font-size: 1.141375rem;
  font-weight: 700;
  line-height: 1.345625rem;
  letter-spacing: 0.0845rem;
}
.c-environment__card .text span {
  font-size: 0.75rem;
}

.p-header {
  padding-block: 0.9775rem 0.93625rem;
}

.p-header__inner {
  padding-inline: 2.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 767px) {
  .p-header__inner {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 0.375rem 1.125rem;
    padding-inline: 1rem;
  }
}

.p-header__logo {
  width: 10rem;
  height: 2.398375rem;
}
@media screen and (max-width: 767px) {
  .p-header__logo {
    width: 6.6875rem;
    height: 1.6039375rem;
  }
}

.p-header__text {
  color: #000;
  font-family: "Inria Sans";
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 0.75rem;
}
@media screen and (max-width: 767px) {
  .p-header__text {
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
    width: 100%;
    text-align: center;
    font-size: 0.8125rem;
  }
}

.p-header__btn-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 1.4rem;
  margin-left: 2.625rem;
}
@media screen and (max-width: 767px) {
  .p-header__btn-wrap {
    margin-left: 0;
    gap: 0.9375rem;
  }
}

.p-header__lead {
  text-align: center;
  color: #FFC828;
  font-family: "Inria Sans";
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 1rem;
  background: #0B308D;
  height: 3.4375rem;
  display: grid;
  place-items: center;
}
@media screen and (max-width: 767px) {
  .p-header__lead {
    font-size: 0.6875rem;
  }
}

.p-environment {
  padding-block: 2.5rem 5.03125rem;
}
@media screen and (max-width: 767px) {
  .p-environment {
    padding-block: 2rem;
  }
}

.p-environment__lead {
  color: #000;
  text-align: center;
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 1.875rem;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .p-environment__lead {
    font-size: 1.25rem;
    margin-bottom: 2rem;
  }
}

.p-environment__title {
  color: #0B308D;
  margin-top: 2.5rem;
  text-align: center;
  font-size: 2.34375rem;
  font-weight: 900;
  line-height: 2.8125rem;
  margin-bottom: 1.59375rem;
}
@media screen and (max-width: 767px) {
  .p-environment__title {
    font-size: 1.5625rem;
    line-height: 1.875rem;
    margin-top: 2rem;
    margin-bottom: 1.0625rem;
  }
}

.p-environment__text {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  color: #000;
  font-size: 1.40625rem;
  font-weight: 500;
  line-height: 2.8125rem;
  margin-bottom: 2.09375rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-environment__text {
    font-size: 0.9375rem;
    line-height: 1.875rem;
    margin-bottom: 1.25rem;
  }
}
.p-environment__text::before {
  content: "";
  position: absolute;
  background: url(../img/deco3.png) no-repeat center center/cover;
  width: 2.203125rem;
  height: 3.5625rem;
  top: 50%;
  translate: 0 -50%;
  left: -2.34375rem;
}
@media screen and (max-width: 767px) {
  .p-environment__text::before {
    width: 1.46875rem;
    height: 2.375rem;
    left: -1.53125rem;
  }
}
.p-environment__text::after {
  content: "";
  position: absolute;
  background: url(../img/deco4.png) no-repeat center center/cover;
  width: 2.203125rem;
  height: 3.5625rem;
  top: 50%;
  translate: 0 -50%;
  right: -2.34375rem;
}
@media screen and (max-width: 767px) {
  .p-environment__text::after {
    width: 1.46875rem;
    height: 2.375rem;
    right: -1.53125rem;
  }
}

.p-environment__btn-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 1.5rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 767px) {
  .p-environment__btn-wrap {
    gap: 1rem;
  }
}

.p-fv {
  background: url(../img/bg-fv.png) no-repeat center center/cover;
  padding-block: 6rem 7.09375rem;
}
@media screen and (max-width: 767px) {
  .p-fv {
    padding-block: 6.3125rem 6rem;
  }
}

.p-fv__inner {
  width: 63rem;
  margin-inline: auto;
  padding-inline: 2.5rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-fv__inner {
    width: 26.875rem;
    padding-inline: 1rem;
  }
}
.p-fv__inner::before {
  content: "";
  position: absolute;
  background: url(../img/deco1.png) no-repeat center center/cover;
  width: 10.03125rem;
  height: auto;
  aspect-ratio: 1;
  left: -4.4375rem;
  top: -6.3125rem;
}
@media screen and (max-width: 767px) {
  .p-fv__inner::before {
    width: 6.6875rem;
    left: 1rem;
    top: -6.625rem;
  }
}
.p-fv__inner::after {
  content: "";
  position: absolute;
  background: url(../img/deco2.png) no-repeat center center/cover;
  width: 26.018rem;
  height: 6.3375rem;
  right: 2.5rem;
  top: -5.1875rem;
}
@media screen and (max-width: 767px) {
  .p-fv__inner::after {
    width: 17.345625rem;
    height: 4.225rem;
    top: -5.25rem;
    right: 1rem;
  }
}

.p-fv__lead {
  width: 29.5rem;
  height: auto;
  margin-left: 2.9375rem;
  margin-bottom: 0.875rem;
}
@media screen and (max-width: 767px) {
  .p-fv__lead {
    width: 19.1875rem;
    margin-bottom: 0.5625rem;
    margin-left: 5.25rem;
  }
}

.p-fv__text-main {
  color: #0B308D;
  padding: 0.75rem 3.4375rem;
  font-family: "Inria Sans";
  font-size: 1.6875rem;
  font-weight: 700;
  line-height: 2.8125rem;
  border: 4px solid #0B308D;
  background: #FFF;
  margin-bottom: 1.5625rem;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .p-fv__text-main {
    font-size: 1.125rem;
    padding: 0.8125rem 0.625rem 0.625rem 0.625rem;
    line-height: 1.8125rem;
  }
}
.p-fv__text-main .lg {
  font-size: 2.71875rem;
  position: relative;
  isolation: isolate;
}
.p-fv__text-main .lg::after {
  content: "";
  position: absolute;
  background: #FFC828;
  width: 32.5625rem;
  height: 0.6875rem;
  left: 50%;
  translate: -50%;
  bottom: 0rem;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-fv__text-main .lg::after {
    width: 21.75rem;
  }
}
@media screen and (max-width: 767px) {
  .p-fv__text-main .lg {
    font-size: 1.8125rem;
  }
}
.p-fv__text-main .md {
  font-size: 2.0625rem;
  position: relative;
  isolation: isolate;
}
.p-fv__text-main .md::after {
  content: "";
  position: absolute;
  background: #FFC828;
  width: 16.1875rem;
  height: 0.6875rem;
  left: 50%;
  translate: -50%;
  bottom: 0;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-fv__text-main .md::after {
    width: 11.125rem;
  }
}
@media screen and (max-width: 767px) {
  .p-fv__text-main .md {
    font-size: 1.375rem;
    line-height: 1.8125rem;
  }
}

.p-fv__text-sub {
  width: 52.875rem;
  padding: 1.1875rem 3.4375rem;
  background: #FFC828;
  color: #000;
  font-family: "Inria Sans";
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 1.125rem;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 767px) {
  .p-fv__text-sub {
    margin-inline: calc(50% - 50vw);
    width: 100vw;
    font-size: 0.8125rem;
    padding: 0.625rem 0.875rem;
  }
}

.p-fv__img {
  position: absolute;
  width: 22.5rem;
  height: auto;
  right: -0.9875rem;
  top: 1.25rem;
}
@media screen and (max-width: 767px) {
  .p-fv__img {
    width: 16.0625rem;
    right: -2.25rem;
    top: 4.375rem;
  }
}

.p-fv__text-wrap {
  width: 58rem;
  margin-inline: auto;
  padding: 1.6875rem;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.8);
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .p-fv__text-wrap {
    width: 24rem;
    padding: 0.6875rem 0.4375rem 1.125rem 0.5rem;
  }
}

.p-fv__text {
  color: #000;
  font-family: "Inria Sans";
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 1.5rem;
}
@media screen and (max-width: 767px) {
  .p-fv__text {
    font-size: 0.6875rem;
    line-height: 0.9375rem;
  }
}
.p-fv__text .orange {
  color: #FF8127;
}

.p-fv__btn-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 1.5rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.p-fv__environment {
  margin-top: -2.5rem;
  margin-bottom: 5.1875rem;
}

.p-problem {
  padding-block: 15rem 3.875rem;
  background: #F2F2F2;
}
@media screen and (max-width: 767px) {
  .p-problem {
    padding-block: 21.65625rem 1rem;
  }
}

.p-problem__inner {
  position: relative;
  width: 58.25rem;
  padding-inline: 2.5rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-problem__inner {
    width: 26.875rem;
    padding-inline: 1rem;
  }
}

.p-problem__lead {
  color: #0B308D;
  text-align: center;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.875rem;
  letter-spacing: 0.0845rem;
  position: absolute;
  top: -12.5625rem;
  left: 10.4375rem;
}
@media screen and (max-width: 767px) {
  .p-problem__lead {
    line-height: 1.5625rem;
    top: -19.65625rem;
    left: 50%;
    translate: -50%;
    width: 100%;
  }
}

.p-problem__img {
  position: absolute;
  width: 15.3125rem;
  height: 16rem;
  top: -17rem;
  right: 10.4375rem;
  aspect-ratio: 245/256;
}
@media screen and (max-width: 767px) {
  .p-problem__img {
    height: 12.5625rem;
    width: auto;
    top: -13.96875rem;
    right: unset;
    left: 50%;
    translate: -50%;
  }
}

.p-problem__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2.455625rem 1.809375rem;
  margin-bottom: 2.875rem;
}
@media screen and (max-width: 767px) {
  .p-problem__list {
    grid-template-columns: 1fr;
    gap: 1.46875rem;
  }
}

.p-problem__item {
  color: #000;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.5625rem;
  letter-spacing: 0.0845rem;
  padding-left: 2.32625rem;
  position: relative;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .p-problem__item {
    font-size: 0.875rem;
    padding-left: 2.25rem;
  }
}
.p-problem__item::before {
  content: "";
  position: absolute;
  background: url(../img/icon1.png) no-repeat center center/cover;
  width: 1.7448125rem;
  height: 1.6293125rem;
  top: 50%;
  translate: 0 -50%;
  left: 0;
}
@media screen and (max-width: 767px) {
  .p-problem__item::before {
    width: 1.6875rem;
    height: 1.57575rem;
  }
}
.p-problem__item::after {
  content: "";
  position: absolute;
  width: 25.72025rem;
  height: 1px;
  background: #0B308D;
  left: 50%;
  translate: -50%;
  bottom: -0.875rem;
}
@media screen and (max-width: 767px) {
  .p-problem__item::after {
    width: 24.875rem;
  }
}
.p-problem__item span {
  color: #0B308D;
  font-weight: 900;
}

.p-problem__text-main {
  width: 53.25rem;
  height: 4.375rem;
  display: grid;
  place-items: center;
  border: 1px solid #0B308D;
  background: #FFF;
  color: #0B308D;
  font-size: 1.25rem;
  font-weight: 900;
  line-height: 2.1875rem;
  letter-spacing: 0.0845rem;
  position: relative;
  margin-bottom: 3.375rem;
  margin-inline: auto;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-problem__text-main {
    width: 20.375rem;
    height: 6.3125rem;
  }
}
.p-problem__text-main::after {
  content: "";
  position: absolute;
  background: url(../img/icon2.png) no-repeat center center/cover;
  width: 2.5625rem;
  height: 1.375rem;
  right: 9.125rem;
  bottom: -1.375rem;
}
@media screen and (max-width: 767px) {
  .p-problem__text-main::after {
    background: url(../img/icon2-sp.png) no-repeat center center/cover;
    width: 1.625rem;
    height: 1.375rem;
    bottom: -1.375rem;
    right: 3.5rem;
  }
}

.p-problem__text-sub {
  color: #000;
  text-align: center;
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: 1.5625rem;
  letter-spacing: 0.0845rem;
}
@media screen and (max-width: 767px) {
  .p-problem__text-sub {
    font-size: 0.9375rem;
  }
}

.p-lead {
  padding-block: 3rem;
}
@media screen and (max-width: 767px) {
  .p-lead {
    padding-block: 1.5rem 1.625rem;
  }
}

.p-lead__text {
  color: #000;
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: 1.875rem;
}
@media screen and (max-width: 767px) {
  .p-lead__text {
    font-size: 0.9375rem;
  }
}
.p-lead__text span {
  font-weight: 900;
  color: #0B308D;
}

.p-cta {
  padding-block: 9.1875rem 2.5rem;
  background: #0B308D;
}
@media screen and (max-width: 767px) {
  .p-cta {
    padding-block: 12.1875rem 1.875rem;
  }
}

.p-cta__inner {
  position: relative;
}

.p-cta__text-img {
  position: absolute;
  width: 29.53125rem;
  height: 5.15625rem;
  top: -6.3125rem;
  left: 6.5625rem;
}
@media screen and (max-width: 767px) {
  .p-cta__text-img {
    width: 19.6875rem;
    height: 3.4375rem;
    left: 50%;
    translate: -50%;
    top: -10.625rem;
  }
}

.p-cta__deco {
  position: absolute;
  width: 24.2834375rem;
  height: 5.915rem;
  top: -6.6875rem;
  right: 6.5625rem;
}
@media screen and (max-width: 767px) {
  .p-cta__deco {
    right: unset;
    left: 50%;
    translate: -50%;
    top: -6.65625rem;
  }
}

.p-cta__text {
  text-align: center;
  color: #FFF;
  font-size: 1.575rem;
  font-weight: 500;
  line-height: 3.15rem;
}
@media screen and (max-width: 767px) {
  .p-cta__text {
    font-size: 1.125rem;
    line-height: 2.25rem;
  }
}
.p-cta__text span {
  color: #FFC828;
  font-size: 2.1rem;
  font-weight: 900;
}
@media screen and (max-width: 767px) {
  .p-cta__text span {
    font-size: 1.5rem;
  }
}

.p-reason__cta {
  padding-block: 3.0625rem 2.5rem;
  background: #F2F2F2;
}
@media screen and (max-width: 767px) {
  .p-reason__cta {
    padding-block: 1.5rem 1.625rem;
  }
}

.p-reason__cta-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 1rem;
  margin-bottom: 2.3125rem;
}
@media screen and (max-width: 767px) {
  .p-reason__cta-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1.5625rem;
    text-align: center;
  }
}

.p-reason__cta-main {
  color: #0B308D;
  font-size: 1.5625rem;
  font-weight: 900;
  line-height: 1.875rem;
  letter-spacing: 0.0625rem;
}

.p-reason__cta-sub {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.125rem;
  position: relative;
  color: #000;
  font-size: 1.375rem;
  font-weight: 900;
  line-height: 1.875rem;
}
@media screen and (max-width: 767px) {
  .p-reason__cta-sub {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.p-reason__cta-sub::before {
  content: "";
  position: absolute;
  width: 18.875rem;
  height: 1px;
  background: #000;
  left: 50%;
  translate: -50%;
  top: -0.5625rem;
}
.p-reason__cta-sub::after {
  content: "";
  position: absolute;
  width: 18.875rem;
  height: 1px;
  background: #000;
  left: 50%;
  translate: -50%;
  bottom: -0.5625rem;
}

.p-reason__cta-text {
  text-align: center;
  color: #000;
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 2.25rem;
}
.p-reason__cta-text span {
  color: #0B308D;
  font-weight: 900;
}

.p-reason__inner {
  padding-block: 5rem;
}
@media screen and (max-width: 767px) {
  .p-reason__inner {
    padding-block: 2rem;
  }
}

.p-reason__lead {
  color: #0B308D;
  text-align: center;
  font-size: 2.3125rem;
  font-weight: 700;
  line-height: 2.1875rem;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .p-reason__lead {
    font-size: 1.5625rem;
    margin-bottom: 1rem;
  }
}

.p-reason__img {
  width: 70rem;
  margin-inline: auto;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .p-reason__img {
    margin-inline: calc(50% - 50vw);
    width: 100vw;
    margin-bottom: 1rem;
  }
}

.p-reason__text-wrap {
  margin-bottom: 5rem;
}
@media screen and (max-width: 767px) {
  .p-reason__text-wrap {
    margin-bottom: 1.5rem;
  }
}

.p-reason__text {
  color: #000;
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: 1.875rem;
}
@media screen and (max-width: 767px) {
  .p-reason__text {
    font-size: 0.9375rem;
  }
}
.p-reason__text span {
  display: inline;
  color: #0B308D;
  font-weight: 900;
}

.p-reason__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4.0625rem;
}
@media screen and (max-width: 767px) {
  .p-reason__content {
    gap: 2rem;
  }
}

.p-reason__card {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 2rem;
}
@media screen and (max-width: 767px) {
  .p-reason__card {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0.5rem;
  }
}
.p-reason__card:nth-child(even) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .p-reason__card:nth-child(even) {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.p-reason__card:nth-child(4) {
  margin-bottom: -3.0625rem;
}
@media screen and (max-width: 767px) {
  .p-reason__card:nth-child(4) {
    margin-bottom: -1rem;
  }
}

.p-reason__card-img {
  width: 24.875rem;
  height: auto;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin-inline: auto;
}

.p-reason__card-text {
  color: #000;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.5625rem;
}
.p-reason__card-text span {
  display: inline;
  color: #0B308D;
  font-weight: 900;
}

.p-reason__card--3 {
  margin-bottom: 1.25rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 767px) {
  .p-reason__card--3 {
    margin-bottom: 0;
  }
}
.p-reason__card--3 .img {
  width: 24.875rem;
  height: 21rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .p-reason__card--3 .img {
    margin-inline: auto;
    height: 18.25rem;
    margin-bottom: -1.5rem;
  }
}
.p-reason__card--3 .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem;
}
@media screen and (max-width: 767px) {
  .p-reason__card--3 .wrap {
    gap: 0rem;
  }
}
.p-reason__card--3 .wrap img {
  width: 23.125rem;
  height: auto;
}
@media screen and (max-width: 767px) {
  .p-reason__card--3 .wrap img {
    width: 24.875rem;
    margin-inline: auto;
  }
}
.p-reason__card--3 .text {
  color: #000;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.5625rem;
}
.p-reason__card--3 .text span {
  display: inline;
  color: #0B308D;
  font-weight: 900;
}
.p-reason__card-main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 2rem;
  margin-bottom: 0.75rem;
}
@media screen and (max-width: 767px) {
  .p-reason__card-main {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.p-reason__card-note {
  color: #000;
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1.0625rem;
  margin-bottom: 0.875rem;
}

.p-point {
  width: 68.5rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-point {
    width: 24.875rem;
  }
}

.p-point__text {
  color: #0B308D;
  text-align: center;
  font-family: DIN, sans-serif;
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.875rem;
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 767px) {
  .p-point__text {
    font-size: 1.0625rem;
  }
}

.p-point__cards {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 0.9375rem;
}
@media screen and (max-width: 767px) {
  .p-point__cards {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.p-point__card {
  width: 22.1875rem;
  height: 3.6875rem;
  margin-inline: auto;
  position: relative;
  display: grid;
  place-items: center;
  border: 1px solid #0B308D;
}
@media screen and (max-width: 767px) {
  .p-point__card {
    width: 24.875rem;
    height: 3rem;
  }
}
.p-point__card::before {
  content: "";
  position: absolute;
  background: url(../img/icon3.png) no-repeat center center/cover;
  width: 1.0625rem;
  height: auto;
  aspect-ratio: 1;
  top: 0;
  left: 0;
}
@media screen and (max-width: 767px) {
  .p-point__card::before {
    width: 1.1875rem;
  }
}
.p-point__card::after {
  content: "";
  position: absolute;
  background: url(../img/icon4.png) no-repeat center center/cover;
  width: 1.0625rem;
  height: auto;
  aspect-ratio: 1;
  top: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  .p-point__card::after {
    width: 1.1875rem;
  }
}

.p-point__card-text {
  text-align: center;
  color: #0B308D;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.375rem;
}

.p-advantage {
  padding-block: 5rem;
  background: #0B308D;
}
@media screen and (max-width: 767px) {
  .p-advantage {
    padding-block: 2rem 1.75rem;
  }
}

.p-advantage__title {
  color: #FFF;
  text-align: center;
  font-size: 2.3125rem;
  font-weight: 700;
  line-height: 3rem;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .p-advantage__title {
    font-size: 1.5625rem;
    line-height: 2.1875rem;
    margin-bottom: 1rem;
    white-space: nowrap;
  }
}

.p-advantage__img {
  width: 70rem;
  height: auto;
  margin-inline: auto;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .p-advantage__img {
    width: 100%;
    margin-bottom: 1rem;
  }
}

.p-advantage__lead {
  color: #FFF;
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: 1.875rem;
  text-align: center;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  .p-advantage__lead {
    font-size: 0.9375rem;
    margin-bottom: 1.6875rem;
    text-align: left;
  }
}
.p-advantage__lead span {
  color: #FFC828;
  font-weight: 900;
}

.p-advantage__text-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 4.0625rem;
  margin-bottom: 3.125rem;
}
@media screen and (max-width: 767px) {
  .p-advantage__text-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 2.125rem;
    margin-bottom: 2.6875rem;
  }
}

.p-advantage__text {
  color: #FFF;
  text-align: center;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.625rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-advantage__text {
    text-align: left;
  }
}
.p-advantage__text::after {
  content: "";
  position: absolute;
  width: 22.25rem;
  height: 1px;
  background: #fff;
  left: 50%;
  translate: -50%;
  bottom: -1.125rem;
}
@media screen and (max-width: 767px) {
  .p-advantage__text::after {
    width: 24.875rem;
  }
}

.p-advantage__note {
  color: #FFC828;
  font-size: 1.25rem;
  font-weight: 900;
  line-height: 1.875rem;
  margin-bottom: 1.5rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-advantage__note {
    font-size: 0.9375rem;
    margin-bottom: 2.5rem;
    white-space: nowrap;
  }
}

.p-advantage__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 1.5625rem;
}
@media screen and (max-width: 767px) {
  .p-advantage__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 2.5rem;
  }
}

.p-advantage__card {
  width: 16.375rem;
}
@media screen and (max-width: 767px) {
  .p-advantage__card {
    width: 24.875rem;
    margin-inline: auto;
  }
}
.p-advantage__card .num {
  color: #FFF;
  text-align: center;
  font-family: "DIN 1451", "Oswald", sans-serif;
  font-size: 2.8125rem;
  font-weight: 400;
  line-height: 1.875rem;
  margin-bottom: 1.1875rem;
}
@media screen and (max-width: 767px) {
  .p-advantage__card .num {
    margin-bottom: 1.5625rem;
  }
}
.p-advantage__card .title {
  width: 16.375rem;
  height: 6.125rem;
  display: grid;
  place-items: center;
  color: #0B308D;
  text-align: center;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.625rem;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .p-advantage__card .title {
    width: 24.875rem;
    font-size: 1.25rem;
    line-height: 1.875rem;
    text-align: left;
    letter-spacing: 0;
  }
}
.p-advantage__card .img {
  margin-bottom: 0.625rem;
}
@media screen and (max-width: 767px) {
  .p-advantage__card .img {
    margin-bottom: 0.5rem;
  }
}
.p-advantage__card .text {
  color: #FFF;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.5625rem;
}
.p-advantage__card .text span {
  display: inline;
  font-weight: 900;
  color: #FFC828;
}

.p-salary {
  padding-block: 5rem;
}
@media screen and (max-width: 767px) {
  .p-salary {
    padding-block: 2rem 1.5rem;
  }
}

.p-salary__title {
  color: #0B308D;
  text-align: center;
  font-size: 2.3125rem;
  font-weight: 700;
  line-height: 3rem;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .p-salary__title {
    font-size: 1.5625rem;
    line-height: 2.1875rem;
    margin-bottom: 1rem;
  }
}

.p-salary__img {
  width: 70rem;
  height: auto;
  margin-inline: auto;
  margin-bottom: 1.6875rem;
}
@media screen and (max-width: 767px) {
  .p-salary__img {
    margin-inline: calc(50% - 50vw);
    width: 100vw;
    margin-bottom: 1.5rem;
  }
}

.p-salary__lead {
  color: #000;
  font-size: 1.375rem;
  font-weight: 500;
  line-height: 1.875rem;
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 767px) {
  .p-salary__lead {
    font-size: 0.9375rem;
    margin-bottom: 0.75rem;
  }
}

.p-salary__note {
  color: #000;
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1.1875rem;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 767px) {
  .p-salary__note {
    margin-bottom: 1rem;
  }
}

.p-salary__text {
  color: #000;
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: 1.875rem;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .p-salary__text {
    font-size: 0.9375rem;
    margin-bottom: 1.5rem;
  }
}
.p-salary__text span {
  color: #0B308D;
  font-weight: 900;
}

.p-salary__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 1.375rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 767px) {
  .p-salary__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1.5rem;
  }
}

.p-salary__card {
  width: 22.4183125rem;
  height: 24.7916875rem;
}
@media screen and (max-width: 767px) {
  .p-salary__card {
    width: 24.5rem;
    height: 27.125rem;
    margin-inline: auto;
  }
}

.p-caution {
  padding-block: 2.5rem 1rem;
  background: #FFC828;
}
@media screen and (max-width: 767px) {
  .p-caution {
    padding-block: 2rem 0.8125rem;
  }
}

.p-caution__title {
  color: #000;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.8125rem;
  text-align: center;
}
.p-caution__title span {
  color: #0B308D;
  font-size: 2.1875rem;
}

.p-caution__text {
  width: 40.625rem;
  margin-inline: auto;
  color: #000;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.875rem;
  margin-block: 1.5rem;
}
@media screen and (max-width: 767px) {
  .p-caution__text {
    margin-block: 1rem;
    width: 24.875rem;
  }
}

.p-caution__list {
  background: #fff;
  padding-block: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 5.375rem;
}
@media screen and (max-width: 767px) {
  .p-caution__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0.625rem;
    padding-left: 3.3125rem;
  }
}
.p-caution__list li {
  color: #000;
  font-size: 1.0625rem;
  font-weight: 900;
  line-height: 1.5rem;
  position: relative;
}
.p-caution__list li::before {
  content: "";
  position: absolute;
  background: url(../img/icon5.png) no-repeat center center/cover;
  width: 1.9375rem;
  height: auto;
  aspect-ratio: 1;
  top: 50%;
  translate: 0 -50%;
  left: -2.375rem;
}

.p-flow {
  padding-block: 1.5rem 5rem;
}
@media screen and (max-width: 767px) {
  .p-flow {
    padding-block: 1rem 1.5rem;
  }
}

.p-flow__inner {
  width: 58.25rem;
  margin-inline: auto;
  padding-inline: 2.5rem;
}
@media screen and (max-width: 767px) {
  .p-flow__inner {
    width: 26.875rem;
    padding-inline: 1rem;
  }
}

.p-flow__title {
  color: #0B308D;
  text-align: center;
  font-size: 2.3125rem;
  font-weight: 700;
  line-height: 3rem;
  margin-bottom: 6.0625rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-flow__title {
    font-size: 1.5625rem;
    line-height: 2.1875rem;
    margin-bottom: 2.9375rem;
  }
}
.p-flow__title::after {
  content: "";
  position: absolute;
  background: url(../img/icon6.png) no-repeat center center/cover;
  width: 2.375rem;
  height: 4.3125rem;
  left: 50%;
  translate: -50%;
  bottom: -5.0625rem;
}
@media screen and (max-width: 767px) {
  .p-flow__title::after {
    width: 1.19525rem;
    height: 2.167875rem;
    bottom: -2.382875rem;
  }
}

.p-flow__lead {
  margin-bottom: 2.5rem;
  color: #000;
  text-align: center;
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: 1.5625rem;
}
@media screen and (max-width: 767px) {
  .p-flow__lead {
    font-size: 0.9375rem;
    margin-bottom: 1.4375rem;
  }
}

.p-flow__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2.0625rem;
  margin-bottom: 1.4625rem;
}
@media screen and (max-width: 767px) {
  .p-flow__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1.5rem;
    margin-bottom: 1rem;
  }
}

.p-flow__img {
  width: 100%;
}

.p-flow__text {
  color: #000;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.875rem;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 767px) {
  .p-flow__text {
    margin-bottom: 1.1875rem;
  }
}
.p-flow__text span {
  color: #0B308D;
  font-weight: 900;
}

.p-flow__note {
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.875rem;
}

.p-step {
  padding-bottom: 5rem;
}
@media screen and (max-width: 767px) {
  .p-step {
    padding-block: 1rem 2rem;
  }
}

.p-step__inner {
  width: 58.625rem;
  padding-inline: 2.5rem;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-step__inner {
    width: 26.875rem;
    padding-inline: 1rem 0.1875rem;
  }
}

.p-step__title {
  color: #0B308D;
  text-align: center;
  font-size: 2.3125rem;
  font-weight: 700;
  line-height: 3rem;
  margin-bottom: 6.5625rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-step__title {
    font-size: 1.5625rem;
    line-height: 2.1875rem;
    margin-bottom: 3.125rem;
  }
}
.p-step__title::after {
  content: "";
  position: absolute;
  background: url(../img/icon6.png) no-repeat center center/cover;
  width: 2.375rem;
  height: 4.3125rem;
  left: 50%;
  translate: -50%;
  bottom: -5.0625rem;
}
@media screen and (max-width: 767px) {
  .p-step__title::after {
    width: 1.19525rem;
    height: 2.167875rem;
    bottom: -2.382875rem;
  }
}

.p-step__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1.2325rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-step__content {
    gap: 1rem;
  }
}
.p-step__content::before {
  content: "";
  position: absolute;
  width: 0.231125rem;
  height: 41.4515rem;
  background: #0B308D;
  top: 50%;
  translate: 0 -50%;
  left: 3.8525rem;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-step__content::before {
    width: 0.1875rem;
    height: 37.4375rem;
    left: 3rem;
  }
}

.p-step__step {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.001875rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767px) {
  .p-step__step {
    gap: 0.8125rem;
  }
}
.p-step__step:nth-child(4) {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.p-step__step:nth-child(4) .p-step__text {
  margin-top: 1.695rem;
}
@media screen and (max-width: 767px) {
  .p-step__step:nth-child(4) .p-step__text {
    margin-top: 0.625rem;
  }
}

.p-step__num {
  width: 7.3965625rem;
  height: auto;
  aspect-ratio: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .p-step__num {
    width: 6rem;
  }
}

.p-step__text {
  color: #000;
  font-size: 1.23275rem;
  font-weight: 400;
  line-height: 1.9261875rem;
}
@media screen and (max-width: 767px) {
  .p-step__text {
    font-size: 1rem;
    line-height: 1.5625rem;
  }
}
.p-step__text span {
  font-size: 0.9245625rem;
}
@media screen and (max-width: 767px) {
  .p-step__text span {
    font-size: 0.75rem;
  }
}

.p-step__text--blue {
  color: #0B308D;
  font-size: 1.23275rem;
  font-weight: 400;
  line-height: 1.9261875rem;
  margin-top: 1.849375rem;
}
@media screen and (max-width: 767px) {
  .p-step__text--blue {
    font-size: 1rem;
    line-height: 1.5625rem;
    margin-top: 0.75rem;
    margin-bottom: 0.5rem;
  }
}

.p-step__note {
  margin-top: 0.61625rem;
  color: #0B308D;
  font-size: 0.9245625rem;
  font-weight: 400;
  line-height: 1.9261875rem;
}
@media screen and (max-width: 767px) {
  .p-step__note {
    font-size: 0.75rem;
    line-height: 1.5625rem;
    margin-top: 0.3125rem;
    white-space: nowrap;
  }
}

.p-about {
  padding-bottom: 5rem;
}
@media screen and (max-width: 767px) {
  .p-about {
    padding-block: 1rem 3.01875rem;
  }
}

.p-about__title {
  color: #0B308D;
  text-align: center;
  font-size: 2.3125rem;
  font-weight: 700;
  line-height: 3rem;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 767px) {
  .p-about__title {
    font-size: 2.5rem;
    line-height: 2.1875rem;
  }
}

.p-about__logo {
  width: 36.75rem;
  height: 8.8125rem;
  margin-inline: auto;
  margin-bottom: 1.5rem;
}
@media screen and (max-width: 767px) {
  .p-about__logo {
    width: 22.8539375rem;
    height: 5.48125rem;
  }
}

.p-about__content {
  width: 23.125rem;
  margin-inline: auto;
}

.p-about__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1.1875rem;
  text-align: center;
}

.p-about__list-title {
  color: #0B308D;
  text-align: center;
  font-size: 1rem;
  font-weight: 700;
  line-height: 2.1875rem;
  margin-bottom: -0.375rem;
}

.p-about__item {
  color: #000;
  text-align: center;
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 2.1875rem;
}

.p-info {
  padding-bottom: 5rem;
}
@media screen and (max-width: 767px) {
  .p-info {
    padding-bottom: 1.4375rem;
  }
}

.p-info__title {
  color: #0B308D;
  text-align: center;
  font-size: 2.3125rem;
  font-weight: 700;
  line-height: 3rem;
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .p-info__title {
    font-size: 2.5rem;
    line-height: 2.1875rem;
    margin-bottom: 1.3125rem;
  }
}

.p-info__table {
  border: 1px solid #0B308D;
  border-collapse: collapse;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .p-info__row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.p-info__table-title {
  background: #E8EEFF;
  padding-block: 0.6875rem 1rem;
  width: 21.0625rem;
  height: 3.0625rem;
  border-bottom: 1px solid #0B308D;
  vertical-align: middle;
  color: #000;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 1.375rem;
}
@media screen and (max-width: 767px) {
  .p-info__table-title {
    width: 118px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    height: auto;
  }
}

.p-info__item {
  padding-block: 0.6875rem 1rem;
  border-bottom: 1px solid #0B308D;
  padding-left: 3.75rem;
}
@media screen and (max-width: 767px) {
  .p-info__item {
    width: auto;
    padding-inline: 1.3125rem;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
  }
}

.p-info__text {
  color: #0B308D;
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1.375rem;
}
.p-info__text span {
  font-size: 0.75rem;
}

.p-info__note {
  color: #000;
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1.125rem;
}

.p-contact {
  background: #E8E8E8;
  padding-block: 75.69px 73.88px;
}
@media screen and (max-width: 767px) {
  .p-contact {
    padding-block: 2.168125rem 1.665rem;
  }
}

.p-contact__inner {
  width: 430px;
  padding-inline: 16px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-contact__inner {
    width: 26.875rem;
    padding-inline: 1rem;
  }
}

.p-contact__title {
  color: #000;
  text-align: center;
  font-size: 16px;
  font-weight: 350;
  line-height: 25px;
  letter-spacing: 0.16px;
  margin-bottom: 31.82px;
}

.p-contact__form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 23.4px;
}

.p-contact__row {
  color: #000;
  text-align: center;
  font-size: 16px;
  font-weight: 350;
  line-height: 25px;
  letter-spacing: 0.16px;
  margin-bottom: 8px;
}
.p-contact__row span {
  color: #CD0C0A;
}

.p-contact__note {
  font-size: 12px;
  font-weight: 350;
  line-height: 18px;
  letter-spacing: 0.12px;
}

input[type=text],
input[type=email],
input[type=tel],
select,
textarea {
  border-radius: 5px;
  border: 0.5px solid #000;
  background: #FFF;
  width: 100%;
  padding: 10.11px 13px 11.88px 13px;
}
input[type=text]::-webkit-input-placeholder, input[type=email]::-webkit-input-placeholder, input[type=tel]::-webkit-input-placeholder, select::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #767676;
  font-size: 16px;
  font-weight: 350;
  line-height: 25px;
  letter-spacing: 0.16px;
}
input[type=text]::-moz-placeholder, input[type=email]::-moz-placeholder, input[type=tel]::-moz-placeholder, select::-moz-placeholder, textarea::-moz-placeholder {
  color: #767676;
  font-size: 16px;
  font-weight: 350;
  line-height: 25px;
  letter-spacing: 0.16px;
}
input[type=text]:-ms-input-placeholder, input[type=email]:-ms-input-placeholder, input[type=tel]:-ms-input-placeholder, select:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #767676;
  font-size: 16px;
  font-weight: 350;
  line-height: 25px;
  letter-spacing: 0.16px;
}
input[type=text]::-ms-input-placeholder, input[type=email]::-ms-input-placeholder, input[type=tel]::-ms-input-placeholder, select::-ms-input-placeholder, textarea::-ms-input-placeholder {
  color: #767676;
  font-size: 16px;
  font-weight: 350;
  line-height: 25px;
  letter-spacing: 0.16px;
}
input[type=text]::placeholder,
input[type=email]::placeholder,
input[type=tel]::placeholder,
select::placeholder,
textarea::placeholder {
  color: #767676;
  font-size: 16px;
  font-weight: 350;
  line-height: 25px;
  letter-spacing: 0.16px;
}

textarea {
  resize: vertical;
}

.address {
  height: 96px;
}

.message {
  height: 206px;
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

.p-contact__select-wrap {
  position: relative;
}
.p-contact__select-wrap::after {
  content: "";
  position: absolute;
  background: url(../img/icon7.png) no-repeat center center/cover;
  width: 24px;
  height: auto;
  aspect-ratio: 1;
  top: 50%;
  translate: 0 -50%;
  right: 12.11px;
}

input[type=submit],
input[type=button] {
  border-radius: 0px;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  -moz-appearance: button;
       appearance: button;
  border: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  cursor: pointer;
  background: transparent;
}

input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}

.row.jc-center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.p-contact__submit {
  text-align: center;
  width: 110.171px;
  height: 39.77px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  background: #000;
  display: grid;
  place-items: center;
  margin-inline: auto;
}
.p-contact__submit input[type=submit] {
  color: #FFF;
  font-size: 16px;
  font-weight: 350;
  line-height: 25px;
  letter-spacing: 0.16px;
}

.wpcf7-spinner {
  height: 0 !important;
  width: 0 !important;
}

/* Contact Form 7 送信完了メッセージ（div版）のスタイル */
.wpcf7-response-output {
  margin-top: 24px !important;
  padding: 1.5em 1em !important;
  background-color: #0B308D !important;
  color: #FFF !important;
  border-radius: 8px !important;
  text-align: center !important;
  font-weight: bold !important;
}

/* 不要なpタグのメッセージを非表示にする */
.p-contact p[role=status] {
  display: none !important;
}

@media (min-width: 768px) {
  .u-sp {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .u-pc {
    display: none !important;
  }
}
.u-font {
  font-family: "Noto Sans JP", sans-serif;
}
.u-font__jp {
  font-family: "Noto Sans JP", sans-serif;
}
.u-font__en {
  font-family: "Inria Sans", sans-serif;
}

.u-text__center {
  text-align: center !important;
}
@media screen and (max-width: 767px) {
  .u-text__center--sp {
    text-align: center !important;
  }
}
@media (min-width: 768px) {
  .u-text__center--pc {
    text-align: center !important;
  }
}

.u-text__left {
  text-align: left !important;
}
@media screen and (max-width: 767px) {
  .u-text__left--sp {
    text-align: left !important;
  }
}
@media (min-width: 768px) {
  .u-text__left--pc {
    text-align: left !important;
  }
}

.u-text__right {
  text-align: right !important;
}
@media screen and (max-width: 767px) {
  .u-text__right--sp {
    text-align: right !important;
  }
}
@media (min-width: 768px) {
  .u-text__right--pc {
    text-align: right !important;
  }
}

.u-text__nowrap {
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .u-text__nowrap--sp {
    white-space: nowrap;
  }
}
@media (min-width: 768px) {
  .u-text__nowrap--pc {
    white-space: nowrap;
  }
}

.u-pointer__none {
  pointer-events: none !important;
}
@media screen and (max-width: 767px) {
  .u-pointer__none--sp {
    pointer-events: none !important;
  }
}
@media (min-width: 768px) {
  .u-pointer__none--pc {
    pointer-events: none !important;
  }
}