@charset "UTF-8";

/* ==========================================================================
    lp style
============================================================================= */
main {
  background: url(../img_lp/failproof_app/body_bg.svg) repeat 0 0 / 100% auto;
}

/* ---------------------------------
  main visual
--------------------------------- */
.p-mv {
  overflow: hidden;
  -webkit-padding-before: 30px;
  padding-block-start: 30px;
  position: relative;
}

.p-mv::before {
  content: "";
  background: url("../img_lp/failproof_app/mv_bg.svg") no-repeat center 0 / contain;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 76.388%;
  height: 100%;
}

.p-mv .l-container {
  position: relative;
  z-index: 1;
}

.p-mv__liner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font: italic bold clamp(10rem, 18.75vw, 27rem) var(--font-3);
  position: absolute;
  top: 0;
  white-space: nowrap;
}

.p-mv__liner p {
  background: var(--gradient-color-1);
  background-clip: text;
  flex: 0 0 auto;
  font: italic bold clamp(10rem, 18.75vw, 27rem) var(--font-3);
  letter-spacing: 0.05em;
  padding-inline: .25em;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-transform: uppercase;
  white-space: nowrap;
}

.p-mv__liner.left {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  -webkit-transform-origin: left top;
  transform-origin: left top;
  left: calc(1em - 20px);
}

.p-mv__liner.right {
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
  -webkit-transform-origin: right top;
  transform-origin: right top;
  right: calc(1em - 20px);
}

.p-mv__liner.left p {
  animation: mv-loop-left 120s linear infinite reverse
}

.p-mv__liner.right p {
  animation: mv-loop-right 120s linear infinite reverse
}

.p-mv__inner {
  margin-inline: auto;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.p-mv__sub {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
  gap: 10px;
  position: absolute;
  left: -6.11vw;
  top: 0;
}

.p-mv__sub mark {
  background: inherit;
  display: inline-block;
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.1;
  overflow: hidden;
  padding: 10px 11px;
  position: relative;
}

.p-mv__sub mark::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
}

.p-mv__sub mark span {
  position: relative;
  z-index: 2;
}

.p-mv__sub.is-active mark::before {
  -webkit-animation: slide-in-left 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
  animation: slide-in-left 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
  background-color: #acffaa;
}

.p-mv__title {
  -webkit-animation-delay: 2s;
  animation-delay: 2s;
  font-size: clamp(6.5rem, 6.25vw, 9rem);
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1.3;
  margin-block: 52px 80px;
  -webkit-padding-before: 158px;
  padding-block-start: 158px;
  text-align: center;
}

.p-mv__txt {
  -webkit-animation-delay: 3s;
  animation-delay: 3s;
  color: var(--color-gray);
  font-size: 2rem;
  letter-spacing: 0.2em;
  line-height: 2;
  -webkit-margin-after: 97px;
  margin-block-end: 97px;
  text-align: center;
}

.p-mv__img {
  position: relative;
  z-index: 1;
}

.p-mv__img::before {
  background: url("../img_lp/failproof_app/mv_img_bg.svg") no-repeat center 0 / 100% auto;
  content: "";
  height: 48.6111vw;
  position: absolute;
  top: -5vw;
  width: 100%;
}

.p-mv__img--list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[3];
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 3.47222vw, 50px);
  max-width: 730px;
  margin-inline: auto;
  position: relative;
  z-index: 10;
}

