@charset "UTF-8";

* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

ul {
  list-style-type: none;
}

a {
  color: inherit;
  text-decoration: none;
}

ul,
ol,
div {
  margin: 0;
  padding: 0;
}

html {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 10px;
  color: #292929;
  scroll-behavior: smooth;
}

.image {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}

.image--100 {
  height: 100%;
}

.image--auto {
  width: auto;
}

.image--contain {
  -o-object-fit: contain;
  object-fit: contain;
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  padding-inline: 2%;
  z-index: 900;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
  padding-top: 24px;
  -webkit-filter: drop-shadow(0 0 6px #c3f2e8);
  filter: drop-shadow(0 0 6px #c3f2e8);
}

@media screen and (max-width: 980px) {
  .header {
    padding-inline: 0;
  }
}

@media screen and (max-width: 767px) {
  .header {
    padding-top: 14px;
  }
}

.header.active .header__nav {
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

.header__ctr {
  max-width: 1667px;
  height: 90px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 40px;
}

@media screen and (max-width: 1200px) {
  .header__ctr {
    gap: 20px;
  }
}

@media screen and (max-width: 767px) {
  .header__ctr {
    height: 60px;
  }
}

.header__wrapper {
  max-width: 1342px;
  width: 100%;
  height: 100%;
}

.header__inner {
  padding: 23px 40px;
  background-color: #fff;
  border-radius: 45px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 980px) {
  .header__inner {
    max-width: 97%;
    margin: 0 auto;
    height: 100%;
  }
}

@media screen and (max-width: 767px) {
  .header__inner {
    padding: 18px 24px;
  }
}

.header__logo {
  width: 171px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 1200px) {
  .header__logo {
    width: 141px;
  }
}

@media screen and (max-width: 767px) {
  .header__logo {
    width: 102px;
  }
}

@media screen and (max-width: 980px) {
  .header__nav {
    position: fixed;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #fff;
    overflow: auto;
    -webkit-transform: translateY(-100%);
    transform: translateY(-100%);
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease;
    height: 100svh;
    height: 100vh;
  }
}

.header__nav-wrap {
  min-height: 100%;
  position: relative;
  overflow: hidden;
}

.header__nav-wrap::before {
  content: "";
  width: 485px;
  height: 353px;
  background: url("./public/img/deco/deco-1.png") no-repeat center/100% 100%;
  position: absolute;
  top: -92px;
  left: -173px;
  z-index: -1;
}

.header__nav-wrap::after {
  content: "";
  width: 281px;
  height: 232px;
  background: url("./public/img/deco/deco-2.png") no-repeat center/100% 100%;
  position: absolute;
  bottom: -80px;
  right: -140px;
  z-index: -1;
}

.header__nav-list {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  padding-inline: 27px;
  gap: 40px;
}

@media screen and (max-width: 767px) {
  .header__nav-list {
    gap: 24px;
  }
}

.header__nav-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 40px;
}

@media screen and (max-width: 1200px) {
  .header__nav-inner {
    gap: 20px;
  }
}

@media screen and (max-width: 980px) {
  .header__nav-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    min-height: 100%;
  }
}

.header__nav-inner--sp-tab {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  padding: 200px 15px 148px;
}

@media screen and (max-width: 767px) {
  .header__nav-inner--sp-tab {
    padding: 154px 15px 148px;
  }
}

.header__nav-link {
  font-size: 1.6rem;
  font-weight: 700;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

@media screen and (max-width: 980px) {
  .header__nav-link {
    font-size: 2.8rem;
  }
}

@media screen and (max-width: 767px) {
  .header__nav-link {
    font-size: 18px;
  }
}

.header__nav-link:hover {
  color: #7d7d7d;
}

.header__hamburger {
  width: 24px;
  height: 16px;
  position: relative;
  cursor: pointer;
}

.header__hamburger.active .header__hamburger-item:nth-child(1) {
  -webkit-transform: rotate(45deg) translate(6px, 5px);
  transform: rotate(45deg) translate(6px, 5px);
}

.header__hamburger.active .header__hamburger-item:nth-child(2) {
  opacity: 0;
}

.header__hamburger.active .header__hamburger-item:nth-child(3) {
  -webkit-transform: rotate(-45deg) translate(6px, -5px);
  transform: rotate(-45deg) translate(6px, -5px);
}

.header__hamburger-item {
  display: block;
  height: 2px;
  width: 24px;
  background-color: black;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
  -webkit-transform-origin: center;
  transform-origin: center;
  border-radius: 15px;
  position: absolute;
}

.header__hamburger-item:nth-child(1) {
  top: 0;
}

.header__hamburger-item:nth-child(2) {
  top: 8px;
}

.header__hamburger-item:nth-child(3) {
  top: 16px;
}

.header__text-ctr {
  text-align: center;
}

@media screen and (max-width: 980px) {
  .header__text-ctr {
    width: 53%;
  }
}

@media screen and (max-width: 767px) {
  .header__text-ctr {
    width: 60%;
  }
}

.header__text-ctr--fab {
  width: 100%;
}

@media screen and (max-width: 380px) {
  .header__text-ctr--fab {
    width: 55%;
  }
}

.header__link {
  max-width: 285px;
  width: 100%;
  background-color: #f28200;
  padding: 10px 8px;
  border-radius: 45px;
  position: relative;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-filter: drop-shadow(0 0 6px #c3f2e8);
  filter: drop-shadow(0 0 6px #c3f2e8);
}

@media screen and (max-width: 1200px) {
  .header__link {
    max-width: 250px;
  }
}

@media screen and (max-width: 980px) {
  .header__link {
    max-width: 345px;
    -ms-flex-item-align: center;
    align-self: center;
    margin-top: 55px;
  }
}

@media screen and (max-width: 767px) {
  .header__link {
    margin-top: 15px;
  }
}

.header__link::before {
  content: "";
  width: 9px;
  height: 16px;
  background: url("./public/img/icons/carret.svg") no-repeat center/100% 100%;
  position: absolute;
  top: 50%;
  right: 20px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.header__link:hover {
  background-color: #f2a200;
}

.header__link--sm {
  padding: 20px 8px;
  margin-top: 0;
}

.header__link--fab {
  max-width: 100%;
  width: 100%;
  margin-top: 0;
  padding: 7px 8px;
}

.header__link-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16px;
}

.header__link-inner--sm {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.header__link-inner--fab {
  width: 100%;
}

.header__promo {
  width: 71px;
  height: 71px;
  border-radius: 50%;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 1200px) {
  .header__promo {
    width: 66px;
    height: 66px;
  }
}

@media screen and (max-width: 980px) {
  .header__promo {
    width: 78px;
    height: 78px;
  }
}

@media screen and (max-width: 767px) {
  .header__promo {
    width: 61px;
    height: 61px;
  }
}

.header__promo--fab {
  width: 51px;
  height: 51px;
}

.header__promo-text {
  font-size: 1.8rem;
  font-weight: 700;
  color: #f28200;
}

@media screen and (max-width: 1024px) {
  .header__promo-text {
    font-size: 14px;
  }
}

@media screen and (max-width: 980px) {
  .header__promo-text {
    font-size: 2rem;
  }
}

@media screen and (max-width: 1024px) {
  .header__promo-text {
    font-size: 14px;
  }
}

.header__promo-text--fab {
  font-size: 12px;
}

.header__link-text {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #fff;
  display: block;
  text-align: center;
}

@media screen and (max-width: 1200px) {
  .header__link-text {
    font-size: 1.4rem;
  }
}

@media screen and (max-width: 767px) {
  .header__link-text {
    font-size: 1.4rem;
  }
}

.header__link-text.sm {
  font-size: 1.3rem;
  font-weight: 500;
  margin-bottom: 6px;
  position: relative;
  display: inline-block;
}

@media screen and (max-width: 1024px) {
  .header__link-text.sm {
    font-size: 11px;
  }
}

@media screen and (max-width: 980px) {
  .header__link-text.sm {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 767px) {
  .header__link-text.sm {
    font-size: 11px;
  }
}

.header__link-text.sm::before,
.header__link-text.sm::after {
  content: "";
  width: 1px;
  height: 15px;
  background-color: #fff;
  position: absolute;
  top: 3px;
  left: -8px;
  -webkit-transform: rotate(-30deg);
  transform: rotate(-30deg);
}

.header__link-text.sm::after {
  -webkit-transform: rotate(30deg);
  transform: rotate(30deg);
  left: unset;
  right: -8px;
}

.button {
  max-width: 736px;
  width: 100%;
  padding: 19px 48px 21px;
  background-color: #f28200;
  border-radius: 20px;
  -webkit-transform: all 0.3s ease;
  transform: all 0.3s ease;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .button {
    padding: 16px 33px;
    border-radius: 10px;
  }
}

.button__text-wrap {
  text-align: center;
}

.button__text {
  font-size: 3.2rem;
  font-weight: 700;
  color: #fff;
  display: block;
}

@media screen and (max-width: 767px) {
  .button__text {
    font-size: 24px;
  }
}

.button__text.sm {
  font-size: 1.6rem;
  margin-bottom: 8px;
  position: relative;
}

.button__text.sm::before {
  content: "";
  width: 1px;
  height: 15px;
  background-color: #fff;
  position: absolute;
  top: 5px;
  left: 73px;
  -webkit-transform: rotate(-30deg);
  transform: rotate(-30deg);
}

@media screen and (max-width: 767px) {
  .button__text.sm::before {
    left: 43px;
  }
}

.button__text.sm::after {
  content: "";
  width: 1px;
  height: 15px;
  background-color: #fff;
  position: absolute;
  top: 5px;
  right: 73px;
  -webkit-transform: rotate(30deg);
  transform: rotate(30deg);
}

@media screen and (max-width: 767px) {
  .button__text.sm::after {
    right: 43px;
  }
}

.button::after {
  content: "";
  width: 13px;
  height: 24px;
  background: url("./public/img/icons/carret.svg") no-repeat center/100% 100%;
  position: absolute;
  top: 50%;
  right: 24px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

@media screen and (max-width: 767px) {
  .button::after {
    width: 9px;
    height: 16px;
    right: 23px;
  }
}

.button:hover {
  background-color: #f2a200;
}

.button--center {
  margin-inline: auto;
}

.button--contact {
  max-width: 400px;
  padding: 22px 32px 23px;
  border-radius: 40px;
}

.button--contact::after {
  width: 8px;
  height: 14px;
}

.button--contact .button__text {
  font-size: 2.4rem;
}

@media screen and (max-width: 767px) {
  .button--contact .button__text {
    font-size: 16px;
  }
}

.button--gray {
  background-color: #7d7d7d;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.button--gray:hover {
  background-color: #b5c5c2;
}

.button--gray::after {
  -webkit-transform: translateY(-50%) rotate(180deg);
  transform: translateY(-50%) rotate(180deg);
  right: unset;
  left: 24px;
}

.title {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .title {
    gap: 8px;
  }
}

.title__en {
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  font-size: 2.4rem;
  color: #52b3c7;
}

@media screen and (max-width: 767px) {
  .title__en {
    font-size: 16px;
  }
}

.title__jp {
  font-size: 4rem;
}

@media screen and (max-width: 767px) {
  .title__jp {
    font-size: 24px;
  }
}

.fab__inner {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  position: relative;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .fab__inner {
    width: 50px;
    height: 50px;
  }
}

.fab__inner::before {
  content: "";
  position: absolute;
  inset: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(#52b3c7), color-stop(#51b1c5), to(#76e7b8));
  background: linear-gradient(to bottom, #52b3c7, #51b1c5, #76e7b8);
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
  z-index: 0;
}

.fab__inner::after {
  content: "";
  position: absolute;
  inset: 0;
  background: -webkit-gradient(linear, left bottom, left top, from(#52b3c7), color-stop(#51b1c5), to(#76e7b8));
  background: linear-gradient(to top, #52b3c7, #51b1c5, #76e7b8);
  opacity: 0;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
  z-index: 1;
}

.fab__inner:hover::after {
  opacity: 1;
}

.fab__inner img {
  position: relative;
  z-index: 2;
}

.fab__container {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: fixed;
  bottom: 40px;
  padding-inline: 40px;
  z-index: 99;
}

@media screen and (max-width: 767px) {
  .fab__container {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    bottom: 20px;
    gap: 15px;
    padding-inline: 20px;
  }
}

.lp {
  position: relative;
  overflow: hidden;
}

.lp::before {
  content: "";
  width: 951px;
  height: 694px;
  background: url("./public/img/deco/mv-deco-1.png") no-repeat center/100% 100%;
  position: absolute;
  top: -155px;
  left: -238px;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .lp::before {
    width: 485px;
    height: 353px;
    top: -92px;
    left: -167px;
  }
}

.lp::after {
  content: "";
  width: 516px;
  height: 426px;
  background: url("./public/img/deco/mv-deco-2.png") no-repeat center/100% 100%;
  position: absolute;
  top: 690px;
  right: -90px;
  z-index: 1;
}

@media screen and (max-width: 980px) {
  .lp::after {
    top: 930px;
    right: -210px;
  }
}

@media screen and (max-width: 767px) {
  .lp::after {
    width: 281px;
    height: 232px;
    top: 600px;
    right: -160px;
  }
}

.lp__mv {
  padding-block: 249px 153px;
  position: relative;
  background: linear-gradient(290deg, rgb(255, 255, 255) 0%, rgb(240, 255, 252) 100%);
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .lp__mv {
    padding-block: 126px 120px;
  }
}

.lp__mv::after {
  content: "";
  width: 161px;
  height: 226px;
  background: url("./public/img/top/mv_top.svg") no-repeat center/100% 100%;
  position: absolute;
  top: 180px;
  right: 126px;
}

@media screen and (max-width: 980px) {
  .lp__mv::after {
    top: 130px;
    right: 40px;
  }
}

@media screen and (max-width: 767px) {
  .lp__mv::after {
    width: 78px;
    height: 109px;
    top: 330px;
    right: 20px;
  }
}

@media screen and (max-width: 480px) {
  .lp__mv::after {
    top: 290px;
  }
}

.lp__mv-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 73px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 1290px) {
  .lp__mv-wrap {
    padding-inline: 4%;
    gap: 43px;
  }
}

@media screen and (max-width: 980px) {
  .lp__mv-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}

.lp__mv-title-ctr {
  max-width: 560px;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .lp__mv-title-ctr {
    max-width: 100%;
    padding-inline: 17px;
  }
}

.lp__mv-subtitle {
  font-size: 4rem;
  font-weight: 700;
  display: block;
}

@media screen and (max-width: 980px) {
  .lp__mv-subtitle {
    text-align: center;
  }
}

@media screen and (max-width: 767px) {
  .lp__mv-subtitle {
    font-size: 24px;
  }
}

.lp__mv-title {
  font-size: 8rem;
  line-height: 1.45em;
  color: #52b3c7;
  margin-block: 40px;
}

@media screen and (max-width: 767px) {
  .lp__mv-title {
    font-size: 44px;
    margin-block: 16px 24px;
  }
}

@media screen and (max-width: 480px) {
  .lp__mv-title {
    font-size: 30px;
  }
}

.lp__mv-title--sm {
  font-size: 5.6rem;
  color: #292929;
}

@media screen and (max-width: 767px) {
  .lp__mv-title--sm {
    font-size: 36px;
  }
}

@media screen and (max-width: 480px) {
  .lp__mv-title--sm {
    font-size: 24px;
  }
}

.lp__mv-info {
  font-size: 2rem;
  font-weight: 700;
  line-height: 2em;
}

@media screen and (max-width: 767px) {
  .lp__mv-info {
    font-size: 16px;
    line-height: 2em;
  }
}

@media screen and (max-width: 480px) {
  .lp__mv-info {
    font-size: 14px;
  }
}

.lp__text-highlight {
  position: relative;
  white-space: nowrap;
}

.lp__text-highlight::before {
  content: "";
  width: 100%;
  height: 12px;
  background-color: #c3f2e8;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}

@media screen and (max-width: 767px) {
  .lp__text-highlight::before {
    height: 8px;
  }
}

.lp__text-highlight--bg {
  z-index: 1;
}

.lp__text-highlight--bg::before {
  height: 15px;
}

@media screen and (max-width: 767px) {
  .lp__text-highlight--bg::before {
    height: 8px;
  }
}

.lp__mv-bubble {
  width: 410px;
  height: 96px;
  border: 2px solid #f8c600;
  background-color: #fff;
  padding: 8px 16px;
  border-radius: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .lp__mv-bubble {
    max-width: 345px;
    padding: 8px;
    gap: 15px;
    height: 72px;
  }
}

.lp__mv-bubble::after {
  content: "";
  position: absolute;
  bottom: -30px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 16px solid transparent;
  border-right: 16px solid transparent;
  border-top: 30px solid #f8c600;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .lp__mv-bubble::after {
    border-left: 12px solid transparent;
    border-right: 12px solid transparent;
    border-top: 18px solid #f8c600;
    bottom: -18px;
  }
}

.lp__mv-bubble::before {
  content: "";
  position: absolute;
  bottom: -27px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 15px solid transparent;
  border-right: 15px solid transparent;
  border-top: 28px solid #fff;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .lp__mv-bubble::before {
    border-left: 11px solid transparent;
    border-right: 11px solid transparent;
    border-top: 16px solid #fff;
    bottom: -16px;
  }
}

.lp__btn-img {
  position: absolute;
  left: 32px;
  top: -27px;
  width: 19.33%;
}

@media screen and (max-width: 1290px) {
  .lp__btn-img {
    width: 17.33%;
  }
}

@media screen and (max-width: 767px) {
  .lp__btn-img {
    width: 55px;
    top: -4px;
  }
}

@media screen and (max-width: 480px) {
  .lp__btn-img {
    width: 50px;
    height: 65px;
    left: 10px;
  }

  .lp__btn-img img {
    height: 100%;
  }
}

.lp__mv-bubble-icon {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background-color: #f28200;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .lp__mv-bubble-icon {
    width: 56px;
    height: 56px;
  }
}

.lp__mv-promo {
  max-width: 667px;
  width: 100%;
  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: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 46px;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .lp__mv-promo {
    gap: 30px;
  }
}

.lp__promo-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.lp__mv-bubble-text {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.2em;
  color: #fff;
}

@media screen and (max-width: 767px) {
  .lp__mv-bubble-text {
    font-size: 16px;
  }
}

.lp__mv-promo-text {
  font-size: 1.8rem;
  font-weight: 700;
}

@media screen and (max-width: 767px) {
  .lp__mv-promo-text {
    font-size: 16px;
  }
}

.lp__mv-promo-text .text-bg {
  font-family: "Roboto", sans-serif;
  font-size: 6.4rem;
  font-weight: 500;
  color: #f28200;
  padding-left: 8px;
  display: inline-block;
  position: relative;
}

@media screen and (max-width: 767px) {
  .lp__mv-promo-text .text-bg {
    padding-left: 7px;
    line-height: 1em;
  }
}

.lp__mv-promo-text .text-bg::before {
  content: "";
  width: 14px;
  height: 15px;
  background: url("./public/img/deco/text-deco.svg") no-repeat center/100% 100%;
  position: absolute;
  top: 3px;
  left: -3px;
}

@media screen and (max-width: 767px) {
  .lp__mv-promo-text .text-bg::before {
    width: 7px;
    height: 7px;
    top: 8px;
    left: 3px;
  }
}

.lp__mv-promo-text .text-md {
  font-size: 2.4rem;
  padding-inline: 5px;
}

@media screen and (max-width: 767px) {
  .lp__mv-promo-text .text-md {
    padding-inline: 0 7px;
  }
}

.lp__mv-btn {
  max-width: 667px;
  width: 100%;
  height: 172px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .lp__mv-btn {
    height: 86px;
  }
}

.lp__mv-btn::before {
  content: "";
  width: 100%;
  height: 160px;
  background-color: #de4f0f;
  position: absolute;
  border-radius: 80px;
  top: 6px;
  left: 0;
  z-index: -1;
  -webkit-transition: top 0.3s ease-in-out;
  transition: top 0.3s ease-in-out;
}

@media screen and (max-width: 767px) {
  .lp__mv-btn::before {
    height: 82px;
    top: 4px;
  }
}

.lp__mv-btn:hover .lp__btn {
  top: 0;
}

.lp__mv-btn:hover::before {
  top: 6px;
}

.lp__btn {
  width: 100%;
  height: 160px;
  background-color: #f28200;
  border-radius: 80px;
  padding: 24px 0;
  position: absolute;
  top: -6px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 6px;
  -webkit-transition: top 0.3s ease-in-out;
  transition: top 0.3s ease-in-out;
}

@media screen and (max-width: 767px) {
  .lp__btn {
    height: 82px;
    padding: 11px 25px 17px;
    top: -4px;
  }
}

.lp__btn::after {
  content: "";
  width: 19px;
  height: 34px;
  background: url("./public/img/icons/carret.svg") no-repeat center/100% 100%;
  position: absolute;
  top: 50%;
  right: 32px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

@media screen and (max-width: 767px) {
  .lp__btn::after {
    width: 9px;
    height: 16px;
  }
}

.lp__btn-text {
  font-size: 4rem;
  font-weight: 700;
  color: #fff;
  display: block;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .lp__btn-text {
    font-size: 24px;
  }
}

.lp__btn-text.sm {
  font-size: 2.4rem;
  margin-bottom: 8px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .lp__btn-text.sm {
    font-size: 13px;
    margin-bottom: 0;
  }
}

.lp__btn-text.sm::before {
  content: "";
  width: 2px;
  height: 20px;
  background-color: #fff;
  position: absolute;
  top: 10px;
  left: 80px;
  -webkit-transform: rotate(-30deg);
  transform: rotate(-30deg);
}

@media screen and (max-width: 767px) {
  .lp__btn-text.sm::before {
    height: 10px;
    top: 5px;
    left: 53px;
  }
}

.lp__btn-text.sm::after {
  content: "";
  width: 2px;
  height: 20px;
  background-color: #fff;
  position: absolute;
  top: 10px;
  right: 80px;
  -webkit-transform: rotate(30deg);
  transform: rotate(30deg);
}

@media screen and (max-width: 767px) {
  .lp__btn-text.sm::after {
    height: 10px;
    top: 5px;
    right: 53px;
  }
}

.lp__articles {
  position: relative;
  padding-bottom: 155px;
  background: -webkit-gradient(linear, left bottom, left top, from(rgb(100, 228, 255)), color-stop(20%, rgb(241, 253, 239)), color-stop(66.66%, rgb(247, 251, 225)), to(rgb(252, 255, 254)));
  background: linear-gradient(to top, rgb(100, 228, 255) 0%, rgb(241, 253, 239) 20%, rgb(247, 251, 225) 66.66%, rgb(252, 255, 254) 100%);
}

.lp__articles::before {
  content: "";
  width: 53px;
  height: 286px;
  position: absolute;
  background: url("./public/img/top/seo.svg") no-repeat center/100% 100%;
  top: 185px;
  left: 160px;
  z-index: 2;
}

@media screen and (max-width: 1200px) {
  .lp__articles::before {
    width: 33px;
    height: 266px;
    top: 245px;
    left: 50px;
  }
}

@media screen and (max-width: 980px) {
  .lp__articles::before {
    top: 275px;
  }
}

@media screen and (max-width: 767px) {
  .lp__articles::before {
    width: 26px;
    height: 141px;
    top: -40px;
    left: 35px;
  }
}

.lp__articles-wrap {
  overflow: hidden;
  position: relative;
  z-index: 1;
}

.lp__articles-intro {
  position: relative;
  background: linear-gradient(135deg, rgba(240, 255, 252, 0.6) 10%, transparent 20%);
}

.lp__articles-intro::before {
  content: "";
  width: 100%;
  height: 100%;
  background: url("./public/img/deco/articles-intro.png") no-repeat center/cover;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
}

@media screen and (max-width: 767px) {
  .lp__articles-intro::before {
    background: url("./public/img/deco/bg-gray-sp.png") no-repeat center/100% 100%;
  }
}

.lp__articles-ctr {
  position: relative;
  z-index: 2;
  padding: 0 4%;
  margin: 0 auto;
  max-width: calc(1200px + 8%);
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 767px) {
  .lp__articles-ctr {
    max-width: 100%;
  }
}

.lp__articles-intro-ctr {
  padding: 122px 4% 179px !important;
  text-align: center;
  position: relative;
  z-index: 2;
  padding: 0 4%;
  margin: 0 auto;
  max-width: calc(1200px + 8%);
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 767px) {
  .lp__articles-intro-ctr {
    max-width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .lp__articles-intro-ctr {
    padding: 40px 4% !important;
  }
}

.lp__articles-intro-title {
  font-size: 4.8rem;
  line-height: 1.4583333333em;
  color: #52b3c7;
  margin-bottom: 24px;
}

@media screen and (max-width: 767px) {
  .lp__articles-intro-title {
    font-size: 20px;
    line-height: 1.45em;
    margin-bottom: 12px;
  }
}

.lp__articles-intro-text {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2em;
}

@media screen and (max-width: 767px) {
  .lp__articles-intro-text {
    font-size: 16px;
    line-height: 2.25em;
  }
}

.lp__articles-list {
  padding-top: 49px;
  counter-reset: count;
}

@media screen and (max-width: 767px) {
  .lp__articles-list {
    padding-top: 69px;
  }
}

.lp__articles-item:not(:last-child) {
  margin-bottom: 80px;
}

.lp__articles-title {
  font-size: 3.2rem;
  line-height: 1.4375em;
  margin-bottom: 40px;
  counter-increment: count;
  gap: 40px;
  text-align: left;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .lp__articles-title {
    font-size: 24px;
    line-height: 1.3333333333em;
    margin-bottom: 27px;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    gap: 20px;
  }
}

@media screen and (max-width: 480px) {
  .lp__articles-title {
    font-size: 20px;
    line-height: 1.4em;
    gap: 10px;
  }
}

.lp__articles-title::before {
  content: counter(count, decimal-leading-zero);
  font-family: "Roboto", sans-serif;
  font-size: 8rem;
  font-weight: 700;
  color: #52b3c7;
  display: block;
}

@media screen and (max-width: 767px) {
  .lp__articles-title::before {
    font-size: 48px;
  }
}

@media screen and (max-width: 480px) {
  .lp__articles-title::before {
    font-size: 38px;
  }
}

.lp__strategy-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-block: 24px 60px;
}

@media screen and (max-width: 980px) {
  .lp__strategy-list {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media screen and (max-width: 767px) {
  .lp__strategy-list {
    margin-block: 24px 36px;
    gap: 9px;
  }
}

.lp__strategy-list--grid-3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.lp__strategy-list--grid-2 {
  grid-template-columns: repeat(2, 1fr);
  margin-block: 24px;
}

.lp__strategy-item {
  padding: 24px;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 16px;
  -webkit-backdrop-filter: blur(50px);
  backdrop-filter: blur(50px);
  background-color: rgba(255, 255, 255, 0.5);
  border: 1px solid #52b3c7;
  border-radius: 10px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .lp__strategy-item {
    padding: 24px 14px 36px;
    gap: 8px !important;
    border-radius: 5px;
  }
}

.lp__strategy-item::before {
  content: "";
  width: 8px;
  height: 8px;
  background-color: #52b3c7;
  border-radius: 50%;
  position: absolute;
  top: 24px;
  left: 16px;
}

.lp__strategy-item--grid-3 {
  width: calc(34% - 24px);
  gap: 24px;
  padding: 32px 27px 24px 20px;
}

@media screen and (max-width: 980px) {
  .lp__strategy-item--grid-3 {
    width: calc(50% - 24px);
  }
}

@media screen and (max-width: 767px) {
  .lp__strategy-item--grid-3 {
    width: calc(50.5% - 9px);
  }
}

.lp__strategy-item--grid-3 .lp__strategy-img {
  height: 118px;
}

.lp__strategy-item--grid-3 .lp__strategy-img img {
  height: 100%;
}

.lp__strategy-img img {
  max-width: 100%;
}

.lp__strategy-title {
  font-size: 2rem;
}

@media screen and (max-width: 767px) {
  .lp__strategy-title {
    font-size: 16px;
  }
}

.lp__strategy-info {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2em;
  text-align: left;
}

@media screen and (max-width: 767px) {
  .lp__strategy-info {
    font-size: 13px;
    line-height: 1.5384615385em;
  }
}

.lp__articles-point {
  padding: 47px 24px 24px;
  border: 1px solid #52b3c7;
  border-radius: 10px;
  position: relative;
  background-color: #fff;
}

@media screen and (max-width: 767px) {
  .lp__articles-point {
    padding: 28px 13px 16px;
    border-radius: 5px;
  }
}

.lp__articles-point-text {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.5em;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .lp__articles-point-text {
    font-size: 16px;
    line-height: 1.5em;
  }
}

.lp__articles-point-tag {
  max-width: 219px;
  width: 100%;
  padding: 16px;
  background-color: #52b3c7;
  border-radius: 39px;
  font-size: 2.4rem;
  font-weight: 700;
  color: #fff;
  position: absolute;
  top: -39px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  gap: 19px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .lp__articles-point-tag {
    max-width: 120px;
    font-size: 16px;
    gap: 8px;
    padding: 8px;
    top: -20px;
  }
}

.lp__articles-point-tag::before {
  content: "";
  width: 24px;
  height: 24px;
  background: url("./public/img/icons/point-icon.svg") no-repeat center/100% 100%;
  display: block;
}

@media screen and (max-width: 767px) {
  .lp__articles-point-tag::before {
    width: 16px;
    height: 16px;
  }
}

.lp__articles-note {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.4583333333em;
  text-align: center;
  margin-bottom: 60px;
}

@media screen and (max-width: 767px) {
  .lp__articles-note {
    font-size: 20px;
    line-height: 1.6em;
    margin-bottom: 36px;
  }
}

.lp__promo-ctr {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 77px;
}

@media screen and (max-width: 1200px) {
  .lp__promo-ctr {
    gap: 55px;
  }
}

@media screen and (max-width: 980px) {
  .lp__promo-ctr {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}

@media screen and (max-width: 767px) {
  .lp__promo-ctr {
    gap: 16px;
  }
}

.lp__promo-wrap {
  max-width: 387px;
  width: 100%;
}

@media screen and (max-width: 980px) {
  .lp__promo-wrap {
    max-width: 100%;
  }
}

.lp__promo-contact {
  max-width: 736px;
  width: 100%;
}

@media screen and (max-width: 980px) {
  .lp__promo-contact {
    max-width: 100%;
  }
}

.lp__promo-btn {
  margin: 25px auto 0;
}

.lp__promo-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  background-color: #fff;
  border: 1px solid #52b3c7;
  border-radius: 10px;
  padding: 24px 20px;
  gap: 4%;
  margin-bottom: 16px;
}

@media screen and (max-width: 767px) {
  .lp__promo-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 26px;
    border-radius: 5px;
  }
}

.lp__promo-title {
  font-size: 4rem;
  line-height: 1.75em;
}

@media screen and (max-width: 980px) {
  .lp__promo-title {
    text-align: center;
  }
}

@media screen and (max-width: 767px) {
  .lp__promo-title {
    font-size: 20px;
  }
}

.lp__promo-title .roboto {
  font-family: "Roboto", sans-serif;
  font-size: 6.4rem;
}

@media screen and (max-width: 767px) {
  .lp__promo-title .roboto {
    font-size: 40px;
  }
}

.lp__promo-title .orange {
  font-size: 5.6rem;
  color: #f28200;
  position: relative;
  display: inline-block;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .lp__promo-title .orange {
    font-size: 40px;
    line-height: 6rem;
  }
}

.lp__promo-title .orange::before {
  content: "";
  width: 100%;
  height: 23px;
  background-color: #fff;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: -1;
}

@media screen and (max-width: 767px) {
  .lp__promo-title .orange::before {
    height: 11px;
  }
}

.lp__promo {
  margin-top: 120px;
}

@media screen and (max-width: 767px) {
  .lp__promo {
    margin-top: 40px;
  }
}

.lp__promo-text {
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 2em;
  margin-top: 40px;
}

@media screen and (max-width: 767px) {
  .lp__promo-text {
    font-size: 16px;
    text-align: center;
    margin-top: 16px;
  }
}

.lp__promo-item {
  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: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16px;
}

@media screen and (max-width: 767px) {
  .lp__promo-item {
    gap: 8px;
  }
}

.lp__promo-icon {
  width: 32px;
}

@media screen and (max-width: 767px) {
  .lp__promo-icon {
    width: 16px;
    height: 16px;
  }
}

.lp__promo-item-text {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.7777777778em;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .lp__promo-item-text {
    font-size: 16px;
  }
}

.lp__promo-item-text .bold {
  font-weight: 700;
}

.lp__promo-note {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.4444444444em;
  text-align: left;
}

@media screen and (max-width: 767px) {
  .lp__promo-note {
    font-size: 16px;
  }
}

.lp__works {
  padding-bottom: 116px;
  position: relative;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .lp__works {
    padding-bottom: 49px;
  }
}

.lp__works::before,
.lp__works::after {
  content: "";
  width: 1093px;
  height: 1250px;
  background: url("./public/img/deco/works-deco-1.png") no-repeat center/cover;
  position: absolute;
  top: 136px;
  right: -385px;
  z-index: 1;
}

.lp__works::after {
  background: url("./public/img/deco/works-deco-2.png") no-repeat center/100% 100%;
  top: unset;
  bottom: 0;
  right: unset;
  left: -415px;
}

.lp__works-list {
  position: relative;
  z-index: 2;
}

.lp__works-intro {
  position: relative;
  padding-block: 120px 64px;
  background: -webkit-gradient(linear, left bottom, left top, from(#fff), color-stop(50%, #fff), color-stop(50%, #64e4ff), to(#64e4ff));
  background: linear-gradient(to top, #fff 0%, #fff 50%, #64e4ff 50%, #64e4ff 100%);
}

@media screen and (max-width: 767px) {
  .lp__works-intro {
    padding-block: 86px 40px;
  }
}

.lp__works-intro::before {
  content: "";
  width: 100%;
  height: 100%;
  background: url("./public/img/deco/work-intro-bg.png") no-repeat center/cover;
  position: absolute;
  top: 0;
  left: 0;
}

@media screen and (max-width: 767px) {
  .lp__works-intro::before {
    background: url("./public/img/deco/bg-white-sp.png") no-repeat center/100% 100%;
    height: 204px;
  }
}

.lp__works-ctr {
  position: relative;
  z-index: 1;
  padding: 0 4%;
  margin: 0 auto;
  max-width: calc(1200px + 8%);
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 767px) {
  .lp__works-ctr {
    max-width: 100%;
  }
}

.lp__works-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 9.3%;
  margin-bottom: 40px;
}

@media screen and (max-width: 1200px) {
  .lp__works-wrap {
    gap: 3%;
  }
}

@media screen and (max-width: 980px) {
  .lp__works-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 70px;
  }
}

.lp__works-item {
  padding: 87px 40px 40px;
  border: 1px solid #52b3c7;
  background-color: #fff;
  border-radius: 10px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .lp__works-item {
    border-radius: 5px;
    padding: 101px 18px 24px;
  }
}

.lp__works-item:not(:last-child) {
  margin-bottom: 40px;
}

.lp__works-tag {
  font-size: 2.4rem;
  font-weight: 500;
  max-width: 166px;
  width: 100%;
  padding-block: 16px;
  border-top-left-radius: 10px;
  border-bottom-right-radius: 10px;
  background-color: #52b3c7;
  color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .lp__works-tag {
    font-size: 20px;
    max-width: 100%;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
    border-bottom-right-radius: 0;
  }
}

.lp__works-graph {
  max-width: 502px;
  width: 100%;
}

.lp__works-info-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

@media screen and (max-width: 980px) {
  .lp__works-info-wrap {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}

@media screen and (max-width: 767px) {
  .lp__works-info-wrap {
    gap: 16px;
  }
}

.lp__works-duration {
  max-width: 449px;
  width: 100%;
}

@media screen and (max-width: 980px) {
  .lp__works-duration {
    max-width: 100%;
  }
}

.lp__works-info-item--end {
  justify-self: flex-end;
}

.lp__works-heading {
  font-size: 2.4rem;
  font-weight: 700;
  max-width: 397px;
  width: 100%;
  text-align: center;
  margin: 0 auto;
  padding: 8px;
  border: 1px solid #52b3c7;
}

.lp__works-icon {
  width: 142px;
}

@media screen and (max-width: 1200px) {
  .lp__works-icon {
    width: 100px;
  }
}

@media screen and (max-width: 767px) {
  .lp__works-icon {
    width: 90px;
    height: 96px;
  }
}

@media screen and (max-width: 480px) {
  .lp__works-icon {
    width: 70px;
    height: 76px;
  }
}

.lp__works-label {
  font-size: 3.2rem;
  font-weight: 700;
}

@media screen and (max-width: 767px) {
  .lp__works-label {
    font-size: 20px;
  }
}

@media screen and (max-width: 480px) {
  .lp__works-label {
    font-size: 18px;
  }
}

.lp__works-approx {
  font-size: 3.2rem;
  font-weight: 700;
  margin-left: 24px;
  white-space: nowrap;
}

@media screen and (max-width: 767px) {
  .lp__works-approx {
    font-size: 20px;
    margin-left: 16px;
  }
}

.lp__works-approx .lp__num {
  font-size: 8rem;
  color: #52b3c7;
  position: relative;
  top: 3px;
}

@media screen and (max-width: 767px) {
  .lp__works-approx .lp__num {
    font-size: 56px;
    padding-inline: 6px 3px;
  }
}

@media screen and (max-width: 480px) {
  .lp__works-approx .lp__num {
    font-size: 46px;
  }
}

.lp__support-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  position: relative;
}

@media screen and (max-width: 980px) {
  .lp__support-wrap {
    grid-template-columns: 1fr;
    gap: 8px;
  }
}

.lp__support-block {
  background-color: #f6f6f5;
  border-radius: 10px;
  padding: 24px 48px 64px 60px;
  position: relative;
}

@media screen and (max-width: 980px) {
  .lp__support-block {
    padding: 44px 48px 64px 60px;
  }
}

@media screen and (max-width: 767px) {
  .lp__support-block {
    padding: 28px 18px 32px;
    border-radius: 5px;
  }
}

.lp__support-block--after {
  background-color: #52b3c7;
}

.lp__support-tag {
  font-size: 2.4rem;
  font-weight: 700;
  padding-block: 8px;
  max-width: 176px;
  width: 100%;
  margin: 0 auto;
  background-color: #fff;
  border-radius: 39px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .lp__support-tag {
    font-size: 20px;
    max-width: 140px;
  }
}

.lp__support-tag--after {
  color: #52b3c7;
}

.lp__support-list {
  margin-top: 40px;
}

@media screen and (max-width: 767px) {
  .lp__support-list {
    margin-top: 16px;
  }
}

.lp__support-item {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2em;
  position: relative;
  padding-left: 24px;
}

@media screen and (max-width: 767px) {
  .lp__support-item {
    padding-left: 21px;
  }
}

.lp__support-item::after {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #292929;
  position: absolute;
  top: 12px;
  left: 0;
}

.lp__support-item:not(:last-child) {
  margin-bottom: 32px;
}

@media screen and (max-width: 767px) {
  .lp__support-item:not(:last-child) {
    margin-bottom: 16px;
  }
}

.lp__support-item--after {
  color: #fff;
  padding-left: 36px;
}

@media screen and (max-width: 767px) {
  .lp__support-item--after {
    padding-left: 21px;
  }
}

.lp__support-item--after::after {
  content: "";
  width: 20px;
  height: 16px;
  border-radius: 0;
  background: url("./public/img/icons/check-w.svg") no-repeat center/100% 100%;
  top: 10px;
}

@media screen and (max-width: 767px) {
  .lp__support-item--after::after {
    width: 14px;
    height: 11px;
  }
}

.lp__support-divider {
  position: absolute;
  top: 50%;
  right: -60px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  z-index: 1;
}

@media screen and (max-width: 980px) {
  .lp__support-divider {
    right: 50%;
    top: unset;
    bottom: -30px;
    -webkit-transform: translate(50%, 0) rotate(90deg);
    transform: translate(50%, 0) rotate(90deg);
  }
}

@media screen and (max-width: 767px) {
  .lp__support-divider {
    bottom: -20px;
  }
}

.lp__support-divider-inner {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background-color: #fff;
  -webkit-filter: drop-shadow(0 0 10px #c3f2e8);
  filter: drop-shadow(0 0 10px #c3f2e8);
  position: relative;
}

@media screen and (max-width: 980px) {
  .lp__support-divider-inner {
    width: 60px;
    height: 60px;
  }
}

@media screen and (max-width: 767px) {
  .lp__support-divider-inner {
    width: 40px;
    height: 40px;
  }
}

.lp__support-divider-inner::before {
  content: "";
  width: 18px;
  height: 32px;
  background: url("./public/img/icons/caret-b.svg") no-repeat center/100% 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

@media screen and (max-width: 980px) {
  .lp__support-divider-inner::before {
    width: 13px;
    height: 22px;
  }
}

@media screen and (max-width: 767px) {
  .lp__support-divider-inner::before {
    width: 9px;
    height: 16px;
  }
}

.lp__price-flow {
  padding-block: 213px 240px;
  position: relative;
  overflow: hidden;
  background: -webkit-gradient(linear, left bottom, left top, from(rgb(255, 255, 255)), color-stop(40%, rgb(222, 255, 254)), color-stop(60%, rgb(255, 255, 255)), to(rgb(240, 255, 252)));
  background: linear-gradient(to top, rgb(255, 255, 255) 0%, rgb(222, 255, 254) 40%, rgb(255, 255, 255) 60%, rgb(240, 255, 252) 100%);
}

@media screen and (max-width: 767px) {
  .lp__price-flow {
    padding-block: 56px 160px;
  }
}

.lp__price-flow::before {
  content: "";
  width: 100%;
  height: 448px;
  background: url("./public/img/deco/deco-price-w.png") no-repeat center/cover;
  position: absolute;
  top: -410px;
  left: 0;
}

@media screen and (max-width: 767px) {
  .lp__price-flow::before {
    background: url("./public/img/deco/bg-white-sp.png") no-repeat center/100% 100%;
    height: 247px;
    top: -237px;
  }
}

.lp__price-flow::after {
  content: "";
  width: 100%;
  height: 328px;
  background: url("./public/img/deco/deco-price.png") no-repeat top/100% 100%;
  position: absolute;
  bottom: -185px;
  left: 0;
}

@media screen and (max-width: 767px) {
  .lp__price-flow::after {
    background: url("./public/img/deco/bg-gray-sp.png") no-repeat top/cover;
    height: 117px;
    bottom: -60px;
  }
}

.lp__price-ctr {
  padding: 0 4%;
  margin: 0 auto;
  max-width: calc(1200px + 8%);
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 767px) {
  .lp__price-ctr {
    max-width: 100%;
  }
}

.lp__price-plan {
  padding: 90px 80px;
  background-color: #fff;
  -webkit-filter: drop-shadow(0 0 6px #c3f2e8);
  filter: drop-shadow(0 0 6px #c3f2e8);
  border-radius: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 120px;
  position: relative;
}

@media screen and (max-width: 980px) {
  .lp__price-plan {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 60px;
  }
}

@media screen and (max-width: 767px) {
  .lp__price-plan {
    gap: 23px;
    padding: 24px 24px 70px;
  }
}

.lp__price-img {
  width: 16.25%;
  position: absolute;
  top: 24px;
  right: 42px;
  z-index: -1;
}

@media screen and (max-width: 980px) {
  .lp__price-img {
    top: unset;
    bottom: 24px;
  }
}

@media screen and (max-width: 767px) {
  .lp__price-img {
    width: 102px;
    height: 68px;
  }
}

.lp__price-title-ctr {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

@media screen and (max-width: 767px) {
  .lp__price-title-ctr {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}

.lp__price-title-ctr--center {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding-left: 0;
}

.lp__price-title {
  font-size: 2.4rem;
  margin-bottom: 8px;
  position: relative;
  padding-left: 24px;
}

@media screen and (max-width: 767px) {
  .lp__price-title {
    font-size: 20px;
  }
}

.lp__price-title::before {
  content: "";
  width: 8px;
  height: 8px;
  background-color: #52b3c7;
  border-radius: 50%;
  position: absolute;
  top: 12px;
  left: 0;
}

.lp__price-subtitle {
  font-size: 1.6rem;
  font-weight: 500;
  padding-left: 24px;
}

@media screen and (max-width: 980px) {
  .lp__price-subtitle {
    padding-left: 0;
  }
}

.lp__price-intro {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
  text-align: center;
  margin-block: 40px 64px;
}

@media screen and (max-width: 767px) {
  .lp__price-intro {
    margin-block: 24px 40px;
    text-align: left;
  }
}

.lp__price-intro--price {
  margin-block: 0 40px;
}

.lp__price-text {
  font-size: 2.4rem;
  font-weight: 700;
}

@media screen and (max-width: 980px) {
  .lp__price-text {
    text-align: center;
  }
}

@media screen and (max-width: 767px) {
  .lp__price-text {
    font-size: 18px;
  }
}

.lp__price-text .num {
  font-size: 4.8rem;
  color: #52b3c7;
  margin-right: 16px;
}

@media screen and (max-width: 767px) {
  .lp__price-text .num {
    font-size: 40px;
    margin-right: 8px;
  }
}

.lp__price-text .num-bg {
  font-size: 8rem;
  color: #52b3c7;
  margin-inline: 24px 12px;
}

@media screen and (max-width: 767px) {
  .lp__price-text .num-bg {
    font-size: 40px;
    margin-inline: 8px;
  }
}

.lp__price-note {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2em;
  margin-top: 24px;
}

@media screen and (max-width: 767px) {
  .lp__price-note {
    font-size: 16px;
    line-height: 2em;
  }
}

.lp__plan {
  margin-top: 40px;
  padding: 40px;
  background-color: #fff;
  -webkit-filter: drop-shadow(0 0 6px #c3f2e8);
  filter: drop-shadow(0 0 6px #c3f2e8);
  border-radius: 20px;
}

@media screen and (max-width: 767px) {
  .lp__plan {
    padding: 20px;
    border-radius: 10px;
  }
}

.lp__plan-ctr {
  position: relative;
  overflow: hidden;
}

.lp__plan-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
}

@media screen and (max-width: 980px) {
  .lp__plan-wrap {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 767px) {
  .lp__plan-wrap {
    gap: 29px;
  }
}

.lp__plan-shape {
  width: 100%;
  min-height: 248px;
  background-color: #52b3c7;
  display: block;
  position: absolute;
  left: 50%;
  top: 0;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  -webkit-clip-path: ellipse(45% 62% at 50% -15%);
  clip-path: ellipse(45% 62% at 50% -15%);
  z-index: -1;
}

@media screen and (max-width: 767px) {
  .lp__plan-shape {
    -webkit-clip-path: ellipse(50% 62% at 50% -15%);
    clip-path: ellipse(50% 62% at 50% -15%);
  }
}

@media screen and (max-width: 400px) {
  .lp__plan-shape {
    -webkit-clip-path: ellipse(50% 50% at 50% -15%);
    clip-path: ellipse(50% 50% at 50% -15%);
  }
}

.lp__plan-shape--gradient {
  background: -webkit-gradient(linear, left top, right top, from(rgb(82, 179, 199)), color-stop(10%, rgb(81, 177, 197)), to(rgb(118, 231, 184)));
  background: linear-gradient(90deg, rgb(82, 179, 199) 0%, rgb(81, 177, 197) 10%, rgb(118, 231, 184) 100%);
}

.lp__plan-block {
  padding: 148px 40px 37px;
  border: 2px solid #52b3c7;
  border-radius: 10px;
  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: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .lp__plan-block {
    padding: 88px 16px 40px 14px;
    border-radius: 5px;
  }
}

@media screen and (max-width: 400px) {
  .lp__plan-block {
    padding: 60px 16px 40px 14px;
  }
}

.lp__plan-heading {
  position: absolute;
  top: 0;
}

.lp__plan-title {
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  font-size: 2.4rem;
  line-height: 1.4583333333em;
  text-align: center;
  color: #fff;
  padding-block: 34px 55px;
}

@media screen and (max-width: 1200px) {
  .lp__plan-title {
    font-size: 2rem;
  }
}

@media screen and (max-width: 767px) {
  .lp__plan-title {
    font-size: 18px;
    line-height: 1.4444444444em;
    padding-block: 43px 43px;
  }
}

@media screen and (max-width: 400px) {
  .lp__plan-title {
    font-size: 14px;
    padding-block: 30px 43px;
  }
}

.lp__plan-title--gradient {
  padding-block: 16px 38px;
}

@media screen and (max-width: 767px) {
  .lp__plan-title--gradient {
    padding-block: 12px 32px;
  }
}

@media screen and (max-width: 416px) {
  .lp__plan-title--gradient {
    padding-block: 15px 32px;
  }
}

@media screen and (max-width: 767px) {
  .lp__plan-icon {
    width: 145px;
    height: 107px;
    position: relative;
  }
}

.lp__plan-label {
  font-size: 2.4rem;
  font-weight: 700;
  text-align: center;
  display: block;
}

@media screen and (max-width: 767px) {
  .lp__plan-label {
    font-size: 16px;
    font-weight: 500;
  }
}

.lp__plan-info {
  margin-block: 40px;
}

@media screen and (max-width: 767px) {
  .lp__plan-info {
    max-width: 253px;
    width: 100%;
    margin-block: 24px !important;
  }
}

.lp__plan-info--bg {
  margin-block: 98px 125px;
}

@media screen and (max-width: 980px) {
  .lp__plan-concept {
    width: 100%;
  }
}

.lp__plan-num {
  font-size: 6.4rem;
  font-weight: 700;
  color: #52b3c7;
  line-height: 1em;
}

@media screen and (max-width: 1200px) {
  .lp__plan-num {
    font-size: 5.4rem;
  }
}

@media screen and (max-width: 767px) {
  .lp__plan-num {
    font-size: 40px;
  }
}

@media screen and (max-width: 416px) {
  .lp__plan-num {
    font-size: 35px;
  }
}

.lp__plan-cost {
  margin-bottom: 32px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

@media screen and (max-width: 767px) {
  .lp__plan-cost {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    margin-bottom: 16px;
  }
}

.lp__plan-cost--no-mb {
  margin-bottom: 14;
}

.lp__plan-tax {
  -ms-flex-item-align: end;
  align-self: flex-end;
}

.lp__plan-text {
  font-size: 2.4rem;
  font-weight: 700;
  margin-left: 16px;
}

@media screen and (max-width: 1200px) {
  .lp__plan-text {
    font-size: 20px;
  }
}

@media screen and (max-width: 767px) {
  .lp__plan-text {
    font-size: 18px;
    margin-left: 8px;
  }
}

@media screen and (max-width: 416px) {
  .lp__plan-text {
    font-size: 16px;
  }
}

.lp__plan-note {
  font-size: 1.8rem;
  font-weight: 500;
  text-align: center;
  display: block;
}

@media screen and (max-width: 767px) {
  .lp__plan-note {
    font-size: 16px;
  }
}

.lp__plan-desc {
  font-size: 1.8rem;
  font-weight: 500;
  padding: 32px 20px;
  line-height: 2em;
  border-top: 2px solid #52b3c7;
  border-bottom: 2px solid #52b3c7;
}

@media screen and (max-width: 767px) {
  .lp__plan-desc {
    font-size: 16px;
    padding: 24px 15px;
  }
}

@media screen and (max-width: 480px) {
  .lp__plan-desc {
    padding: 24px 10px;
  }
}

.lp__plan-list {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2em;
  margin-top: 36px;
}

@media screen and (max-width: 767px) {
  .lp__plan-list {
    font-size: 16px;
    margin-top: 24px;
    padding-inline: 16px;
  }
}

.lp__plan-item {
  position: relative;
  padding-left: 40px;
}

@media screen and (max-width: 767px) {
  .lp__plan-item {
    padding-left: 32px;
  }
}

.lp__plan-item::before {
  content: "";
  width: 24px;
  height: 24px;
  background: url("./public/img/icons/round-check.svg") no-repeat center/100% 100%;
  position: absolute;
  top: 7px;
  left: 0;
}

@media screen and (max-width: 767px) {
  .lp__plan-item::before {
    width: 16px;
    height: 16px;
    top: 10px;
  }
}

.lp__plan-item:not(:last-child) {
  margin-bottom: 18px;
}

@media screen and (max-width: 767px) {
  .lp__plan-item:not(:last-child) {
    margin-bottom: 13px;
  }
}

.lp__options {
  padding: 40px;
  border-radius: 10px;
  margin-block: 40px 80px;
  background-color: #fff;
  -webkit-filter: drop-shadow(0 0 6px #c3f2e8);
  filter: drop-shadow(0 0 6px #c3f2e8);
}

@media screen and (max-width: 767px) {
  .lp__options {
    padding: 24px 16px 40px;
    margin-block: 20px 40px;
    border-radius: 5px;
  }
}

.lp__options-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 64px;
  padding-inline: 30px;
  margin-top: 24px;
}

@media screen and (max-width: 1200px) {
  .lp__options-wrap {
    gap: 34px;
  }
}

@media screen and (max-width: 980px) {
  .lp__options-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 16px;
  }
}

@media screen and (max-width: 767px) {
  .lp__options-wrap {
    padding-inline: 0;
  }
}

.lp__options-row {
  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;
  gap: 13px;
}

.lp__options-row:not(:last-child) {
  margin-bottom: 16px;
}

.lp__options-label {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
  position: relative;
  gap: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .lp__options-label {
    font-size: 13px;
    gap: 8px;
  }
}

.lp__options-label::before {
  content: "";
  width: 24px;
  height: 24px;
  background: url("./public/img/icons/round-check.svg") no-repeat center/100% 100%;
  display: inline-block;
}

@media screen and (max-width: 767px) {
  .lp__options-label::before {
    width: 16px;
    height: 16px;
  }
}

.lp__options-price {
  font-size: 1.6rem;
  font-weight: 500;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

@media screen and (max-width: 767px) {
  .lp__options-price {
    font-size: 13px;
  }
}

.lp__options-price .num {
  font-family: "Roboto", sans-serif;
  font-size: 3.2rem;
  font-weight: 700;
  color: #52b3c7;
  margin-right: 8px;
}

@media screen and (max-width: 767px) {
  .lp__options-price .num {
    font-size: 20px;
    margin-right: 4px;
  }
}

.lp__flow {
  margin-top: 120px;
}

@media screen and (max-width: 767px) {
  .lp__flow {
    margin-top: 80px;
  }
}

.lp__flow-wrap {
  position: relative;
}

@media screen and (max-width: 980px) {
  .lp__flow-wrap {
    max-width: 95%;
  }
}

@media screen and (min-width: 981px) {
  .lp__flow-wrap--tab {
    display: none;
  }
}

@media screen and (max-width: 980px) {
  .lp__flow-wrap--tab {
    min-width: 95%;
    -ms-flex-item-align: end;
    align-self: flex-end;
  }
}

.lp__flow-wrapper {
  margin-top: 104px;
}

@media screen and (max-width: 767px) {
  .lp__flow-wrapper {
    margin-top: 76px;
  }
}

@media screen and (max-width: 980px) {
  .lp__flow-block--pc {
    display: none;
  }
}

.lp__flow-head-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 48px;
  margin-bottom: 24px;
}

@media screen and (max-width: 980px) {
  .lp__flow-head-wrap {
    display: none;
  }
}

.lp__flow-head {
  font-family: "Roboto", sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  color: #fff;
  background-color: #52b3c7;
  padding: 16px 16px 8px;
  text-align: center;
  border-radius: 5px;
  position: relative;
}

.lp__flow-head--ai {
  background-color: #15c6e2;
}

.lp__flow-head-icon {
  position: absolute;
  top: -64px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

.lp__flow-content {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 48px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
}

@media screen and (max-width: 980px) {
  .lp__flow-content {
    grid-template-columns: 1fr;
  }
}

.lp__flow-content::before {
  content: "";
  width: 4px;
  height: 81%;
  background-color: #52b3c7;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

@media screen and (max-width: 980px) {
  .lp__flow-content::before {
    display: none;
  }
}

.lp__flow-ctr {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 189px;
}

@media screen and (max-width: 980px) {
  .lp__flow-ctr {
    gap: 82px;
  }
}

@media screen and (max-width: 767px) {
  .lp__flow-ctr {
    gap: 52px;
  }
}

.lp__flow-box {
  padding: 24px;
  border: 4px solid #52b3c7;
  border-radius: 10px;
  background-color: #fff;
}

@media screen and (max-width: 980px) {
  .lp__flow-box {
    padding: 36px 24px 24px;
  }
}

@media screen and (max-width: 767px) {
  .lp__flow-box {
    padding: 28px 24px 24px;
  }
}

.lp__flow-box--ai {
  border: 4px solid #15c6e2;
}

.lp__flow-inner {
  position: relative;
  z-index: 0;
}

.lp__flow-inner:not(:last-child) {
  margin-bottom: 16px;
}

@media screen and (max-width: 980px) {
  .lp__flow-inner:not(:last-child) {
    margin-bottom: 32px;
  }
}

@media screen and (max-width: 767px) {
  .lp__flow-inner:not(:last-child) {
    margin-bottom: 16px;
  }
}

.lp__flow-inner::before {
  content: "";
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background-color: #52b3c7;
  position: absolute;
  top: 50%;
  right: -35px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  z-index: 2;
}

@media screen and (max-width: 980px) {
  .lp__flow-inner::before {
    display: none;
  }
}

.lp__flow-inner::after {
  content: "";
  width: 26px;
  height: 4px;
  background-color: #52b3c7;
  position: absolute;
  right: -25px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  z-index: 1;
}

@media screen and (max-width: 980px) {
  .lp__flow-inner::after {
    display: none;
  }
}

.lp__flow-inner--ai::before {
  right: unset;
  left: -35px;
  background-color: #15c6e2;
}

.lp__flow-inner--ai::after {
  right: unset;
  left: -25px;
  top: 50%;
}

.lp__flow-icon {
  width: 77px;
  height: 77px;
  position: absolute;
  top: -45px;
  left: 27px;
}

@media screen and (min-width: 981px) {
  .lp__flow-icon {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .lp__flow-icon {
    width: 56px;
    height: 56px;
    top: -36px;
    left: 24px;
  }
}

.lp__flow-icon--ai {
  left: unset;
  right: 27px;
}

.lp__flow-line {
  width: 4px;
  height: 100%;
  background: #52b3c7;
  position: absolute;
  bottom: -50%;
  left: 64px;
  z-index: -1;
}

@media screen and (min-width: 981px) {
  .lp__flow-line {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .lp__flow-line {
    bottom: -50%;
    left: 49px;
  }
}

.lp__flow-line--ai {
  background: linear-gradient(to bottom, #52b3c7 4px, #15c6e2 2px 100%);
  left: unset;
  right: 64px;
  top: -86px;
  bottom: unset;
}

@media screen and (max-width: 767px) {
  .lp__flow-line--ai {
    right: 52px;
    top: -56px;
  }
}

.lp__flow-line--last {
  background: linear-gradient(to bottom, #15c6e2 4px, #52b3c7 2px 100%);
  left: 64px;
  bottom: unset;
  top: -85.8px;
}

@media screen and (max-width: 767px) {
  .lp__flow-line--last {
    left: 50px;
    top: -55px;
  }
}

.lp__flow-label {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.4583333333em;
  position: relative;
  padding-left: 44px;
}

@media screen and (max-width: 767px) {
  .lp__flow-label {
    font-size: 18px;
    padding-left: 36px;
  }
}

.lp__flow-label .num {
  font-family: "Roboto", sans-serif;
  font-size: 2.4rem;
  color: #52b3c7;
  position: absolute;
  top: 2px;
  left: 0;
}

.lp__flow-desc {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
  margin-top: 14px;
}

@media screen and (max-width: 767px) {
  .lp__flow-desc {
    margin-top: 8px;
  }
}

.lp__faq-contact {
  background: -webkit-gradient(linear, left top, left bottom, from(rgb(246, 246, 245)), color-stop(30%, rgb(243, 247, 245)), color-stop(50%, rgb(213, 255, 246)), to(rgb(164, 239, 255)));
  background: linear-gradient(to bottom, rgb(246, 246, 245) 0%, rgb(243, 247, 245) 30%, rgb(213, 255, 246) 50%, rgb(164, 239, 255) 100%);
  padding-bottom: 120px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .lp__faq-contact {
    padding-bottom: 80px;
  }
}

.lp__faq-contact::before {
  content: "";
  width: 328px;
  height: 322px;
  background: url("./public/img/top/faq-img.svg") no-repeat center/100% 100%;
  position: absolute;
  top: -165px;
  right: 103px;
}

@media screen and (max-width: 1200px) {
  .lp__faq-contact::before {
    width: 228px;
    height: 222px;
    right: 83px;
  }
}

@media screen and (max-width: 767px) {
  .lp__faq-contact::before {
    width: 110px;
    height: 111px;
    right: 15px;
    top: -90px;
  }
}

.lp__faq-ctr {
  padding: 0 4%;
  margin: 0 auto;
  max-width: calc(1200px + 8%);
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 767px) {
  .lp__faq-ctr {
    max-width: 100%;
  }
}

.lp__faq-content {
  margin-top: 80px;
}

@media screen and (max-width: 767px) {
  .lp__faq-content {
    margin-top: 40px;
  }
}

.lp__faq-question {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 54px;
  position: relative;
  padding-inline: 81px 40px;
  cursor: pointer;
}

@media screen and (max-width: 767px) {
  .lp__faq-question {
    padding-inline: 34px 32px;
  }
}

.lp__faq-answer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 54px;
  max-height: 0;
  overflow: hidden;
  padding-top: 0;
  margin-top: 0;
  -webkit-transition: max-height 0.3s ease, padding-top 0.3s ease, margin-top 0.3s ease;
  transition: max-height 0.3s ease, padding-top 0.3s ease, margin-top 0.3s ease;
  position: relative;
  padding-inline: 81px 40px;
}

@media screen and (max-width: 767px) {
  .lp__faq-answer {
    padding-inline: 34px 32px;
  }
}

.lp__faq-toggle {
  width: 24px;
  height: 24px;
  position: absolute;
  top: 50%;
  right: 7px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}

@media screen and (max-width: 767px) {
  .lp__faq-toggle {
    width: 16px;
    height: 16px;
  }
}

.lp__faq-icon {
  position: relative;
  width: 100%;
  height: 100%;
}

.lp__faq-icon::before,
.lp__faq-icon::after {
  content: "";
  width: 100%;
  height: 4px;
  background-color: #52b3c7;
  position: absolute;
  border-radius: 2px;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.lp__faq-icon::after {
  height: 100%;
  width: 4px;
  -webkit-transition: opacity 0.5s ease, -webkit-transform 0.5s ease;
  transition: opacity 0.5s ease, -webkit-transform 0.5s ease;
  transition: transform 0.5s ease, opacity 0.5s ease;
  transition: transform 0.5s ease, opacity 0.5s ease, -webkit-transform 0.5s ease;
}

.lp__faq-item {
  padding: 32px 40px;
  background-color: #fff;
  border-radius: 10px;
}

@media screen and (max-width: 767px) {
  .lp__faq-item {
    padding: 16px;
  }
}

.lp__faq-item.is-open .lp__faq-toggle .lp__faq-icon::after {
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
  transform: translate(-50%, -50%) rotate(90deg);
  opacity: 0;
}

.lp__faq-item.is-open .lp__faq-answer {
  max-height: 1000px;
  padding-top: 24px;
  margin-top: 33px;
  border-top: 2px solid #52b3c7;
}

@media screen and (max-width: 767px) {
  .lp__faq-item.is-open .lp__faq-answer {
    margin-top: 16px;
  }
}

.lp__faq-item:not(:last-child) {
  margin-bottom: 24px;
}

.lp__faq-text {
  font-family: "Roboto", sans-serif;
  font-size: 4rem;
  font-weight: 700;
  color: #52b3c7;
  position: absolute;
  top: -8px;
  left: 0;
}

@media screen and (max-width: 767px) {
  .lp__faq-text {
    font-size: 24px;
    top: 3px;
  }
}

.lp__faq-text--ans {
  top: 16px;
}

@media screen and (max-width: 767px) {
  .lp__faq-text--ans {
    top: 28px;
  }
}

.lp__faq-desc {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2em;
}

@media screen and (max-width: 767px) {
  .lp__faq-desc {
    font-size: 16px;
  }
}

.lp__contact {
  margin-top: 120px;
}

@media screen and (max-width: 767px) {
  .lp__contact {
    margin-top: 50px;
  }
}

.lp__contact-ctr.step-2 .lp__contact-btn {
  gap: 30px;
  margin-top: 80px;
}

@media screen and (max-width: 767px) {
  .lp__contact-ctr.step-2 .lp__contact-btn {
    margin-top: 40px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    gap: 20px;
  }
}

.lp__contact-ctr.step-2 .lp__contact-col.lp__contact-col--textarea .lp__contact-label {
  margin-top: 7px;
}

.lp__contact-intro {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
  margin-top: 41px;
}

@media screen and (max-width: 767px) {
  .lp__contact-intro {
    margin-top: 24px;
  }
}

.lp__contact-wrap {
  margin-top: 40px;
}

@media screen and (max-width: 767px) {
  .lp__contact-wrap {
    margin-top: 20px;
  }
}

.lp__contact-col {
  display: grid;
  grid-template-columns: 285px 1fr;
  gap: 24px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 980px) {
  .lp__contact-col {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 767px) {
  .lp__contact-col {
    gap: 8px;
  }
}

.lp__contact-col:not(:last-child) {
  margin-bottom: 32px;
}

@media screen and (max-width: 767px) {
  .lp__contact-col:not(:last-child) {
    margin-bottom: 16px;
  }
}

.lp__contact-col--textarea {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.lp__contact-col--textarea .lp__contact-label {
  margin-top: 24px;
}

@media screen and (max-width: 767px) {
  .lp__contact-col--textarea .lp__contact-label {
    margin-top: 0;
  }
}

.lp__contact-col--checkbox {
  margin-block: 40px 80px !important;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 0;
}

@media screen and (max-width: 767px) {
  .lp__contact-col--checkbox {
    margin-block: 24px 40px !important;
  }

  .lp__contact-col--checkbox::before {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
  }
}

.lp__contact-col--checkbox.required::before {
  content: "必須";
  font-size: 1.3rem;
  font-weight: 500;
  color: #fff;
  background-color: #f35757;
  padding: 4px 16px;
  border-radius: 5px;
  margin-right: 24px;
}

@media screen and (max-width: 767px) {
  .lp__contact-col--checkbox.required::before {
    padding: 2px 5px;
    margin-right: 0;
    margin-left: 16px;
  }
}

.lp__contact-label {
  font-size: 1.6rem;
  font-weight: 700;
  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;
}

@media screen and (max-width: 980px) {
  .lp__contact-label {
    max-width: -webkit-max-content;
    max-width: -moz-max-content;
    max-width: max-content;
    gap: 32px;
  }
}

@media screen and (max-width: 767px) {
  .lp__contact-label {
    gap: 16px;
  }
}

.lp__contact-label.required::after {
  content: "必須";
  font-size: 1.3rem;
  font-weight: 500;
  color: #fff;
  background-color: #f35757;
  padding: 4px 16px;
  border-radius: 5px;
}

@media screen and (max-width: 767px) {
  .lp__contact-label.required::after {
    padding: 2px 5px;
  }
}

.lp__contact-input {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
}

.lp__contact-input input[type=text],
.lp__contact-input input[type=email],
.lp__contact-input input[type=url],
.lp__contact-input textarea {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
  display: block;
  width: 100%;
  height: 72px;
  border-radius: 5px;
  padding: 24px;
  outline: none;
  border: none;
}

@media screen and (max-width: 767px) {

  .lp__contact-input input[type=text],
  .lp__contact-input input[type=email],
  .lp__contact-input input[type=url],
  .lp__contact-input textarea {
    padding: 12px 16px;
    height: 48px;
    border-radius: 2px;
  }
}

.lp__contact-input input[type=text]::-webkit-input-placeholder,
.lp__contact-input input[type=email]::-webkit-input-placeholder,
.lp__contact-input input[type=url]::-webkit-input-placeholder,
.lp__contact-input textarea::-webkit-input-placeholder {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
  color: #c2c2c2;
}

.lp__contact-input input[type=text]::-moz-placeholder,
.lp__contact-input input[type=email]::-moz-placeholder,
.lp__contact-input input[type=url]::-moz-placeholder,
.lp__contact-input textarea::-moz-placeholder {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
  color: #c2c2c2;
}

.lp__contact-input input[type=text]:-ms-input-placeholder,
.lp__contact-input input[type=email]:-ms-input-placeholder,
.lp__contact-input input[type=url]:-ms-input-placeholder,
.lp__contact-input textarea:-ms-input-placeholder {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
  color: #c2c2c2;
}

.lp__contact-input input[type=text]::-ms-input-placeholder,
.lp__contact-input input[type=email]::-ms-input-placeholder,
.lp__contact-input input[type=url]::-ms-input-placeholder,
.lp__contact-input textarea::-ms-input-placeholder {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
  color: #c2c2c2;
}

.lp__contact-input input[type=text]::placeholder,
.lp__contact-input input[type=email]::placeholder,
.lp__contact-input input[type=url]::placeholder,
.lp__contact-input textarea::placeholder {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
  color: #c2c2c2;
}

.lp__contact-input--textarea textarea {
  font-size: 1.6rem;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  line-height: 2.25em;
  height: 112px;
  resize: none;
}

@media screen and (max-width: 767px) {
  .lp__contact-input--textarea textarea {
    height: 170px;
  }
}

.lp__contact-input label input[type=checkbox] {
  display: none;
}

.lp__contact-input label span {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 7px;
  font-size: 1.6rem;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  letter-spacing: 0.05em;
}

@media screen and (max-width: 767px) {
  .lp__contact-input label span {
    font-size: 14px;
  }
}

.lp__contact-input label input[type=checkbox]+span::before {
  content: "";
  display: block;
  width: 14.4px;
  height: 14.4px;
  background-color: #fff;
  border: 1px solid #52b3c7;
  border-radius: 2px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  position: relative;
}

.lp__contact-input label input[type=checkbox]+span::after {
  content: "";
  width: 12px;
  height: 12px;
  position: absolute;
  left: 3%;
  top: 50%;
  background: url("./public/img/icons/check-icon.svg") no-repeat center/100% 100%;
  font-family: "Noto Sans JP", sans-serif;
  color: #52b3c7;
  line-height: 1em;
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transform-origin: center;
  transform-origin: center;
}

.lp__contact-input label input[type=checkbox]:not(:checked)+span::after {
  -webkit-transform: translate(-50%, -50%) scale(0);
  transform: translate(-50%, -50%) scale(0);
}

.lp__contact-input label input[type=checkbox]:checked+span::after {
  -webkit-transform: translate(-50%, -50%) scale(1);
  transform: translate(-50%, -50%) scale(1);
}

.lp__contact-checkbox-text {
  font-size: 1.6rem;
  font-weight: 500;
  margin-left: 9px;
  line-height: 2em;
}

.lp__checkbox-link {
  color: #f28200;
  text-decoration: underline;
}

.lp__contact-btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.lp__about {
  background-color: #a4efff;
  position: relative;
  overflow: hidden;
  padding-block: 120px;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .lp__about {
    padding-block: 80px;
  }
}

.lp__about::before {
  content: "";
  width: 100%;
  height: 100%;
  background: url("./public/img/deco/about-bg.png") no-repeat top/cover;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}

.lp__about-ctr {
  padding: 0 4%;
  margin: 0 auto;
  max-width: calc(1200px + 8%);
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 767px) {
  .lp__about-ctr {
    max-width: 100%;
  }
}

.lp__about-content {
  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: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: 80px;
}

@media screen and (max-width: 767px) {
  .lp__about-content {
    margin-top: 40px;
  }
}

.lp__about-image {
  max-width: 587px;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .lp__about-image {
    max-width: 345px;
  }
}

.lp__about-desc {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
  margin-block: 40px 80px;
}

@media screen and (max-width: 767px) {
  .lp__about-desc {
    margin-block: 24px 40px;
  }
}

.lp__about-info {
  max-width: 800px;
  width: 100%;
  padding: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 64px;
  background-color: #fff;
  -webkit-filter: drop-shadow(0 0 6px #c3f2e8);
  filter: drop-shadow(0 0 6px #c3f2e8);
  border-radius: 10px;
}

@media screen and (max-width: 767px) {
  .lp__about-info {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    border-radius: 5px;
    gap: 29px;
    padding: 24px 18px;
  }
}

@media screen and (max-width: 767px) {
  .lp__about-wrap {
    width: 100%;
  }
}

.lp__about-website {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 16px;
}

.lp__about-link {
  font-size: 1.3rem;
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16px;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

@media screen and (max-width: 767px) {
  .lp__about-link {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
}

.lp__about-other-info {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25em;
}

.lp__contact-confirm {
  padding-top: 100px;
  background: -webkit-gradient(linear, left top, left bottom, from(rgb(246, 246, 245)), color-stop(30%, rgb(243, 247, 245)), color-stop(50%, rgb(213, 255, 246)));
  background: linear-gradient(to bottom, rgb(246, 246, 245) 0%, rgb(243, 247, 245) 30%, rgb(213, 255, 246) 50%);
}

@media screen and (max-width: 767px) {
  .lp__contact-confirm {
    padding-top: 100px;
  }
}

.lp__contact-confirm .lp__about {
  background: -webkit-gradient(linear, left bottom, left top, from(rgb(246, 246, 245)), color-stop(30%, rgb(243, 247, 245)), color-stop(50%, rgb(213, 255, 246)));
  background: linear-gradient(to top, rgb(246, 246, 245) 0%, rgb(243, 247, 245) 30%, rgb(213, 255, 246) 50%);
}

.lp__contact-btn-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: 120px;
}

@media screen and (max-width: 767px) {
  .lp__contact-btn-group {
    margin-top: 60px;
  }
}

.lp__contact-complete {
  padding-top: 100px;
  background: -webkit-gradient(linear, left top, left bottom, from(rgb(246, 246, 245)), color-stop(30%, rgb(243, 247, 245)), color-stop(50%, rgb(213, 255, 246)));
  background: linear-gradient(to bottom, rgb(246, 246, 245) 0%, rgb(243, 247, 245) 30%, rgb(213, 255, 246) 50%);
}

@media screen and (max-width: 767px) {
  .lp__contact-complete {
    padding-top: 80px;
  }
}

.lp__contact-complete .lp__about {
  background: -webkit-gradient(linear, left bottom, left top, from(rgb(246, 246, 245)), color-stop(30%, rgb(243, 247, 245)), color-stop(50%, rgb(213, 255, 246)));
  background: linear-gradient(to top, rgb(246, 246, 245) 0%, rgb(243, 247, 245) 30%, rgb(213, 255, 246) 50%);
}

.lp__contact-complete-title {
  font-size: 2.4rem;
  margin-bottom: 30px;
}

@media screen and (max-width: 767px) {
  .lp__contact-complete-title {
    margin-bottom: 15px;
  }
}

.lp__contact-complete-desc {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2em;
}

.overflow {
  overflow: hidden;
}

.pc {
  display: block;
}

@media screen and (max-width: 767px) {
  .pc {
    display: none;
  }
}

@media screen and (max-width: 980px) {
  .pc-tablet {
    display: none;
  }
}

@media screen and (min-width: 981px) {
  .sp-tablet {
    display: none;
  }
}

.sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .sp {
    display: block;
  }
}

.sp-flex {
  display: none;
}

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

.anchor {
  display: block;
  position: relative;
  top: -150px;
  visibility: hidden;
}

@media screen and (max-width: 767px) {
  .anchor {
    top: -100px;
  }
}

.hidden {
  display: none !important;
}

.fab__container .js-contact-btn {
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}

.fab__container .js-contact-btn.is-hidden {
  opacity: 0;
  pointer-events: none;
}

.lp__contact-confirm .lp__contact-input {
  word-break: break-all;
}

.lp__contact .wpcf7-list-item {
  margin: 0 !important;
}

.lp__contact .wpcf7-not-valid-tip {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  font-size: 13px !important;
  line-height: 1em !important;
  position: absolute;
  bottom: -17px;
  left: 0;
}

@media screen and (max-width: 767px) {
  .lp__contact .wpcf7-not-valid-tip {
    font-size: 10px !important;
    bottom: -13px;
  }
}

.lp__contact .lp__contact-input {
  position: relative;
}

.lp__contact .lp__contact-col.lp__contact-col--checkbox .lp__contact-input.lp__contact-input--checkbox .wpcf7-not-valid-tip {
  position: absolute;
  bottom: -35px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

@media screen and (max-width: 767px) {
  .lp__contact .lp__contact-col.lp__contact-col--checkbox .lp__contact-input.lp__contact-input--checkbox .wpcf7-not-valid-tip {
    bottom: -20px;
  }
}

.lp__contact button,
.lp__contact-confirm button {
  border: 0;
}