img {
  height: auto;
  max-width: 100%;
  vertical-align: bottom;
}

@media (any-hover: hover) {
  a:hover {
    opacity: 0.8;
  }
}

:root {
  --color-font: #333;
  --color-sub: #666;
  --color-primary: #577de8;
  --color-secondary: #f7931e;
  --color-tertiary: #fff880;
  --font-NotoSansJP: "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", YuGothic, sans-serif;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  background: #fff;
  color: var(--color-font);
  font-family: var(--font-NotoSansJP);
  font-weight: 400;
  letter-spacing: 0;
  margin-inline: auto;
  overflow-wrap: break-word;
  width: 100%;
}
@media screen and (min-width: 1240px) {
  body {
    min-width: 1240px;
  }
}

.l-wrapper {
  overflow: hidden;
  position: relative;
  width: 100%;
}

@media screen and (min-width: 769px) {
  .l-inner {
    margin-inline: auto;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-inner {
    width: 96.774%;
  }
}
@media screen and (min-width: 1240px) {
  .l-inner {
    width: 1200px;
  }
}

@media screen and (min-width: 769px) {
  .l-inner-m {
    margin-inline: auto;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-inner-m {
    width: 80.645%;
  }
}
@media screen and (min-width: 1240px) {
  .l-inner-m {
    width: 1000px;
  }
}

.l-header {
  background: #fff;
  left: 0;
  line-height: 1;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 100;
}

.l-header__inner {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .l-header__inner {
    -webkit-padding-start: 3.067vw;
            padding-inline-start: 3.067vw;
  }
}

@media screen and (max-width: 768px) {
  .l-header__logo {
    width: 33.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-header__logo {
    width: 16.129vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-header__logo {
    width: 200px;
  }
}

@media screen and (max-width: 768px) {
  .l-header__button {
    width: 32vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-header__button {
    width: 13.71vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-header__button {
    width: 170px;
  }
}

.l-header__button-link {
  align-items: center;
  background: var(--color-primary);
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-decoration: none;
}
@media screen and (max-width: 768px) {
  .l-header__button-link {
    gap: 1.6vw;
    height: 13.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-header__button-link {
    gap: 0.645vw;
    height: 5.645vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-header__button-link {
    gap: 8px;
    height: 70px;
  }
}

.l-header__button-lead {
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  .l-header__button-lead {
    font-size: 2.533vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-header__button-lead {
    font-size: 1.048vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-header__button-lead {
    font-size: 13px;
  }
}

.l-header__button-bottom {
  align-items: center;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .l-header__button-bottom {
    gap: 1.6vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-header__button-bottom {
    gap: 0.645vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-header__button-bottom {
    gap: 8px;
  }
}

@media screen and (max-width: 768px) {
  .l-header__button-icon {
    width: 4.133vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-header__button-icon {
    width: 1.855vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-header__button-icon {
    width: 23px;
  }
}

.l-header__button-label {
  font-weight: 700;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 768px) {
  .l-header__button-label {
    font-size: 3.467vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-header__button-label {
    font-size: 1.452vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-header__button-label {
    font-size: 18px;
  }
}

.l-footer {
  background: var(--color-font);
  color: #fff;
}

.l-pagetop {
  position: fixed;
  z-index: 100;
}
@media screen and (max-width: 768px) {
  .l-pagetop {
    bottom: 3.333vw;
    right: 3.333vw;
    width: 24vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-pagetop {
    bottom: 2.016vw;
    right: 2.016vw;
    width: 9.677vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-pagetop {
    bottom: 25px;
    right: 25px;
    width: 120px;
  }
}
@media screen and (max-width: 768px) {
  .l-pagetop.is-scrolled {
    bottom: 18.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-pagetop.is-scrolled {
    bottom: 16.935vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-pagetop.is-scrolled {
    bottom: 210px;
  }
}

@media screen and (max-width: 768px) {
  .l-footer__inner {
    padding-block: 4.667vw 5.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-footer__inner {
    padding-block: 2.419vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-footer__inner {
    padding-block: 30px;
  }
}

.l-nav__list {
  display: flex;
  justify-content: center;
  margin-block: 0;
  padding-inline: 0;
}
@media screen and (max-width: 768px) {
  .l-nav__list {
    gap: 8.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-nav__list {
    gap: 1.21vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-nav__list {
    gap: 40px;
  }
}

.l-nav__item {
  align-items: center;
  display: flex;
  gap: 1em;
  letter-spacing: 0.02em;
  line-height: 1;
  margin-block: 0;
  padding-inline: 0;
}
@media screen and (max-width: 768px) {
  .l-nav__item {
    font-size: 2.933vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-nav__item {
    font-size: 1.21vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-nav__item {
    font-size: 15px;
  }
}

.l-nav__arrow {
  fill: none;
  stroke: #fff;
  stroke-miterlimit: 10;
  stroke-width: 2;
}
@media screen and (max-width: 768px) {
  .l-nav__arrow {
    width: 1.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-nav__arrow {
    width: 0.645vw;
  }
}
@media screen and (min-width: 1240px) {
  .l-nav__arrow {
    width: 8px;
  }
}

.l-nav__link {
  color: #fff;
  text-decoration: underline;
}
@media (any-hover: hover) {
  .l-nav__link:hover {
    opacity: 0.8;
    text-decoration: none;
  }
}

.l-copyright {
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  .l-copyright {
    font-size: 2.667vw;
    margin-block: 5.333vw 0;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .l-copyright {
    font-size: 1.048vw;
    margin-block: 1.935vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .l-copyright {
    font-size: 13px;
    margin-block: 24px 0;
  }
}

.c-cta {
  line-height: 1;
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
@media screen and (max-width: 768px) {
  .c-cta {
    margin-inline: auto;
    width: 80vw;
  }
}

.c-cta__lead {
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .c-cta__lead {
    width: 61.867vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .c-cta__lead {
    width: 28.629vw;
  }
}
@media screen and (min-width: 1240px) {
  .c-cta__lead {
    width: 355px;
  }
}

.c-cta__button {
  letter-spacing: 0.12em;
  margin-inline: 0;
}
@media screen and (max-width: 768px) {
  .c-cta__button {
    font-size: 5.333vw;
    line-height: 3.5;
    -webkit-margin-before: 2.4vw;
            margin-block-start: 2.4vw;
  }
}
@media screen and (min-width: 769px) {
  .c-cta__button {
    line-height: 2.813;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .c-cta__button {
    font-size: 2.581vw;
    -webkit-margin-before: 0.968vw;
            margin-block-start: 0.968vw;
  }
}
@media screen and (min-width: 1240px) {
  .c-cta__button {
    font-size: 32px;
    -webkit-margin-before: 12px;
            margin-block-start: 12px;
  }
}

.c-cta__button-link {
  background: var(--color-secondary);
  border-radius: 100vw;
  color: #fff;
  display: block;
  text-decoration: none;
}

.c-cta-area {
  background: #2a5ae2;
}

@media screen and (max-width: 768px) {
  .c-cta-area__inner {
    padding-block: 12vw 10.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .c-cta-area__inner {
    padding-block: 4.032vw 5.645vw;
  }
}
@media screen and (min-width: 1240px) {
  .c-cta-area__inner {
    padding-block: 50px 70px;
  }
}

.c-cta-area__title {
  color: #fff;
  margin-block: 0;
}

.c-cta-area__title-lead {
  align-items: center;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .c-cta-area__title-lead {
    font-size: 5.067vw;
    gap: 1.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .c-cta-area__title-lead {
    font-size: 2.903vw;
    gap: 0.806vw;
  }
}
@media screen and (min-width: 1240px) {
  .c-cta-area__title-lead {
    font-size: 36px;
    gap: 10px;
  }
}

.c-cta-area__title-logo {
  display: block;
  fill: #fff;
}
@media screen and (max-width: 768px) {
  .c-cta-area__title-logo {
    width: 48vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .c-cta-area__title-logo {
    width: 27.016vw;
  }
}
@media screen and (min-width: 1240px) {
  .c-cta-area__title-logo {
    width: 335px;
  }
}

.c-cta-area__title-main {
  display: block;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  .c-cta-area__title-main {
    font-size: 5.067vw;
    line-height: 1.579;
    -webkit-margin-before: 2vw;
            margin-block-start: 2vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .c-cta-area__title-main {
    font-size: 2.823vw;
    -webkit-margin-before: 1.613vw;
            margin-block-start: 1.613vw;
  }
}
@media screen and (min-width: 1240px) {
  .c-cta-area__title-main {
    font-size: 35px;
    -webkit-margin-before: 20px;
            margin-block-start: 20px;
  }
}

@media screen and (max-width: 768px) {
  .c-cta-area .c-cta {
    -webkit-margin-before: 6vw;
            margin-block-start: 6vw;
  }
}
@media screen and (min-width: 769px) {
  .c-cta-area .c-cta {
    margin-inline: auto;
    width: 60%;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .c-cta-area .c-cta {
    -webkit-margin-before: 3.629vw;
            margin-block-start: 3.629vw;
  }
}
@media screen and (min-width: 1240px) {
  .c-cta-area .c-cta {
    -webkit-margin-before: 45px;
            margin-block-start: 45px;
  }
}

.c-en-title {
  line-height: 1;
  margin-block: 0;
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .c-en-title {
    width: 19.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .c-en-title {
    width: 9.597vw;
  }
}
@media screen and (min-width: 1240px) {
  .c-en-title {
    width: 119px;
  }
}

.p-home {
  line-height: 1;
}

.p-kv {
  background: #eef4ff;
}

@media screen and (max-width: 768px) {
  .p-kv__inner {
    padding-block: 26vw 10vw;
  }
}
@media screen and (min-width: 769px) {
  .p-kv__inner {
    display: grid;
    gap: 0;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-kv__inner {
    grid-template-columns: 50vw 37.097vw;
    grid-template-rows: 15.323vw 8.871vw 1fr;
    padding-block: 8.065vw 3.226vw;
    padding-inline: 4.032vw 5.645vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-kv__inner {
    grid-template-columns: 620px 460px;
    grid-template-rows: 190px 110px 1fr;
    padding-block: 100px 40px;
    padding-inline: 50px 70px;
  }
}

.p-kv__title {
  display: grid;
  align-items: center;
  margin-block: 0;
}
@media screen and (max-width: 768px) {
  .p-kv__title {
    gap: 1.333vw 1.067vw;
    grid-template-columns: 18.667vw 1fr;
    -webkit-margin-start: 6vw;
            margin-inline-start: 6vw;
  }
}
@media screen and (min-width: 769px) {
  .p-kv__title {
    grid-area: 1/1/2/2;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-kv__title {
    gap: 1.21vw 0.806vw;
    grid-template-columns: 9.677vw 1fr;
    -webkit-padding-before: 4.839vw;
            padding-block-start: 4.839vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-kv__title {
    gap: 15px 10px;
    grid-template-columns: 120px 1fr;
    -webkit-padding-before: 60px;
            padding-block-start: 60px;
  }
}

.p-kv__title-target {
  background: var(--color-primary);
  border-radius: 50%;
  color: #fff;
  display: grid;
  grid-area: 1/1/3/2;
  letter-spacing: 0.1em;
  place-items: center;
}
@media screen and (max-width: 768px) {
  .p-kv__title-target {
    font-size: 4.667vw;
    line-height: 1.143;
    height: 18.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-kv__title-target {
    line-height: 1.067;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-kv__title-target {
    font-size: 2.419vw;
    height: 9.677vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-kv__title-target {
    font-size: 30px;
    height: 120px;
  }
}

.p-kv__title-action {
  display: block;
  grid-area: 1/2/2/3;
  letter-spacing: 0.1em;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .p-kv__title-action {
    font-size: 7.2vw;
    -webkit-padding-before: 0.8vw;
            padding-block-start: 0.8vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-kv__title-action {
    font-size: 3.952vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-kv__title-action {
    font-size: 49px;
  }
}

.p-kv__title-partner {
  display: block;
  grid-area: 2/2/3/3;
  letter-spacing: 0.06em;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .p-kv__title-partner {
    font-size: 9.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-kv__title-partner {
    font-size: 4.839vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-kv__title-partner {
    font-size: 60px;
  }
}

.p-kv__text {
  letter-spacing: 0.12em;
}
@media screen and (max-width: 768px) {
  .p-kv__text {
    font-size: 4.267vw;
    line-height: 1.563;
    -webkit-margin-before: 5.333vw;
            margin-block-start: 5.333vw;
  }
}
@media screen and (min-width: 769px) {
  .p-kv__text {
    grid-area: 2/1/3/2;
    line-height: 1.652;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-kv__text {
    font-size: 1.855vw;
    margin-block: 2.419vw 0;
    -webkit-padding-end: 1.21vw;
            padding-inline-end: 1.21vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-kv__text {
    font-size: 23px;
    margin-block: 30px 0;
    -webkit-padding-end: 15px;
            padding-inline-end: 15px;
  }
}

.p-kv__image {
  margin-block: 0;
  margin-inline: 0;
}
@media screen and (max-width: 768px) {
  .p-kv__image {
    margin-inline: auto;
    width: 58.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-kv__image {
    grid-area: 1/2/4/3;
  }
}

@media screen and (max-width: 768px) {
  .p-kv .c-cta {
    -webkit-margin-before: 3.333vw;
            margin-block-start: 3.333vw;
  }
}
@media screen and (min-width: 769px) {
  .p-kv .c-cta {
    grid-area: 3/1/4/2;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-kv .c-cta {
    -webkit-margin-start: 2.823vw;
            margin-inline-start: 2.823vw;
    width: 44.355vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-kv .c-cta {
    -webkit-margin-start: 35px;
            margin-inline-start: 35px;
    width: 550px;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-kv .c-cta__lead {
    text-indent: -0.806vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-kv .c-cta__lead {
    text-indent: -10px;
  }
}

@media screen and (max-width: 768px) {
  .p-intro__inner {
    padding-block: 12.267vw 8.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-intro__inner {
    padding-block: 3.871vw 17.742vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-intro__inner {
    padding-block: 48px 220px;
  }
}

.p-intro__title {
  align-items: center;
  display: flex;
  justify-content: center;
  margin-block: 0;
  margin-inline: auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  .p-intro__title {
    height: 30.667vw;
    width: 88vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-intro__title {
    height: 4.839vw;
    width: 79.032vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-intro__title {
    height: 60px;
    width: 980px;
  }
}
.p-intro__title::before, .p-intro__title::after {
  border: 1px solid var(--color-font);
  content: "";
  display: block;
  height: 100%;
  position: absolute;
}
@media screen and (max-width: 768px) {
  .p-intro__title::before, .p-intro__title::after {
    width: 1.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-intro__title::before, .p-intro__title::after {
    width: 0.806vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-intro__title::before, .p-intro__title::after {
    width: 10px;
  }
}
.p-intro__title::before {
  border-right: 0;
  left: 0;
}
.p-intro__title::after {
  border-left: 0;
  right: 0;
}

.p-intro__title-label {
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  .p-intro__title-label {
    font-size: 6vw;
    line-height: 1.333;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-intro__title-label {
    font-size: 2.903vw;
    line-height: 1;
  }
}
@media screen and (min-width: 1240px) {
  .p-intro__title-label {
    font-size: 36px;
    line-height: 1;
  }
}

.p-intro__content {
  position: relative;
  z-index: 5;
}
@media screen and (min-width: 769px) {
  .p-intro__content {
    display: grid;
    gap: 0 7%;
    grid-template-columns: 28% 65%;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-intro__content {
    -webkit-margin-before: 3.629vw;
            margin-block-start: 3.629vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-intro__content {
    -webkit-margin-before: 45px;
            margin-block-start: 45px;
  }
}

@media screen and (max-width: 768px) {
  .p-intro__image {
    margin-block: 2.933vw 0;
    margin-inline: auto;
    width: 45.333vw;
  }
}
@media screen and (min-width: 769px) {
  .p-intro__image {
    margin-inline: 0;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-intro__image {
    margin-block: 0.806vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-intro__image {
    margin-block: 10px 0;
  }
}

.p-intro__text {
  letter-spacing: 0.08em;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .p-intro__text {
    font-size: 3.6vw;
    line-height: 2;
    margin-block: 6.667vw 0;
    margin-inline: auto;
    text-align: justify;
    width: 88vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-intro__text {
    font-size: 1.774vw;
    margin-block: 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-intro__text {
    font-size: 22px;
    margin-block: 0;
  }
}

.p-features {
  background: #eef4ff;
  position: relative;
}
@media screen and (max-width: 768px) {
  .p-features {
    background: url(../images/home/features_bg_sp.png) 0 0/100% auto no-repeat #eef4ff;
  }
}
@media screen and (min-width: 769px) {
  .p-features::before {
    background: url(../images/home/features_bg_pc.png) 50% 100%/auto 100% no-repeat;
    content: "";
    display: block;
    left: 0;
    position: absolute;
    width: 100%;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-features::before {
    height: 12.903vw;
    top: -12.742vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-features::before {
    height: 160px;
    top: -158px;
  }
}

.p-features__inner {
  position: relative;
}
@media screen and (max-width: 768px) {
  .p-features__inner {
    padding-block: 16vw 10.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-features__inner {
    padding-block: 2.016vw 5.645vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-features__inner {
    padding-block: 25px 70px;
  }
}

@media screen and (min-width: 769px) {
  .p-features__en-title {
    left: 50%;
    position: absolute;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    z-index: 5;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-features__en-title {
    top: -5.645vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-features__en-title {
    top: -70px;
  }
}

.p-features__lead {
  letter-spacing: 0.1em;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .p-features__lead {
    font-size: 6.133vw;
    margin-block: 8.667vw 0;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-features__lead {
    font-size: 2.742vw;
    margin-block: 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-features__lead {
    font-size: 34px;
    margin-block: 0;
  }
}

@media screen and (max-width: 768px) {
  .p-features__title {
    font-size: 8vw;
    letter-spacing: 0.04em;
    line-height: 1.333;
    margin-block: 2.667vw 0;
  }
}
@media screen and (min-width: 769px) {
  .p-features__title {
    letter-spacing: 0.08em;
    line-height: 1;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-features__title {
    font-size: 3.871vw;
    margin-block: 1.613vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-features__title {
    font-size: 48px;
    margin-block: 20px 0;
  }
}

@media screen and (max-width: 768px) {
  .p-features__list {
    margin-inline: auto;
    width: 90.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-features__list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-features__list {
    gap: 0 1.613vw;
    -webkit-margin-before: 11.29vw;
            margin-block-start: 11.29vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-features__list {
    gap: 0 20px;
    -webkit-margin-before: 140px;
            margin-block-start: 140px;
  }
}

.p-features__item {
  background: #fff;
  position: relative;
}
@media screen and (max-width: 768px) {
  .p-features__item {
    -webkit-margin-before: 20vw;
            margin-block-start: 20vw;
    padding-block: 17.333vw 7.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-features__item {
    padding-block: 8.871vw 2.419vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-features__item {
    padding-block: 110px 30px;
  }
}

.p-features__icon {
  background: linear-gradient(135deg, rgb(87, 125, 232) 0%, rgb(188, 203, 246) 100%);
  border-radius: 50%;
  left: 50%;
  margin-block: 0;
  margin-inline: 0;
  position: absolute;
  top: 0;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (max-width: 768px) {
  .p-features__icon {
    width: 26.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-features__icon {
    width: 12.903vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-features__icon {
    width: 160px;
  }
}

.p-features__sub-title {
  letter-spacing: 0.06em;
  margin-block: 0;
}
@media screen and (max-width: 768px) {
  .p-features__sub-title {
    font-size: 5.333vw;
    line-height: 1.5;
  }
}
@media screen and (min-width: 769px) {
  .p-features__sub-title {
    line-height: 1.538;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-features__sub-title {
    font-size: 2.097vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-features__sub-title {
    font-size: 26px;
  }
}

.p-features__text {
  margin-inline: auto;
  text-align: justify;
}
@media screen and (max-width: 768px) {
  .p-features__text {
    font-size: 3.6vw;
    letter-spacing: 0.02em;
    line-height: 2;
    margin-block: 4vw 0;
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .p-features__text {
    letter-spacing: 0.04em;
    line-height: 1.778;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-features__text {
    font-size: 1.452vw;
    margin-block: 1.613vw 0;
    width: 20.968vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-features__text {
    font-size: 18px;
    margin-block: 20px 0;
    width: 260px;
  }
}

.p-toss-up {
  background: #fff;
  border: 1px solid var(--color-primary);
  position: relative;
}
@media screen and (max-width: 768px) {
  .p-toss-up {
    -webkit-margin-before: 8vw;
            margin-block-start: 8vw;
    margin-inline: auto;
    padding-block: 1.333vw 6.667vw;
    width: 90.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-toss-up {
    align-items: center;
    display: grid;
    gap: 0;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-toss-up {
    grid-template-columns: 26.613vw 50vw;
    -webkit-margin-before: 4.032vw;
            margin-block-start: 4.032vw;
    padding-block: 3.226vw;
    padding-inline: 0.403vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-toss-up {
    grid-template-columns: 330px 620px;
    -webkit-margin-before: 50px;
            margin-block-start: 50px;
    padding-block: 40px;
    padding-inline: 5px;
  }
}
.p-toss-up::before {
  background: linear-gradient(90deg, rgb(87, 125, 232) 0%, rgb(188, 203, 246) 100%);
  clip-path: polygon(0 0, 0% 100%, 100% 0);
  content: "";
  display: block;
  left: -1px;
  position: absolute;
  top: -1px;
}
@media screen and (max-width: 768px) {
  .p-toss-up::before {
    height: 6.667vw;
    width: 6.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-toss-up::before {
    height: 4.032vw;
    width: 4.032vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-toss-up::before {
    height: 50px;
    width: 50px;
  }
}

.p-toss-up__title {
  letter-spacing: 0.06em;
  margin-block: 0;
}
@media screen and (max-width: 768px) {
  .p-toss-up__title {
    border-bottom: 1px solid var(--color-primary);
    font-size: 5.067vw;
    line-height: 1.053;
    margin-inline: auto;
    padding-block: 4.667vw;
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .p-toss-up__title {
    line-height: 1.538;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-toss-up__title {
    font-size: 2.097vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-toss-up__title {
    font-size: 26px;
  }
}

.p-toss-up__text {
  letter-spacing: 0.02em;
}
@media screen and (max-width: 768px) {
  .p-toss-up__text {
    font-size: 3.6vw;
    line-height: 2;
    margin-block: 3.333vw 0;
    margin-inline: auto;
    text-align: justify;
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .p-toss-up__text {
    border-left: 1px solid var(--color-primary);
    line-height: 1.778;
    margin-block: 0;
    margin-inline: 0;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-toss-up__text {
    font-size: 1.452vw;
    -webkit-padding-start: 4.435vw;
            padding-inline-start: 4.435vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-toss-up__text {
    font-size: 18px;
    -webkit-padding-start: 55px;
            padding-inline-start: 55px;
  }
}

@media screen and (max-width: 768px) {
  .p-merit {
    padding-block: 10.667vw 11.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit {
    padding-block: 6.855vw 5.645vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit {
    padding-block: 85px 70px;
  }
}

@media screen and (max-width: 768px) {
  .p-merit__title {
    font-size: 8vw;
    letter-spacing: 0.04em;
    line-height: 1.333;
    margin-block: 5.333vw 0;
  }
}
@media screen and (min-width: 769px) {
  .p-merit__title {
    letter-spacing: 0.08em;
    line-height: 1;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit__title {
    font-size: 3.871vw;
    margin-block: 2.419vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit__title {
    font-size: 48px;
    margin-block: 30px 0;
  }
}

@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit__list {
    -webkit-margin-before: 5.242vw;
            margin-block-start: 5.242vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit__list {
    -webkit-margin-before: 65px;
            margin-block-start: 65px;
  }
}

@media screen and (max-width: 768px) {
  .p-merit-item {
    -webkit-margin-before: 30.667vw;
            margin-block-start: 30.667vw;
    width: 96vw;
  }
}
@media screen and (min-width: 769px) {
  .p-merit-item {
    position: relative;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item {
    -webkit-margin-before: 4.839vw;
            margin-block-start: 4.839vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item {
    -webkit-margin-before: 60px;
            margin-block-start: 60px;
  }
}
@media screen and (min-width: 769px) {
  .p-merit-item::before {
    background: #f5f5f5;
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    top: 0;
    width: 50%;
  }
}

.p-merit-item__inner {
  background: #f5f5f5;
  position: relative;
}
@media screen and (max-width: 768px) {
  .p-merit-item__inner {
    padding-block: 14vw 8vw;
  }
}
@media screen and (min-width: 769px) {
  .p-merit-item__inner {
    align-items: center;
    display: flex;
    justify-content: space-between;
    z-index: 5;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item__inner {
    padding-block: 4.839vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item__inner {
    padding-block: 60px;
  }
}

.p-merit-item__image {
  margin-block: 0;
  margin-inline: 0;
}
@media screen and (max-width: 768px) {
  .p-merit-item__image {
    position: absolute;
    top: -25.333vw;
  }
}

.p-merit-item__title {
  display: grid;
  margin-block: 0;
}
@media screen and (max-width: 768px) {
  .p-merit-item__title {
    gap: 3.333vw;
    grid-template-columns: 10.133vw 1fr;
    -webkit-margin-start: 0.8vw;
            margin-inline-start: 0.8vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item__title {
    gap: 1.613vw;
    grid-template-columns: 5.323vw 1fr;
    -webkit-margin-after: 2.419vw;
            margin-block-end: 2.419vw;
    -webkit-margin-start: 1.613vw;
            margin-inline-start: 1.613vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item__title {
    gap: 20px;
    grid-template-columns: 66px 1fr;
    -webkit-margin-after: 30px;
            margin-block-end: 30px;
    -webkit-margin-start: 20px;
            margin-inline-start: 20px;
  }
}

.p-merit-item__title-num {
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .p-merit-item__title-num {
    -webkit-margin-before: 0.4vw;
            margin-block-start: 0.4vw;
  }
}

.p-merit-item__title-label {
  letter-spacing: 0.02em;
}
@media screen and (max-width: 768px) {
  .p-merit-item__title-label {
    font-size: 5.6vw;
    line-height: 1.476;
  }
}
@media screen and (min-width: 769px) {
  .p-merit-item__title-label {
    line-height: 1.25;
    -webkit-margin-before: 0.18em;
            margin-block-start: 0.18em;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item__title-label {
    font-size: 2.581vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item__title-label {
    font-size: 32px;
  }
}

.p-merit-item__text {
  letter-spacing: 0.02em;
  text-align: justify;
}
@media screen and (max-width: 768px) {
  .p-merit-item__text {
    font-size: 3.6vw;
    line-height: 2;
    margin-block: 3.333vw 0;
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .p-merit-item__text {
    line-height: 1.778;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item__text {
    font-size: 1.452vw;
    margin-block: 1.613vw 0;
    -webkit-margin-start: 2.419vw;
            margin-inline-start: 2.419vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item__text {
    font-size: 18px;
    margin-block: 20px 0;
    -webkit-margin-start: 30px;
            margin-inline-start: 30px;
  }
}

.p-merit-item__point {
  background: #fff;
  list-style: none;
}
@media screen and (max-width: 768px) {
  .p-merit-item__point {
    border-radius: 1.333vw;
    box-shadow: 0 0 1.333vw rgba(87, 125, 232, 0.1);
    margin-block: 3.333vw 0;
    padding-block: 0;
    padding-inline: 4vw;
    width: 80vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item__point {
    border-radius: 0.806vw;
    box-shadow: 0 0 0.806vw rgba(87, 125, 232, 0.1);
    margin-block: 1.613vw 0;
    padding-block: 1.613vw;
    padding-inline: 2.419vw;
    width: 54.032vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item__point {
    border-radius: 10px;
    box-shadow: 0 0 10px rgba(87, 125, 232, 0.1);
    margin-block: 20px 0;
    padding-block: 20px;
    padding-inline: 30px;
    width: 670px;
  }
}

.p-merit-item__point-item {
  background: url(../images/home/icon_check.svg) no-repeat;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 768px) {
  .p-merit-item__point-item {
    background-position: 0 5.333vw;
    background-size: 4vw auto;
    border-bottom: 1px dotted #abbef3;
    font-size: 3.6vw;
    line-height: 1.481;
    padding-block: 4vw;
    padding-inline: 7.333vw 2.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-merit-item__point-item {
    background-position: 0 1em;
    border-bottom: 2px dotted #abbef3;
    line-height: 1.778;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item__point-item {
    background-size: 1.613vw auto;
    font-size: 1.452vw;
    padding-block: 0.645vw;
    padding-inline: 2.419vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item__point-item {
    background-size: 20px auto;
    font-size: 18px;
    padding-block: 8px;
    padding-inline: 30px 0;
  }
}
.p-merit-item__point-item:last-child {
  border-bottom: 0;
}

@media screen and (min-width: 769px) {
  .p-merit-item:nth-child(2n+1)::before {
    left: 0;
  }
}
@media screen and (max-width: 768px) {
  .p-merit-item:nth-child(2n+1) .p-merit-item__inner {
    border-top-right-radius: 26.667vw;
    -webkit-padding-start: 8vw;
            padding-inline-start: 8vw;
  }
}
@media screen and (min-width: 769px) {
  .p-merit-item:nth-child(2n+1) .p-merit-item__inner {
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item:nth-child(2n+1) .p-merit-item__inner {
    border-top-right-radius: 16.129vw;
    padding-inline: 8.065vw 4.839vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item:nth-child(2n+1) .p-merit-item__inner {
    border-top-right-radius: 200px;
    padding-inline: 100px 60px;
  }
}
@media screen and (max-width: 768px) {
  .p-merit-item:nth-child(2n+1) .p-merit-item__image {
    left: 36.667vw;
    width: 26.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item:nth-child(2n+1) .p-merit-item__image {
    width: 23.387vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item:nth-child(2n+1) .p-merit-item__image {
    width: 290px;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item:nth-child(2n+1) .p-merit-item__content {
    width: 57.258vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item:nth-child(2n+1) .p-merit-item__content {
    width: 710px;
  }
}
@media screen and (max-width: 768px) {
  .p-merit-item:nth-child(2n) {
    margin-inline: auto 0;
  }
}
@media screen and (min-width: 769px) {
  .p-merit-item:nth-child(2n)::before {
    right: 0;
  }
}
@media screen and (max-width: 768px) {
  .p-merit-item:nth-child(2n) .p-merit-item__inner {
    border-top-left-radius: 26.667vw;
    -webkit-padding-start: 8vw;
            padding-inline-start: 8vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item:nth-child(2n) .p-merit-item__inner {
    border-top-left-radius: 16.129vw;
    padding-inline: 4.839vw 8.065vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item:nth-child(2n) .p-merit-item__inner {
    border-top-left-radius: 200px;
    padding-inline: 60px 100px;
  }
}
@media screen and (max-width: 768px) {
  .p-merit-item:nth-child(2n) .p-merit-item__image {
    left: 37.333vw;
    width: 19.6vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item:nth-child(2n) .p-merit-item__image {
    width: 16.371vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item:nth-child(2n) .p-merit-item__image {
    width: 203px;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-merit-item:nth-child(2n) .p-merit-item__content {
    width: 62.097vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-merit-item:nth-child(2n) .p-merit-item__content {
    width: 770px;
  }
}

.p-agency {
  background: #eef4ff;
}

@media screen and (max-width: 768px) {
  .p-agency__inner {
    padding-block: 14.667vw 9.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-agency__inner {
    padding-block: 6.048vw 3.629vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-agency__inner {
    padding-block: 75px 45px;
  }
}

.p-agency__title {
  line-height: 1;
  margin-block: 0;
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .p-agency__title {
    font-size: 8vw;
    letter-spacing: 0.04em;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-agency__title {
    font-size: 3.871vw;
    letter-spacing: 0.08em;
  }
}
@media screen and (min-width: 1240px) {
  .p-agency__title {
    font-size: 48px;
    letter-spacing: 0.08em;
  }
}

.p-agency__text {
  letter-spacing: 0.02em;
}
@media screen and (max-width: 768px) {
  .p-agency__text {
    font-size: 3.6vw;
    line-height: 2;
    margin-block: 6vw 0;
    margin-inline: auto;
    width: 90.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-agency__text {
    line-height: 1.778;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-agency__text {
    font-size: 1.452vw;
    margin-block: 2.419vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-agency__text {
    font-size: 18px;
    margin-block: 30px 0;
  }
}

@media screen and (max-width: 768px) {
  .p-agency-type {
    margin-inline: auto;
    width: 90.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-agency-type {
    display: flex;
    justify-content: space-between;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-agency-type {
    -webkit-margin-before: 3.629vw;
            margin-block-start: 3.629vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-agency-type {
    -webkit-margin-before: 45px;
            margin-block-start: 45px;
  }
}

@media screen and (max-width: 768px) {
  .p-agency-type__item {
    margin-block: 6.667vw 0;
  }
}
@media screen and (min-width: 769px) {
  .p-agency-type__item {
    margin-block: 0;
    width: 48%;
  }
}

.p-agency-type__title {
  align-items: center;
  background: var(--color-primary);
  display: flex;
  margin-block: 0;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .p-agency-type__title {
    gap: 3.333vw;
    height: 11.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-agency-type__title {
    gap: 1.452vw;
    height: 4.839vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-agency-type__title {
    gap: 18px;
    height: 60px;
  }
}

.p-agency-type__title-label {
  color: #fff;
  letter-spacing: 0.02em;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .p-agency-type__title-label {
    font-size: 5.6vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-agency-type__title-label {
    font-size: 2.419vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-agency-type__title-label {
    font-size: 30px;
  }
}

.p-agency-type__title-sup {
  -webkit-margin-start: 0.3em;
          margin-inline-start: 0.3em;
}
@media screen and (max-width: 768px) {
  .p-agency-type__title-sup {
    font-size: 3.022vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-agency-type__title-sup {
    font-size: 1.29vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-agency-type__title-sup {
    font-size: 16px;
  }
}

.p-agency-type__title-note {
  background: #fff;
  border-radius: 100vw;
  letter-spacing: 0.04em;
  padding-inline: 1em;
}
@media screen and (max-width: 768px) {
  .p-agency-type__title-note {
    font-size: 4.133vw;
    line-height: 1.806;
  }
}
@media screen and (min-width: 769px) {
  .p-agency-type__title-note {
    line-height: 1.818;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-agency-type__title-note {
    font-size: 1.774vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-agency-type__title-note {
    font-size: 22px;
  }
}

.p-agency-type__image {
  margin-block: 0;
  margin-inline: 0;
}

.p-agency__note {
  letter-spacing: 0.02em;
}
@media screen and (max-width: 768px) {
  .p-agency__note {
    font-size: 2.667vw;
    line-height: 1.5;
    margin-block: 4vw 0;
    margin-inline: auto;
    width: 90.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-agency__note {
    line-height: 1.875;
    text-align: center;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-agency__note {
    font-size: 1.29vw;
    margin-block: 2.419vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-agency__note {
    font-size: 16px;
    margin-block: 30px 0;
  }
}

@media screen and (max-width: 768px) {
  .p-about__inner {
    padding-block: 13.333vw 9.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-about__inner {
    padding-block: 5.645vw 16.935vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-about__inner {
    padding-block: 70px 210px;
  }
}

.p-about__title {
  align-items: center;
  display: flex;
  line-height: 1;
  justify-content: center;
  margin-block: 0;
}
.p-about__title::before, .p-about__title::after {
  background: var(--color-primary);
  content: "";
  display: block;
}
@media screen and (max-width: 768px) {
  .p-about__title::before, .p-about__title::after {
    height: 1px;
    width: 10.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-about__title::before, .p-about__title::after {
    height: 2px;
    width: 16.129vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-about__title::before, .p-about__title::after {
    height: 2px;
    width: 200px;
  }
}
.p-about__title::before {
  margin-inline: 0 auto;
}
.p-about__title::after {
  margin-inline: auto 0;
}

.p-about__title-logo {
  display: block;
  fill: var(--color-font);
}
@media screen and (max-width: 768px) {
  .p-about__title-logo {
    width: 58vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-about__title-logo {
    width: 35.081vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-about__title-logo {
    width: 435px;
  }
}

.p-about__title-particle {
  letter-spacing: 0.08em;
  -webkit-margin-start: 0.25em;
          margin-inline-start: 0.25em;
}
@media screen and (max-width: 768px) {
  .p-about__title-particle {
    font-size: 5.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-about__title-particle {
    font-size: 3.226vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-about__title-particle {
    font-size: 40px;
  }
}

.p-about__text {
  letter-spacing: 0.02em;
}
@media screen and (max-width: 768px) {
  .p-about__text {
    font-size: 3.6vw;
    line-height: 2;
    margin-block: 4.667vw 0;
    margin-inline: auto;
    width: 90.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-about__text {
    line-height: 1.882;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-about__text {
    font-size: 1.371vw;
    margin-block: 4.032vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-about__text {
    font-size: 17px;
    margin-block: 50px 0;
  }
}

@media screen and (min-width: 769px) {
  .p-about__content {
    align-items: flex-start;
    display: flex;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-about__content {
    -webkit-margin-before: 2.016vw;
            margin-block-start: 2.016vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-about__content {
    -webkit-margin-before: 25px;
            margin-block-start: 25px;
  }
}

.p-about__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  list-style: none;
  padding-inline: 0;
}
@media screen and (max-width: 768px) {
  .p-about__list {
    gap: 2.419vw 2.823vw;
    margin-block: 6.667vw 0;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-about__list {
    gap: 1.613vw 2.419vw;
    margin-block: 1.613vw 0;
    width: 39.516vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-about__list {
    gap: 20px 30px;
    margin-block: 20px 0;
    width: 490px;
  }
}

.p-about__item {
  margin-block: 0;
}

@media screen and (max-width: 768px) {
  .p-about__item--large {
    width: 65.2vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-about__item--large {
    width: 30.645vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-about__item--large {
    width: 380px;
  }
}

@media screen and (max-width: 768px) {
  .p-about__item--middle {
    width: 39.467vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-about__item--middle {
    width: 18.548vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-about__item--middle {
    width: 230px;
  }
}

@media screen and (max-width: 768px) {
  .p-about__price {
    margin-block: 4.267vw 0;
    margin-inline: 9.067vw 0;
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .p-about__price {
    margin-block: 0;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-about__price {
    margin-inline: -4.435vw -0.403vw;
    width: 45.806vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-about__price {
    margin-inline: -55px -5px;
    width: 568px;
  }
}

.p-case {
  background: #eef4ff;
  position: relative;
}
@media screen and (max-width: 768px) {
  .p-case {
    background: url(../images/home/features_bg_sp.png) 0 0/100% auto no-repeat #eef4ff;
  }
}
@media screen and (min-width: 769px) {
  .p-case::before {
    background: url(../images/home/features_bg_pc.png) 50% 100%/auto 100% no-repeat;
    content: "";
    display: block;
    left: 0;
    position: absolute;
    width: 100%;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case::before {
    height: 12.903vw;
    top: -12.742vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case::before {
    height: 160px;
    top: -158px;
  }
}

.p-case__inner {
  position: relative;
}
@media screen and (max-width: 768px) {
  .p-case__inner {
    padding-block: 16vw 8.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case__inner {
    padding-block: 0.806vw 3.226vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case__inner {
    padding-block: 10px 40px;
  }
}

.p-case__image {
  margin-block: 0;
  margin-inline: 0;
  position: absolute;
  z-index: 5;
}
@media screen and (max-width: 768px) {
  .p-case__image {
    left: 6.4vw;
    top: -5.067vw;
    width: 26.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case__image {
    left: -2.742vw;
    top: -16.935vw;
    width: 21.371vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case__image {
    left: -34px;
    top: -210px;
    width: 265px;
  }
}

@media screen and (min-width: 769px) {
  .p-case__en-title {
    left: 50%;
    position: absolute;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    z-index: 5;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case__en-title {
    top: -6.29vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case__en-title {
    top: -78px;
  }
}

.p-case__title {
  letter-spacing: 0.08em;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .p-case__title {
    font-size: 8vw;
    margin-block: 4.667vw 0;
  }
}
@media screen and (min-width: 769px) {
  .p-case__title {
    margin-block: 0;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case__title {
    font-size: 3.871vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case__title {
    font-size: 48px;
  }
}

.p-case__text {
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  .p-case__text {
    font-size: 4.267vw;
    line-height: 1.563;
    margin-block: 4.667vw 0;
    margin-inline: auto;
    width: 90.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-case__text {
    line-height: 2;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case__text {
    font-size: 1.774vw;
    margin-block: 2.016vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-case__text {
    font-size: 22px;
    margin-block: 25px 0;
  }
}

.p-case__list {
  display: grid;
}
@media screen and (max-width: 768px) {
  .p-case__list {
    gap: 6.667vw 0;
    grid-template-columns: 1fr;
    -webkit-margin-before: 4.667vw;
            margin-block-start: 4.667vw;
    margin-inline: auto;
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .p-case__list {
    gap: 0 1.3333333333%;
    grid-template-columns: repeat(4, 24%);
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case__list {
    -webkit-margin-before: 3.226vw;
            margin-block-start: 3.226vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case__list {
    -webkit-margin-before: 40px;
            margin-block-start: 40px;
  }
}

.p-case-item {
  background: var(--color-primary);
  display: grid;
  gap: 0;
  grid-row: span 4;
  grid-template-rows: subgrid;
  place-items: center;
}
@media screen and (max-width: 768px) {
  .p-case-item {
    -webkit-padding-before: 4vw;
            padding-block-start: 4vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case-item {
    -webkit-padding-before: 1.048vw;
            padding-block-start: 1.048vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case-item {
    -webkit-padding-before: 13px;
            padding-block-start: 13px;
  }
}

.p-case-item__industry {
  background: #fff;
  border-radius: 100vw;
  letter-spacing: 0.08em;
  margin-block: 0;
}
@media screen and (max-width: 768px) {
  .p-case-item__industry {
    font-size: 4.667vw;
    line-height: 1.429;
    width: 66.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-case-item__industry {
    line-height: 1.429;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case-item__industry {
    font-size: 1.129vw;
    width: 16.129vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case-item__industry {
    font-size: 14px;
    width: 200px;
  }
}

.p-case-item__company-name {
  color: #fff;
  letter-spacing: 0.08em;
  margin-block: 0.5em 0;
}
@media screen and (max-width: 768px) {
  .p-case-item__company-name {
    font-size: 4.933vw;
    line-height: 1.351;
    min-height: 2.7em;
    place-content: center;
  }
}
@media screen and (min-width: 769px) {
  .p-case-item__company-name {
    line-height: 1.333;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case-item__company-name {
    font-size: 1.21vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case-item__company-name {
    font-size: 15px;
  }
}

.p-case-item__area {
  color: #fff;
  letter-spacing: 0.08em;
  line-height: 1;
  margin-block: 0.35em 0;
}
@media screen and (max-width: 768px) {
  .p-case-item__area {
    font-size: 4.267vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case-item__area {
    font-size: 1.048vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case-item__area {
    font-size: 13px;
  }
}

.p-case-item__bottom {
  background: #fff;
}
@media screen and (max-width: 768px) {
  .p-case-item__bottom {
    -webkit-margin-before: 3.333vw;
            margin-block-start: 3.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case-item__bottom {
    -webkit-margin-before: 0.806vw;
            margin-block-start: 0.806vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case-item__bottom {
    -webkit-margin-before: 10px;
            margin-block-start: 10px;
  }
}

.p-case-item__thumb {
  margin-block: 0;
  margin-inline: 0;
  position: relative;
}
.p-case-item__thumb::after {
  background: #2f2f2f;
  bottom: 0.5px;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  content: "";
  display: block;
  left: 0;
  position: absolute;
  -webkit-transform: translateY(100%);
          transform: translateY(100%);
  width: 100%;
}
@media screen and (max-width: 768px) {
  .p-case-item__thumb::after {
    height: 7.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case-item__thumb::after {
    height: 1.774vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case-item__thumb::after {
    height: 22px;
  }
}

.p-case-item__cost {
  margin-block: 0;
}
@media screen and (max-width: 768px) {
  .p-case-item__cost {
    padding-block: 13.333vw 8.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case-item__cost {
    padding-block: 3.226vw 2.016vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case-item__cost {
    padding-block: 40px 25px;
  }
}

.p-case-item__cost-title {
  align-items: center;
  display: flex;
  letter-spacing: 0.02em;
  line-height: 1;
  justify-content: center;
  margin-block: 0;
}
@media screen and (max-width: 768px) {
  .p-case-item__cost-title {
    font-size: 5.333vw;
    gap: 3.2vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case-item__cost-title {
    font-size: 1.29vw;
    gap: 0.5em;
  }
}
@media screen and (min-width: 1240px) {
  .p-case-item__cost-title {
    font-size: 16px;
    gap: 0.5em;
  }
}
.p-case-item__cost-title::before, .p-case-item__cost-title::after {
  background: var(--color-font);
  content: "";
  display: block;
  height: 1px;
}
@media screen and (max-width: 768px) {
  .p-case-item__cost-title::before, .p-case-item__cost-title::after {
    width: 16.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case-item__cost-title::before, .p-case-item__cost-title::after {
    width: 4.032vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-case-item__cost-title::before, .p-case-item__cost-title::after {
    width: 50px;
  }
}

.p-case-item__cost-cut {
  margin-inline: 0;
}
@media screen and (max-width: 768px) {
  .p-case-item__cost-cut {
    margin-block: 3.333vw 0;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case-item__cost-cut {
    margin-block: 0.645vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-case-item__cost-cut {
    margin-block: 8px 0;
  }
}

.p-partner {
  background: #fff;
}
@media screen and (max-width: 768px) {
  .p-partner {
    margin-block: 6.667vw 0;
    margin-inline: auto;
    padding-block: 5.067vw;
    width: 90.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-partner {
    margin-block: 2.823vw 0;
    padding-block: 2.823vw 2.016vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-partner {
    margin-block: 35px 0;
    padding-block: 35px 25px;
  }
}

.p-partner__list {
  list-style: none;
  margin-block: 0;
  margin-inline: auto;
  padding-inline: 0;
}
@media screen and (max-width: 768px) {
  .p-partner__list {
    display: grid;
    gap: 3.333vw 1.6vw;
    grid-template-columns: repeat(4, 1fr);
    width: 70.933vw;
  }
}
@media screen and (min-width: 769px) {
  .p-partner__list {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-partner__list {
    gap: 1.21vw 0.968vw;
    width: 75.806vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-partner__list {
    gap: 15px 12px;
    width: 940px;
  }
}

.p-partner__item {
  margin-block: 0;
  margin-inline: 0;
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-partner__item {
    width: 10vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-partner__item {
    width: 124px;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-partner__item:nth-of-type(8) {
    -webkit-margin-start: 1.613vw;
            margin-inline-start: 1.613vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-partner__item:nth-of-type(8) {
    -webkit-margin-start: 20px;
            margin-inline-start: 20px;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-partner__item:nth-of-type(13) {
    -webkit-margin-end: 1.613vw;
            margin-inline-end: 1.613vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-partner__item:nth-of-type(13) {
    -webkit-margin-end: 20px;
            margin-inline-end: 20px;
  }
}

.p-partner__more {
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .p-partner__more {
    margin-block: 3.333vw 0;
    margin-inline: auto 5.067vw;
    width: 14.4vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-partner__more {
    margin-block: 1.774vw 0;
    margin-inline: auto 2.903vw;
    width: 7.419vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-partner__more {
    margin-block: 22px 0;
    margin-inline: auto 36px;
    width: 92px;
  }
}

.p-case__note {
  color: #666;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
  .p-case__note {
    font-size: 2.667vw;
    line-height: 1.6;
    margin-block: 5.067vw 0;
    margin-inline: auto;
    text-align: center;
    width: 90.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-case__note {
    line-height: 2.308;
    text-align: right;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-case__note {
    font-size: 1.048vw;
    margin-block: 1.613vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-case__note {
    font-size: 13px;
    margin-block: 20px 0;
  }
}

@media screen and (max-width: 768px) {
  .p-contact__inner {
    padding-block: 14vw 6.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-contact__inner {
    padding-block: 8.468vw 4.032vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-contact__inner {
    padding-block: 105px 50px;
  }
}

.p-contact__title {
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .p-contact__title {
    font-size: 8vw;
    letter-spacing: 0.04em;
    margin-block: 5.333vw 0;
  }
}
@media screen and (min-width: 769px) {
  .p-contact__title {
    letter-spacing: 0.08em;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-contact__title {
    font-size: 3.871vw;
    margin-block: 4.032vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-contact__title {
    font-size: 48px;
    margin-block: 50px 0;
  }
}

.p-form {
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .p-form {
    -webkit-margin-before: 6vw;
            margin-block-start: 6vw;
    width: 85.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-form {
    -webkit-margin-before: 3.629vw;
            margin-block-start: 3.629vw;
    width: 64.516vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-form {
    -webkit-margin-before: 45px;
            margin-block-start: 45px;
    width: 800px;
  }
}

.p-form__note {
  letter-spacing: 0.02em;
  line-height: 1;
  margin-block: 0;
}
@media screen and (max-width: 768px) {
  .p-form__note {
    font-size: 2.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-form__note {
    font-size: 1.129vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-form__note {
    font-size: 14px;
  }
}

@media screen and (max-width: 768px) {
  .p-form__group {
    margin-block: 4vw 0;
    padding-block: 0 4vw;
  }
}
@media screen and (min-width: 769px) {
  .p-form__group {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-form__group {
    margin-block: 1.613vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-form__group {
    margin-block: 20px 0;
  }
}

.p-form__title {
  letter-spacing: 0.02em;
  line-height: 1;
  margin-block: 0;
}
@media screen and (max-width: 768px) {
  .p-form__title {
    font-size: 3.733vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-form__title {
    font-size: 1.29vw;
    -webkit-padding-before: 1.613vw;
            padding-block-start: 1.613vw;
    width: 11.29vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-form__title {
    font-size: 16px;
    -webkit-padding-before: 20px;
            padding-block-start: 20px;
    width: 140px;
  }
}

.p-form__data {
  margin-inline: 0;
}
@media screen and (max-width: 768px) {
  .p-form__data {
    margin-block: 2.667vw 0;
  }
}
@media screen and (min-width: 769px) {
  .p-form__data {
    margin-block: 0;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-form__data {
    width: 52.419vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-form__data {
    width: 650px;
  }
}

.p-form__input,
.p-form__textarea {
  -webkit-appearance: none;
          appearance: none;
  background: #f2f2f2;
  border: 1px solid #b3b3b3;
  letter-spacing: 0.02em;
  line-height: 1.38;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .p-form__input,
  .p-form__textarea {
    border-radius: 0.667vw;
    font-size: 3.467vw;
    padding-block: 3.333vw;
    padding-inline: 3.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-form__input,
  .p-form__textarea {
    font-size: 1.21vw;
    padding-block: 1.532vw;
    padding-inline: 1.613vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-form__input,
  .p-form__textarea {
    border-radius: 5px;
    font-size: 15px;
    padding-block: 19px;
    padding-inline: 20px;
  }
}
.p-form__input::-webkit-input-placeholder, .p-form__textarea::-webkit-input-placeholder {
  color: #b3b3b3;
}
.p-form__input:-ms-input-placeholder, .p-form__textarea:-ms-input-placeholder {
  color: #b3b3b3;
}
.p-form__input::-ms-input-placeholder, .p-form__textarea::-ms-input-placeholder {
  color: #b3b3b3;
}
.p-form__input::placeholder,
.p-form__textarea::placeholder {
  color: #b3b3b3;
}

.p-form__textarea {
  field-sizing: content;
}
@media screen and (max-width: 768px) {
  .p-form__textarea {
    height: 40vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-form__textarea {
    height: 12.097vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-form__textarea {
    height: 150px;
  }
}

.p-form .c-cta {
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .p-form .c-cta {
    -webkit-margin-before: 9.333vw;
            margin-block-start: 9.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-form .c-cta {
    -webkit-margin-before: 6.048vw;
            margin-block-start: 6.048vw;
    width: 48.387vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-form .c-cta {
    -webkit-margin-before: 75px;
            margin-block-start: 75px;
    width: 600px;
  }
}
.p-form .c-cta__button {
  line-height: 1;
}

.c-cta__button-submit {
  -webkit-appearance: none;
          appearance: none;
  background: var(--color-secondary);
  border: 0;
  border-radius: 100vw;
  color: #fff;
  cursor: pointer;
  font-size: 100%;
  font-weight: 500;
  display: block;
  letter-spacing: 0.12em;
  text-decoration: none;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .c-cta__button-submit {
    line-height: 3.5;
  }
}
@media screen and (min-width: 769px) {
  .c-cta__button-submit {
    line-height: 2.813;
  }
}
@media (any-hover: hover) {
  .c-cta__button-submit:hover {
    opacity: 0.8;
  }
}

.p-company {
  background: #eef4ff;
}
@media screen and (max-width: 768px) {
  .p-company {
    padding-block: 13.333vw 10.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-company {
    padding-block: 8.871vw 8.065vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-company {
    padding-block: 110px 100px;
  }
}

.p-company__title {
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .p-company__title {
    font-size: 8vw;
    letter-spacing: 0.04em;
    margin-block: 5.067vw 0;
  }
}
@media screen and (min-width: 769px) {
  .p-company__title {
    letter-spacing: 0.08em;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-company__title {
    font-size: 3.871vw;
    margin-block: 4.032vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-company__title {
    font-size: 48px;
    margin-block: 50px 0;
  }
}

.p-company__content {
  background: #fff;
}
@media screen and (max-width: 768px) {
  .p-company__content {
    border-radius: 2.667vw;
    margin-block: 6.667vw 0;
    margin-inline: auto;
    padding-block: 3.333vw 5.333vw;
    width: 92vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-company__content {
    border-radius: 1.613vw;
    margin-block: 3.226vw 0;
    padding-block: 3.629vw 3.226vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-company__content {
    border-radius: 20px;
    margin-block: 40px 0;
    padding-block: 45px 40px;
  }
}

.p-company-table {
  border-collapse: collapse;
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .p-company-table {
    width: 86.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-company-table {
    width: 59.677vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-company-table {
    width: 740px;
  }
}

.p-company-table__header,
.p-company-table__cell {
  font-weight: 400;
  text-align: left;
  vertical-align: top;
}
@media screen and (max-width: 768px) {
  .p-company-table__header,
  .p-company-table__cell {
    border-bottom: 1px solid #e6e6e6;
    font-size: 3.2vw;
    line-height: 1.25;
    padding-block: 3.2vw;
  }
}
@media screen and (min-width: 769px) {
  .p-company-table__header,
  .p-company-table__cell {
    letter-spacing: 0.04em;
    line-height: 1.667;
    padding-inline: 0;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-company-table__header,
  .p-company-table__cell {
    font-size: 1.452vw;
    padding-block: 0.806vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-company-table__header,
  .p-company-table__cell {
    font-size: 18px;
    padding-block: 10px;
  }
}

@media screen and (max-width: 768px) {
  .p-company-table__row:last-child .p-company-table__header,
  .p-company-table__row:last-child .p-company-table__cell {
    border-bottom: 0 !important;
  }
}

.p-company-table__header {
  letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
  .p-company-table__header {
    padding-inline: 2.933vw;
    width: 26.667vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-company-table__header {
    width: 17.742vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-company-table__header {
    width: 220px;
  }
}

@media screen and (max-width: 768px) {
  .p-company-table__cell {
    padding-inline: 0;
  }
}

@media screen and (max-width: 768px) {
  .p-error404 {
    padding-block: 26vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-error404 {
    padding-block: 12.097vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-error404 {
    padding-block: 150px;
  }
}

.p-error404__title {
  margin-block: 0;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .p-error404__title {
    font-size: 8vw;
    letter-spacing: 0.04em;
    line-height: 1.333;
  }
}
@media screen and (min-width: 769px) {
  .p-error404__title {
    letter-spacing: 0.08em;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-error404__title {
    font-size: 3.871vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-error404__title {
    font-size: 48px;
  }
}

.p-error404__text {
  letter-spacing: 0.02em;
}
@media screen and (max-width: 768px) {
  .p-error404__text {
    font-size: 3.6vw;
    line-height: 2;
    margin-block: 6vw 0;
    margin-inline: auto;
    width: 90.667vw;
  }
}
@media screen and (min-width: 769px) {
  .p-error404__text {
    line-height: 1.778;
    text-align: center;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-error404__text {
    font-size: 1.452vw;
    margin-block: 4.839vw 0;
  }
}
@media screen and (min-width: 1240px) {
  .p-error404__text {
    font-size: 18px;
    margin-block: 60px 0;
  }
}
.p-error404__text + .p-error404__text {
  -webkit-margin-before: 1.5em;
          margin-block-start: 1.5em;
}

.p-error404 .c-cta {
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .p-error404 .c-cta {
    -webkit-margin-before: 9.333vw;
            margin-block-start: 9.333vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 1239px) {
  .p-error404 .c-cta {
    -webkit-margin-before: 6.048vw;
            margin-block-start: 6.048vw;
    width: 48.387vw;
  }
}
@media screen and (min-width: 1240px) {
  .p-error404 .c-cta {
    -webkit-margin-before: 75px;
            margin-block-start: 75px;
    width: 600px;
  }
}

@media screen and (min-width: 769px) {
  .u-only-sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .u-only-pc {
    display: none !important;
  }
}
.u-sup {
  font-size: 58.3%;
  vertical-align: super;
}

.u-color-primary {
  color: var(--color-primary);
}

.u-color-secondary {
  color: var(--color-secondary);
}

.u-color-tertiary {
  color: var(--color-tertiary);
}

.u-align-center {
  text-align: center;
}

.u-align-right {
  text-align: right;
}

.u-visibility-hidden {
  visibility: hidden;
}

.u-fw900 {
  font-weight: 900 !important;
}

.u-fw700 {
  font-weight: 700 !important;
}

.u-fw500 {
  font-weight: 500 !important;
}

.u-fw400 {
  font-weight: 400 !important;
}

.u-fw300 {
  font-weight: 300 !important;
}

.u-fz70 {
  font-size: 0.7em;
}/*# sourceMappingURL=style.css.map */