.p-mv__img--list>li {
  aspect-ratio: 1;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(51%, #f78922), to(#f7db4d));
  background: -webkit-linear-gradient(top, #f78922 51%, #f7db4d 100%);
  background: linear-gradient(180deg, #f78922 51%, #f7db4d 100%);
  border: solid 2px #fff;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-weight: bold;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  color: #fff;
  width: 100%;
  height: 100%;
  position: relative;
}

.p-mv__img--list>li::before {
  content: "";
  background: url("../img_lp/failproof_app/mv_list_bg.svg") no-repeat center/100% auto;
  width: 90.47619%;
  height: 90.47619%;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.p-mv__img--list>li:nth-child(even) {
  -webkit-margin-before: -26px;
  margin-block-start: -26px;
}

.p-mv__img--list>li .sub {
  font-size: 2rem;
  letter-spacing: 0.05em;
}

.p-mv__img--list>li strong {
  font-size: clamp(3rem, 2.3611vw, 3.4rem);
  letter-spacing: 0.05em;
}

.p-mv__img--list>li strong.lspace-0 {
  letter-spacing: 0;
}

.p-mv__img--list>li b {
  font-family: var(--font-3);
  font-size: clamp(4rem, 3.333vw, 4.8rem);
}

.p-mv__img--mask {
  -webkit-mask-image: url("../img_lp/failproof_app/mv_mask.svg");
  mask-image: url("../img_lp/failproof_app/mv_mask.svg");
  -webkit-mask-size: cover;
  mask-size: cover;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-margin-after: -116px;
  margin-block-end: -116px;
  -webkit-transform: translateY(-116px);
  transform: translateY(-116px);
  position: relative;
  z-index: 1;
}

.p-mv__img--mask img {
  width: 100%;
}

.p-mv+.p-contact {
  -webkit-margin-after: -11.805vw;
  margin-block-end: -11.805vw;
  position: relative;
  -webkit-transform: translateY(-11.805vw);
  transform: translateY(-11.805vw);
  z-index: 1;
}

@media screen and (min-width: 768px) {
  .p-mv__img--list>li {
    opacity: 0;
  }

  .p-mv__img--list.is-active>li {
    -webkit-animation: fade-in 0.8s 1 forwards;
    animation: fade-in 0.8s 1 forwards;
  }

  .p-mv__img--list.is-active>li:nth-child(1) {
    -webkit-animation-delay: 0;
    animation-delay: 0;
  }

  .p-mv__img--list.is-active>li:nth-child(2) {
    -webkit-animation-delay: 0.5s;
    animation-delay: 0.5s;
  }

  .p-mv__img--list.is-active>li:nth-child(3) {
    -webkit-animation-delay: 1s;
    animation-delay: 1s;
  }
}

@media screen and (max-width: 767.98px) {
  .p-mv__title {
    font-size: 5rem;
    margin-block: 30px;
    padding-block-start: 116px;
  }

  .p-mv__txt {
    font-size: 1.6rem;
  }

  .p-mv__sub {
    left: 0;
    margin-block-end: 30px;
  }

  .p-mv__sub mark {
    font-size: 1.4rem;
  }

  .p-mv__img--list {
    gap: 10px;
    transform: translateY(-50px);
    margin-inline: 10px;
  }

  .p-mv__img--list>li .sub {
    font-size: 1.4rem;
  }

  .p-mv__img--list>li strong {
    font-size: 2.4rem;
  }

  .p-mv__img--list>li b {
    font-size: 3rem;
  }

  .p-mv__img--mask img {
    height: 300px;
    max-width: inherit;
    object-fit: cover;
    width: 100%;
  }
}

/* ---------------------------------
  contact
--------------------------------- */
.p-contact .cmp-hdg01 {
  -webkit-margin-after: 40px;
  margin-block-end: 40px;
  text-align: center;
}

.p-contact .cmp-hdg01+.txt {
  text-align: center;
}

.p-contact__inner {
  background: var(--gradient-color-1);
  border-radius: 80px;
  -webkit-box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.1);
  box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.1);
  margin-inline: auto;
  max-width: 945px;
  padding: 68px 0 60px;
  position: relative;
}

.p-contact__list {
  list-style: none;
  display: -ms-grid;
  display: grid;
  gap: 77px;
  -webkit-margin-before: 60px;
  margin-block-start: 60px;
  margin-inline: auto;
  position: relative;
  text-align: center;
  width: 74.8148%;
}

.p-contact__list>li {
  text-align: center;
}

.p-contact__list .cont {
  aspect-ratio: 1;
  background-color: #fff;
  border-radius: 50%;
  -webkit-margin-after: 17px;
  margin-block-end: 17px;
  max-width: 270px;
  margin-inline: auto;
  position: relative;
}

.p-contact__list .cont .ttl {
  display: -ms-grid;
  display: grid;
  font-size: 1.8rem;
  letter-spacing: 0.2em;
  place-content: center;
  -webkit-padding-after: 25.555%;
  padding-block-end: 25.555%;
  height: 100%;
  width: 100%;
}

.p-contact__list .cont .ttl em {
  color: var(--color-orange);
  display: block;
  font-size: clamp(2.8rem, 2.222vw, 3.2rem);
  font-style: normal;
  font-weight: bold;
  letter-spacing: 0.2em;
}

.p-contact__list .cont img {
  position: absolute;
  left: 0;
  right: 0;
  margin-inline: auto;
  height: 54%;
  max-height: 143px;
  -o-object-fit: contain;
  object-fit: contain;
}

.p-contact__list .cont img.img01 {
  bottom: -6px;
}

.p-contact__list .cont img.img02 {
  left: 23px;
  bottom: -12px;
}

@media screen and (min-width: 768px) {
  .p-contact__list {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }

  .p-contact__list>li:nth-child(odd) {
    -webkit-margin-end: 10.4667%;
    margin-inline-end: 10.4667%;
  }

  .p-contact__list>li:nth-child(even) {
    -webkit-margin-start: 10.4667%;
    margin-inline-start: 10.4667%;
  }

  .p-contact__list>li+li::before {
    content: "";
    width: 1px;
    height: 100%;
    background-color: rgba(51, 51, 51, 0.1);
    position: absolute;
    left: 50%;
    top: 0;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
  }
}

@media screen and (max-width: 767.98px) {
  .p-contact__inner {
    border-radius: 50px;
    margin-inline: 20px;
  }

  .p-contact__list {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
}

/* ---------------------------------
  gradi background
--------------------------------- */
.bg-gradi {
  position: relative;
}

.bg-gradi::before {
  content: "";
  background: url("../img_lp/failproof_app/bg_gradi.webp") no-repeat center bottom/100% 100%;
  position: absolute;
  bottom: calc(-10.41666vw - (53.819vw / 4));
  left: 0;
  height: 53.819vw;
  width: 100%;
}

@media (max-width: 575.98px) {
  .bg-gradi::before {
    bottom: calc(-53.819vw / 2);
  }
  .p-case.bg-gradi::before {
    bottom: 60px;
  }
}

/* ---------------------------------
  case
--------------------------------- */
.p-case {
  padding-block: 120px 150px;
}

.p-case .l-container {
  max-width: 1100px;
}

.p-case__card {
  display: -ms-grid;
  display: grid;
  list-style: none;
  gap: 40px 2.777vw;
  -webkit-margin-before: 50px;
  margin-block-start: 50px;
}

.p-case__card .cont {
  background-color: #fff;
  border: solid 2px rgba(17, 17, 17, 0.05);
  border-radius: 30px;
  -webkit-box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.03);
  box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.03);
  cursor: pointer;
  overflow: hidden;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}

.p-case__card .cont:hover .btn::after {
  left: 0;
}

.p-case__card .cont:hover .btn span {
  color: #fff;
}

.p-case__card .cont:hover .btn span::after {
  -webkit-filter: brightness(0) invert(1);
  filter: brightness(0) invert(1);
}

.p-case__card .figure {
  aspect-ratio: 1.7/1;
  max-height: 200px;
  width: 100%;
}

.p-case__card .figure img {
  -o-object-fit: cover;
  object-fit: cover;
  height: 100%;
  width: 100%;
}

.p-case__card .details {
  padding: 30px 2.0833vw;
}

.p-case__card .details>* {
  letter-spacing: 0.1em;
}

.p-case__card .details .tag {
  border: solid 1px #acffaa;
  border-radius: 50px;
  display: inline-block;
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 1;
  -webkit-margin-after: 25px;
  margin-block-end: 25px;
  padding: 10px 18px;
}

.p-case__card .details .ttl {
  font-size: 2.2rem;
  -webkit-margin-after: 30px;
  margin-block-end: 30px;
}

.p-case__card .details .btn {
  background-color: #f5f5f5;
  border-radius: 40px;
  display: block;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1;
  margin: 64px 0 0 auto;
  overflow: hidden;
  padding: 16px 30px;
  position: relative;
  width: 177px;
}

.p-case__card .details .btn::after {
  background-color: var(--color-green);
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  left: -177px;
  top: 0;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}

.p-case__card .details .btn span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
  z-index: 10;
}

