@charset "UTF-8";
/* mv */
.mv {
  position: relative;
}
.mv-text {
  left: 0;
  margin: 0 auto;
  position: absolute;
  right: 0;
  top: 128px;
  width: 34.25%;
  z-index: 1;
}
@media screen and (max-width: 801px) {
  .mv-text {
    top: 10vw;
    width: 70.6666666667%;
  }
}

/* mv */
/* intro */
.intro {
  background: url(../images/top/bg_intro.webp) no-repeat center bottom;
  background-size: cover;
  color: #fff;
}
.intro h2 {
  font-size: clamp(2rem, 1.2rem + 2.5vw, 6rem);
  letter-spacing: 0.1em;
  line-height: 1.2;
  margin-bottom: 30px;
  padding-bottom: 30px;
  position: relative;
}
.intro h2 .fz_s {
  font-size: 50%;
}
@media screen and (max-width: 801px) {
  .intro h2 {
    margin-bottom: 15px;
    padding-bottom: 15px;
  }
}
.intro h2::after {
  background: #FFFFFF;
  background: radial-gradient(circle, rgb(255, 255, 255) 0%, rgba(255, 255, 255, 0.47) 50%, rgba(42, 51, 67, 0.57) 100%);
  bottom: 0;
  content: "";
  height: 1px;
  left: 0;
  margin: 0 auto;
  position: absolute;
  right: 0;
  width: 1115px;
}
@media screen and (max-width: 801px) {
  .intro h2::after {
    width: 100%;
  }
}
.intro h3 {
  font-size: clamp(1.8rem, 1.16rem + 2vw, 5rem);
  letter-spacing: 0.1em;
}

/* intro */
/* merit */
.merit {
  background: url(../images/top/bg_merit.webp) no-repeat center;
  background-size: cover;
}
.merit-list {
  justify-content: space-between;
  margin-top: 68px;
}
@media screen and (max-width: 801px) {
  .merit-list {
    flex-wrap: wrap;
    margin-top: 50px;
    position: relative;
  }
  .merit-list::before {
    background: #fff;
    content: "";
    height: 1px;
    left: 0;
    position: absolute;
    right: 0;
    top: -25px;
    width: 100%;
  }
}
.merit-list li {
  position: relative;
  width: 26.6666666667%;
}
@media screen and (max-width: 801px) {
  .merit-list li {
    width: 100%;
  }
}
.merit-list li:not(:first-child) {
  width: 26%;
}
@media screen and (max-width: 801px) {
  .merit-list li:not(:first-child) {
    margin-top: 50px;
    width: 100%;
  }
}
.merit-list li:not(:first-child)::before {
  background: #fff;
  bottom: -10px;
  content: "";
  left: -18%;
  position: absolute;
  top: -10px;
  width: 1px;
}
@media screen and (max-width: 801px) {
  .merit-list li:not(:first-child)::before {
    bottom: auto;
    height: 1px;
    left: 0;
    right: 0;
    top: -25px;
    width: 100%;
  }
}

