html {
  font-size: 62.5%;
  font-feature-settings: "palt";
  scroll-behavior: smooth;
}
@media screen and (min-width: 821px) {
  html {
    scroll-padding-top: 70px;
  }
}

body {
  font-size: 1.6rem;
  letter-spacing: 0.06em;
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}
@media screen and (min-width: 821px) {
  body {
    padding-top: 70px;
  }
}

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

.section-title {
  text-align: center;
  font-size: 27px;
  font-weight: 600;
  line-height: 1.35;
  margin-bottom: 4.8rem;
  font-weight: 600;
  color: #0086EA;
  position: relative;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 821px) {
  .section-title {
    font-size: 40px;
  }
}
.section-title span {
  display: block;
  margin-top: 0.4rem;
  font-family: "Montserrat", sans-serif;
  font-size: 100px;
  font-weight: 300;
  letter-spacing: 0.025em;
  color: rgba(204, 204, 204, 0.2);
  position: absolute;
  transform: translate(-50%, -50%);
  left: 50%;
  top: 50%;
  z-index: -1;
  width: 100%;
}
@media screen and (min-width: 821px) {
  .section-title span {
    font-size: 135px;
  }
}

main {
  overflow-x: hidden;
}

.l-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
}

.c-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 11rem;
  padding: 0.9rem 1.6rem;
  font-size: 1.4rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
  text-decoration: none;
  transition: opacity 0.2s, transform 0.15s;
}
.c-btn:hover {
  opacity: 0.92;
}
.c-btn:active {
  transform: scale(0.98);
}

.c-btn--document {
  background: #ec407a;
}

.c-btn--contact {
  background: #111f70;
}

.c-btns--sticky {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 900;
  display: flex;
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
  padding-bottom: env(safe-area-inset-bottom, 0px);
  box-sizing: border-box;
}
@media screen and (min-width: 821px) {
  .c-btns--sticky {
    max-width: 800px;
    gap: 60px;
    margin: 0 auto;
    position: absolute;
    bottom: -40px;
  }
  .c-btns--sticky.is-stick {
    position: fixed;
    bottom: 0;
  }
}

.c-btn--sticky {
  position: relative;
  min-width: 0;
  min-height: 5.2rem;
  padding: 1.6rem 1rem 1.6rem 1.8rem;
  border-radius: 0;
  justify-content: flex-start;
  gap: 1rem;
  font-size: 1.6rem;
  line-height: 1.35;
  box-shadow: 3px 3px 12px rgba(0, 134, 234, 0.5);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  width: 50%;
}
@media screen and (min-width: 821px) {
  .c-btn--sticky {
    padding: 2.5rem 1rem 2.5rem 1.8rem;
  }
}
.c-btn--sticky img {
  width: 20px !important;
}
@media screen and (min-width: 821px) {
  .c-btn--sticky img {
    width: 30px !important;
  }
}
@media screen and (min-width: 821px) {
  .c-btn--sticky {
    justify-content: center;
    width: 370px;
    font-size: 20px;
  }
}
.c-btn--sticky .c-btn__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
}
.c-btn--sticky .c-btn__icon svg {
  display: block;
}
.c-btn--sticky .c-btn__text {
  min-width: 0;
  text-align: center;
  padding: 0 0.25rem;
  text-align: left;
}
@media screen and (min-width: 821px) {
  .c-btn--sticky .c-btn__text {
    font-size: 2rem;
  }
}
.c-btn--sticky .c-btn__line {
  flex-shrink: 0;
  width: 2.2rem;
  height: 2px;
  background: #fff;
  transition: width 0.2s ease;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  overflow: hidden;
}
@media screen and (min-width: 821px) {
  .c-btn--sticky .c-btn__line {
    width: 42px;
  }
}
@media screen and (min-width: 821px) {
  .c-btn--sticky:hover {
    opacity: 1;
    transform: scale(1.05);
    z-index: 1;
    box-shadow: 0 -4px 28px rgba(0, 134, 234, 0.35);
  }
  .c-btn--sticky:hover .c-btn__line {
    width: 0;
  }
}
.c-btn--sticky:active {
  transform: scale(1.02);
}
.c-btn--sticky:focus-visible {
  outline: 2px solid #fff;
  outline-offset: -4px;
}

.c-btn--sticky.c-btn--document {
  background: #E2426C;
}
.c-btn--sticky.c-btn--document img {
  width: 15px !important;
}
@media screen and (min-width: 821px) {
  .c-btn--sticky.c-btn--document img {
    width: 24px !important;
  }
}

.c-btn--sticky.c-btn--contact {
  background: #111f70;
}

@media screen and (min-width: 821px) {
  .p-header__bar {
    background: #fff;
  }
}

.p-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.6rem;
  max-width: 100%;
  margin: 0 auto;
  min-height: 50px;
}
@media screen and (min-width: 821px) {
  .p-header__inner {
    padding: 0 2rem;
    min-height: 70px;
    gap: 2rem;
    padding: 0 20px;
  }
}
@media screen and (min-width: 1300px) {
  .p-header__inner {
    gap: 2.4rem;
    padding: 0 50px 0 100px;
  }
}

.p-header__logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  opacity: 0;
  width: 0;
}
@media screen and (min-width: 821px) {
  .p-header__logo {
    opacity: 1;
    width: auto;
  }
}

.p-header__logo-img {
  display: block;
  width: auto;
}
@media screen and (min-width: 821px) {
  .p-header__logo-img {
    max-width: 200px;
  }
}

.p-header__nav--pc {
  display: none;
}
@media screen and (min-width: 821px) {
  .p-header__nav--pc {
    display: flex;
    flex: 1;
    justify-content: center;
    min-width: 0;
  }
}

.p-header__nav-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
@media screen and (min-width: 1300px) {
  .p-header__nav-list {
    gap: 4rem;
  }
}

.p-header__nav-link {
  color: #808080;
  font-size: 1.6rem;
  font-weight: 500;
  text-decoration: none;
  white-space: nowrap;
  transition: opacity 0.2s;
}
.p-header__nav-link:hover {
  opacity: 0.65;
}

.p-header__right {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  gap: 1rem;
}
@media screen and (min-width: 1300px) {
  .p-header__right {
    gap: 3rem;
  }
}

.p-header__cta--pc {
  display: none;
}
@media screen and (min-width: 821px) {
  .p-header__cta--pc {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    padding-left: 10px;
    position: relative;
  }
  .p-header__cta--pc::before {
    content: "";
    display: block;
    width: 1px;
    height: 70px;
    background: #808080;
    position: absolute;
    left: 0;
    top: 0;
    top: -19px;
  }
}
@media screen and (min-width: 1300px) {
  .p-header__cta--pc {
    gap: 1.2rem;
    padding-left: 33px;
  }
}
.p-header__cta--pc .c-btn {
  width: 150px;
}
@media screen and (max-width: 1100px) {
  .p-header__cta--pc .c-btn {
    width: 122px;
  }
}

.p-header__toggle {
  position: relative;
  z-index: 2002;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  width: 4.8rem;
  height: 4.8rem;
  padding: 0;
  border: none;
  border-radius: 1rem;
  background: transparent;
  cursor: pointer;
  transition: background 0.2s;
}
@media screen and (min-width: 821px) {
  .p-header__toggle {
    display: none;
  }
}
.p-header__toggle:focus-visible {
  outline: 2px solid #111f70;
  outline-offset: 2px;
}

.p-header__toggle-line {
  display: block;
  width: 2.1rem;
  height: 0.2rem;
  border-radius: 0.2rem;
  background: #111f70;
  transition: transform 0.3s ease, opacity 0.2s ease, background 0.2s ease;
}

.p-header.is-open .p-header__toggle {
  position: fixed;
  top: 0.8rem;
  right: 0.8rem;
}

.p-header.is-open .p-header__toggle-line {
  background: #fff;
}

.p-header.is-open .p-header__toggle-line:nth-child(1) {
  transform: translateY(0.8rem) rotate(45deg);
}

.p-header.is-open .p-header__toggle-line:nth-child(2) {
  opacity: 0;
}

.p-header.is-open .p-header__toggle-line:nth-child(3) {
  transform: translateY(-0.8rem) rotate(-45deg);
}

.p-header__drawer {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 2000;
  display: flex;
  flex-direction: column;
  pointer-events: none;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.35s ease, visibility 0.35s;
  width: 200px;
}
.p-header__drawer[aria-hidden=false] {
  pointer-events: auto;
  visibility: visible;
  opacity: 1;
}
@media screen and (min-width: 821px) {
  .p-header__drawer {
    display: none;
  }
}

.p-header__drawer-inner {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3rem;
  padding: 60px 16px 32px;
  margin-top: 0;
  background: url("../img/bg-menu.webp") no-repeat center top/cover;
  border-radius: 0 0 0 2.4rem;
  min-height: 100%;
  box-sizing: border-box;
  box-shadow: -5px 5px 7px 0 rgba(0, 0, 0, 0.2);
}