.p-case__card .details .btn span::after {
  content: "";
  display: block;
  background: url("data:image/svg+xml,%3Csvg width='11' height='12' viewBox='0 0 11 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0.46967 9.96967C0.176777 10.2626 0.176777 10.7374 0.46967 11.0303C0.762563 11.3232 1.23744 11.3232 1.53033 11.0303L0.46967 9.96967ZM10.75 1.5C10.75 1.08579 10.4142 0.75 10 0.75H3.25C2.83579 0.75 2.5 1.08579 2.5 1.5C2.5 1.91421 2.83579 2.25 3.25 2.25H9.25V8.25C9.25 8.66421 9.58579 9 10 9C10.4142 9 10.75 8.66421 10.75 8.25V1.5ZM1 10.5L1.53033 11.0303L10.5303 2.03033L10 1.5L9.46967 0.96967L0.46967 9.96967L1 10.5Z' fill='%23333333'/%3E%3C/svg%3E%0A") no-repeat center/100% auto;
  fill: #fff;
  width: 9px;
  height: 9px;
}

@media screen and (min-width: 768px) {
  .p-case__card {
    grid-template-columns: repeat(3, 1fr);
  }

  .p-case__card>li:nth-child(even) {
    -webkit-margin-before: 50px;
    margin-block-start: 50px;
  }
}

