/* =======================================
 home
 最終更新：2025/09/16 13:30
======================================= */

@media screen and (min-width: 769px) {
  .fv-inner {
    /* 2025/10/29 fv04のデザインに変更にあたりコメントアウト */
    /* margin: 70px auto 0 !important; */
    max-width: none !important;
    width: 93.75% !important;
  }
}


/* home-title */
.home-title {
  text-align: center;
}
.home-title::after {
  background: var(--color-primary);
  content: "";
  display: block;
}
@media screen and (max-width: 768px) {
  .home-title::after {
    height: 1px;
    margin: 2.667vw auto 0;
    width: 8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-title::after {
    height: 2px;
    margin: 1.953vw auto 0;
    width: 4.688vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-title::after {
    margin: 25px auto 0;
    width: 60px;
  }
}

.home-title__en {
  color: var(--color-primary);
  letter-spacing: 0.14em;
  line-height: 1;
  margin: 0;
  padding: 0;
  text-transform: uppercase;
}
@media screen and (max-width: 768px) {
  .home-title__en {
    font-size: 3.733vw;
  }
}
@media screen and (min-width: 769px) {
  .home-title__en {
    font-size: 1.719vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-title__en {
    font-size: 22px;
  }
}

.home-title__ja {
  color: #333;
  letter-spacing: 0.1em;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .home-title__ja {
    font-size: 6.667vw;
    line-height: 1.36;
    margin: 0.667vw 0 0;
  }
}
@media screen and (min-width: 769px) {
  .home-title__ja {
    font-size: 2.813vw;
    line-height: 1.3;
    margin: 0.781vw 0 0;
  }
}
@media screen and (min-width: 1280px) {
  .home-title__ja {
    font-size: 36px;
    margin: 10px 0 0;
  }
}

/* cta */
.home-cta {
  display: flex;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .home-cta {
    align-items: center;
    flex-direction: column;
    gap: 4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-cta {
    gap: 1.563vw;
    justify-content: center;
  }
}
@media screen and (min-width: 1280px) {
  .home-cta {
    gap: 20px;
  }
}

.home-cta__item {
  align-items: center;
  background-repeat: no-repeat;
  display: flex;
  flex-direction: column;
  justify-content: center;
  line-height: 1;
  padding: 0;
  position: relative;
  text-align: center;
  text-decoration: none;
  transition: box-shadow 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .home-cta__item {
    border-radius: 7.333vw;
    box-shadow: 0.587vw 1.173vw 0 rgba(53, 96, 122, 0.3);
    gap: 2vw;
    height: 14.667vw;
    width: 70.4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-cta__item {
    border-radius: 3.906vw;
    box-shadow: 0.313vw 0.625vw 0 rgba(53, 96, 122, 0.3);
    gap: 0.781vw;
    height: 7.813vw;
    width: 37.5vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-cta__item {
    border-radius: 50px;
    box-shadow: 4px 8px 0 rgba(53, 96, 122, 0.3);
    gap: 10px;
    height: 100px;
    width: 480px;
  }
}

.home-cta__label-lead {
  font-weight: 700;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
  .home-cta__label-lead {
    font-size: 2.933vw;
  }
}
@media screen and (min-width: 769px) {
  .home-cta__label-lead {
    font-size: 1.406vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-cta__label-lead {
    font-size: 18px;
  }
}

.home-cta__label {
  font-weight: 700;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
  .home-cta__label {
    font-size: 4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-cta__label {
    font-size: 1.719vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-cta__label {
    font-size: 22px;
  }
}

.home-cta__arrow {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .home-cta__arrow {
    right: 2.933vw;
    width: 3.6vw;
  }
}
@media screen and (min-width: 769px) {
  .home-cta__arrow {
    right: 1.563vw;
    width: 1.953vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-cta__arrow {
    right: 20px;
    width: 25px;
  }
}

.home-cta__item--dl {
  background: #ff4c4d;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .home-cta__item--dl {
    border: 1px solid #ff4c4d;
  }
}
@media screen and (min-width: 769px) {
  .home-cta__item--dl {
    border: 2px solid #ff4c4d;
  }
}
.home-cta__item--dl .home-cta__arrow {
  fill: #fff;
}
@media (any-hover: hover) {
  .home-cta__item--dl:hover {
    background: #fff;
    box-shadow: unset;
    color: #ff4c4d;
  }
}
@media screen and (any-hover: hover) and (max-width: 768px) {
  .home-cta__item--dl:hover {
    -webkit-transform: translateY(1.173vw);
            transform: translateY(1.173vw);
  }
}
@media screen and (any-hover: hover) and (min-width: 769px) {
  .home-cta__item--dl:hover {
    -webkit-transform: translateY(0.625vw);
            transform: translateY(0.625vw);
  }
}
@media screen and (any-hover: hover) and (min-width: 1280px) {
  .home-cta__item--dl:hover {
    -webkit-transform: translateY(8px);
            transform: translateY(8px);
  }
}
@media (any-hover: hover) {
  .home-cta__item--dl:hover .home-cta__arrow {
    fill: #ff4c4d;
  }
}

.home-cta__item--trial {
  background: #fff;
  color: var(--color-tertiary);
}
@media screen and (max-width: 768px) {
  .home-cta__item--trial {
    border: 1px solid var(--color-tertiary);
  }
}
@media screen and (min-width: 769px) {
  .home-cta__item--trial {
    border: 2px solid var(--color-tertiary);
  }
}
.home-cta__item--trial .home-cta__arrow {
  fill: var(--color-tertiary);
}
@media (any-hover: hover) {
  .home-cta__item--trial:hover {
    background: var(--color-tertiary);
    box-shadow: unset;
    color: #fff;
  }
}
@media screen and (any-hover: hover) and (max-width: 768px) {
  .home-cta__item--trial:hover {
    -webkit-transform: translateY(1.173vw);
            transform: translateY(1.173vw);
  }
}
@media screen and (any-hover: hover) and (min-width: 769px) {
  .home-cta__item--trial:hover {
    -webkit-transform: translateY(0.625vw);
            transform: translateY(0.625vw);
  }
}
@media screen and (any-hover: hover) and (min-width: 1280px) {
  .home-cta__item--trial:hover {
    -webkit-transform: translateY(8px);
            transform: translateY(8px);
  }
}
@media (any-hover: hover) {
  .home-cta__item--trial:hover .home-cta__arrow {
    fill: #fff;
  }
}

.home .main {
  padding-top: 0;
}

/* kv */
@media screen and (max-width: 768px) {
  .home-kv {
    background: url(../images/home/kv_bg_sp.jpg) 0 0/100% auto no-repeat;
    /* 2025/10/29 fv04のデザインに変更にあたりコメントアウト */
    /* padding: 23.333vw 0 6.667vw; */
  }
}
@media screen and (min-width: 769px) {
  .home-kv {
    background: linear-gradient(150deg, rgb(255, 255, 255) 0%, rgb(249, 252, 253) 16.2%, rgb(233, 242, 247) 37.4%, rgb(206, 227, 238) 61.38%, rgb(168, 205, 225) 87.21%, rgb(147, 193, 217) 100%);
    /* 2025/10/29 fv04のデザインに変更にあたりコメントアウト */
    /* padding: 8.594vw 0 0; */
    position: relative;
  }
}
@media screen and (min-width: 1280px) {
  .home-kv {
    /* 6/4 fv全画面化のため修正 */
    /* padding: 110px 0 0; */
    /* 2025/10/29 fv04のデザインに変更にあたりコメントアウト */
    /* padding: 80px 0 0; */
  }
}
@media screen and (min-width: 769px) {
  .home-kv::after {
    background: url(../images/home/kv_bg_pc_02.svg) 50% 100%/auto 100% no-repeat;
    bottom: -1px;
    content: "";
    display: block;
    height: 9.688vw;
    left: 0;
    position: absolute;
    width: 100%;
  }
}
@media screen and (min-width: 1280px) {
  .home-kv::after {
    background-size: auto 124px;
    height: 124px;
  }
}
@media screen and (min-width: 2000px) {
  .home-kv::after {
    background-size: cover;
  }
}

.home-kv__top {
  align-items: center;
  display: flex;
  
}
@media screen and (max-width: 768px) {
  .home-kv__top {
    gap: 5.333vw;
    flex-direction: column;
  }
}
@media screen and (min-width: 769px) {
  .home-kv__top {
    justify-content: space-between;
    padding: 0px 4.219vw 0 5.078vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-kv__top {
    /* 6/4 fv全画面化のため修正 */
    /* padding: 0 54px 0 65px; */
    /* 10/24追加 fv03デザインに変更に伴いコメントアウト */
    /* padding: 30px 6vw 0 !important; */
    /* 6/4 fv全画面化のため追加 */
    transform: scale(0.9);
    gap: 4vw;
    height: auto;
  }
}

@media screen and (max-width: 768px) {
  .home-kv__content {
    width: 84.8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-kv__content {
    width: 41.406vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-kv__content {
    /* 6/4 fv全画面化のため追加 */
    /* width: 530px; */
    flex: 1;
  }
}

.home-support {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-support {
    margin-top: 3.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-support {
    margin-top: 1.419vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-support {
    margin-top: 22px;
  }
}

.home-support__title {
  color: #333;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .home-support__title {
    font-size: 5.067vw;
  }
}
@media screen and (min-width: 769px) {
  .home-support__title {
    font-size: 2.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-support__title {
    font-size: 30px;
  }
}

.home-support__list {
  display: flex;
  justify-content: center;
  list-style: none;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .home-support__list {
    gap: 0.8vw;
    margin: 2.667vw 0 0;
  }
}
@media screen and (min-width: 769px) {
  .home-support__list {
    gap: 0.391vw;
    margin: 0.938vw 0 0;
  }
}
@media screen and (min-width: 1280px) {
  .home-support__list {
    gap: 5px;
    /* 6/4 fv全画面化のため修正 */
    /* margin: 12px 0 0; */
    margin: 1.2vw 0 0 0;
  }
}

.home-support__item {
  color: #fff;
}
@media screen and (max-width: 768px) {
  .home-support__item {
    border-radius: 0.96vw;
    font-size: 3.467vw;
    line-height: 2.308;
    width: 20vw;
  }
}
@media screen and (min-width: 769px) {
  .home-support__item {
    border-radius: 0.469vw;
    font-size: 1.719vw;
    line-height: 2.273;
    width: 9.766vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-support__item {
    border-radius: 6px;
    font-size: 19px;
    /* 6/4 fv全画面化のため修正 */
    /* width: 125px; */
    width: 7.8vw;
    aspect-ratio: 5 / 2;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3vw !important;
  }
}
.home-support__item--chatgpt {
  background: #5dbba7;
}
.home-support__item--claude {
  background: #cd7a55;
}
.home-support__item--gemini {
  background: linear-gradient(10deg, rgb(69, 139, 199) 0%, rgb(72, 140, 199) 25.89%, rgb(80, 145, 201) 41.47%, rgb(94, 152, 203) 54.32%, rgb(115, 163, 206) 65.68%, rgb(141, 177, 210) 76.06%, rgb(173, 194, 215) 85.73%, rgb(211, 213, 221) 94.67%, rgb(237, 227, 225) 100%);
}
.home-support__item--perplexity {
  background: #1e7884;
}
.home-support__item--grok {
  background: #343434;
}

.home-kv__image {
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .home-kv__image {
    width: 64.267vw;
  }
}
@media screen and (min-width: 769px) {
  .home-kv__image {
    width: 37.656vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-kv__image {
    /* 6/4 fv全画面化のため修正 */
    /* width: 482px; */
    flex: 0.8;
    height: auto;
    img {
      width: 100%;
    }
  }
}

.home-detail {
  display: flex;
  position: relative;
  justify-content: center;
  list-style: none;
  padding: 0;
  width: fit-content;
}
@media screen and (max-width: 768px) {
  .home-detail {
    gap: 1.067vw;
    margin: 2.933vw auto 0;
  }
}
@media screen and (min-width: 769px) {
  .home-detail {
    gap: 0.781vw;
    margin: 2.188vw auto 0;
  }
}
@media screen and (min-width: 1280px) {
  .home-detail {
    gap: 10px;
    /* 6/4 fv全画面化のため修正 */
    /* margin: 28px 0 0; */
    margin: 1vw auto 0;
  }
}

.home-detail__item {
  align-items: center;
  display: flex;
  justify-content: center;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-detail__item {
    height: 14.667vw;
    width: 24vw;
  }
}
@media screen and (min-width: 769px) {
  .home-detail__item {
    height: 7.031vw;
    width: 19.531vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-detail__item {
    /* 6/4 fv全画面化のため修正 */
    /* height: 90px;
    width: 250px; */
    width: 17vw;
    aspect-ratio: 25 / 9;
  }
}
.home-detail__item::before {
  background: linear-gradient(180deg, rgb(96, 202, 200) 0%, rgb(94, 197, 199) 1.76%, rgb(82, 174, 195) 11.73%, rgb(73, 157, 192) 23.27%, rgb(67, 144, 190) 37.18%, rgb(63, 137, 188) 55.91%, rgb(62, 135, 188) 100%);
  content: "";
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  -webkit-transform: skew(-12deg);
          transform: skew(-12deg);
  width: 100%;
}

.home-detail__label {
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-align: center;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .home-detail__label {
    font-size: 2.933vw;
    line-height: 1.364;
  }
}
@media screen and (min-width: 769px) {
  .home-detail__label {
    font-size: 1.719vw;
    line-height: 1.364;
  }
}
@media screen and (min-width: 1280px) {
  .home-detail__label {
    /* 6/4 fv全画面化のため修正 */
    /* font-size: 22px; */
    font-size: 1.4vw !important;
  }
}

.home-patent {
  align-items: center;
  background: #ffa300;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .home-patent {
    margin: 3.467vw auto 0;
    width: 84.8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-patent {
    margin: 1.953vw auto 0;
    width: 70.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-patent {
    margin: 25px auto 0;
    width: 900px;
  }
}

.home-patent__def-title {
  color: #fff;
  letter-spacing: 0.08em;
  margin: 0;
  padding: 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-patent__def-title {
    font-size: 2.933vw;
    line-height: 1.364;
    width: 18.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-patent__def-title {
    font-size: 1.406vw;
    line-height: 1;
    width: 10.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-patent__def-title {
    font-size: 18px;
    width: 140px;
  }
}

.home-patent__def-data {
  background: #fff;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .home-patent__def-data {
    font-size: 2.4vw;
    line-height: 1.556;
    padding: 1.733vw 2.667vw 1.733vw 2.933vw;
    text-align: justify;
    width: calc(100% - 18.667vw);
  }
}
@media screen and (min-width: 769px) {
  .home-patent__def-data {
    font-size: 1.25vw;
    padding: 0.859vw 0.781vw;
    width: calc(100% - 10.938vw);
  }
}
@media screen and (min-width: 1280px) {
  .home-patent__def-data {
    font-size: 16px;
    padding: 11px 10px;
    width: calc(100% - 140px);
  }
}

.home-cta--kv {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .home-cta--kv {
    margin-top: 7.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-cta--kv {
    margin-top: 6.641vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-cta--kv {
    margin-top: 85px;
  }
}

/* customer */
.home-customer {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .home-customer {
    padding: 3.333vw 0;
  }
}
@media screen and (min-width: 769px) {
  .home-customer {
    margin-top: 4.297vw;
    padding: 1.172vw 0;
  }
}
@media screen and (min-width: 1280px) {
  .home-customer {
    margin-top: 55px;
    padding: 15px 0;
  }
}

@-webkit-keyframes customer-slide {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}

@keyframes customer-slide {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
.home-customer__list {
  -webkit-animation: customer-slide 50s linear infinite;
          animation: customer-slide 50s linear infinite;
  display: flex;
  flex-wrap: nowrap;
  list-style: none;
  margin: 0;
  padding: 0;
}

.home-customer__item {
  display: flex;
  margin: 0;
  width: -webkit-max-content;
  width: max-content;
}
@media screen and (max-width: 768px) {
  .home-customer__item {
    height: 8vw;
    padding: 0 2.933vw;
  }
}
@media screen and (min-width: 769px) {
  .home-customer__item {
    height: 3.125vw;
    padding: 0 1.172vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-customer__item {
    height: 40px;
    padding: 0 15px;
  }
}

.home-customer__image {
  height: 100% !important;
  /* 6/13 修正 */
  /* width: auto !important; */
  width: fit-content !important;
  /* 6/13 追加 */
  object-fit: contain;
}

/* about */

.home-about {
  background: linear-gradient(0deg, rgba(147, 193, 217, 0.35) 0%, rgba(151, 195, 218, 0.35) 18.74%, rgba(164, 203, 223, 0.35) 38.16%, rgba(184, 214, 230, 0.35) 57.89%, rgba(213, 231, 240, 0.35) 77.84%, rgba(250, 252, 253, 0.35) 97.78%, rgba(255, 255, 255, 0.35) 100%);
}
@media screen and (max-width: 768px) {
  iframe {
    max-width: 100%;
  }
  .home-about {
    margin-top: 1.6vw;
    padding: 12vw 0 9.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-about {
    margin-top: 2.031vw;
    padding: 5.469vw 0 6.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-about {
    margin-top: 26px;
    padding: 70px 0 80px;
  }
}

.home-about__title {
  line-height: 1;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .home-about__title {
    width: 67.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-about__title {
    width: 39.297vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-about__title {
    width: 503px;
  }
}

@media screen and (max-width: 768px) {
  .home-about__text-wrap {
    margin: 6.667vw auto 0;
    width: 84.8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-about__text-wrap {
    margin: 2.344vw auto 0;
    width: 78.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-about__text-wrap {
    margin: 30px auto 0;
    width: 1000px;
  }
}

.home-about__text {
  letter-spacing: 0.04em;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .home-about__text {
    font-size: 3.733vw;
    line-break: strict;
    line-height: 1.786;
    text-align: justify;
  }
}
@media screen and (min-width: 769px) {
  .home-about__text {
    font-size: 1.406vw;
    line-height: 2.111;
    text-align: center;
  }
}
@media screen and (min-width: 1280px) {
  .home-about__text {
    font-size: 18px;
  }
}

.home-about__bottom {
  display: flex;
}
@media screen and (max-width: 768px) {
  .home-about__bottom {
    align-items: center;
    gap: 4vw;
    flex-direction: column;
    margin: 8vw auto 0;
    width: 84.8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-about__bottom {
    align-items: flex-start;
    justify-content: space-between;
    margin: 3.125vw auto 0;
    width: 85.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-about__bottom {
    margin: 40px auto 0;
    width: 1100px;
  }
}

.home-movie {
  aspect-ratio: 16/9;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-movie {
    width: 100%;
  }
}
@media screen and (min-width: 769px) {
  .home-movie {
    margin-top: 0.938vw;
    width: 46.094vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-movie {
    margin-top: 12px;
    width: 590px;
  }
}

.home-movie__video {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.home-about__image {
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .home-about__image {
    width: 74.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-about__image {
    width: 37.5vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-about__image {
    width: 480px;
  }
}

/* feature */
@media screen and (max-width: 768px) {
  .home-feature {
    padding: 14.667vw 0 13.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-feature {
    padding: 7.813vw 0 6.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-feature {
    padding: 100px 0 80px;
  }
}

@media screen and (max-width: 768px) {
  .home-feature__content {
    margin-top: 10.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-feature__content {
    margin-top: 5.859vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-feature__content {
    margin-top: 75px;
  }
}

@media screen and (min-width: 769px) {
  .home-point__row {
    display: flex;
    justify-content: space-between;
  }
}

@media screen and (min-width: 769px) {
  .home-point__content {
    width: 41.406vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point__content {
    width: 530px;
  }
}

.home-point__title {
  align-items: center;
  color: #fff;
  display: flex;
  line-height: 1;
  justify-content: center;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-point__title {
    height: 10.667vw;
    margin: 0 auto;
    width: 28vw;
  }
}
@media screen and (min-width: 769px) {
  .home-point__title {
    height: 4.922vw;
    width: 12.891vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point__title {
    height: 63px;
    width: 165px;
  }
}
.home-point__title::before {
  background: linear-gradient(90deg, rgb(96, 202, 200) 0%, rgb(96, 201, 200) 0.66%, rgb(81, 172, 195) 26.01%, rgb(70, 152, 191) 51.22%, rgb(64, 139, 189) 76.04%, rgb(62, 135, 188) 100%);
  content: "";
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  -webkit-transform: skew(-16deg);
          transform: skew(-16deg);
  width: 100%;
}

.home-point__title-label {
  font-weight: 700;
  letter-spacing: 0.08em;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .home-point__title-label {
    font-size: 4.445vw;
  }
}
@media screen and (min-width: 769px) {
  .home-point__title-label {
    font-size: 2.031vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point__title-label {
    font-size: 26px;
  }
}

.home-point__title-num {
  letter-spacing: 0;
}
@media screen and (max-width: 768px) {
  .home-point__title-num {
    font-size: 7.133vw;
  }
}
@media screen and (min-width: 769px) {
  .home-point__title-num {
    font-size: 3.281vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point__title-num {
    font-size: 42px;
  }
}

.home-point__catch {
  font-weight: 900;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  .home-point__catch {
    font-size: 6.133vw;
    line-height: 1.522;
    margin: 2.667vw 0 0;
    text-align: center;
  }
}
@media screen and (min-width: 769px) {
  .home-point__catch {
    font-size: 2.5vw;
    line-height: 1.563;
    margin-bottom: 0;
    margin-top: 2.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point__catch {
    font-size: 32px;
    margin-top: 30px;
  }
}

.home-point__border {
  background: #304499;
  display: block;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-point__border {
    height: 1px;
    margin-top: 4.667vw;
    width: 93.6vw;
  }
}
@media screen and (min-width: 769px) {
  .home-point__border {
    height: 2px;
    margin-top: 1.953vw;
    width: 40.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point__border {
    margin-top: 25px;
    width: 524px;
  }
}
.home-point__border::before {
  aspect-ratio: 1/1;
  border-radius: 50%;
  box-sizing: content-box;
  content: "";
  display: block;
  position: absolute;
  top: 50%;
}
@media screen and (max-width: 768px) {
  .home-point__border::before {
    border: 1px solid #304499;
    -webkit-transform: translateY(-45%);
            transform: translateY(-45%);
    width: 3px;
  }
}
@media screen and (min-width: 769px) {
  .home-point__border::before {
    border: 2px solid #304499;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 6px;
  }
}
@media screen and (min-width: 769px) {
  .home-point__border::after {
    background: #304499;
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    top: 0;
    width: 45vw;
  }
}

.home-point__text {
  letter-spacing: 0.08em;
  text-align: justify;
}
@media screen and (max-width: 768px) {
  .home-point__text {
    font-size: 3.733vw;
    line-height: 1.786;
    margin: 4.8vw auto 0;
    width: 85.2vw;
  }
}
@media screen and (min-width: 769px) {
  .home-point__text {
    font-size: 1.406vw;
    line-height: 2;
    margin-bottom: 0;
    margin-top: 1.563vw;
    width: 35.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point__text {
    font-size: 18px;
    margin-top: 20px;
    width: 460px;
  }
}

.home-point__mark {
  background: #ffff98;
}

@media screen and (max-width: 768px) {
  .home-point__image {
    margin: 5.333vw auto 0;
    width: 82.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-point__image {
    margin: 0;
    width: 48.438vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point__image {
    width: 620px;
  }
}

@media screen and (min-width: 769px) {
  .home-point:nth-child(odd) .home-point__row {
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 769px) {
  .home-point:nth-child(odd) .home-point__title {
    margin: 0 auto 0 0.234vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point:nth-child(odd) .home-point__title {
    margin: 0 auto 0 3px;
  }
}
@media screen and (min-width: 769px) {
  .home-point:nth-child(odd) .home-point__catch {
    margin-left: 1.563vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point:nth-child(odd) .home-point__catch {
    margin-left: 20px;
  }
}
@media screen and (min-width: 769px) {
  .home-point:nth-child(odd) .home-point__text {
    margin-left: auto;
    margin-right: 3.906vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point:nth-child(odd) .home-point__text {
    margin-right: 50px;
  }
}
@media screen and (max-width: 768px) {
  .home-point:nth-child(odd) .home-point__border {
    margin-right: auto;
  }
}
@media screen and (max-width: 768px) {
  .home-point:nth-child(odd) .home-point__border::before {
    right: -4px;
  }
}
@media screen and (min-width: 769px) {
  .home-point:nth-child(odd) .home-point__border::before {
    left: -8px;
  }
}
@media screen and (min-width: 769px) {
  .home-point:nth-child(odd) .home-point__border::after {
    left: 100%;
  }
}
@media screen and (min-width: 769px) {
  .home-point:nth-child(even) .home-point__title {
    margin: 0 auto 0 2.734vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point:nth-child(even) .home-point__title {
    margin: 0 auto 0 35px;
  }
}
@media screen and (min-width: 769px) {
  .home-point:nth-child(even) .home-point__catch,
  .home-point:nth-child(even) .home-point__text {
    margin-left: 3.906vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point:nth-child(even) .home-point__catch,
  .home-point:nth-child(even) .home-point__text {
    margin-left: 50px;
  }
}
@media screen and (max-width: 768px) {
  .home-point:nth-child(even) .home-point__border {
    margin-left: auto;
  }
}
@media screen and (max-width: 768px) {
  .home-point:nth-child(even) .home-point__border::before {
    left: -4px;
  }
}
@media screen and (min-width: 769px) {
  .home-point:nth-child(even) .home-point__border::before {
    right: -8px;
  }
}
@media screen and (min-width: 769px) {
  .home-point:nth-child(even) .home-point__border::after {
    right: 100%;
  }
}

@media screen and (max-width: 768px) {
  .home-point--01 .home-point__image {
    margin-top: 4.533vw;
    text-indent: -0.533vw;
    width: 85.6vw;
  }
}
@media screen and (min-width: 769px) {
  .home-point--01 .home-point__image {
    margin-left: -0.313vw;
    margin-top: -0.469vw;
    width: 50.156vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point--01 .home-point__image {
    margin-left: -4px;
    margin-top: -6px;
    width: 642px;
  }
}

@media screen and (max-width: 768px) {
  .home-point--02 {
    margin-top: 18vw;
  }
}
@media screen and (min-width: 769px) {
  .home-point--02 {
    margin-top: 11.719vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point--02 {
    margin-top: 150px;
  }
}

@media screen and (max-width: 768px) {
  .home-point--03 {
    margin-top: 17.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-point--03 {
    margin-top: 12.5vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point--03 {
    margin-top: 160px;
  }
}

@media screen and (max-width: 768px) {
  .home-point--04 {
    margin-top: 22vw;
  }
}
@media screen and (min-width: 769px) {
  .home-point--04 {
    margin-top: 9.766vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point--04 {
    margin-top: 125px;
  }
}
@media screen and (min-width: 769px) {
  .home-point--04 .home-point__content {
    width: 44.688vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point--04 .home-point__content {
    width: 572px;
  }
}
@media screen and (min-width: 769px) {
  .home-point--04 .home-point__border {
    width: 44.219vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point--04 .home-point__border {
    width: 566px;
  }
}

.home-point--05 {
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-point--05 {
    margin-top: 20vw;
  }
}
@media screen and (min-width: 769px) {
  .home-point--05 {
    margin-top: 10.156vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point--05 {
    margin-top: 130px;
  }
}

@media screen and (max-width: 768px) {
  .home-certification {
    margin: -6.667vw auto 0 6.667vw;
    width: 40vw;
  }
}
@media screen and (min-width: 769px) {
  .home-certification {
    left: 3.906vw;
    position: absolute;
    top: 30.625vw;
    width: 17.969vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-certification {
    left: 50px;
    top: 392px;
    width: 230px;
  }
}

@media screen and (max-width: 768px) {
  .home-point--06 {
    margin-top: 16vw;
  }
}
@media screen and (min-width: 769px) {
  .home-point--06 {
    margin-top: 9.375vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point--06 {
    margin-top: 120px;
  }
}
@media screen and (min-width: 769px) {
  .home-point--06 .home-point__content {
    width: 44.688vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-point--06 .home-point__content {
    width: 572px;
  }
}

/* step */
.home-step {
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-step {
    padding: 3.333vw 6.667vw 4.8vw;
    padding: 3.333vw 0 4.8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-step::before {
    background: rgba(203, 231, 244, 0.5);
    border-radius: 0.781vw;
    bottom: 0;
    content: "";
    display: block;
    height: 21.094vw;
    position: absolute;
    right: 0;
    width: 100%;
  }
}
@media screen and (min-width: 1280px) {
  .home-step::before {
    border-radius: 10px;
    height: 270px;
  }
}

.home-step__list {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .home-step__list {
    display: flex;
    gap: 3.516vw;
    justify-content: center;
  }
}
@media screen and (min-width: 1280px) {
  .home-step__list {
    gap: 45px;
  }
}

.home-step__item {
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-step__item {
    width: 76vw;
  }
}
@media screen and (min-width: 769px) {
  .home-step__item {
    padding: 3.125vw 0 3.516vw;
    width: 26.563vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-step__item {
    padding: 40px 0 45px;
    width: 340px;
  }
}
.home-step__item:not(:last-child)::after {
  background: #113250;
  -webkit-clip-path: polygon(0 0, 0% 100%, 100% 50%);
          clip-path: polygon(0 0, 0% 100%, 100% 50%);
  content: "";
  display: block;
  position: absolute;
}
@media screen and (max-width: 768px) {
  .home-step__item:not(:last-child)::after {
    height: 7.68vw;
    right: 0;
    top: 25.6vw;
    -webkit-transform: translateX(50%);
            transform: translateX(50%);
    width: 3.84vw;
  }
}
@media screen and (min-width: 769px) {
  .home-step__item:not(:last-child)::after {
    height: 3.125vw;
    right: -2.578vw;
    top: 9.375vw;
    width: 1.563vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-step__item:not(:last-child)::after {
    height: 40px;
    right: -33px;
    top: 120px;
    width: 20px;
  }
}

@media screen and (max-width: 768px) {
  .home-step__item-inner {
    padding-bottom: 9.333vw;
    padding-top: 8vw;
    position: relative;
  }
  .home-step__item-inner::before {
    background: #e5f3f9;
    bottom: 0;
    content: "";
    display: block;
    height: 52vw;
    left: 0;
    position: absolute;
    width: 100%;
    z-index: -1;
  }
}

.home-step__num {
  aspect-ratio: 1/1;
  background: var(--color-secondary);
  border-radius: 50%;
  color: #fff;
  font-weight: 700;
  margin: 0;
  padding: 0;
  position: absolute;
  text-align: center;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .home-step__num {
    font-size: 7.467vw;
    left: 50%;
    line-height: 1.786;
    margin-left: -33.6vw;
    top: 0;
    width: 13.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-step__num {
    font-size: 3.125vw;
    left: -0.391vw;
    line-height: 1.75;
    top: 0.391vw;
    width: 5.469vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-step__num {
    font-size: 40px;
    left: -5px;
    top: 5px;
    width: 70px;
  }
}

.home-step__image {
  margin: 0 auto;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .home-step__image {
    width: 63.467vw;
  }
}
@media screen and (min-width: 769px) {
  .home-step__image {
    width: 25.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-step__image {
    width: 330px;
  }
}

.home-step__lead {
  color: var(--color-secondary);
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 2;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-step__lead {
    font-size: 4.8vw;
    margin: 2.667vw auto 0;
    width: 63.467vw;
  }
}
@media screen and (min-width: 769px) {
  .home-step__lead {
    font-size: 1.875vw;
    margin: 0.938vw 0 0;
  }
}
@media screen and (min-width: 1280px) {
  .home-step__lead {
    font-size: 24px;
    margin: 12px 0 0;
  }
}
.home-step__lead::after {
  background: var(--color-font);
  content: "";
  display: block;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .home-step__lead::after {
    height: 1px;
    width: 32vw;
  }
}
@media screen and (min-width: 769px) {
  .home-step__lead::after {
    height: 2px;
    width: 12.812vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-step__lead::after {
    width: 164px;
  }
}

.home-step__text {
  letter-spacing: 0.08em;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-step__text {
    font-size: 3.733vw;
    line-height: 1.643;
    margin: 4vw auto 0;
    width: 69.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-step__text {
    font-size: 1.406vw;
    line-height: 1.722;
    margin: 1.563vw 0 0;
  }
}
@media screen and (min-width: 1280px) {
  .home-step__text {
    font-size: 18px;
    margin: 20px 0 0;
  }
}

@media screen and (max-width: 768px) {
  .home-step__item--01 .home-step__item-inner::before {
    border-bottom-left-radius: 1.92vw;
    border-top-left-radius: 1.92vw;
    margin-left: -5.333vw;
    width: calc(100% + 5.333vw);
  }
}

@media screen and (max-width: 768px) {
  .home-step__item--03 .home-step__item-inner::before {
    border-bottom-right-radius: 1.92vw;
    border-top-right-radius: 1.92vw;
    margin-right: -5.333vw;
    width: calc(100% + 5.333vw);
  }
}

.home-step__item--02 .home-step__image {
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .home-step__item--02 .home-step__image {
    height: 44.267vw;
  }
}
@media screen and (min-width: 769px) {
  .home-step__item--02 .home-step__image {
    height: 17.969vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-step__item--02 .home-step__image {
    height: 230px;
  }
}
.home-step__item--02 .home-step__image::after {
  background: url(../images/home/step_image_02_frame.png) 0/cover no-repeat;
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
.home-step__item--02 .home-step__image-body {
  height: 100%;
  max-height: 100%;
  max-width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  width: 100%;
}

@media screen and (max-width: 768px) {
  .home-step .slick-dots {
    line-height: 0;
    list-style: none;
    margin: 4.8vw 0 0;
    padding: 0;
    text-align: center;
  }
  .home-step .slick-dots li {
    cursor: pointer;
    display: inline-block;
    height: 2.667vw;
    margin: 0 4vw;
    padding: 0;
    position: relative;
    width: 2.667vw;
  }
  .home-step .slick-dots li button {
    background: transparent;
    border: 0;
    color: transparent;
    cursor: pointer;
    display: block;
    font-size: 0;
    line-height: 0;
    height: 2.667vw;
    outline: none;
    padding: 0;
    width: 2.667vw;
  }
  .home-step .slick-dots li button::before {
    background: #ccc;
    border-radius: 50%;
    content: "";
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
  }
  .home-step .slick-dots li.slick-active button::before {
    background: var(--color-secondary);
  }
}

/* instructor */
.home-instructor {
  background: rgba(203, 231, 244, 0.5);
  color: #333;
  display: flex;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-instructor {
    border-radius: 1.333vw;
    flex-direction: column;
    gap: 6vw;
    margin: 3.333vw auto 0;
    padding: 7.333vw 6.4vw 8.667vw;
    width: 84.8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-instructor {
    border-radius: 0.781vw;
    justify-content: space-between;
    margin: -0.781vw auto 0;
    padding: 3.75vw 3.125vw 3.125vw;
    width: 85.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-instructor {
    border-radius: 10px;
    margin: -10px auto 0;
    padding: 48px 40px 40px;
    width: 1100px;
  }
}
.home-instructor::before {
  background: #fff;
  -webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
          clip-path: polygon(0 0, 100% 0, 50% 100%);
  content: "";
  display: block;
  left: 50%;
  position: absolute;
  top: -1px;
  -webkit-transform: translate(-50%);
          transform: translate(-50%);
}
@media screen and (max-width: 768px) {
  .home-instructor::before {
    height: 4vw;
    width: 10.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-instructor::before {
    height: 2.344vw;
    width: 6.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-instructor::before {
    height: 30px;
    width: 80px;
  }
}

@media screen and (min-width: 769px) {
  .home-instructor__summary {
    width: 34.375vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-instructor__summary {
    width: 440px;
  }
}

.home-instructor__name {
  align-items: center;
  display: flex;
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .home-instructor__name {
    gap: 2.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-instructor__name {
    gap: 1.563vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-instructor__name {
    gap: 20px;
  }
}

.home-instructor__def-title {
  aspect-ratio: 1/1;
  background: var(--color-secondary);
  border-radius: 50%;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin: 0;
  padding: 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-instructor__def-title {
    font-size: 3.2vw;
    line-height: 3.333;
    width: 10.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-instructor__def-title {
    font-size: 1.563vw;
    line-height: 4;
    width: 6.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-instructor__def-title {
    font-size: 20px;
    width: 80px;
  }
}

.home-instructor__def-data {
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .home-instructor__def-data {
    font-size: 6.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-instructor__def-data {
    font-size: 3.594vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-instructor__def-data {
    font-size: 46px;
  }
}

.home-instructor__ruby {
  display: inline-block;
  font-weight: 500;
  letter-spacing: 0.22em;
  margin-left: 1em;
  vertical-align: middle;
}
@media screen and (max-width: 768px) {
  .home-instructor__ruby {
    font-size: 2.933vw;
  }
}
@media screen and (min-width: 769px) {
  .home-instructor__ruby {
    font-size: 1.406vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-instructor__ruby {
    font-size: 18px;
  }
}

.home-instructor__post {
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  .home-instructor__post {
    font-size: 2.933vw;
    line-height: 1.455;
    margin: 2vw 0 0 1.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-instructor__post {
    font-size: 1.406vw;
    line-height: 1.778;
    margin: 1.25vw 0 0 0.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-instructor__post {
    font-size: 18px;
    margin: 16px 0 0 10px;
  }
}

.home-instructor__profile {
  letter-spacing: 0.08em;
  margin: 0;
  text-align: justify;
}
@media screen and (max-width: 768px) {
  .home-instructor__profile {
    font-size: 3.467vw;
    line-height: 1.692;
  }
}
@media screen and (min-width: 769px) {
  .home-instructor__profile {
    font-size: 1.406vw;
    line-height: 2;
    width: 42.188vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-instructor__profile {
    font-size: 18px;
    width: 540px;
  }
}

.home-point--06.js_inshow .home-instructor {
  opacity: 0;
  -webkit-transform: translateY(10px);
          transform: translateY(10px);
  transition: opacity 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  transition-delay: 0.4s;
}
.home-point--06.is_show .home-instructor {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

/* practice */
.best-practice {
  position: relative;
}
@media screen and (max-width: 768px) {
  .best-practice {
    margin-top: 13.333vw;
  }
}
@media screen and (min-width: 769px) {
  .best-practice {
    align-items: center;
    display: flex;
    margin-top: 4.688vw;
    padding-top: 2.109vw;
  }
}
@media screen and (min-width: 1280px) {
  .best-practice {
    margin-top: 60px;
    padding-top: 27px;
  }
}

.best-practice__title {
  color: rgba(211, 214, 223, 0.5);
  font-weight: 700;
  left: 0;
  letter-spacing: 0.1em;
  line-height: 1;
  margin: 0;
  padding: 0;
  position: absolute;
  text-align: center;
  top: 0;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .best-practice__title {
    font-size: 12vw;
  }
}
@media screen and (min-width: 769px) {
  .best-practice__title {
    font-size: 7.031vw;
  }
}
@media screen and (min-width: 1280px) {
  .best-practice__title {
    font-size: 90px;
  }
}

.best-practice__image {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .best-practice__image {
    margin: 0 auto;
    width: 82.667vw;
  }
}
@media screen and (min-width: 769px) {
  .best-practice__image {
    margin: 0;
    width: 48.438vw;
  }
}
@media screen and (min-width: 1280px) {
  .best-practice__image {
    width: 620px;
  }
}

.best-practice__content {
  position: relative;
  text-align: center;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .best-practice__content {
    margin-left: -2.344vw;
    width: 44.531vw;
  }
}
@media screen and (min-width: 1280px) {
  .best-practice__content {
    margin-left: -30px;
    width: 570px;
  }
}

.best-practice__text {
  line-height: 1;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .best-practice__text {
    font-size: 3.733vw;
    letter-spacing: 0.08em;
    line-height: 1.786;
  }
}
@media screen and (min-width: 769px) {
  .best-practice__text {
    font-size: 1.563vw;
    letter-spacing: 0.06em;
    line-height: 1.8;
  }
}
@media screen and (min-width: 1280px) {
  .best-practice__text {
    font-size: 20px;
  }
}

.best-practice__catch {
  background: linear-gradient(90deg, rgb(96, 202, 200) 0%, rgb(96, 201, 200) 0.66%, rgb(81, 172, 195) 26.01%, rgb(70, 152, 191) 51.22%, rgb(64, 139, 189) 76.04%, rgb(62, 135, 188) 100%);
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.04em;
  margin-left: 1em;
  vertical-align: middle;
}
@media screen and (max-width: 768px) {
  .best-practice__catch {
    border-radius: 1.52vw;
    font-size: 5.333vw;
    line-height: 1.445;
    margin: 2vw auto 0;
    width: 84.8vw;
  }
}
@media screen and (min-width: 769px) {
  .best-practice__catch {
    border-radius: 0.781vw;
    font-size: 2.656vw;
    line-height: 1.471;
    margin: 0.391vw auto 0;
    width: 42.969vw;
  }
}
@media screen and (min-width: 1280px) {
  .best-practice__catch {
    border-radius: 10px;
    font-size: 34px;
    margin: 5px auto 0;
    width: 550px;
  }
}

.best-practice__catch-small {
  font-size: 80%;
}

.best-practice__sub-catch {
  color: #333;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .best-practice__sub-catch {
    font-size: 4.8vw;
    margin: 1.333vw 0 0;
  }
}
@media screen and (min-width: 769px) {
  .best-practice__sub-catch {
    font-size: 2.266vw;
    margin: 0.391vw 0 0;
  }
}
@media screen and (min-width: 1280px) {
  .best-practice__sub-catch {
    font-size: 29px;
    margin: 5px 0 0;
  }
}

.best-practice__list {
  display: flex;
  justify-content: center;
  list-style: none;
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .best-practice__list {
    gap: 2.667vw;
    margin: 4vw 0 0;
  }
}
@media screen and (min-width: 769px) {
  .best-practice__list {
    gap: 1.563vw;
    margin: 1.563vw 0 0;
  }
}
@media screen and (min-width: 1280px) {
  .best-practice__list {
    gap: 20px;
    margin: 20px 0 0;
  }
}

.best-practice__item {
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .best-practice__item {
    width: 22.667vw;
  }
}
@media screen and (min-width: 769px) {
  .best-practice__item {
    width: 10.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .best-practice__item {
    width: 140px;
  }
}

/* function */
@media screen and (max-width: 768px) {
  .home-function {
    background: url(../images/home/function_bg_sp.jpg) 0 100%/100% auto no-repeat #fdfefe;
  }
}
@media screen and (min-width: 769px) {
  .home-function {
    background-image: url(../images/home/function_bg_pc_02.png), url(../images/home/function_bg_pc_01.jpg);
    background-position: 50% 100%, 50% 0;
    background-repeat: no-repeat;
    background-size: 156.25vw auto, cover;
  }
}
@media screen and (min-width: 1280px) {
  .home-function {
    background-size: 2000px auto, cover;
  }
}

.inner--function {
  position: relative;
}
@media screen and (max-width: 768px) {
  .inner--function {
    padding: 16vw 0 34.667vw;
  }
}
@media screen and (min-width: 769px) {
  .inner--function {
    padding: 7.813vw 0 11.719vw;
  }
}
@media screen and (min-width: 1280px) {
  .inner--function {
    padding: 100px 0 150px;
  }
}

.home-function__group {
  background: rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 768px) {
  .home-function__group {
    border-radius: 1.333vw;
    box-shadow: 0.667vw 0.667vw 0.667vw rgba(53, 96, 122, 0.3);
    padding: 7.333vw 0 4vw;
    width: 94.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-function__group {
    border-radius: 0.781vw;
    box-shadow: 0.391vw 0.391vw 0.391vw rgba(53, 96, 122, 0.3);
    padding-top: 3.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-function__group {
    border-radius: 10px;
    box-shadow: 5px 5px 5px rgba(53, 96, 122, 0.3);
    padding-top: 40px;
  }
}

.home-function__group-title {
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  margin: 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-function__group-title {
    font-size: 5.067vw;
  }
}
@media screen and (min-width: 769px) {
  .home-function__group-title {
    font-size: 2.813vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-function__group-title {
    font-size: 36px;
  }
}

.home-function__list {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .home-function__list {
    gap: 1.333vw;
    margin: 5.333vw 0 0 4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-function__list {
    gap: 0.781vw;
    margin: 3.125vw 3.906vw 0 6.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-function__list {
    gap: 10px;
    margin: 40px 50px 0 80px;
  }
}

.home-function__item {
  align-items: center;
  background: #fff;
  display: flex;
  justify-content: center;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-function__item {
    border-radius: 0.96vw;
    gap: 1.333vw;
    min-height: 28vw;
    padding: 16.667vw 0 1.333vw;
    width: 28vw;
  }
}
@media screen and (min-width: 769px) {
  .home-function__item {
    border-radius: 0.625vw;
    gap: 1.563vw;
    min-height: 17.969vw;
    padding: 10.938vw 0 0.781vw;
    width: 15.625vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-function__item {
    border-radius: 8px;
    gap: 20px;
    min-height: 230px;
    padding: 140px 0 10px;
    width: 200px;
  }
}

.home-function__patent {
  align-items: center;
  background: linear-gradient(90deg, rgb(252, 207, 0) 0%, rgb(245, 170, 0) 100%);
  border-radius: 50%;
  display: flex;
  font-weight: 500;
  letter-spacing: 0.08em;
  justify-content: center;
  margin: 0;
  padding: 0 0.5em;
  position: absolute;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .home-function__patent {
    font-size: 2.267vw;
    line-height: 1.112;
    height: 8.4vw;
    left: -1.2vw;
    top: -1.2vw;
    width: 8.4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-function__patent {
    font-size: 1.406vw;
    line-height: 1.167;
    height: 5.469vw;
    left: -0.938vw;
    top: -1.406vw;
    width: 5.469vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-function__patent {
    font-size: 18px;
    height: 70px;
    left: -12px;
    top: -18px;
    width: 70px;
  }
}

img.home-function__icon {
  left: 50%;
  position: absolute;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: auto;
}
@media screen and (max-width: 768px) {
  img.home-function__icon {
    height: 12vw;
    top: 3.6vw;
  }
}
@media screen and (min-width: 769px) {
  img.home-function__icon {
    height: 7.813vw;
    top: 2.344vw;
  }
}
@media screen and (min-width: 1280px) {
  img.home-function__icon {
    height: 100px;
    top: 30px;
  }
}

.home-function__label {
  color: #333;
  font-weight: 700;
  letter-spacing: 0.04em;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .home-function__label {
    font-size: 3.2vw;
    line-height: 1.333;
  }
}
@media screen and (min-width: 769px) {
  .home-function__label {
    font-size: 1.563vw;
    line-height: 1.4;
  }
}
@media screen and (min-width: 1280px) {
  .home-function__label {
    font-size: 20px;
  }
}
@media screen and (max-width: 768px) {
  .home-function__label:has(.home-function__label-add) {
    line-height: 1;
  }
}
@media screen and (min-width: 769px) {
  .home-function__label:has(.home-function__label-add) {
    line-height: 1.2;
  }
}

@media screen and (max-width: 768px) {
  .home-function__label-add {
    font-size: 1.867vw;
    letter-spacing: 0;
  }
}
@media screen and (min-width: 769px) {
  .home-function__label-add {
    font-size: 1.094vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-function__label-add {
    font-size: 14px;
  }
}

.home-function__label-fw400 {
  font-weight: 400;
  display: inline-block;
}
@media screen and (max-width: 768px) {
  .home-function__label-fw400 {
    font-size: 1.68vw;
    line-height: 1.286;
    padding-top: 0.5em;
  }
}
@media screen and (min-width: 769px) {
  .home-function__label-fw400 {
    letter-spacing: 0;
    line-height: 1.286;
    margin-top: 0.25em;
  }
}

.home-function__label-sup {
  font-size: 58.3%;
  top: -0.7em;
}

.home-function__note {
  text-align: right;
}
@media screen and (max-width: 768px) {
  .home-function__note {
    font-size: 2.4vw;
    margin: 2vw auto 0;
    width: 86.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-function__note {
    font-size: 1.25vw;
    margin: 1.172vw auto 0;
    width: 81.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-function__note {
    font-size: 16px;
    margin: 15px auto 0;
    width: 1040px;
  }
}

@media screen and (max-width: 768px) {
  .home-function__group--user {
    margin: 10.667vw auto 0;
  }
}
@media screen and (min-width: 769px) {
  .home-function__group--user {
    margin-top: 5.078vw;
    padding-bottom: 4.297vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-function__group--user {
    margin-top: 65px;
    padding-bottom: 55px;
  }
}
.home-function__group--user .home-function__group-title {
  color: var(--color-tertiary);
}

@media screen and (max-width: 768px) {
  .home-function__group--admin {
    margin: 6.667vw auto 0;
  }
}
@media screen and (min-width: 769px) {
  .home-function__group--admin {
    margin-top: 2.344vw;
    padding-bottom: 3.906vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-function__group--admin {
    margin-top: 30px;
    padding-bottom: 50px;
  }
}
.home-function__group--admin .home-function__group-title {
  color: var(--color-secondary);
}

.home-function__cta-wrap {
  left: 0;
  position: absolute;
  width: 100%;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .home-function__cta-wrap {
    bottom: -8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-function__cta-wrap {
    bottom: -3.906vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-function__cta-wrap {
    bottom: -50px;
  }
}

.home-function__group.js_inshow .home-function__item {
  opacity: 0;
  -webkit-transform: translateY(20px);
          transform: translateY(20px);
  transition: opacity 0.3s ease-in-out, -webkit-transform 0.4s ease-in-out;
  transition: transform 0.4s ease-in-out, opacity 0.3s ease-in-out;
  transition: transform 0.4s ease-in-out, opacity 0.3s ease-in-out, -webkit-transform 0.4s ease-in-out;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(1) {
  transition-delay: 0.1s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(2) {
  transition-delay: 0.2s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(3) {
  transition-delay: 0.3s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(4) {
  transition-delay: 0.4s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(5) {
  transition-delay: 0.5s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(6) {
  transition-delay: 0.6s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(7) {
  transition-delay: 0.7s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(8) {
  transition-delay: 0.8s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(9) {
  transition-delay: 0.9s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(10) {
  transition-delay: 1s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(11) {
  transition-delay: 1.1s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(12) {
  transition-delay: 1.2s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(13) {
  transition-delay: 1.3s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(14) {
  transition-delay: 1.4s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(15) {
  transition-delay: 1.5s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(16) {
  transition-delay: 1.6s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(17) {
  transition-delay: 1.7s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(18) {
  transition-delay: 1.8s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(19) {
  transition-delay: 1.9s;
}
.home-function__group.js_inshow .home-function__item:nth-of-type(20) {
  transition-delay: 2s;
}
.home-function__group.is_show .home-function__item {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

/* compare */
.home-compare {
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-compare {
    padding: 28vw 0 10.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-compare {
    padding: 5.938vw 0 8.984vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-compare {
    padding: 76px 0 115px;
  }
}
.home-compare::after {
  background: linear-gradient(0deg, rgba(147, 193, 217, 0.35) 0%, rgba(151, 195, 218, 0.35) 18.74%, rgba(164, 203, 223, 0.35) 38.16%, rgba(184, 214, 230, 0.35) 57.89%, rgba(213, 231, 240, 0.35) 77.84%, rgba(250, 252, 253, 0.35) 97.78%, rgba(255, 255, 255, 0.35) 100%);
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  position: absolute;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .home-compare::after {
    height: calc(100% - 56.667vw);
  }
}
@media screen and (min-width: 769px) {
  .home-compare::after {
    height: 59.844vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-compare::after {
    height: 766px;
  }
}

.inner--compare {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .inner--compare {
    background: url(../images/home/compare_bg_pc.jpg) 50% 0/100% auto no-repeat;
    padding-top: 6.563vw;
  }
}
@media screen and (min-width: 1280px) {
  .inner--compare {
    padding-top: 84px;
  }
}

.home-compare__lead {
  color: #333;
  letter-spacing: 0.06em;
  line-height: 1.4;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-compare__lead {
    font-size: 4.267vw;
    margin: 4vw auto 0;
    width: 84.8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-compare__lead {
    font-size: 1.953vw;
    margin: 2.344vw 0 0;
  }
}
@media screen and (min-width: 1280px) {
  .home-compare__lead {
    font-size: 25px;
    margin: 30px 0 0;
  }
}

@media screen and (max-width: 768px) {
  .home-compare__table-wrap {
    cursor: pointer;
    margin: 2.667vw 0 0 auto;
    padding: 7.333vw 0 6vw 0;
    overflow-x: scroll;
    width: 92.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-compare__table-wrap {
    margin: 7.813vw auto 0;
    width: 85.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-compare__table-wrap {
    margin: 100px auto 0;
    width: 1100px;
  }
}
@media screen and (max-width: 768px) {
  .home-compare__table-wrap .simplebar-track.simplebar-horizontal {
    background: #ccc;
    border-radius: 0.667vw;
    height: 2.133vw;
    margin: 0;
    max-width: 92%;
  }
}
@media screen and (min-width: 769px) {
  .home-compare__table-wrap .simplebar-track.simplebar-horizontal {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .home-compare__table-wrap .simplebar-track.simplebar-horizontal .simplebar-scrollbar {
    background: var(--color-tertiary);
    border-radius: 1.067vw;
    height: 100%;
  }
  .home-compare__table-wrap .simplebar-track.simplebar-horizontal .simplebar-scrollbar::before {
    background: var(--color-tertiary);
  }
}
@media screen and (min-width: 769px) {
  .home-compare__table-wrap .simplebar-wrapper,
  .home-compare__table-wrap .simplebar-height-auto-observer-wrapper,
  .home-compare__table-wrap .simplebar-mask,
  .home-compare__table-wrap .simplebar-content-wrapper {
    overflow: initial !important;
  }
}
.home-table {
  display: grid;
  grid-row: repeat(4, 1fr);
}
@media screen and (max-width: 768px) {
  .home-table {
    grid-template-columns: 29.867vw 40vw repeat(2, 33.333vw) 33.733vw;
    width: 178vw;
    padding-right: 7.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table {
    grid-template-columns: 17.188vw 19.531vw repeat(2, 16.406vw) 16.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table {
    grid-template-columns: 220px 250px repeat(2, 210px) 216px;
  }
}

.home-table__thead {
  display: grid;
  place-content: center;
  place-items: center;
}
@media screen and (max-width: 768px) {
  .home-table__thead {
    height: 11.733vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__thead {
    height: 7.031vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__thead {
    height: 90px;
  }
}

.home-table__thead-text {
  font-weight: 700;
  letter-spacing: 0.08em;
  margin: 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-table__thead-text {
    font-size: 3.2vw;
    line-height: 1.25;
  }
}
@media screen and (min-width: 769px) {
  .home-table__thead-text {
    font-size: 1.563vw;
    line-height: 1.5;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__thead-text {
    font-size: 20px;
  }
}

.home-table__cell {
  display: grid;
  place-content: center;
  place-items: center;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-table__cell {
    gap: 0.667vw;
    height: 23.2vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__cell {
    gap: 0.781vw;
    height: 12.5vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__cell {
    gap: 10px;
    height: 160px;
  }
}
.home-table__cell:not(:last-child)::after {
  bottom: 0;
  content: "";
  display: block;
  height: 1px;
  left: 50%;
  position: absolute;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

@media screen and (max-width: 768px) {
  .home-table__icon {
    width: 8.267vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__icon {
    width: 4.375vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__icon {
    width: 56px;
  }
}

.home-table__text {
  font-weight: 700;
  margin: 0;
  text-align: center;
}

.home-table__text--thead {
  color: #fff;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  .home-table__text--thead {
    font-size: 3.733vw;
    line-height: 1.429;
  }
}
@media screen and (min-width: 769px) {
  .home-table__text--thead {
    font-size: 1.563vw;
    line-height: 1.5;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__text--thead {
    font-size: 20px;
  }
}

.home-table__text--in-house {
  color: #333;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  .home-table__text--in-house {
    font-size: 3.467vw;
    line-height: 1.308;
  }
}
@media screen and (min-width: 769px) {
  .home-table__text--in-house {
    font-size: 1.563vw;
    line-height: 1.5;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__text--in-house {
    font-size: 20px;
  }
}

.home-table__text--data {
  color: #595757;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
  .home-table__text--data {
    display: flex;
    flex-direction: column;
    font-size: 2.933vw;
    justify-content: center;
    line-height: 1.455;
    min-height: 2.6em;
  }
}
@media screen and (min-width: 769px) {
  .home-table__text--data {
    font-size: 1.406vw;
    line-height: 1.667;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__text--data {
    font-size: 18px;
  }
}

.home-table__col--header {
  left: 0;
  position: sticky;
  top: 0;
  z-index: 5;
}
.home-table__col--header .home-table__cell {
  background: var(--color-tertiary);
}
.home-table__col--header .home-table__cell:not(:last-child)::after {
  background: #fff;
}
@media screen and (max-width: 768px) {
  .home-table__col--header .home-table__cell:not(:last-child)::after {
    width: 25.067vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--header .home-table__cell:not(:last-child)::after {
    width: 14.844vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--header .home-table__cell:not(:last-child)::after {
    width: 190px;
  }
}
@media screen and (max-width: 768px) {
  .home-table__col--header .home-table__cell:nth-of-type(2) {
    border-top-left-radius: 2.24vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--header .home-table__cell:nth-of-type(2) {
    border-top-left-radius: 1.094vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--header .home-table__cell:nth-of-type(2) {
    border-top-left-radius: 14px;
  }
}
@media screen and (max-width: 768px) {
  .home-table__col--header .home-table__cell:last-child {
    border-bottom-left-radius: 2.24vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--header .home-table__cell:last-child {
    border-bottom-left-radius: 1.094vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--header .home-table__cell:last-child {
    border-bottom-left-radius: 14px;
  }
}
.home-table__col--header .home-table__thead--hidden {
  background: transparent;
}

.home-table__col--in-house {
  background: linear-gradient(0deg, rgb(96, 202, 200) 0%, rgb(96, 201, 200) 0.66%, rgb(81, 172, 195) 26.01%, rgb(70, 152, 191) 51.22%, rgb(64, 139, 189) 76.04%, rgb(62, 135, 188) 100%);
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-table__col--in-house {
    border-radius: 2.24vw;
    box-shadow: 0.8vw 0.8vw 0.8vw rgba(53, 96, 122, 0.3);
    padding: 0.96vw;
    top: -3.6%;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--in-house {
    border-radius: 1.094vw;
    box-shadow: 0.391vw 0.391vw 0.391vw rgba(53, 96, 122, 0.3);
    padding: 0.469vw;
    top: -5%;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--in-house {
    border-radius: 14px;
    box-shadow: 5px 5px 5px rgba(53, 96, 122, 0.3);
    padding: 6px;
  }
}
.home-table__col--in-house .home-table__thead {
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-table__col--in-house .home-table__thead {
    height: 15.733vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--in-house .home-table__thead {
    height: 10.469vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--in-house .home-table__thead {
    height: 134px;
  }
}
.home-table__col--in-house .home-table__thead::before {
  background: linear-gradient(180deg, rgb(96, 202, 200) 0%, rgb(96, 201, 200) 0.66%, rgb(81, 172, 195) 26.01%, rgb(70, 152, 191) 51.22%, rgb(64, 139, 189) 76.04%, rgb(62, 135, 188) 100%);
  content: "";
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .home-table__col--in-house .home-table__thead::before {
    height: calc(100% + 0.96vw);
    left: -0.96vw;
    top: -0.96vw;
    width: calc(100% + 1.92vw);
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--in-house .home-table__thead::before {
    height: calc(100% + 0.469vw);
    left: -0.469vw;
    top: -0.469vw;
    width: calc(100% + 0.938vw);
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--in-house .home-table__thead::before {
    height: calc(100% + 6px);
    left: -6px;
    top: -6px;
    width: calc(100% + 12px);
  }
}
.home-table__col--in-house .home-table__logo {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .home-table__col--in-house .home-table__logo {
    width: 34.4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--in-house .home-table__logo {
    width: 16.797vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--in-house .home-table__logo {
    width: 215px;
  }
}
.home-table__col--in-house .home-table__cell {
  background: #fff;
}
.home-table__col--in-house .home-table__cell:not(:last-child)::after {
  background: #dcdddd;
}
@media screen and (max-width: 768px) {
  .home-table__col--in-house .home-table__cell:not(:last-child)::after {
    width: 30.4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--in-house .home-table__cell:not(:last-child)::after {
    width: 14.844vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--in-house .home-table__cell:not(:last-child)::after {
    width: 190px;
  }
}
@media screen and (max-width: 768px) {
  .home-table__col--in-house .home-table__cell:last-child {
    border-bottom-left-radius: 1.973vw;
    border-bottom-right-radius: 1.973vw;
    height: 26.4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--in-house .home-table__cell:last-child {
    border-bottom-left-radius: 1.094vw;
    border-bottom-right-radius: 1.094vw;
    height: 14.063vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--in-house .home-table__cell:last-child {
    border-bottom-left-radius: 14px;
    border-bottom-right-radius: 14px;
    height: 180px;
  }
}

.home-table__col--data .home-table__thead {
  background: #d3d6df;
}
.home-table__col--data .home-table__cell:not(:last-child)::after {
  background: #9fa0a0;
}
@media screen and (max-width: 768px) {
  .home-table__col--data .home-table__cell:not(:last-child)::after {
    width: 28.8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--data .home-table__cell:not(:last-child)::after {
    width: 14.063vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--data .home-table__cell:not(:last-child)::after {
    width: 180px;
  }
}
@media screen and (max-width: 768px) {
  .home-table__col--data .home-table__cell:last-child {
    border-bottom: 0.96vw solid #d3d6df;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--data .home-table__cell:last-child {
    border-bottom: 0.469vw solid #d3d6df;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--data .home-table__cell:last-child {
    border-bottom: 6px solid #d3d6df;
  }
}

.home-table__col--dataA .home-table__thead {
  position: relative;
}
.home-table__col--dataA .home-table__thead::after {
  background: #fff;
  content: "";
  display: block;
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 1px;
}
@media screen and (max-width: 768px) {
  .home-table__col--dataA .home-table__thead::after {
    height: calc(100% - 1.867vw);
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--dataA .home-table__thead::after {
    height: calc(100% - 0.938vw);
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--dataA .home-table__thead::after {
    height: calc(100% - 12px);
  }
}
.home-table__col--dataA .home-table__cell {
  background: #e9eaef;
}

.home-table__col--dataB .home-table__thead {
  position: relative;
}
.home-table__col--dataB .home-table__thead::after {
  background: #fff;
  content: "";
  display: block;
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 1px;
}
@media screen and (max-width: 768px) {
  .home-table__col--dataB .home-table__thead::after {
    height: calc(100% - 1.867vw);
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--dataB .home-table__thead::after {
    height: calc(100% - 0.938vw);
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--dataB .home-table__thead::after {
    height: calc(100% - 12px);
  }
}
.home-table__col--dataB .home-table__cell {
  background: #fff;
}

@media screen and (max-width: 768px) {
  .home-table__col--dataC .home-table__thead {
    border-top-right-radius: 1.6vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--dataC .home-table__thead {
    border-top-right-radius: 0.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--dataC .home-table__thead {
    border-top-right-radius: 10px;
  }
}
.home-table__col--dataC .home-table__cell {
  background: #e9eaef;
}
@media screen and (max-width: 768px) {
  .home-table__col--dataC .home-table__cell {
    border-right: 0.96vw solid #d3d6df;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--dataC .home-table__cell {
    border-right: 0.469vw solid #d3d6df;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--dataC .home-table__cell {
    border-right: 6px solid #d3d6df;
  }
}
@media screen and (max-width: 768px) {
  .home-table__col--dataC .home-table__cell:last-child {
    border-bottom-right-radius: 1.6vw;
  }
}
@media screen and (min-width: 769px) {
  .home-table__col--dataC .home-table__cell:last-child {
    border-bottom-right-radius: 0.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-table__col--dataC .home-table__cell:last-child {
    border-bottom-right-radius: 10px;
  }
}

/* case */
.home-case {
  /* display: none; */
}
@media screen and (max-width: 768px) {
  .home-case {
    padding: 17.333vw 0 23.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-case {
    padding: 6.25vw 0 8.594vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-case {
    padding: 80px 0 110px;
  }
}

.detail_link {
  color: var(--color-primary);
  text-decoration: underline !important;
  display: block !important;
  margin-top: 1rem;
}

/* 以下は仕様変更により適用されていない */
/* .home-case__list {
  position: static;
}
@media screen and (max-width: 768px) {
  .home-case__list {
    margin-top: 13.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-case__list {
    margin-top: 4.844vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-case__list {
    margin-top: 62px;
  }
}

@media screen and (max-width: 768px) {
  .home-case__item {
    padding: 0 4.667vw;
    width: 76vw;
  }
}
@media screen and (min-width: 769px) {
  .home-case__item {
    padding: 0 1.563vw;
    width: 29.688vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-case__item {
    padding: 0 20px;
    width: 380px;
  }
}

.home-case__card {
  background: rgba(211, 238, 241, 0.6);
  display: block;
  overflow: hidden;
  position: relative;
  text-decoration: none;
}
@media screen and (max-width: 768px) {
  .home-case__card {
    border-radius: 3.787vw;
    padding-bottom: 14.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-case__card {
    border-radius: 1.563vw;
    padding-bottom: 7.422vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-case__card {
    border-radius: 20px;
    padding-bottom: 95px;
  }
}
@media (any-hover: hover) {
  .home-case__card:hover .home-case__thumb img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .home-case__card:hover .home-case__more {
    text-decoration: none;
  }
}

.home-case__thumb {
  margin: 0;
  overflow: hidden;
}
.home-case__thumb img {
  transition: -webkit-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
}

.home-case__company {
  color: var(--color-primary);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-case__company {
    font-size: 4.8vw;
    margin: 5.333vw auto 0;
    width: 58.4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-case__company {
    font-size: 1.875vw;
    margin: 3.125vw auto 0;
    width: 20.313vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-case__company {
    font-size: 24px;
    margin: 40px auto 0;
    width: 260px;
  }
}

.home-case__excerpt {
  letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
  .home-case__excerpt {
    font-size: 3.733vw;
    line-height: 1.786;
    margin: 2vw auto 0;
    width: 58.4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-case__excerpt {
    font-size: 1.25vw;
    line-height: 2.125;
    margin: 1.563vw auto 0;
    width: 20.313vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-case__excerpt {
    font-size: 16px;
    margin: 20px auto 0;
    width: 260px;
  }
}

.home-case__more {
  color: var(--color-primary);
  letter-spacing: 0.04em;
  line-height: 1;
  position: absolute;
  text-align: right;
  text-decoration: underline;
}
@media screen and (max-width: 768px) {
  .home-case__more {
    bottom: 5.6vw;
    font-size: 3.2vw;
    right: 3.733vw;
    width: 58.4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-case__more {
    bottom: 4.219vw;
    font-size: 1.25vw;
    right: 2.969vw;
    width: 20.313vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-case__more {
    bottom: 54px;
    font-size: 16px;
    right: 38px;
    width: 260px;
  }
}

.home-case__icon {
  fill: none;
  stroke: var(--color-primary);
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}
@media screen and (max-width: 768px) {
  .home-case__icon {
    margin-left: 2vw;
    width: 1.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-case__icon {
    margin-left: 0.781vw;
    width: 0.547vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-case__icon {
    margin-left: 10px;
    width: 7px;
  }
}

.home-case__list .slick-track {
  display: flex;
}
.home-case__list .slick-dots {
  line-height: 0;
  list-style: none;
  padding: 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-case__list .slick-dots {
    margin: 10vw 0 0;
  }
}
@media screen and (min-width: 769px) {
  .home-case__list .slick-dots {
    margin: 4.531vw 0 0;
  }
}
@media screen and (min-width: 1280px) {
  .home-case__list .slick-dots {
    margin: 58px 0 0;
  }
}
.home-case__list .slick-dots li {
  cursor: pointer;
  display: inline-block;
  padding: 0;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-case__list .slick-dots li {
    height: 1.067vw;
    margin: 0 1vw;
    width: 10.4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-case__list .slick-dots li {
    height: 0.625vw;
    margin: 0 0.547vw;
    width: 6.094vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-case__list .slick-dots li {
    height: 8px;
    margin: 0 7px;
    width: 78px;
  }
}
.home-case__list .slick-dots li button {
  background: transparent;
  border: 0;
  color: transparent;
  cursor: pointer;
  display: block;
  font-size: 0;
  line-height: 0;
  outline: none;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .home-case__list .slick-dots li button {
    height: 1.067vw;
    width: 10.4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-case__list .slick-dots li button {
    height: 0.625vw;
    width: 6.094vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-case__list .slick-dots li button {
    height: 8px;
    width: 78px;
  }
}
.home-case__list .slick-dots li button::before {
  background: #d3eef1;
  content: "";
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
.home-case__list .slick-dots li.slick-active button::before {
  background: #8bd3db;
} */

/* price */
.home-price {
  background: rgba(211, 214, 223, 0.3);
}
@media screen and (max-width: 768px) {
  .home-price {
    padding: 16vw 0 20vw;
  }
}
@media screen and (min-width: 769px) {
  .home-price {
    padding: 7.813vw 0;
  }
}
@media screen and (min-width: 1280px) {
  .home-price {
    padding: 100px 0;
  }
}

.home-plan {
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-plan {
    margin: 2.667vw 0 0;
    padding-bottom: 42.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan {
    margin: 3.125vw 0 0;
    padding-top: 3.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan {
    margin: 40px 0 0;
    padding-top: 40px;
  }
}

@media screen and (max-width: 768px) {
  .home-plan__list {
    position: static;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__list {
    display: flex;
    gap: 0.391vw;
    justify-content: center;
    padding-bottom: 0.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__list {
    gap: 5px;
    padding-bottom: 10px;
  }
}
@media screen and (max-width: 768px) {
  .home-plan__list .slick-list {
    padding-top: 4.267vw;
  }
}
@media screen and (max-width: 768px) {
  .home-plan__list .slick-track {
    display: flex;
  }
}

.home-plan__item {
  display: flex !important;
}
@media screen and (max-width: 768px) {
  .home-plan__item {
    height: auto !important;
    padding: 4vw 1.333vw 1.333vw 0;
  }
}

.home-plan__card {
  background: #fff;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-plan__card {
    box-shadow: 1vw 1vw 1vw rgba(53, 96, 122, 0.3);
    width: 78.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__card {
    box-shadow: 0.391vw 0.391vw 0.391vw rgba(53, 96, 122, 0.3);
    width: 27.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__card {
    box-shadow: 5px 5px 5px rgba(53, 96, 122, 0.3);
    width: 350px;
  }
}

.home-plan__title {
  align-items: center;
  color: #fff;
  display: flex;
  justify-content: center;
  letter-spacing: 0.06em;
  margin: 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-plan__title {
    font-size: 6vw;
    height: 21.6vw;
    line-height: 1.156;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__title {
    font-size: 2.344vw;
    height: 10.156vw;
    line-height: 1.333;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__title {
    font-size: 30px;
    height: 130px;
  }
}

.home-plan__lead {
  font-weight: 500;
  left: 50%;
  letter-spacing: 0.08em;
  margin: 0;
  position: absolute;
  text-align: center;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  .home-plan__lead {
    background: url(../images/home/plan_ent_bg_sp.svg) 0/contain no-repeat;
    font-size: 3.733vw;
    height: 7.2vw;
    line-height: 1.929;
    top: -2.933vw;
    width: 57.6vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__lead {
    background: url(../images/home/plan_ent_bg_pc.svg) 0/contain no-repeat;
    font-size: 1.406vw;
    height: 3.594vw;
    line-height: 2.556;
    top: -1.563vw;
    width: 22.5vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__lead {
    font-size: 18px;
    height: 46px;
    top: -20px;
    width: 288px;
  }
}

.home-plan__summay-wrap {
  align-items: center;
  display: flex;
  justify-content: center;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-plan__summay-wrap {
    height: 17.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__summay-wrap {
    height: 7.813vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__summay-wrap {
    height: 100px;
  }
}
.home-plan__summay-wrap::after {
  -webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
          clip-path: polygon(0 0, 100% 0, 50% 100%);
  content: "";
  display: block;
  left: 50%;
  line-height: 0;
  position: absolute;
  -webkit-transform: translate(-50%, 100%);
          transform: translate(-50%, 100%);
}
@media screen and (max-width: 768px) {
  .home-plan__summay-wrap::after {
    bottom: 0.4vw;
    height: 3.333vw;
    width: 6.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__summay-wrap::after {
    bottom: 0.234vw;
    height: 1.797vw;
    width: 2.813vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__summay-wrap::after {
    bottom: 3px;
    height: 23px;
    width: 36px;
  }
}

.home-plan__summay {
  letter-spacing: 0.06em;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .home-plan__summay {
    font-size: 4vw;
    line-height: 1.467;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__summay {
    font-size: 1.563vw;
    line-height: 1.6;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__summay {
    font-size: 20px;
  }
}

.home-plan__fee {
  align-items: flex-end;
  color: #151961;
  display: flex;
  line-height: 1;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .home-plan__fee {
    gap: 0.667vw;
    padding-bottom: 2vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__fee {
    gap: 0.391vw;
    padding-bottom: 0.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__fee {
    gap: 5px;
    padding-bottom: 10px;
  }
}

.home-plan__fee-lead {
  font-weight: 700;
  letter-spacing: 0.08em;
  min-height: 2.5em;
  -webkit-writing-mode: vertical-lr;
      -ms-writing-mode: tb-lr;
          writing-mode: vertical-lr;
}
@media screen and (max-width: 768px) {
  .home-plan__fee-lead {
    font-size: 3.867vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__fee-lead {
    font-size: 1.719vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__fee-lead {
    font-size: 22px;
  }
}

.home-plan__fee-num {
  font-weight: 700;
  letter-spacing: -0.04em;
}
@media screen and (max-width: 768px) {
  .home-plan__fee-num {
    font-size: 12vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__fee-num {
    font-size: 4.688vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__fee-num {
    font-size: 60px;
  }
}

.home-plan__fee-comma {
  font-size: 60%;
}

.home-plan__fee-yen {
  font-weight: 700;
  letter-spacing: 0.08em;
  padding-bottom: 0.2em;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-plan__fee-yen {
    font-size: 6vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__fee-yen {
    font-size: 2.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__fee-yen {
    font-size: 30px;
  }
}

.home-plan__fee-tax {
  left: -0.54em;
  letter-spacing: 0.02em;
  position: absolute;
  top: -1em;
}
@media screen and (max-width: 768px) {
  .home-plan__fee-tax {
    font-size: 2.133vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__fee-tax {
    font-size: 0.938vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__fee-tax {
    font-size: 12px;
  }
}

@media screen and (max-width: 768px) {
  .home-plan__body {
    padding: 5.333vw 0;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__body {
    padding: 3.125vw 0 17.969vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__body {
    padding: 40px 0 230px;
  }
}

.home-plan__feature {
  display: flex;
  flex-direction: column;
  list-style: none;
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .home-plan__feature {
    gap: 2.667vw;
    padding: 0 0 0 4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__feature {
    gap: 1.563vw;
    padding: 0 0 0 1.563vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__feature {
    gap: 20px;
    padding: 0 0 0 20px;
  }
}

.home-plan__feature-item {
  align-items: center;
  display: flex;
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .home-plan__feature-item {
    gap: 2vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__feature-item {
    gap: 0.781vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__feature-item {
    gap: 10px;
  }
}

@media screen and (max-width: 768px) {
  .home-plan__feature-icon {
    margin: 1.333vw 0;
    width: 20vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__feature-icon {
    width: 7.813vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__feature-icon {
    width: 100px;
  }
}

.home-plan__feature-text {
  background: url(../images/home/plan_check.svg) no-repeat;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .home-plan__feature-text {
    background-position: 0 1.333vw;
    background-size: 3.2vw auto;
    font-size: 3.733vw;
    line-height: 1.5;
    padding-left: 5.333vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__feature-text {
    background-position: 0 0.391vw;
    background-size: 1.25vw auto;
    font-size: 1.406vw;
    line-height: 1.556;
    padding-left: 2.031vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__feature-text {
    background-position: 0 5px;
    background-size: 16px auto;
    font-size: 18px;
    padding-left: 26px;
  }
}

@media screen and (max-width: 768px) {
  .home-plan__feature-note {
    font-size: 3.2vw;
    line-height: 1.417;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__feature-note {
    font-size: 1.094vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__feature-note {
    font-size: 14px;
  }
}

@media screen and (max-width: 768px) {
  .home-plan__feature-small {
    font-size: 3.2vw;
    line-height: 1.417;
  }
}

.home-plan__card--pro .home-plan__title {
  background: var(--color-primary);
}
.home-plan__card--pro .home-plan__summay-wrap {
  background: #d3ebee;
}
.home-plan__card--pro .home-plan__summay-wrap::after {
  background: #d3ebee;
}
@media screen and (min-width: 769px) {
  .home-plan__card--pro .home-plan__body {
    padding-top: 2.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__card--pro .home-plan__body {
    padding-top: 30px;
  }
}

.home-plan__card--biz .home-plan__title {
  background: var(--color-tertiary);
}
.home-plan__card--biz .home-plan__summay-wrap {
  background: #daeaf2;
}
.home-plan__card--biz .home-plan__summay-wrap::after {
  background: #daeaf2;
}

.home-plan__card--ent .home-plan__title {
  background: #f5aa00;
}
@media screen and (max-width: 768px) {
  .home-plan__card--ent .home-plan__title {
    padding-top: 2.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__card--ent .home-plan__title {
    padding-top: 1.563vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__card--ent .home-plan__title {
    padding-top: 20px;
  }
}
.home-plan__card--ent .home-plan__summay-wrap {
  background: #fef5cc;
}
.home-plan__card--ent .home-plan__summay-wrap::after {
  background: #fef5cc;
}

@media screen and (max-width: 768px) {
  .home-plan .slick-dots {
    bottom: 6.667vw;
    left: 0;
    line-height: 0;
    list-style: none;
    margin: 0;
    padding: 0;
    position: absolute;
    text-align: center;
    width: 100%;
  }
  .home-plan .slick-dots li {
    cursor: pointer;
    display: inline-block;
    height: 2.667vw;
    margin: 0 4vw;
    padding: 0;
    position: relative;
    width: 2.667vw;
  }
  .home-plan .slick-dots li button {
    background: transparent;
    border: 0;
    color: transparent;
    cursor: pointer;
    display: block;
    font-size: 0;
    line-height: 0;
    height: 2.667vw;
    outline: none;
    padding: 0;
    width: 2.667vw;
  }
  .home-plan .slick-dots li button::before {
    background: #ccc;
    border-radius: 50%;
    content: "";
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
  }
  .home-plan .slick-dots li.slick-active button::before {
    background: var(--color-secondary);
  }
}

@media screen and (min-width: 769px) {
  .home-plan.js_inshow .home-plan__item {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
    transition: opacity 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
    transition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out;
    transition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  }
  .home-plan.js_inshow .home-plan__item:nth-of-type(1) {
    transition-delay: 0.2s;
  }
  .home-plan.js_inshow .home-plan__item:nth-of-type(2) {
    transition-delay: 0.4s;
  }
  .home-plan.js_inshow .home-plan__item:nth-of-type(3) {
    transition-delay: 0.6s;
  }
  .home-plan.is_show .home-plan__item {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

.home-plan__special {
  align-items: center;
  background: linear-gradient(180deg, rgb(96, 202, 200) 0%, rgb(79, 168, 194) 40.33%, rgb(67, 144, 190) 77.31%, rgb(62, 135, 188) 100%);
  display: flex;
  justify-content: center;
  left: 50%;
  position: absolute;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .home-plan__special {
    border: 0.4vw solid #fccc34;
    border-radius: 2.8vw;
    bottom: 16.667vw;
    gap: 2.667vw;
    height: 20.267vw;
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__special {
    border: 0.313vw solid #fccc34;
    border-radius: 1.094vw;
    bottom: 4.375vw;
    gap: 2.344vw;
    height: 11.719vw;
    width: 78.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__special {
    border-width: 4px;
    border-radius: 14px;
    bottom: 56px;
    gap: 30px;
    height: 150px;
    width: 1000px;
  }
}

@media screen and (max-width: 768px) {
  .home-plan__special-icon {
    width: 10.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__special-icon {
    width: 7.813vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__special-icon {
    width: 100px;
  }
}

.home-plan__special-text {
  color: #fff;
  font-weight: 700;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .home-plan__special-text {
    font-size: 5.6vw;
    letter-spacing: 0.04em;
    line-height: 1.143;
    text-align: center;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__special-text {
    background: url(../images/home/plan_check.svg) 0 58% no-repeat;
    background-size: 1.875vw auto;
    font-size: 1.953vw;
    letter-spacing: 0.06em;
    line-height: 1;
    padding-left: 2.734vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__special-text {
    background-size: 24px auto;
    font-size: 25px;
    padding-left: 35px;
    margin-top: -8px;
  }
}

@media screen and (max-width: 768px) {
  .home-plan__special-num {
    font-size: 6.4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-plan__special-num {
    font-size: 2.813vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-plan__special-num {
    font-size: 36px;
  }
}

@media screen and (max-width: 768px) {
  .home-plan__special-xs {
    font-size: 4.533vw;
  }
}

@media screen and (max-width: 768px) {
  .home-plan__special-small {
    font-size: 5.333vw;
  }
}

.home-price__text {
  font-weight: 700;
  letter-spacing: 0.12em;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home-price__text {
    font-size: 4.267vw;
    line-height: 1.719;
    margin: 6vw auto 0;
    width: 84.8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-price__text {
    font-size: 1.563vw;
    line-height: 1.8;
    margin: cVW(65) auto 0;
    width: cVW(1000);
  }
}
@media screen and (min-width: 1280px) {
  .home-price__text {
    font-size: 20px;
    margin: 65px auto 0;
    width: 1000px;
  }
}

.home-price__campaign-text {
  font-size: 14px;
  margin: 65px auto 0;
  width: 1000px;
}
@media screen and (max-width: 768px) {
  .home-price__campaign-text {
    font-size: 3.267vw;
    line-height: 1.719;
    margin: 6vw auto 0;
    width: 84.8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-price__campaign-text {
    font-size: 1.563vw;
    line-height: 1.8;
    margin: cVW(65) auto 0;
    width: cVW(1000);
  }
}
@media screen and (min-width: 1280px) {
  .home-price__campaign-text {
    font-size: 20px;
    margin: 65px auto 0;
    width: 1000px;
    line-height: 22px;
  }
}



.home-price__btn {
  align-items: center;
  background: #113250;
  background-repeat: no-repeat;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  line-height: 1;
  padding: 0;
  position: relative;
  text-align: center;
  text-decoration: none;
  transition: box-shadow 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .home-price__btn {
    border: 1px solid #113250;
    border-radius: 1.833vw;
    box-shadow: 0.587vw 1.173vw 0 rgba(53, 96, 122, 0.3);
    height: 14.667vw;
    margin: 4vw auto 0;
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .home-price__btn {
    border: 2px solid #113250;
    border-radius: 0.781vw;
    box-shadow: 0.313vw 0.625vw 0 rgba(53, 96, 122, 0.3);
    height: 6.25vw;
    margin: 1.172vw auto 0;
    width: 39.063vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-price__btn {
    border-radius: 10px;
    box-shadow: 4px 8px 0 rgba(53, 96, 122, 0.3);
    height: 80px;
    margin: 15px auto 0;
    width: 500px;
  }
}
@media (any-hover: hover) {
  .home-price__btn:hover {
    background: #fff;
    box-shadow: unset;
    color: #113250;
  }
}
@media screen and (any-hover: hover) and (max-width: 768px) {
  .home-price__btn:hover {
    -webkit-transform: translateY(1.173vw);
            transform: translateY(1.173vw);
  }
}
@media screen and (any-hover: hover) and (min-width: 769px) {
  .home-price__btn:hover {
    -webkit-transform: translateY(0.625vw);
            transform: translateY(0.625vw);
  }
}
@media screen and (any-hover: hover) and (min-width: 1280px) {
  .home-price__btn:hover {
    -webkit-transform: translateY(8px);
            transform: translateY(8px);
  }
}
@media (any-hover: hover) {
  .home-price__btn:hover .home-price__btn-arrow {
    fill: #113250;
  }
}

.home-price__btn-label {
  font-weight: 700;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 768px) {
  .home-price__btn-label {
    font-size: 4.267vw;
    text-indent: -4.267vw;
  }
}
@media screen and (min-width: 769px) {
  .home-price__btn-label {
    font-size: 1.719vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-price__btn-label {
    font-size: 22px;
  }
}

.home-price__btn-arrow {
  fill: #fff;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .home-price__btn-arrow {
    right: 3.467vw;
    width: 4.533vw;
  }
}
@media screen and (min-width: 769px) {
  .home-price__btn-arrow {
    right: 2.344vw;
    width: 1.953vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-price__btn-arrow {
    right: 30px;
    width: 25px;
  }
}

/* qa */
@media screen and (max-width: 768px) {
  .home-qa {
    padding: 16.667vw 0 14.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-qa {
    padding: 6.25vw 0 8.594vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-qa {
    padding: 80px 0 110px;
  }
}

.home-qa__list {
  color: #333;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 768px) {
  .home-qa__list {
    gap: 4vw;
    margin: 12vw auto 0;
    width: 84.8vw;
  }
}
@media screen and (min-width: 769px) {
  .home-qa__list {
    gap: 2.344vw;
    margin: 6.25vw auto 0;
    width: 78.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-qa__list {
    gap: 30px;
    margin: 80px auto 0;
    width: 1000px;
  }
}

.home-qa__question {
  border: solid #333;
  border-width: 1px 0;
  cursor: pointer;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin: 0;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-qa__question {
    font-size: 4.267vw;
    line-height: 1.188;
    padding: 3.333vw 10vw 3.333vw 12vw;
  }
}
@media screen and (min-width: 769px) {
  .home-qa__question {
    font-size: 1.719vw;
    padding: 2.031vw 6.25vw 2.031vw 8.594vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-qa__question {
    font-size: 22px;
    padding: 26px 80px 26px 110px;
  }
}
.home-qa__question::before {
  color: var(--color-secondary);
  content: "Q";
  font-family: var(--font-DIN2014);
  line-height: 1;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .home-qa__question::before {
    font-size: 8vw;
    left: 4vw;
  }
}
@media screen and (min-width: 769px) {
  .home-qa__question::before {
    font-size: 3.125vw;
    left: 1.953vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-qa__question::before {
    font-size: 40px;
    left: 25px;
  }
}
.home-qa__question::after {
  background: url(../images/home/qa_toggle.svg) 0 50%/contain no-repeat;
  content: "";
  display: block;
  line-height: 1;
  position: absolute;
  top: 50%;
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
  transition: -webkit-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
}
@media screen and (max-width: 768px) {
  .home-qa__question::after {
    height: 4.267vw;
    margin-top: -2.133vw;
    right: 2.667vw;
    width: 4.267vw;
  }
}
@media screen and (min-width: 769px) {
  .home-qa__question::after {
    height: 2.344vw;
    margin-top: -1.172vw;
    right: 2.344vw;
    width: 2.344vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-qa__question::after {
    height: 30px;
    margin-top: -15px;
    right: 30px;
    width: 30px;
  }
}
.home-qa__question.is_active::after {
  -webkit-transform: rotate(0);
          transform: rotate(0);
}

.home-qa__answer {
  display: none;
  letter-spacing: 0.04em;
  margin: 0;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home-qa__answer {
    font-size: 3.733vw;
    line-height: 1.571;
    padding: 2.667vw 0 4.667vw 12vw;
  }
}
@media screen and (min-width: 769px) {
  .home-qa__answer {
    font-size: 1.406vw;
    line-height: 2;
    padding: 1.563vw 6.25vw 3.516vw 8.594vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-qa__answer {
    font-size: 18px;
    padding: 20px 80px 45px 110px;
  }
}
.home-qa__answer::before {
  color: var(--color-primary);
  content: "A";
  font-family: var(--font-DIN2014);
  line-height: 1;
  position: absolute;
}
@media screen and (max-width: 768px) {
  .home-qa__answer::before {
    font-size: 8vw;
    left: 4vw;
    top: 4.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-qa__answer::before {
    font-size: 3.125vw;
    left: 1.953vw;
    top: 1.563vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-qa__answer::before {
    font-size: 40px;
    left: 25px;
    top: 20px;
  }
}

@media screen and (max-width: 768px) {
  .home-cta--qa {
    margin-top: 10.667vw;
  }
}
@media screen and (min-width: 769px) {
  .home-cta--qa {
    margin-top: 6.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .home-cta--qa {
    margin-top: 80px;
  }
}

/* 各FV種用調整 ---------------------------- */
.wrapper {
  overflow: hidden !important;
}

.price_fv02 {
  display: none !important;
}

.price_fv03 {
  display: none !important;
}

.price_fv04 {
  display: none !important;
}

/* 各社ロゴ調整用 ---------------------------- */

.logo__adjustwrap {
  display: flex;
  justify-content: center;
  align-items: center;
  width: fit-content;
}

.nissho {
  @media screen and (max-width: 768px) {
    height: 4vw !important;
    object-fit: contain;
  }
  @media screen and (min-width: 769px) {
    height: 2vw !important;
  }
  @media screen and (min-width: 1280px) {
    height: 22px !important;
  }
}

.fundex {
  @media screen and (max-width: 768px) {
    height: 3vw !important;
    object-fit: contain;
  }
  @media screen and (min-width: 769px) {
    height: 2.5vw !important;
  }
  @media screen and (min-width: 1280px) {
    height: 30px !important;
  }
}

/* 2025/10/22 追加 利用企業バッジ ---------------------------- */

.client_badge {
  position: absolute;
  align-content: center;
  top: 0;
  bottom: 0;
  right: -12vw;
  display: flex;
  align-items: center;
  img {
    width: 10vw;
    height: auto;
    object-fit: contain;
  }
  @media screen and (max-width: 768px) {
    right: 0;
    top: -40vw;
    img {
      width: 25vw;
    }
  }
}


/* 2025/10/29 fv04のデザインに変更 ---------------------------- */

@media screen and (min-width: 1280px) {
  .home-kv {
      padding: 0 !important;
  }
}
@media screen and (min-width: 769px) {
  .home-kv {
    padding: 4.294vw 0 0;
  }
}
@media screen and (max-width: 768px) {
  .home-kv {
    padding: 10.333vw 0 6.667vw;
  }
}

.home-kv_catch {
  margin: 30px 0;
  @media screen and (max-width: 1280px) {
    margin: 2vw 0;
  }
}

.fv-inner {
  margin: 70px auto 0 !important;
  max-width: none !important;
  width: 93.75% !important;
}

/*# sourceMappingURL=page_home.css.map */