.p-header__nav--sp {
  width: 100%;
  max-width: 32rem;
}

.p-header__drawer-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1.6rem;
}
.p-header__drawer-list li {
  width: 140px;
}

.p-header__drawer-link {
  display: block;
  padding: 0.5rem 0 0.5rem 1rem;
  border: 1px solid #fff;
  border-radius: 999px;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  text-decoration: none;
  background: transparent;
  transition: background 0.2s, color 0.2s;
}
.p-header__drawer-link:hover, .p-header__drawer-link:focus-visible {
  background: rgba(255, 255, 255, 0.15);
}

.p-header__drawer-logo {
  margin-top: auto;
}

.p-header__drawer-logo-img {
  display: block;
  width: 147px;
  margin: 0 auto;
  filter: none;
}

.p-mv {
  position: relative;
}
.p-mv img {
  display: block;
  width: 100%;
  height: auto;
}

.p-lead {
  padding: 42px 15px 72px;
  background: url("../img/bg-lead-sp.webp") no-repeat top/cover;
  background-position: bottom;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 821px) {
  .p-lead {
    background: url("../img/bg-lead.webp") no-repeat top/cover;
    background-position: bottom;
    padding: 102px 15px 151px;
  }
}
.p-lead h2 {
  font-size: 22px;
  font-weight: 700;
  text-align: center;
  line-height: 1.5909090909;
  margin-bottom: 24px;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 821px) {
  .p-lead h2 {
    font-size: 40px;
  }
}
.p-lead h2 span {
  color: #57AFE5;
  font-weight: 800;
}
@media screen and (min-width: 821px) {
  .p-lead h2 span {
    font-size: 45px;
  }
}
.p-lead figure {
  width: 274px;
  margin: -31px 0 14px auto;
  position: relative;
  z-index: 10;
  padding-right: 16px;
}
@media screen and (min-width: 821px) {
  .p-lead figure {
    width: 340px;
    position: absolute;
    transform: translateX(-50%);
    left: 49%;
    bottom: -22px;
  }
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries {
    max-width: 1000px;
    height: 400px;
    margin: 0 auto;
    position: relative;
  }
}
.p-lead .p-lead__worries .p-lead__worries-item {
  position: relative;
  z-index: 4;
  letter-spacing: 0.1em;
  width: 270px;
  height: 60px;
  font-size: 13px;
  font-weight: bold;
  color: #4D4D4D;
  background: #E4EAEF;
  border-radius: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item {
    width: 405px;
    height: 90px;
    border-radius: 45px;
    font-size: 20px;
    margin-bottom: 0;
  }
}
.p-lead .p-lead__worries .p-lead__worries-item::before {
  content: "";
  display: block;
  width: 17px;
  height: 17px;
  background: url("../img/icon-check.svg") no-repeat center top/cover;
  margin-right: 8px;
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item::before {
    width: 23px;
    height: 23px;
  }
}
.p-lead .p-lead__worries .p-lead__worries-item::after {
  content: "";
  display: block;
  width: 10px;
  height: 16px;
  background: #E4EAEF;
  -webkit-clip-path: polygon(80% 0, 0 0, 80% 100%);
  clip-path: polygon(80% 0, 0 0, 80% 100%);
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -13px;
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item::after {
    width: 20px;
    height: 26px;
    bottom: -23px;
    -webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);
    clip-path: polygon(50% 100%, 0 0, 100% 0);
  }
}
.p-lead .p-lead__worries .p-lead__worries-item:nth-child(even) {
  margin-left: auto;
}
.p-lead .p-lead__worries .p-lead__worries-item span {
  font-size: 17px;
  color: #111f70;
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item span {
    font-size: 25px;
  }
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item:first-child {
    position: absolute;
    transform: translateX(-50%);
    left: 50%;
  }
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item:nth-child(2) {
    position: absolute;
    left: 0;
    top: 110px;
  }
}
.p-lead .p-lead__worries .p-lead__worries-item:nth-child(2)::after {
  -webkit-clip-path: polygon(80% 0, 0 0, 0 100%);
  clip-path: polygon(80% 0, 0 0, 0 100%);
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item:nth-child(2)::after {
    -webkit-clip-path: polygon(100% 100%, 20% 0, 100% 0);
    clip-path: polygon(100% 100%, 20% 0, 100% 0);
    left: 86%;
  }
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item:nth-of-type(3) {
    position: absolute;
    bottom: 72px;
    left: 0;
    z-index: 11;
  }
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item:nth-of-type(3)::after {
    -webkit-clip-path: polygon(100% 100%, 20% 0, 100% 0);
    clip-path: polygon(100% 100%, 20% 0, 100% 0);
    left: 86%;
    top: inherit;
    bottom: -23px;
  }
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item:nth-of-type(4) {
    position: absolute;
    right: 0;
    top: 110px;
  }
}
.p-lead .p-lead__worries .p-lead__worries-item:nth-of-type(4)::after {
  -webkit-clip-path: polygon(0 100%, 80% 0, 80% 100%);
  clip-path: polygon(0 100%, 80% 0, 80% 100%);
  bottom: inherit;
  top: -13px;
  z-index: 11;
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item:nth-of-type(4)::after {
    -webkit-clip-path: polygon(0 100%, 0 0, 80% 0);
    clip-path: polygon(0 100%, 0 0, 80% 0);
    left: 13%;
    top: initial;
    bottom: -23px;
  }
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item:nth-of-type(5) {
    position: absolute;
    bottom: 72px;
    right: 0;
  }
}
.p-lead .p-lead__worries .p-lead__worries-item:nth-of-type(5)::after {
  -webkit-clip-path: polygon(80% 100%, 0 0, 0 100%);
  clip-path: polygon(80% 100%, 0 0, 0 100%);
  bottom: inherit;
  top: -13px;
  z-index: 11;
}
@media screen and (min-width: 821px) {
  .p-lead .p-lead__worries .p-lead__worries-item:nth-of-type(5)::after {
    -webkit-clip-path: polygon(0 100%, 0 0, 80% 0);
    clip-path: polygon(0 100%, 0 0, 80% 0);
    top: initial;
    bottom: -23px;
    left: 13%;
  }
}

.solution-area {
  text-align: center;
  position: relative;
  padding: 55px 0 32px;
  background: url("../img/bg-solution-sp.webp") no-repeat top/cover;
  background-position: bottom;
  z-index: 0;
  margin-top: -54px;
}
@media screen and (min-width: 821px) {
  .solution-area {
    background: url("../img/bg-solution.webp") no-repeat top/cover;
    background-position: bottom;
    margin-top: -120px;
    padding: 136px 0 33px;
  }
}
.solution-area figure {
  width: 20%;
  margin: 0 auto -12px;
}
@media screen and (min-width: 821px) {
  .solution-area figure {
    width: 94px;
  }
}
.solution-area h3 {
  font-size: 30px;
  color: #111f70;
  font-weight: bold;
  line-height: 1.3;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 821px) {
  .solution-area h3 {
    font-size: 45px;
  }
}
.solution-area h3 span {
  font-size: 25px;
  display: block;
}
@media screen and (min-width: 821px) {
  .solution-area h3 span {
    font-size: 40px;
  }
}

.p-staff {
  padding: 88px 0 46px;
}
@media screen and (min-width: 821px) {
  .p-staff {
    padding: 10px 0 70px;
  }
}
.p-staff .p-staff__inner {
  max-width: 1390px;
  margin: 0 auto;
}
@media screen and (min-width: 821px) {
  .p-staff .section-title {
    margin-bottom: 5.8rem;
  }
}