@media screen and (max-width: 767.98px) {
  .p-case__card .details {
    padding-inline: 30px;
  }
}

/* ---------------------------------
  problem
--------------------------------- */
.p-problem {
  background-color: #fff;
  position: relative;
}

.p-problem .l-container {
  max-width: 1240px;
}

.p-problem .cmp-hdg02 {
  -webkit-margin-after: 116px;
  margin-block-end: 116px;
}

.p-problem__list {
  background-color: #f5f5f5;
  border-radius: 80px;
  counter-reset: order;
  display: -ms-grid;
  display: grid;
  list-style: none;
  position: relative;
  text-align: center;
  z-index: 2;
}

.p-problem__list>li {
  -webkit-padding-after: 60px;
  padding-block-end: 60px;
  position: relative;
}

.p-problem__list .figure {
  margin-block: -30px 50px;
  padding-inline: 30px;
  position: relative;
  z-index: 2;
}

.p-problem__list .details p {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2.0833vw;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-margin-start: -6.944vw;
  margin-inline-start: -6.944vw;
}

.p-problem__list .details p b {
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.5;
}

.p-problem__list .details .num {
  aspect-ratio: 1;
  background: url("../img_lp/failproof_app/problem_num.svg") no-repeat center/100% auto;
  color: var(--color-green);
  font-family: var(--font-3);
  display: -ms-grid;
  display: grid;
  place-content: center;
  position: relative;
  width: 90px;
}

.p-problem__list .details .num::before,
.p-problem__list .details .num::after {
  display: block;
  letter-spacing: 0.1em;
  line-height: 1;
}

.p-problem__list .details .num::before {
  content: "CASE";
  font-size: 1.6rem;
}

.p-problem__list .details .num::after {
  counter-increment: order;
  content: '00' counter(order);
  font-size: 2.8rem;
  font-style: italic;
}