/* merit */
/* plan */
.plan {
  background: url(../images/top/bg_plan.webp) no-repeat center;
  background-size: cover;
}
@media screen and (max-width: 801px) {
  .plan {
    background-size: 100% 100%;
  }
}
.plan-detail .slick-prev,
.plan-detail .slick-next {
  background: none;
}
@media screen and (max-width: 801px) {
  .plan-detail .slick-prev,
  .plan-detail .slick-next {
    width: 3.2%;
  }
}
.plan-detail .slick-prev:before {
  content: url(../images/top/arrow_prev.svg);
}
.plan-detail .slick-next:before {
  content: url(../images/top/arrow_next.svg);
}
.plan-detail .name {
  align-items: center;
  border-top: 3px solid #231815;
  border-bottom: 3px solid #231815;
  margin: 75px auto 70px;
  padding: 20px 30px;
  position: relative;
}
@media screen and (max-width: 801px) {
  .plan-detail .name {
    flex-wrap: wrap;
    margin: 30px auto;
    padding: 20px 0;
  }
}
.plan-detail .name::before {
  border-top: 1px solid #231815;
  border-bottom: 1px solid #231815;
  content: "";
  height: calc(100% - 6px);
  left: 0;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 2px;
  width: 100%;
}
.plan-detail .name .left {
  border-right: 1px solid;
  margin-right: 20px;
  padding-right: 50px;
  text-align: center;
  width: 29.3859649123%;
}
@media screen and (max-width: 801px) {
  .plan-detail .name .left {
    align-items: center;
    border-bottom: 1px solid;
    border-right: none;
    display: flex;
    justify-content: center;
    margin-right: auto;
    padding-bottom: 10px;
    padding-right: 0;
    width: 100%;
  }
}
.plan-detail .name .left .type {
  border-bottom: 1px solid;
  font-size: clamp(1.5rem, 1.18rem + 1vw, 3.1rem);
  margin-bottom: 10px;
  padding-bottom: 10px;
}
.plan-detail .name .left .type .fz_l {
  font-size: 250%;
}
@media screen and (max-width: 801px) {
  .plan-detail .name .left .type {
    border-bottom: none;
    border-right: 1px solid;
    margin-bottom: 0;
    margin-right: 10px;
    padding-bottom: 0;
    padding-right: 10px;
  }
}
.plan-detail .name .left .ldk {
  font-size: clamp(1.4rem, 1.12rem + 0.875vw, 2.8rem);
  word-break: break-all;
}
.plan-detail .name .left .ldk .fz_l {
  font-size: 146%;
}
@media screen and (max-width: 801px) {
  .plan-detail .name .right {
    width: 100%;
  }
}
.plan-detail .name .right .area {
  font-size: clamp(1.4rem, 1.24rem + 0.5vw, 2.2rem);
  line-height: 1.5;
}
.plan-detail .name .right .area .fz_m {
  font-size: 200%;
}
.plan-detail .name .right .area .fz_l {
  font-size: 350%;
}
@media screen and (max-width: 801px) {
  .plan-detail .name .right .area .fz_l {
    font-size: 250%;
  }
}
.plan-detail .name .right .area:first-child {
  border-bottom: 1px solid;
  margin-bottom: 10px;
  padding-bottom: 10px;
}
.plan-img {
  margin: 0 auto;
  width: 85.1875%;
}
.plan .hanrei {
  display: flex;
  flex-direction: column;
  font-size: clamp(1rem, 0.84rem + 0.5vw, 1.8rem);
  margin-bottom: 20px;
}
@media screen and (max-width: 801px) {
  .plan .hanrei {
    line-height: 1.4;
  }
}
.plan .hanrei p {
  margin-bottom: 10px;
}
.plan .hanrei img {
  display: inline !important;
  margin-right: 10px;
}
@media screen and (max-width: 801px) {
  .plan .hanrei img {
    height: 2vw;
    width: auto;
  }
}
.plan-feature {
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 2px;
}
.plan-feature li {
  align-items: center;
  background: url(../images/top/plan_feature.svg) no-repeat center;
  background-size: 100% auto;
  color: #002c69;
  display: flex;
  font-size: clamp(1.2rem, 0.78rem + 1.3125vw, 3.3rem);
  font-weight: bold;
  justify-content: center;
  height: 110px;
  margin-bottom: 20px;
  text-align: center;
  width: 32.5%;
}
@media screen and (max-width: 801px) {
  .plan-feature li {
    height: auto;
    margin-bottom: 0;
    padding: 5vw;
    width: 49%;
  }
}
.plan-list {
  font-size: clamp(1.4rem, 1.12rem + 0.875vw, 2.8rem);
  margin: 70px auto 0;
  max-width: 840px;
}
@media screen and (max-width: 801px) {
  .plan-list {
    margin: 10px auto;
  }
}
.plan-list .fz_l {
  font-size: 164%;
}
.plan-list .fz_m {
  font-size: 67%;
}
.plan-list .slick-track {
  width: 100% !important;
}
.plan-list-text {
  border-bottom: 2px solid;
  padding-bottom: 5px;
  text-align: center;
  width: 29.7619047619% !important;
}
@media screen and (max-width: 801px) {
  .plan-list-text {
    width: 100% !important;
  }
}
.plan-list-text.is-active, .plan-list-text:hover {
  cursor: pointer;
  opacity: 0.7;
}
.plan-list-text:not(:first-child) {
  margin-left: 40px;
  position: relative;
}
@media screen and (max-width: 801px) {
  .plan-list-text:not(:first-child) {
    margin-left: auto;
    margin-top: 10px;
  }
}
.plan-list-text:not(:first-child)::before {
  content: "・";
  left: -25px;
  position: absolute;
  top: 30%;
}
@media screen and (max-width: 801px) {
  .plan-list-text:not(:first-child)::before {
    content: none;
  }
}