.p-staff__splide {
  position: relative;
  padding-bottom: 4.8rem;
}
.p-staff__splide .splide__list {
  align-items: stretch;
}
.p-staff__splide .splide__slide {
  height: auto;
  padding: 0.8rem 0;
  box-sizing: border-box;
}
.p-staff__splide .p-staff__slide-scale {
  height: 100%;
  transform: scale(0.8);
  transform-origin: center center;
  transition: transform 0.1s ease, opacity 0.1s ease;
  opacity: 0.65;
}
@media screen and (min-width: 821px) {
  .p-staff__splide .p-staff__slide-scale {
    transform: scale(0.85);
  }
}
.p-staff__splide .splide__slide.is-active .p-staff__slide-scale {
  transform: scale(1);
  opacity: 1;
}
.p-staff__splide .p-staff__arrows {
  position: absolute;
  left: 0;
  right: 0;
  top: 38%;
  transform: translateY(-50%);
  pointer-events: none;
  z-index: 5;
}
.p-staff__splide .p-staff__arrows img {
  width: 22px;
  height: 6px;
}
.p-staff__splide .p-staff__arrow {
  pointer-events: auto;
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4.4rem;
  height: 4.4rem;
  border-radius: 50%;
  background: #111f70;
  border: none;
  opacity: 1;
  color: #fff;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(17, 31, 112, 0.25);
  transition: background 0.2s, transform 0.15s;
}
.p-staff__splide .p-staff__arrow:hover {
  background: #15268b;
}
.p-staff__splide .p-staff__arrow:active {
  transform: scale(0.96);
}
.p-staff__splide .p-staff__arrow.p-staff__arrow--prev img {
  transform: scaleX(-1);
}
@media screen and (min-width: 821px) {
  .p-staff__splide .p-staff__arrow--prev {
    left: calc(50% - (100% - 4 * 1.6rem) / 10 - 2.2rem);
  }
  .p-staff__splide .p-staff__arrow--next {
    right: calc(50% - (100% - 4 * 1.6rem) / 10 - 2.2rem);
  }
}
@media screen and (max-width: 820px) {
  .p-staff__splide .p-staff__arrow--prev {
    left: calc(50% - min(42vw, 16rem) - 2.2rem);
  }
  .p-staff__splide .p-staff__arrow--next {
    right: calc(50% - min(42vw, 16rem) - 2.2rem);
  }
}
.p-staff__splide .p-staff__pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.4rem;
  margin: 0;
  padding: 0;
  list-style: none;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
}
.p-staff__splide .p-staff__pagination li {
  margin: 0;
  padding: 0;
}
.p-staff__splide .p-staff__pagination__btn {
  display: block;
  width: 0.8rem;
  height: 0.8rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: #d0d0d0;
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
}
.p-staff__splide .p-staff__pagination__btn:hover {
  background: #a8a8a8;
}
.p-staff__splide .p-staff__pagination__btn.is-active {
  background: #111f70;
  transform: scale(1.15);
}

.c-staff-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  max-width: 100%;
  margin: 0 auto;
  background: #57AFE5;
  border-radius: 20px;
}

.c-staff-card__visual {
  position: relative;
  overflow: hidden;
  background: #fff;
}
.c-staff-card__visual img {
  display: block;
  width: 100%;
}

.c-staff-card__badge {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 90px;
  min-height: 90px;
  padding: 0.4rem;
  border-radius: 50%;
  background: #fff;
  font-family: "Montserrat", sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #0086EA;
  text-align: center;
  line-height: 1.3;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.c-staff-card__name {
  margin: 12px 12px;
  padding: 1rem;
  border-top: none;
  background: #fff;
  font-size: 16px;
  font-weight: 600;
  color: #111f70;
  text-align: center;
  line-height: 1.3;
}
@media screen and (min-width: 821px) {
  .c-staff-card__name {
    font-size: 17px;
    margin: 20px 12px 14px;
  }
}

.c-staff-card__desc {
  margin: 0;
  padding: 0 0 20px;
  font-size: 14px;
  font-weight: 500;
  font-size: 14px;
  line-height: 1.65;
  color: #fff;
  text-align: center;
  letter-spacing: 0.025em;
}

.p-merit {
  padding: 52px 15px;
  background: url("../img/bg-merit-sp.webp") no-repeat center top/cover;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 821px) {
  .p-merit {
    padding: 67px 16px 256px;
    background: url("../img/bg-merit.webp") no-repeat center top/cover;
  }
}
@media screen and (min-width: 821px) {
  .p-merit::before, .p-merit::after {
    content: "";
    display: block;
    width: 100px;
    height: 3000px;
    background: url("../img/deco-merit-pc.webp") no-repeat center top/cover;
    position: absolute;
    top: 30px;
    left: 16px;
    z-index: -1;
  }
}
@media screen and (min-width: 821px) {
  .p-merit::after {
    left: inherit;
    right: 16px;
    transform: rotate(180deg);
  }
}
.p-merit .p-merit__logo {
  width: 200px;
  margin: 0 auto 20px;
}
.p-merit h2 {
  text-align: center;
  font-size: 40px;
  color: #0086EA;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 58px;
  position: relative;
}
@media screen and (min-width: 821px) {
  .p-merit h2 {
    font-size: 52px;
    margin-bottom: 92px;
  }
}
.p-merit h2::before {
  content: "";
  display: block;
  width: 42px;
  height: 7px;
  background: #111F70;
  bottom: -33px;
  left: 50%;
  transform: translateX(-50%);
  position: absolute;
}
@media screen and (min-width: 821px) {
  .p-merit h2::before {
    bottom: -46px;
  }
}
.p-merit h2 span {
  font-size: 27px;
  color: #333;
}
@media screen and (min-width: 821px) {
  .p-merit h2 span {
    font-size: 40px;
    font-weight: 500;
  }
}
.p-merit h2::after {
  content: "";
  display: block;
  width: 45px;
  height: 50px;
  background: url("../img/deco-merit.webp") no-repeat center top/cover;
  margin-left: 8px;
}
@media screen and (min-width: 821px) {
  .p-merit .p-merit__list {
    max-width: 1000px;
    margin: 0 auto;
  }
}
.p-merit .p-merit__list .p-merit__item {
  margin-bottom: 32px;
}
@media screen and (min-width: 821px) {
  .p-merit .p-merit__list .p-merit__item {
    margin-bottom: 38px;
  }
}
.p-merit .p-merit__list .p-merit__item:last-child {
  margin-bottom: 0;
}
.p-merit .p-merit__list .p-merit__item:nth-child(even) figure {
  margin-left: auto;
  margin-right: calc(50% - 50vw);
}
@media screen and (min-width: 821px) {
  .p-merit .p-merit__list .p-merit__item:nth-child(even) figure {
    margin-right: 0;
  }
}
.p-merit .p-merit__list .p-merit__item:nth-child(even) .p-merit__content {
  color: #111f70;
  background: #F0F6FF;
  background: linear-gradient(90deg, rgb(240, 246, 255) 4%, rgb(202, 229, 255) 100%);
}
@media screen and (min-width: 821px) {
  .p-merit .p-merit__list .p-merit__item:nth-child(even) .p-merit__content {
    margin-left: 0;
  }
}
.p-merit .p-merit__list .p-merit__item:nth-child(even) .p-merit__content::before {
  background: url("../img/overlay-merit02-sp.webp") no-repeat center top/cover;
}
.p-merit .p-merit__list .p-merit__item:nth-child(even) .p-merit__content .p-merit__item-number {
  color: rgba(0, 134, 234, 0.2);
}
.p-merit .p-merit__list .p-merit__item figure {
  position: relative;
  z-index: 2;
  margin: 0;
  max-width: 100%;
  margin-left: calc(50% - 50vw);
  width: 325px;
}
@media screen and (min-width: 821px) {
  .p-merit .p-merit__list .p-merit__item figure {
    margin: 0;
    width: 100%;
    max-width: 750px;
  }
}
.p-merit .p-merit__list .p-merit__item .p-merit__item-number {
  font-family: "Jost", sans-serif;
  font-size: 70px;
  font-weight: bold;
  font-style: italic;
  color: rgba(255, 255, 255, 0.2);
  position: absolute;
  top: -28px;
  right: 8px;
  letter-spacing: 0.02em;
  z-index: 10;
}
@media screen and (min-width: 821px) {
  .p-merit .p-merit__list .p-merit__item .p-merit__item-number {
    font-size: 120px;
    top: -50px;
    color: rgba(0, 134, 234, 0.3);
  }
}
.p-merit .p-merit__list .p-merit__item .p-merit__content {
  color: #fff;
  background: #0086EA;
  padding: 13px 23px 20px;
  position: relative;
  margin-top: -18px;
  z-index: 10;
}
@media screen and (min-width: 821px) {
  .p-merit .p-merit__list .p-merit__item .p-merit__content {
    width: 710px;
    margin-left: auto;
    padding: 24px 20px 32px 58px;
    margin-top: -126px;
  }
}
.p-merit .p-merit__list .p-merit__item .p-merit__content::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: url("../img/overlay-merit01-sp.webp") no-repeat center top/cover;
  position: absolute;
  top: -7px;
  left: -7px;
  z-index: 1;
  mix-blend-mode: multiply;
}
.p-merit .p-merit__list .p-merit__item .p-merit__content h3 {
  font-size: 23px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.1em;
  position: relative;
  z-index: 11;
}
@media screen and (min-width: 821px) {
  .p-merit .p-merit__list .p-merit__item .p-merit__content h3 {
    font-size: 30px;
    margin-bottom: 6px;
  }
}
.p-merit .p-merit__list .p-merit__item .p-merit__content p {
  font-size: 14px;
  line-height: 1.9;
  letter-spacing: 0.1em;
  position: relative;
  z-index: 2;
  font-weight: 500;
}
@media screen and (min-width: 821px) {
  .p-merit .p-merit__list .p-merit__item .p-merit__content p {
    font-size: 16px;
  }
}