@media screen and (min-width: 768px) {
  .p-problem__list {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    -ms-grid-rows: (1fr)[2];
    grid-template-rows: repeat(2, 1fr);
  }

  .p-problem__list>li::before,
  .p-problem__list>li::after {
    background-color: rgba(17, 17, 17, 0.1);
    content: "";
    position: absolute;
  }

  .p-problem__list>li:nth-child(2)::before,
  .p-problem__list>li:nth-child(4)::before {
    height: calc(100% - 4.8611vw);
    width: 1px;
    left: 0;
  }

  .p-problem__list>li:nth-child(2)::before {
    bottom: 15px;
  }

  .p-problem__list>li:nth-child(4)::before {
    top: 15px;
  }

  .p-problem__list>li:nth-child(4)::after {
    left: 15px;
  }

  .p-problem__list>li:nth-child(3)::after,
  .p-problem__list>li:nth-child(4)::after {
    height: 1px;
    width: calc(100% - 4.8611vw);
    top: 0;
  }

  .p-problem__list>li:nth-child(3)::after {
    right: 15px;
  }
}

@media (max-width: 1359.98px) {
  .p-problem .l-container {
    padding-inline: 20px;
  }
}

@media screen and (max-width: 767.98px) {
  .p-problem__list {
    border-radius: 50px;
  }

  .p-problem__list>li+li::before {
    background-color: rgba(17, 17, 17, 0.1);
    content: "";
    display: block;
    margin-inline: auto;
    height: 1px;
    width: calc(100% - 60px);
  }

  .p-problem__list .details p {
    -webkit-margin-start: 0;
    margin-inline-start: 0;
  }
  
  .p-problem__list .details .num {
    width: 70px;
  }

  .p-problem__list .details .num::after {
    font-size: 2rem;
  }
}

/* ---------------------------------
  strengths
--------------------------------- */
.p-strengths {
  background-color: var(--color-green);
  -webkit-margin-after: -210px;
  margin-block-end: -210px;
  padding-block: 316px 0;
  position: relative;
  overflow: hidden;
  -webkit-transform: translateY(-210px);
  transform: translateY(-210px);
}

.p-strengths__mark {
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font: italic 900 clamp(10rem, 18.75vw, 27rem) var(--font-3-bold);
  line-height: 0.8;
  letter-spacing: 0.05em;
  opacity: 0.1;
  text-transform: uppercase;
  white-space: nowrap;
}

.p-strengths__mark p {
  animation: text-loop 120s linear -60s infinite;
  padding-inline-start: .5em;
}

.p-strengths__mark.is-active p {
  /* -webkit-animation: text-loop 120s -85s linear infinite;
  animation: text-loop 120s -85s linear infinite; */
  animation: text-loop 120s linear -60s infinite;
}

.p-strengths__mark p:nth-child(even) {
  /* -webkit-animation: text-loop2 120s linear infinite;
  animation: text-loop2 120s linear infinite; */
  animation: text-loop2 120s linear infinite;
}

.p-strengths__ttl {
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  max-width: 854px;
  margin: 0 auto -4.1666vw;
  position: relative;
  top: -4.1666vw;
}

.p-strengths__ttl::before {
  aspect-ratio: 1;
  content: "";
  background: url("../img_lp/failproof_app/strengths_ico.svg") no-repeat center/100% auto;
  max-width: 110px;
  max-height: 110px;
  width: 12.8805%;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.p-strengths__ttl .ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: clamp(2.6rem, 2.222vw, 3.2rem);
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  font-weight: bold;
  gap: 20px;
  letter-spacing: 0.2em;
  text-align: center;
}

.p-strengths__ttl .ttl b {
  font-size: clamp(4rem, 3.6111vw, 5.2rem);
  letter-spacing: 0.2em;
}

.p-strengths__txt {
  color: #fff;
  letter-spacing: 0.1em;
  -webkit-margin-before: 60px;
  margin-block-start: 60px;
}

@media screen and (min-width: 768px) {
  .p-strengths__txt {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 5px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}

@media screen and (max-width: 767.98px) {
  .p-strengths .bg {
    height: 200px;
    -o-object-fit: cover;
    object-fit: cover;
  }

  .p-strengths__ttl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 120px;
  }

  .p-strengths__txt {
    line-height: 2;
    text-align: center;
  }

  .p-strengths__txt img {
    max-width: 180px;
    vertical-align: bottom;
  }
}