/* plan */
/* contents */
.contents {
  background: #596265 url(../images/top/bg_bottom.webp) no-repeat center bottom;
  background-size: 100% auto;
  color: #fff;
  padding-top: 150px;
}
@media screen and (max-width: 801px) {
  .contents {
    background: #293234 url(../images/top/bg_bottom_sp.webp) no-repeat center bottom;
    background-size: 100% auto;
    padding: 40px 20px 0;
  }
}
.contents-wrap {
  margin-bottom: 200px;
}
@media screen and (max-width: 801px) {
  .contents-wrap {
    flex-wrap: wrap;
    margin-bottom: 0;
    padding-bottom: 80px;
    position: relative;
    text-align: center;
  }
  .contents-wrap::after {
    background: #fff;
    bottom: 20px;
    content: "";
    height: 60px;
    left: 0;
    margin: 0 auto;
    position: absolute;
    right: 0;
    width: 1px;
  }
  .contents-wrap-text {
    border: none !important;
    margin: 0 auto !important;
    padding: 0 !important;
    text-align: center !important;
  }
}
.contents-wrap:nth-child(odd) {
  flex-direction: row-reverse;
  text-align: right;
}
@media screen and (max-width: 801px) {
  .contents-wrap:nth-child(odd) {
    text-align: center;
  }
}
.contents-wrap:nth-child(odd) .contents-wrap-text {
  border-right: 1px solid;
  margin-right: 50px;
  padding-right: 50px;
}
.contents-wrap:nth-child(odd) .contents-wrap-title span::after {
  right: -100px;
}
.contents-wrap:last-child {
  margin-bottom: 85vw;
}
.contents-wrap:nth-child(even) .contents-wrap-text {
  border-left: 1px solid;
  margin-left: 50px;
  padding-left: 50px;
}
@media screen and (max-width: 801px) {
  .contents-wrap:nth-child(even) .contents-wrap-text {
    width: 100%;
  }
}
.contents-wrap:nth-child(even) .contents-wrap-title span::after {
  left: -100px;
}
.contents-wrap-img {
  width: 46.875%;
}
@media screen and (max-width: 801px) {
  .contents-wrap-img {
    align-items: center;
    display: flex;
    justify-content: center;
    margin-bottom: 20px;
    width: 100%;
  }
}
.contents-wrap-title {
  color: #b5a370;
  font-size: clamp(3rem, 1.9rem + 3.4375vw, 8.5rem);
  line-height: 1;
  margin-bottom: 50px;
  padding-bottom: 50px;
  position: relative;
}
@media screen and (max-width: 801px) {
  .contents-wrap-title {
    margin-bottom: 0;
    padding-bottom: 0;
  }
}
.contents-wrap-title span::after {
  border-bottom: 1px solid #fff;
  bottom: 0;
  content: "";
  position: absolute;
  width: 100%;
}
@media screen and (max-width: 801px) {
  .contents-wrap-title {
    left: 0;
    position: absolute;
    right: 0;
    z-index: 1;
  }
}
.contents-wrap-lead {
  font-size: clamp(1.8rem, 1.52rem + 0.875vw, 3.2rem);
  line-height: 1.5;
  margin-bottom: 20px;
}
.contents-wrap-note {
  font-size: clamp(1.4rem, 1.32rem + 0.25vw, 1.8rem);
  line-height: 2;
}

/* contents *//*# sourceMappingURL=top.css.map */