.p-flow {
  padding: 57px 18px 90px;
  background-position: top;
  position: relative;
  z-index: 1;
  background: rgba(202, 229, 255, 0.3);
  position: relative;
}
@media screen and (min-width: 821px) {
  .p-flow {
    background: url("../img/bg-flow.webp") no-repeat top/cover;
    background-position: bottom;
    padding: 92px 10px 70px;
  }
}
.p-flow::after {
  content: "";
  display: block;
  width: 100%;
  height: 203px;
  background: url("../img/deco-flow-sp.webp") no-repeat center top/cover;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 0;
}
@media screen and (min-width: 821px) {
  .p-flow::after {
    display: none;
  }
}
.p-flow h2 {
  text-align: center;
  font-size: 30px;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 250px;
  height: 56px;
  border-radius: 999px;
  font-weight: bold;
  letter-spacing: 0.1em;
  margin: 0 auto 30px;
  position: absolute;
  top: -30px;
  left: 50%;
  background: url("../img/bg-title.webp") no-repeat center top/cover;
  transform: translateX(-50%);
}
@media screen and (min-width: 821px) {
  .p-flow h2 {
    margin: 0 0 40px 0;
    width: 362px;
    height: 80px;
    font-size: 40px;
    left: 0;
    transform: none;
    top: -128px;
    transform: translateX(-48px);
  }
}
.p-flow h2 span {
  font-size: 15px;
  font-weight: 600;
  font-family: "Montserrat", sans-serif;
  color: #fff;
  position: absolute;
  transform: translateX(-50%);
  left: 50%;
  top: -7px;
}
@media screen and (min-width: 821px) {
  .p-flow h2 span {
    font-size: 20px;
    left: 30%;
  }
}
.p-flow .p-flow__inner {
  margin: 0 auto;
}
@media screen and (min-width: 821px) {
  .p-flow .p-flow__inner {
    max-width: 1000px;
    position: relative;
  }
}
.p-flow .p-flow__subtitle {
  text-align: center;
  color: #0086EA;
  font-weight: 500;
  margin-bottom: 19px;
}
@media screen and (min-width: 821px) {
  .p-flow .p-flow__subtitle {
    display: flex;
    flex-direction: column;
    margin-bottom: 6px;
  }
}
.p-flow .p-flow__subtitle span {
  font-size: 17px;
  display: inline-block;
  background: #fff;
  padding: 7px 15px;
  font-weight: 500;
  margin-bottom: 6px;
}
@media screen and (min-width: 821px) {
  .p-flow .p-flow__subtitle span {
    font-size: 33px;
    padding: 14px 23px;
    margin-bottom: 8px;
    letter-spacing: 0.1em;
  }
}
.p-flow .p-flow__subtitle:last-child {
  margin-bottom: 0;
}
.p-flow strong {
  font-size: 22px;
}

.p-flow__text {
  text-align: center;
  color: #fff;
  font-size: 14px;
  line-height: 1.7857142857;
  margin-bottom: 36px;
}
@media screen and (min-width: 821px) {
  .p-flow__text {
    font-size: 16px;
    margin-bottom: 64px;
  }
}

.p-flow__list {
  position: relative;
}
@media screen and (min-width: 821px) {
  .p-flow__list {
    max-width: 867px;
    margin: 0 auto;
    gap: 38px;
    display: flex;
  }
}
.p-flow__list::before {
  content: "";
  display: block;
  width: 2px;
  height: 105%;
  background: #fff;
  position: absolute;
  transform: translateX(-50%);
  left: 50%;
  top: 0;
  z-index: 1;
}
@media screen and (min-width: 821px) {
  .p-flow__list::before {
    width: 108%;
    height: 2px;
    left: 0;
    transform: translateY(-50%);
    top: 50%;
  }
}
.p-flow__list::after {
  content: "";
  display: block;
  width: 2px;
  height: 20px;
  background: #fff;
  position: absolute;
  bottom: -5.3%;
  left: 52%;
  position: absolute;
  transform: translateX(-50%) rotate(45deg);
  z-index: 1;
}
@media screen and (min-width: 821px) {
  .p-flow__list::after {
    right: -7.4%;
    left: inherit;
    bottom: inherit;
    top: 44%;
    transform: translateX(-50%) rotate(-55deg);
  }
}
.p-flow__list .p-flow__item {
  background: #fff;
  border: 1px solid #111F70;
  border-radius: 20px;
  padding: 30px 18px 18px;
  margin-bottom: 45px;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 821px) {
  .p-flow__list .p-flow__item {
    margin-bottom: 0;
    padding: 42px 18px 28px;
  }
}
.p-flow__list .p-flow__item:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 821px) {
  .p-flow__list .p-flow__item:nth-of-type(3) .p-flow__item-flex figure img {
    margin-top: 13px;
  }
}
@media screen and (min-width: 821px) {
  .p-flow__list .p-flow__item:nth-of-type(4) .p-flow__item-flex figure img {
    margin-top: 13px;
  }
}
.p-flow__list .p-flow__item .p-flow__item-number {
  width: 50px;
  height: 50px;
  position: absolute;
  transform: translateX(-50%);
  left: 50%;
  top: -25px;
}
.p-flow__list .p-flow__item .p-flow__item-flex {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 8px;
}
@media screen and (min-width: 821px) {
  .p-flow__list .p-flow__item .p-flow__item-flex {
    flex-direction: column;
    align-items: center;
    margin-bottom: 14px;
  }
}
.p-flow__list .p-flow__item .p-flow__item-flex figure {
  max-width: 57px;
}
@media screen and (min-width: 821px) {
  .p-flow__list .p-flow__item .p-flow__item-flex figure {
    height: 65px;
  }
}
.p-flow__list .p-flow__item .p-flow__item-flex h3 {
  font-size: 20px;
  color: #0086EA;
}
.p-flow__list .p-flow__item p {
  font-size: 13px;
  line-height: 1.6;
  font-weight: 500;
}

.p-faq {
  background: #f2f2f2;
  padding: 48px 15px 56px;
}
@media screen and (min-width: 821px) {
  .p-faq {
    padding: 70px 10px 80px;
  }
}
.p-faq .section-title {
  margin-bottom: 50px;
  color: #333333;
}
@media screen and (min-width: 821px) {
  .p-faq .section-title {
    margin-bottom: 64px;
  }
}
.p-faq .section-title strong {
  z-index: 1;
  position: relative;
  font-weight: 600;
}
.p-faq .section-title span {
  z-index: 0;
  color: rgba(255, 255, 255, 0.5);
}
.p-faq__inner {
  max-width: 800px;
  margin: 0 auto;
}
.p-faq__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.p-faq__item.is-open .p-faq__icon img {
  transform: rotate(0deg);
}
.p-faq__item .p-faq__icon img {
  transform: rotate(180deg);
}
.p-faq__trigger {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  width: 100%;
  padding: 14px 14px 14px 16px;
  border: none;
  background: #111f70;
  color: #fff;
  font-family: inherit;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.45;
  text-align: left;
  cursor: pointer;
}
@media screen and (min-width: 821px) {
  .p-faq__trigger {
    font-size: 1.8rem;
  }
}
.p-faq__trigger:focus-visible {
  outline: 2px solid #0086EA;
  outline-offset: 2px;
}
.p-faq__q {
  flex-shrink: 0;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
  margin-top: 2px;
}
@media screen and (min-width: 821px) {
  .p-faq__q {
    font-size: 1.8rem;
  }
}
.p-faq__question {
  flex: 1;
  min-width: 0;
  letter-spacing: 0.1em;
}
.p-faq__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-faq__icon img {
  display: block;
  width: 20px;
  height: 20px;
  transition: transform 0.25s ease;
}
@media screen and (min-width: 821px) {
  .p-faq__icon img {
    width: 28px;
    height: 28px;
  }
}
.p-faq__panel {
  border: 1px solid #111f70;
  border-top: none;
  background: #fff;
  overflow: hidden;
}
.p-faq__answer {
  padding: 16px 18px 20px;
  color: #111f70;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.65;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 821px) {
  .p-faq__answer {
    font-size: 1.6rem;
  }
}
.p-faq__answer p {
  margin: 0;
}