/* ---------------------------------
  compare
--------------------------------- */
.p-compare {
  background-color: var(--color-green);
  color: #fff;
  padding-block: 150px;
}

.p-compare .cmp-hdg02 {
  color: #fff;
}

.p-compare .cmp-hdg02 .en {
  background: inherit;
  color: rgba(255, 255, 255, 0.2);
  -webkit-text-fill-color: inherit;
}

.p-compare .cmp-hdg02 b::before {
  background-color: #fff;
}

.p-compare__table {
  border-collapse: collapse;
  border-spacing: 0;
  color: #FAFAFA;
}

.p-compare__table tr {
  -webkit-border-after: solid 1px rgba(255, 255, 255, 0.2);
  border-block-end: solid 1px rgba(255, 255, 255, 0.2);
}

.p-compare__table .item-label {
  background-color: rgba(0, 0, 0, 0.03);
  border-inline-end: solid 1px rgba(255, 255, 255, 0.2);
  color: #FAFAFA;
  letter-spacing: 0.05em;
  width: 190px;
}

.p-compare__table .item-label span {
  display: block;
  font-size: 1.4rem;
}

.p-compare__table thead th {
  -webkit-border-end: solid 1px rgba(255, 255, 255, 0.2);
  border-inline-end: solid 1px rgba(255, 255, 255, 0.2);
}

.p-compare__table thead .head-ttl {
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  line-height: 1.8;
  padding-block: 30px;
}

.p-compare__table thead .head-ttl b {
  display: block;
}

.p-compare__table tbody td {
  -webkit-border-end: solid 1px rgba(255, 255, 255, 0.2);
  border-inline-end: solid 1px rgba(255, 255, 255, 0.2);
  padding: 40px 24px;
  vertical-align: top;
}

.p-compare__table tbody .body-ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  letter-spacing: 0.05em;
  gap: 12px;
  text-align: center;
}

.p-compare__table tbody .body-ttl>span+span::before {
  background-color: rgba(255, 255, 255, 0.5);
  content: "";
  display: inline-block;
  -webkit-margin-end: 12px;
  margin-inline-end: 12px;
  height: 1px;
  width: 10px;
}

.p-compare__table tbody .sub {
  display: block;
  font-size: 1.3rem;
  letter-spacing: 0.05em;
  line-height: 1.8;
  -webkit-margin-before: 22px;
  margin-block-start: 22px;
  text-align: center;
}

.p-compare__table .ours {
  background-color: rgba(255, 255, 255, 0.05);
}

.p-compare__table .ours .head-ttl {
  color: var(--color-yellow);
}

.p-compare__table .ours .head-ttl b {
  font-size: 2rem;
}

.p-compare__table .ours .body-ttl {
  color: var(--color-yellow);
  font-size: 2.4rem;
  font-weight: bold;
}

.p-compare__table .others {
  background-color: rgba(0, 0, 0, 0.1);
  color: #FAFAFA;
}

.p-compare__table .others .head-ttl b {
  font-size: 1.8rem;
}

.p-compare__table .others .body-ttl {
  font-size: 1.8rem;
  font-weight: 400;
}

@media (max-width: 973.98px) {
  .p-compare .table-wrap table .item-label {
    background-color: var(--color-green);
    padding-inline: 40px;
    position: -webkit-sticky;
    position: sticky;
    left: 0;
    z-index: 1;
  }

  .p-compare .table-wrap table th,
  .p-compare .table-wrap table td {
    white-space: normal;
    word-break: break-word;
  }

  .p-compare .table-wrap table .ours .body-ttl {
    font-size: 2rem;
  }

  .p-compare .table-wrap table .others .body-ttl {
    font-size: 1.6rem;
  }

  .p-compare .table-wrap table .cmp-disc {
    font-size: 1.4rem;
  }
}

@media (max-width: 767.98px) {
  .p-compare {
    padding-block: 100px;
  }

  .p-compare .table-wrap table .item-label {
    min-height: 360px;
    padding-inline: 10px;
    width: 6em;
  }
  .p-compare .table-wrap table .item-label b {
    -webkit-writing-mode: vertical-lr;
    -ms-writing-mode: tb-lr;
    writing-mode: vertical-lr;
    text-orientation: upright;
  }

  .p-compare .table-wrap table th,
  .p-compare .table-wrap table td {
    padding-inline: 14px;
  }

  .p-compare .table-wrap .c-yellow,
  .p-compare .table-wrap .d-ib {
    display: block !important;
  }
}

@media (max-width: 575.98px) {
  .p-compare .table-wrap {
    overflow-x: scroll;
    max-width: 100%;
  }

  .p-compare .table-wrap table {
    table-layout: auto;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
  }

  .p-compare .table-wrap table th,
  .p-compare .table-wrap table td {
    vertical-align: middle;
  }

  .p-compare .table-wrap table .item-label {
    padding-inline: 0;
    width: 3em;
  }

  .p-compare .table-wrap table .item-label b {
    font-size: 1.4rem;
  }

  .p-compare .table-wrap table .item-label b span {
    display: inline;
  }

  .p-compare .table-wrap table .item-label b br {
    display: none;
  }

  .p-compare__table .ours .head-ttl b {
    font-size: 1.8rem;
  }

  .p-compare .table-wrap table .ours .body-ttl {
    font-size: 1.6rem;
  }
}


/* ---------------------------------
  feature
--------------------------------- */
.p-feature {
  background-color: #FAFAFA;
  padding-block: 150px 132px;
  overflow: hidden;
}

.p-feature .l-container {
  max-width: 1100px;
}

.p-feature__list {
  counter-reset: order;
  list-style: none;
  -webkit-margin-before: 120px;
  margin-block-start: 120px;
}

.p-feature__list>li {
  border-radius: 50px;
  -webkit-box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.03);
  box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.03);
  max-width: 1036px;
  padding: 90px 64px 110px;
  position: relative;
}

.p-feature__list>li+li {
  -webkit-margin-before: 210px;
  margin-block-start: 210px;
}

.p-feature__list>li .figure {
  position: absolute;
  max-width: 565px;
  width: 54.53667%;
  top: -14.02083vw;
}

.p-feature__list>li .figure img {
  border-radius: 20px;
  -o-object-fit: cover;
  object-fit: cover;
  height: 100%;
  width: 100%;
}

.p-feature__list>li:nth-child(odd) .figure {
  right: -20px;
}

.p-feature__list>li:nth-child(even) .figure {
  top: -17.02083vw;
  left: -20px;
}

.p-feature__list>li .details {
  position: relative;
  z-index: 2;
}