.p-reasons {
  padding: 40px 8px 80px;
  background: url("../img/bg-reasons-sp.webp") no-repeat top/cover;
  background-position: bottom;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 821px) {
  .p-reasons {
    padding: 64px 0 130px;
    background: url("../img/bg-reasons.webp") no-repeat top/cover;
    background-position: bottom;
  }
}
.p-reasons__inner {
  margin: 0 auto;
}
.p-reasons__title {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 27px;
  padding: 14px 45px;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: #fff;
  background: #111f70;
  border-radius: 999px;
  position: relative;
}
@media screen and (min-width: 821px) {
  .p-reasons__title {
    font-size: 27px;
  }
}
.p-reasons__title::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -12px;
  transform: translateX(-50%);
  width: 2px;
  height: 16px;
  background: #111f70;
}
@media screen and (min-width: 821px) {
  .p-reasons__title::after {
    bottom: -17px;
    transform: translateX(-50%);
    width: 3px;
    height: 24px;
  }
}
.p-reasons__title::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -12px;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: #111f70;
}
@media screen and (min-width: 821px) {
  .p-reasons__title::before {
    width: 7px;
    height: 7px;
    bottom: -20px;
  }
}
.p-reasons__heading {
  margin: 0 0 38px;
  text-align: center;
  font-weight: 700;
  line-height: 1.35;
  color: #111f70;
}
.p-reasons__heading-line1 {
  display: block;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 821px) {
  .p-reasons__heading-line1 {
    font-size: 35px;
  }
}
.p-reasons__heading-line2 {
  display: inline-block;
  margin-top: -8px;
  padding-bottom: 0px;
  font-size: 43px;
  font-weight: 700;
  border-bottom: 4px solid #111f70;
}
@media screen and (min-width: 821px) {
  .p-reasons__heading-line2 {
    font-size: 64px;
  }
}
.p-reasons__heading-line2 strong {
  font-size: 57px;
  font-weight: 700;
  line-height: 1;
}
@media screen and (min-width: 821px) {
  .p-reasons__heading-line2 strong {
    font-size: 92px;
  }
}
.p-reasons__list {
  margin: 0;
}
.p-reasons__item {
  margin: 0 0 36px;
}
.p-reasons__item:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 821px) {
  .p-reasons__item {
    display: flex;
    align-items: center;
    gap: 40px;
  }
}
@media screen and (min-width: 1600px) {
  .p-reasons__item {
    max-width: 1404px;
    margin: 0 auto;
  }
}
@media screen and (min-width: 821px) {
  .p-reasons__item:nth-child(even) {
    flex-direction: row-reverse;
  }
}
.p-reasons__item:nth-child(even) .p-reasons__item-visual .p-reasons__item-figure {
  margin-right: calc(50% - 50vw);
  margin-left: auto;
}
@media screen and (min-width: 821px) {
  .p-reasons__item:nth-child(even) .p-reasons__item-visual .p-reasons__item-figure {
    margin: 0;
  }
}
@media screen and (min-width: 821px) {
  .p-reasons__item:nth-child(even) .p-reasons__item-body h3::after {
    left: auto;
    right: 0;
  }
}
.p-reasons__item-visual {
  position: relative;
}
@media screen and (min-width: 821px) {
  .p-reasons__item-visual {
    max-width: 650px;
    flex-shrink: 0;
  }
}
.p-reasons__item-visual figcaption {
  font-family: "Montserrat", sans-serif;
  font-size: 60px;
  color: #fff;
  font-weight: 300;
  letter-spacing: 0;
}
@media screen and (min-width: 821px) {
  .p-reasons__item-visual figcaption {
    display: none;
  }
}
.p-reasons__item-figure {
  position: relative;
  z-index: 2;
  margin: 0;
  max-width: 100%;
  margin-left: calc(50% - 50vw);
}
@media screen and (min-width: 821px) {
  .p-reasons__item-figure {
    margin: 0;
  }
}
.p-reasons__item-figure img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 2px;
}
.p-reasons__item-body {
  position: relative;
  margin-top: -29px;
  padding: 0 7px;
}
@media screen and (min-width: 821px) {
  .p-reasons__item-body {
    margin-top: 30px;
    max-width: 675px;
    padding: 0 18px;
  }
}
.p-reasons .p-reasons__item-visual-caption {
  display: none;
}
@media screen and (min-width: 821px) {
  .p-reasons .p-reasons__item-visual-caption {
    color: #fff;
    font-family: "Montserrat", sans-serif;
    font-size: 120px;
    position: absolute;
    top: -54px;
    left: -10px;
    display: block;
    font-weight: 300;
    z-index: 0;
    letter-spacing: 0.025em;
  }
}
.p-reasons__item-body h3, .p-reasons__item-body p, .p-reasons__item-body ul {
  position: relative;
  z-index: 1;
}
.p-reasons__item-body h3 {
  margin: 0 0 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid #333333;
  font-size: 23px;
  font-weight: 700;
  line-height: 1.55;
  color: #333;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 821px) {
  .p-reasons__item-body h3 {
    font-size: 36px;
    border-bottom: none;
    margin: 8px 0 16px;
    padding-bottom: 29px;
  }
  .p-reasons__item-body h3::after {
    content: "";
    display: block;
    width: 200%;
    height: 1px;
    background: #333333;
    margin-top: 16px;
    position: absolute;
    left: 0;
    bottom: 0;
  }
}
.p-reasons__item-title-accent {
  color: #0086EA;
  font-weight: 700;
}
.p-reasons__item-body p {
  margin: 0 0 20px;
  font-size: 14px;
  line-height: 1.75;
  color: #4d4d4d;
  letter-spacing: 0.1em;
  font-weight: 500;
}
@media screen and (min-width: 821px) {
  .p-reasons__item-body p {
    font-size: 16px;
    margin: 0 0 30px;
  }
}
.p-reasons__item-body ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
}
@media screen and (min-width: 821px) {
  .p-reasons__item-body ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
}
.p-reasons__item-body li {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 23px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.45;
  color: #0086EA;
  background: #fff;
  border: 1px solid #B3B3B3;
  border-radius: 999px;
  letter-spacing: 0.025em;
}
@media screen and (min-width: 821px) {
  .p-reasons__item-body li {
    font-size: 13px;
    padding: 8px 16px;
    gap: 5px;
    letter-spacing: 0em;
  }
}
@media screen and (min-width: 1350px) {
  .p-reasons__item-body li {
    font-size: 16px;
  }
}
.p-reasons__item-body li::before {
  content: "";
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  background: url("../img/icon-check-blue.svg") no-repeat center/contain;
}
@media screen and (min-width: 821px) {
  .p-reasons__item-body li::before {
    width: 18px;
    height: 18px;
  }
}
@media screen and (max-width: 1260px) {
  .p-reasons .break-line {
    display: none;
  }
}

.p-data {
  background: url("../img/bg-data-sp.webp") no-repeat top/cover;
  background-position: bottom;
  padding: 83px 18px 100px;
  position: relative;
  z-index: 0;
  margin-top: -64px;
}
@media screen and (min-width: 821px) {
  .p-data {
    background: url("../img/bg-data.webp") no-repeat top/cover;
    background-position: bottom;
    margin-top: -100px;
    padding: 123px 15px 28px;
  }
}
.p-data h2 {
  text-align: center;
  color: #fff;
  font-size: 26px;
  line-height: 1.4;
  margin-bottom: 23px;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 821px) {
  .p-data h2 {
    font-size: 40px;
    margin-bottom: 35px;
  }
}
.p-data h2 span {
  font-size: 36px;
}
@media screen and (min-width: 821px) {
  .p-data h2 span {
    font-size: 50px;
  }
}
.p-data__list {
  display: flex;
  flex-direction: column;
  gap: 26px;
}
@media screen and (min-width: 821px) {
  .p-data__list {
    flex-direction: row;
    gap: 20px;
    max-width: 1000px;
    margin: 0 auto;
  }
}
.p-data__list h3 {
  color: #fff;
  background: #111f70;
  padding: 12px 10px;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
  border-radius: 999px;
  text-align: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  font-size: 17px;
  width: fit-content;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  width: 277px;
}
@media screen and (min-width: 821px) {
  .p-data__list h3 {
    font-size: 20px;
  }
}
.p-data__list h3:after {
  content: "";
  display: block;
  -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 17px;
  height: 17px;
  background: #111f70;
  position: absolute;
  left: 50%;
  bottom: -12px;
  transform: translateX(-50%);
}
.p-data__list figure {
  margin-top: -21px;
  position: relative;
  z-index: 0;
}
@media screen and (min-width: 821px) {
  .p-data__list figure {
    margin-top: -15px;
  }
}
.p-data .p-data__text {
  text-align: center;
  color: rgba(255, 255, 255, 0.5);
  font-size: 86px;
  position: absolute;
  bottom: -13px;
  left: 50%;
  transform: translateX(-50%);
  font-weight: 300;
  line-height: 1;
  font-family: "Montserrat", sans-serif;
}
@media screen and (min-width: 821px) {
  .p-data .p-data__text {
    font-size: 86px;
    left: -9px;
    bottom: inherit;
    top: 50%;
    transform: translateY(-50%);
    writing-mode: vertical-rl;
  }
}
@media screen and (min-width: 821px) {
  .p-data .p-data__text:nth-child(2) {
    left: inherit;
    right: -9px;
    transform: translateY(-50%) rotate(180deg);
  }
}
.p-data .p-data__annotation {
  text-align: center;
  color: #fff;
  font-size: 13px;
  margin-top: 16px;
}
@media screen and (min-width: 821px) {
  .p-data .p-data__annotation {
    text-align: right;
    margin-top: 30px;
  }
}

.p-career {
  position: relative;
}
@media screen and (min-width: 821px) {
  .p-career {
    padding-bottom: 78px;
  }
}
.p-career .p-career__content {
  background: #F0F6FF;
  background: linear-gradient(136deg, rgb(240, 246, 255) 0%, rgb(202, 229, 255) 100%);
  padding: 42px 15px 100px;
}
@media screen and (min-width: 821px) {
  .p-career .p-career__content {
    background: none;
    padding: 62px 10px 0;
  }
}
.p-career .p-career__content h2 {
  text-align: center;
  font-size: 26px;
  font-weight: bold;
  line-height: 1.3461538462;
  margin-bottom: 24px;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 821px) {
  .p-career .p-career__content h2 {
    font-size: 40px;
    margin-bottom: 40px;
  }
}
.p-career .p-career__content h2 span {
  color: #E2426C;
}
@media screen and (min-width: 821px) {
  .p-career .p-career__content h2 span {
    font-size: 45px;
  }
}
@media screen and (min-width: 821px) {
  .p-career .p-career__content .p-career__image {
    max-width: 1000px;
    margin: 0 auto;
    background: linear-gradient(136deg, rgb(240, 246, 255) 0%, rgb(202, 229, 255) 100%);
    padding: 65px 0 160px;
    position: relative;
    z-index: 1;
  }
}
.p-career .p-career__content figure {
  width: 260px;
  margin: 0 auto;
}
@media screen and (min-width: 821px) {
  .p-career .p-career__content figure {
    width: 874px;
    margin: 0 auto;
  }
}
.p-career .p-career__list {
  padding: 0 16px;
  margin-top: -63px;
  position: relative;
  z-index: 11;
}
@media screen and (min-width: 821px) {
  .p-career .p-career__list {
    max-width: 870px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    margin: -106px auto 0;
    padding: 0;
  }
}
.p-career .p-career__list .p-career__item {
  position: relative;
  padding: 12px 13px;
  border: 1px solid #B3B3B3;
  margin-bottom: 15px;
  background: #fff;
}
@media screen and (min-width: 821px) {
  .p-career .p-career__list .p-career__item {
    margin-bottom: 0;
    padding: 18px 23px;
  }
}
.p-career .p-career__list .p-career__item:last-child {
  margin-bottom: 0;
}
.p-career .p-career__list .p-career__item .p-career__item-number {
  font-size: 15px;
  width: 30px;
  height: 30px;
  background: #0086EA;
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: -6px;
  left: -6px;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 821px) {
  .p-career .p-career__list .p-career__item .p-career__item-number {
    font-size: 19px;
    width: 38px;
    height: 38px;
  }
}
.p-career .p-career__list .p-career__item h3 {
  font-size: 16px;
  color: #0086EA;
  font-weight: bold;
  margin-bottom: 15px;
  text-align: center;
}
@media screen and (min-width: 821px) {
  .p-career .p-career__list .p-career__item h3 {
    font-size: 20px;
  }
}
.p-career .p-career__list .p-career__item p {
  font-size: 14px;
  text-align: left;
  line-height: 1.8;
  font-weight: 500;
  color: #808080;
}
.p-career .p-career__text {
  font-size: 86px;
  font-family: "Montserrat", sans-serif;
  writing-mode: vertical-rl;
  position: absolute;
  left: -15px;
  top: 0;
  color: rgb(204, 204, 204);
  font-weight: bold;
  mix-blend-mode: overlay;
}
@media screen and (min-width: 821px) {
  .p-career .p-career__text {
    font-size: 125px;
    left: 50%;
    transform: translateX(-50%);
    top: 138px;
    writing-mode: initial;
    width: 100%;
    text-align: center;
    color: rgba(204, 204, 204, 0.3);
  }
}

.p-usecases {
  padding: 48px 16px 40px;
  background: url("../img/bg-usecase-sp.webp") no-repeat center top/cover;
  background-position: bottom;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 821px) {
  .p-usecases {
    padding: 90px 16px 60px;
    background: url("../img/bg-usecase.webp") no-repeat center top/cover;
    background-position: bottom;
  }
}
.p-usecases .p-usecases__inner {
  max-width: 1200px;
  margin: 0 auto;
}
.p-usecases .section-title {
  color: #333;
  margin-bottom: 30px;
}
@media screen and (min-width: 821px) {
  .p-usecases .section-title {
    margin-bottom: 50px;
  }
}
.p-usecases .section-title span {
  font-size: 58px;
  color: #fff;
}
@media screen and (min-width: 821px) {
  .p-usecases .section-title span {
    font-size: 135px;
  }
}
.p-usecases .p-usecases__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin: 0 0 24px;
  padding: 0;
  list-style: none;
}
@media screen and (min-width: 821px) {
  .p-usecases .p-usecases__list {
    grid-template-columns: repeat(4, 1fr);
    max-width: 800px;
    margin: 0 auto 48px;
  }
}
.p-usecases .p-usecases__item {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 6rem;
  margin: 0;
  padding: 1.2rem 1rem;
  border: 1px solid #b3b3b3;
  background: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
  color: #000;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 821px) {
  .p-usecases .p-usecases__item {
    padding: 2.14rem 1rem;
    font-size: 1.8rem;
  }
}
.p-usecases .p-usecases__item:nth-child(1) {
  color: #EA8A42;
}
.p-usecases .p-usecases__item:nth-child(2) {
  color: #2BB6CC;
}
.p-usecases .p-usecases__item:nth-child(3) {
  color: #35769E;
}
.p-usecases .p-usecases__item:nth-child(4) {
  color: #1DBFA0;
}
.p-usecases .p-usecases__item:nth-child(5) {
  color: #5168A8;
}
.p-usecases .p-usecases__item:nth-child(6) {
  color: #D1B026;
}
.p-usecases .p-usecases__item:nth-child(7) {
  color: #34ADE2;
}
.p-usecases .p-usecases__item:nth-child(8) {
  color: #EA6060;
}
.p-usecases .p-usecases__item:nth-child(9) {
  color: #E2609B;
}
.p-usecases .p-usecases__item:nth-child(10) {
  color: #9E664F;
}
.p-usecases .p-usecases__item:nth-child(11) {
  color: #605F5E;
}
.p-usecases .p-usecases__item:nth-child(12) {
  color: #9B5EAA;
}
@media screen and (min-width: 821px) {
  .p-usecases figure {
    max-width: 778px;
    margin: 0 auto;
  }
}

.bg {
  background: url("../img/bg-voice-sp.webp") no-repeat top/cover;
  background-position: top;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 821px) {
  .bg {
    background: url("../img/bg-voice.webp") no-repeat top/cover;
    background-position: top;
    margin-top: -204px;
  }
}

.p-voice {
  padding: 80px 15px 90px;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 821px) {
  .p-voice {
    padding: 95px 15px 116px;
  }
}
.p-voice .p-voice__inner {
  max-width: 1000px;
  margin: 0 auto;
}
.p-voice h2 {
  text-align: center;
  font-size: 30px;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 250px;
  height: 56px;
  border-radius: 999px;
  background: url("../img/bg-title.webp") no-repeat center top/cover;
  font-weight: bold;
  letter-spacing: 0.1em;
  margin: 0 auto 30px;
  position: relative;
}
@media screen and (min-width: 821px) {
  .p-voice h2 {
    margin: 0 0 53px 0;
    width: 362px;
    height: 80px;
    font-size: 40px;
    transform: translateX(-48px);
  }
}
.p-voice h2 span {
  font-size: 15px;
  font-weight: 600;
  font-family: "Montserrat", sans-serif;
  color: #fff;
  position: absolute;
  transform: translateX(-50%);
  left: 50%;
  top: -7px;
}
@media screen and (min-width: 821px) {
  .p-voice h2 span {
    font-size: 20px;
    left: 30%;
  }
}
@media screen and (min-width: 821px) {
  .p-voice .p-voice__list {
    display: flex;
    gap: 20px;
  }
}
.p-voice .p-voice__item {
  margin-bottom: 30px;
  background: #fff;
  padding: 25px 23px 19px;
  position: relative;
}
@media screen and (min-width: 821px) {
  .p-voice .p-voice__item {
    margin-bottom: 0;
    padding: 31px 38px 24px;
    width: 490px;
  }
}
.p-voice .p-voice__item:last-child {
  margin-bottom: 0;
}
.p-voice .p-voice__item .p-voice__item-number {
  position: absolute;
  top: 25px;
  left: 10px;
  color: #0086EA;
  font-size: 10px;
  font-weight: bold;
  font-family: "Montserrat", sans-serif;
  writing-mode: vertical-rl;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 821px) {
  .p-voice .p-voice__item .p-voice__item-number {
    top: 30px;
  }
}
.p-voice .p-voice__item .p-voice__item-number::after {
  content: "";
  display: block;
  width: 1px;
  height: 40px;
  background: #0086EA;
}
.p-voice .p-voice__item figure {
  margin-bottom: 16px;
}
@media screen and (min-width: 821px) {
  .p-voice .p-voice__item figure {
    margin-bottom: 18px;
  }
  .p-voice .p-voice__item figure img {
    height: 228px;
    -o-object-fit: cover;
    object-fit: cover;
    width: auto;
  }
}
.p-voice .p-voice__item h3 {
  color: #0086EA;
  font-weight: 600;
  margin-bottom: 12px;
  letter-spacing: 0.06em;
}
@media screen and (min-width: 821px) {
  .p-voice .p-voice__item h3 {
    margin-bottom: 10px;
    font-size: 1.8rem;
  }
}
.p-voice .p-voice__item p {
  font-size: 14px;
  line-height: 1.7857142857;
  letter-spacing: 0.1em;
  font-weight: 500;
}
@media screen and (min-width: 821px) {
  .p-voice .p-voice__item p {
    letter-spacing: 0.025em;
  }
}