.p-feature__list>li .details .head {
  -webkit-margin-start: auto;
  margin-inline-start: auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.p-feature__list>li .details .ttl {
  font-size: 2.8rem;
  -webkit-margin-after: 40px;
  margin-block-end: 40px;
  letter-spacing: 0.2em;
}

.p-feature__list>li .details .ttl::before {
  counter-increment: order;
  content: '(0' counter(order) ')';
  color: #77f674;
  display: block;
  font-size: 1.6rem;
  -webkit-margin-after: 30px;
  margin-block-end: 30px;
}

.p-feature__list>li .details .lead {
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  -webkit-margin-after: 55px;
  margin-block-end: 55px;
}

.p-feature__list>li .details .txt {
  letter-spacing: 0.2em;
  line-height: 2;
}

.p-feature__list>li .details .txt mark {
  background: var(--gradient-color-1);
}

.p-feature+.p-contact {
  background-color: #fcfcfc;
}

@media (min-width: 1160px) {
  .p-feature__list>li:nth-child(odd) {
    -webkit-margin-end: auto;
    margin-inline-end: auto;
  }

  .p-feature__list>li:nth-child(odd) .figure {
    top: -130px;
    right: -64px;
  }

  .p-feature__list>li:nth-child(even) {
    -webkit-margin-start: auto;
    margin-inline-start: auto;
  }

  .p-feature__list>li:nth-child(even) .figure {
    top: -130px;
    left: -64px;
  }
}

@media (max-width: 1099.98px) and (min-width: 768px) {
  .p-feature__list>li:nth-child(odd) {
    -webkit-margin-end: 20px;
    margin-inline-end: 20px;
  }

  .p-feature__list>li:nth-child(even) {
    -webkit-margin-start: 20px;
    margin-inline-start: 20px;
  }
}

@media screen and (max-width: 767.98px) {
  .p-feature {
    padding-block: 100px;
  }

  .p-feature__list>li {
    padding-inline: 30px;
    padding-block-end: 50px;
  }

  .p-feature__list>li+li {
    -webkit-margin-before: 160px;
    margin-block-start: 100px;
  }

  .p-feature__list>li .details .head {
    -webkit-margin-start: 0;
    margin-inline-start: 0;
  }
  
  .p-feature__list>li:nth-child(even) .figure {
    left: inherit;
    right: -20px;
  }
}

@media screen and (max-width: 575.98px) {
  .p-feature__list>li .figure {
    top: -30px;
    width: 72.53667%;
  }
}

/* ---------------------------------
  flow
--------------------------------- */
.p-flow {
  background-color: #fff;
  padding-block: 150px;
}

.p-flow__list {
  list-style: none;
  max-width: 847px;
  margin: 0 auto 150px;
}

.p-flow__list>li {
  -webkit-margin-before: 50px;
  margin-block-start: 50px;
}

.p-flow__list .cont {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.p-flow__list .cont img {
  -webkit-margin-start: -30px;
  margin-inline-start: -30px;
  position: relative;
  width: 190px;
}

.p-flow__list .ttl {
  aspect-ratio: 1;
  background: url("../img_lp/failproof_app/flow_bg.svg") no-repeat center/100% auto;
  display: -ms-grid;
  display: grid;
  font-size: 2rem;
  -ms-flex-preferred-size: 200px;
  flex-basis: 200px;
  letter-spacing: 0.1em;
  line-height: 1.5;
  place-content: center;
  text-align: center;
}

.p-flow__list .ttl .sub {
  color: #888;
  display: block;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  -webkit-margin-before: 30px;
  margin-block-start: 30px;
}

.p-flow__list .txt {
  -ms-flex-preferred-size: 53.9551%;
  flex-basis: 53.9551%;
  line-height: 1.8;
  -webkit-margin-start: 30px;
  margin-inline-start: 30px;
}

.p-flow .cmp-hdg03 {
  -webkit-margin-after: 60px;
  margin-block-end: 60px;
}

.p-flow__chart img {
  -webkit-margin-after: 30px;
  margin-block-end: 30px;
}

@media screen and (min-width: 768px) {
  .p-flow__list>li+li .ttl {
    position: relative;
  }

  .p-flow__list>li+li .ttl::before {
    background: #acffaa;
    content: "";
    height: 30px;
    width: 1.5px;
    position: absolute;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    top: -40px;
  }
}

@media screen and (max-width: 767.98px) {
  .p-flow {
    padding-block: 100px;
  }

  .p-flow__list>li {
    margin-block-start: 80px;
    position: relative;
  }

  .p-flow__list>li + li::before {
    background-color: #acffaa;
    content: "";
    height: 40px;
    width: 1px;
    position: absolute;
    left: 50%;
    top: -60px;
    transform: translateX(-50%);
  }

  .p-flow__list .cont {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 20px;
  }

  .p-flow__list .cont img {
    width: 140px;
  }

  .p-flow__list .ttl {
    -ms-flex-preferred-size: 160px;
    flex-basis: 160px;
  }

  .p-flow__list .ttl .sub {
    -webkit-margin-before: 15px;
    margin-block-start: 15px;
  }

  .p-flow__list .txt {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    -webkit-margin-start: 0;
    margin-inline-start: 0;
  }
}