.p-compliance {
  background: url("../img/bg-compliance-sp.webp") no-repeat center top/cover;
  position: relative;
  z-index: 1;
  padding: 48px 15px 192px;
}
@media screen and (min-width: 821px) {
  .p-compliance {
    padding: 82px 15px 69px;
    background: url("../img/bg-compliance.webp") no-repeat center top/cover;
  }
}
@media screen and (min-width: 821px) {
  .p-compliance .p-compliance__inner {
    max-width: 1000px;
    margin: 0 auto;
    position: relative;
  }
}
.p-compliance .p-compliance__title {
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-size: 54px;
  font-weight: 300;
  letter-spacing: 0.025em;
  position: absolute;
  transform: translateX(-50%);
  left: 50%;
  top: -8px;
  mix-blend-mode: overlay;
  z-index: 10;
}
@media screen and (min-width: 821px) {
  .p-compliance .p-compliance__title {
    font-size: 111px;
    left: 0;
    transform: none;
    top: -7%;
    z-index: -1;
    color: rgba(255, 255, 255, 0.5);
  }
}
.p-compliance h2 {
  text-align: center;
  color: #fff;
  font-size: 27px;
  margin-bottom: 20px;
}
@media screen and (min-width: 821px) {
  .p-compliance h2 {
    font-size: 45px;
    text-align: left;
  }
}
.p-compliance h3 {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 12px;
  align-items: flex-start;
}
@media screen and (min-width: 821px) {
  .p-compliance h3 {
    gap: 8px;
  }
}
.p-compliance h3 span {
  background: #111f70;
  color: #fff;
  display: inline-block;
  padding: 4px 10px;
}
@media screen and (min-width: 821px) {
  .p-compliance h3 span {
    font-size: 23px;
    padding: 10px 12px;
  }
}
.p-compliance p {
  color: #fff;
  font-size: 13px;
  line-height: 1.6;
  margin-bottom: 20px;
}
@media screen and (min-width: 821px) {
  .p-compliance p {
    font-size: 16px;
    margin-bottom: 32px;
  }
}
.p-compliance .p-compliance__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  max-width: 305px;
  margin: 0 auto;
}
@media screen and (min-width: 821px) {
  .p-compliance .p-compliance__list {
    max-width: 1000px;
    grid-template-columns: repeat(4, 1fr);
    position: relative;
    z-index: 10;
  }
}
.p-compliance .p-compliance__list .p-compliance__item {
  background: #fff;
  width: 145px;
  height: 145px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 12px;
}
@media screen and (min-width: 821px) {
  .p-compliance .p-compliance__list .p-compliance__item {
    width: 223px;
    height: 223px;
  }
}
.p-compliance .p-compliance__list .p-compliance__item figure {
  height: 68px;
  display: flex;
  align-items: flex-start;
}
@media screen and (min-width: 821px) {
  .p-compliance .p-compliance__list .p-compliance__item figure {
    height: 110px;
  }
}
.p-compliance .p-compliance__list .p-compliance__item figure img {
  width: auto;
  height: 55px;
}
@media screen and (min-width: 821px) {
  .p-compliance .p-compliance__list .p-compliance__item figure img {
    height: 88px;
  }
}
.p-compliance .p-compliance__list .p-compliance__item h4 {
  color: #0086EA;
  text-align: center;
  font-size: 16px;
  font-weight: 600;
}
@media screen and (min-width: 821px) {
  .p-compliance .p-compliance__list .p-compliance__item h4 {
    font-size: 22px;
  }
}
.p-compliance .p-compliance__list .p-compliance__item:nth-child(3) figure img {
  height: 68px;
}
@media screen and (min-width: 821px) {
  .p-compliance .p-compliance__list .p-compliance__item:nth-child(3) figure img {
    height: 110px;
  }
}
.p-compliance .p-compliance__list .p-compliance__item:nth-child(4) figure img {
  height: 68px;
}
@media screen and (min-width: 821px) {
  .p-compliance .p-compliance__list .p-compliance__item:nth-child(4) figure img {
    height: 110px;
  }
}
.p-compliance .p-compliance__image {
  width: 306px;
  height: 222px;
  position: absolute;
  transform: translateX(-50%);
  left: 50%;
  bottom: 0;
}
@media screen and (min-width: 821px) {
  .p-compliance .p-compliance__image {
    width: 383px;
    height: 297px;
    left: inherit;
    transform: none;
    right: 54px;
    top: 0%;
    bottom: inherit;
  }
}

.p-form {
  padding: 58px 0 0;
}
@media screen and (min-width: 821px) {
  .p-form {
    padding: 82px 0;
  }
}
.p-form .section-title {
  margin-bottom: 32px;
  color: #333;
}
@media screen and (min-width: 821px) {
  .p-form .section-title {
    margin-bottom: 50px;
  }
}
.p-form .section-title span {
  font-size: 75px;
  color: rgba(0, 134, 234, 0.1);
}
@media screen and (min-width: 821px) {
  .p-form .section-title span {
    font-size: 135px;
  }
}
.p-form p {
  font-size: 1.4rem;
  line-height: 1.6;
  margin-bottom: 53px;
  text-align: center;
}
@media screen and (min-width: 821px) {
  .p-form p {
    font-size: 16px;
    margin-bottom: 39px;
  }
}
.p-form__tab-bar {
  display: flex;
  align-items: flex-end;
  padding: 0 17px;
  gap: 10px;
}
@media screen and (min-width: 821px) {
  .p-form__tab-bar {
    width: 573px;
    margin: 0 auto;
    justify-content: center;
    padding: 0;
    gap: 30px;
  }
}
.p-form__tab-btn {
  width: 43%;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px 18px 0 0;
  gap: 7px;
  padding: 8px 4px 10px;
  border: none;
  font-family: inherit;
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.35;
  text-align: center;
  cursor: pointer;
  color: #fff;
  letter-spacing: 0.1em;
  transition: padding 0.2s ease, font-size 0.2s ease, color 0.2s ease, width 0.2s ease;
}
@media screen and (min-width: 821px) {
  .p-form__tab-btn {
    width: 245px;
    padding: 14px 8px;
    font-size: 1.6rem;
  }
}
.p-form__tab-btn--document {
  background: #ec407a;
}
.p-form__tab-btn--document.is-active {
  padding: 20px 13px 20px !important;
}
@media screen and (min-width: 821px) {
  .p-form__tab-btn--document.is-active {
    padding: 20px 12px 20px !important;
  }
}
.p-form__tab-btn--document img {
  width: 13px !important;
}
@media screen and (min-width: 821px) {
  .p-form__tab-btn--document img {
    width: 20px !important;
  }
}
.p-form__tab-btn--contact {
  background: #111f70;
}
.p-form__tab-btn--contact img {
  width: 20px !important;
}
@media screen and (min-width: 821px) {
  .p-form__tab-btn--contact img {
    width: 24px !important;
  }
}
.p-form__tab-btn.is-active {
  padding: 14px 8px 14px;
  font-size: 1.6rem;
  color: #fff;
  width: 54%;
}
@media screen and (min-width: 821px) {
  .p-form__tab-btn.is-active {
    width: 300px;
    padding: 20px 12px;
    font-size: 19px;
  }
}
.p-form__tab-icon {
  display: block;
  width: 22px;
  height: 22px;
  fill: currentColor;
}
.p-form__inner {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 15px;
  background: #fff;
  border: 3px solid #f2f2f2;
}
@media screen and (min-width: 821px) {
  .p-form__inner {
    padding: 0 50px;
  }
}
.p-form__panel {
  padding: 32px 0 50px;
}
@media screen and (min-width: 821px) {
  .p-form__panel {
    padding: 48px 0 0px;
  }
}
.p-form__panel[hidden] {
  display: none;
}
.p-form__panel#form-panel-document iframe {
  height: 1251px;
}
@media screen and (min-width: 821px) {
  .p-form__panel#form-panel-document iframe {
    height: 1200px;
  }
}
.p-form__panel#form-panel-contact iframe {
  height: 1671px;
}
@media screen and (min-width: 821px) {
  .p-form__panel#form-panel-contact iframe {
    height: 1570px;
  }
}
.p-form__heading {
  font-size: 2.3rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 28px;
}
@media screen and (min-width: 821px) {
  .p-form__heading {
    font-size: 3rem;
    margin-bottom: 20px;
  }
}
.p-form__field-row {
  display: grid;
  gap: 0 20px;
  grid-template-columns: 1fr;
}
@media screen and (min-width: 821px) {
  .p-form__field-row {
    grid-template-columns: 1fr 1fr;
  }
}
.p-form__field {
  margin-bottom: 18px;
}
.p-form__label {
  display: block;
  font-size: 1.6rem;
  font-weight: 600;
  color: #333;
  margin-bottom: 8px;
}
@media screen and (min-width: 821px) {
  .p-form__label {
    font-size: 2rem;
    margin-bottom: 10px;
  }
}
.p-form__required {
  color: #E2426C;
  margin-left: 2px;
  font-weight: 700;
}
.p-form__input, .p-form__select, .p-form__textarea {
  display: block;
  width: 100%;
  padding: 13px 14px;
  border: 1px solid #B3B3B3;
  font-family: inherit;
  font-size: 1.6rem;
  color: #333;
  background: #fff;
  box-sizing: border-box;
  -moz-appearance: none;
  appearance: none;
  -webkit-appearance: none;
}
.p-form__input::-moz-placeholder, .p-form__select::-moz-placeholder, .p-form__textarea::-moz-placeholder {
  color: #aaa;
  font-size: 1.4rem;
}
.p-form__input::placeholder, .p-form__select::placeholder, .p-form__textarea::placeholder {
  color: #aaa;
  font-size: 1.4rem;
}
.p-form__input:focus, .p-form__select:focus, .p-form__textarea:focus {
  outline: 2px solid #0086EA;
  outline-offset: 0;
  border-color: #0086EA;
}
.p-form__select-wrap {
  position: relative;
}
.p-form__select-wrap::after {
  content: "";
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid #888;
  pointer-events: none;
}
.p-form__select {
  padding-right: 36px;
  cursor: pointer;
}
.p-form__textarea {
  resize: vertical;
  min-height: 120px;
  line-height: 1.6;
}
@media screen and (min-width: 821px) {
  .p-form__textarea {
    min-height: 175px;
  }
}
.p-form__privacy {
  margin: 28px 0 0;
}
.p-form__privacy-heading {
  display: block;
  font-size: 1.4rem;
  color: #333;
  margin-bottom: 8px;
}
@media screen and (min-width: 821px) {
  .p-form__privacy-heading {
    font-size: 2rem;
    margin-bottom: 10px;
  }
}
.p-form__privacy-body {
  border: 1px solid #ccc;
  border-radius: 4px;
  max-height: 160px;
  overflow-y: auto;
  padding: 14px 16px;
  font-size: 1.3rem;
  color: #333;
  line-height: 1.75;
  background: #fff;
}
.p-form__privacy-body p {
  margin: 0 0 10px;
  text-align: left;
}
.p-form__privacy-body p:last-child {
  margin-bottom: 0;
}
.p-form__privacy-body h4 {
  font-size: 1.3rem;
  font-weight: 700;
  margin: 12px 0 4px;
}
@media screen and (min-width: 821px) {
  .p-form__privacy-body h4 {
    font-size: 1.6rem;
  }
}
.p-form__privacy-body h4:first-child {
  margin-top: 0;
}
.p-form__privacy-agree {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 0;
  font-size: 1.6rem;
  font-weight: 600;
  color: #0086EA;
  cursor: pointer;
}
@media screen and (min-width: 821px) {
  .p-form__privacy-agree {
    font-size: 1.8rem;
    justify-content: center;
    padding: 20px 0 40px;
  }
}
.p-form__privacy-agree input[type=checkbox] {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  accent-color: #0086EA;
  cursor: pointer;
}
.p-form__submit {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  gap: 8px;
  width: 100%;
  margin-top: 8px;
  padding: 16px;
  border: none;
  border-radius: 999px;
  background: #0086EA;
  color: #fff;
  font-family: inherit;
  font-size: 1.7rem;
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.2s;
  width: 315px;
  margin: 10px auto 0;
}
@media screen and (min-width: 821px) {
  .p-form__submit {
    font-size: 2rem;
  }
}
.p-form__submit:hover {
  opacity: 0.9;
}
.p-form__submit:active {
  opacity: 0.85;
}
.p-form__submit-icon {
  display: block;
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
}

.p-thanks {
  padding: 100px 20px 80px;
  min-height: 50vh;
}
@media screen and (min-width: 821px) {
  .p-thanks {
    padding: 140px 40px 120px;
  }
}
.p-thanks__inner {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.p-thanks__title {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.45;
  color: #0086EA;
  margin-bottom: 2.4rem;
  letter-spacing: 0.06em;
}
@media screen and (min-width: 821px) {
  .p-thanks__title {
    font-size: 2.8rem;
    margin-bottom: 3.2rem;
  }
}
.p-thanks__text {
  font-size: 1.5rem;
  line-height: 1.85;
  color: #333;
  margin-bottom: 3.6rem;
  text-align: left;
}
@media screen and (min-width: 821px) {
  .p-thanks__text {
    font-size: 1.6rem;
    text-align: center;
    margin-bottom: 4rem;
  }
}
.p-thanks__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.6rem;
}
@media screen and (min-width: 821px) {
  .p-thanks__actions {
    flex-direction: row;
    justify-content: center;
    gap: 2rem;
  }
}
.p-thanks__btn {
  min-width: 22rem;
  padding: 1.2rem 2.4rem;
  font-size: 1.5rem;
  border-radius: 4px;
  text-decoration: none;
}
@media screen and (min-width: 821px) {
  .p-thanks__btn {
    min-width: 24rem;
    font-size: 1.6rem;
  }
}

.footer {
  background: #111f70;
  color: #fff;
  margin-bottom: 75px;
}
.footer__inner {
  padding: 45px 0 0;
  position: relative;
}
.footer .footer__address {
  text-align: center;
  font-size: 1.3rem;
  line-height: 1.8461538462;
  margin-bottom: 20px;
}
@media screen and (min-width: 821px) {
  .footer .footer__address {
    margin-bottom: 30px;
  }
}
.footer__logo {
  width: 300px;
  margin: 0 auto 20px;
}
@media screen and (min-width: 821px) {
  .footer__logo {
    width: 420px;
  }
}
.footer .footer__btn {
  width: 170px;
  margin: 0 auto 20px;
  display: block;
}
@media screen and (min-width: 821px) {
  .footer .footer__btn {
    margin: 0 auto 40px;
  }
}
.footer__nav {
  margin: 0;
}
.footer__nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1em 1.5em;
  padding: 0 86px;
  margin-bottom: 30px;
}
@media screen and (min-width: 821px) {
  .footer__nav-list {
    display: block;
    position: absolute;
    right: 0;
    top: 46%;
    transform: translateY(-50%);
  }
}
.footer__nav-item--full {
  grid-column: 1/-1;
}
.footer__nav-item {
  text-align: center;
}
@media screen and (min-width: 821px) {
  .footer__nav-item {
    text-align: right;
    margin-bottom: 20px;
  }
}
.footer__nav-link {
  color: inherit;
  font-size: 1.4rem;
  font-weight: 500;
  text-decoration: none;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 821px) {
  .footer__nav-link {
    font-size: 1.6rem;
  }
}
.footer__nav-link:hover {
  opacity: 0.85;
}
.footer__nav-link:focus-visible {
  outline: 2px solid #0086EA;
  outline-offset: 2px;
}
.footer .footer__copyright {
  text-align: center;
  color: #fff;
  font-size: 1.2rem;
  padding: 14px 0;
  border-top: 1px solid #fff;
}

.u-sp-only {
  display: block !important;
}
@media screen and (min-width: 821px) {
  .u-sp-only {
    display: none !important;
  }
}

.u-pc-only {
  display: none !important;
}
@media screen and (min-width: 821px) {
  .u-pc-only {
    display: block !important;
  }
}
/*# sourceMappingURL=style.css.map */