:root {
  --pc: 1400 * 100vw;
  --sp: 375 * 100vw;
}

html {
  scroll-behavior: smooth;
}

.lp {
  background: #F8F6F2;
  font-family: "Zen Old Mincho", serif;
}
.lp ul, .lp ol, .lp li {
  margin: 0;
  list-style: none;
}
.lp img {
  width: 100%;
  height: auto;
}
.lp section {
  position: relative;
}
.lp section .section-inner {
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .lp section .section-inner {
    width: 900px;
  }
}
@media screen and (max-width: 768px) {
  .lp section .section-inner {
    width: calc(345 / var(--sp));
  }
}
.lp section .regist-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 350px;
  height: 50px;
  margin-inline: auto;
  color: #fff;
  font-weight: 900;
  font-size: 20px;
  line-height: 1;
  border-radius: 30px;
  background: linear-gradient(138deg, #D3B589 -100.91%, #CBAF83 -86.22%, #B79E72 -65.23%, #978358 -37.95%, #796A3F -19.05%, #897C51 -12.76%, #B3AB80 -4.36%, #FFFFD5 4.03%, #FAF9CE 5.51%, #EEE9BD 14.53%, #DBD0A3 22.92%, #CBBB8D 29.22%, #BEAB7C 39.72%, #B6A070 50.21%, #B19969 64.9%, #B09868 108.98%);
}
@media screen and (max-width: 768px) {
  .lp section .regist-btn {
    width: calc(220 / var(--sp));
    height: calc(44 / var(--sp));
    font-size: calc(16 / var(--sp));
    border-radius: calc(30 / var(--sp));
  }
}
.lp section.kv {
  text-align: center;
  padding-bottom: 48px;
}
@media screen and (max-width: 768px) {
  .lp section.kv {
    margin-top: calc(13 / var(--sp));
    padding-bottom: calc(50 / var(--sp));
  }
}
.lp section.kv .kv-image {
  margin-bottom: 85px;
  aspect-ratio: 1800/900;
}
@media screen and (max-width: 768px) {
  .lp section.kv .kv-image {
    width: 100vw;
    margin-left: calc(-15 / var(--sp));
    margin-bottom: calc(45 / var(--sp));
    aspect-ratio: 1/1;
  }
}
.lp section.kv h2 {
  position: relative;
  display: inline-block;
  margin-bottom: 38px;
  padding: 5px 20px 30px;
  color: #99752D;
  font-size: 24px;
}
@media screen and (max-width: 768px) {
  .lp section.kv h2 {
    margin-bottom: calc(10 / var(--sp));
    padding-top: calc(4 / var(--sp));
    padding-inline: calc(18 / var(--sp));
    padding-bottom: calc(32 / var(--sp));
    font-size: calc(20 / var(--sp));
  }
}
.lp section.kv h2::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 71px;
  background-image: url(../img/title-about.svg);
  background-size: contain;
  background-repeat: no-repeat;
}
.lp section.kv .benefit-nav {
  margin-bottom: 60px;
}
@media screen and (max-width: 768px) {
  .lp section.kv .benefit-nav {
    margin-bottom: calc(40 / var(--sp));
  }
}
.lp section.kv .benefit-nav ul {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 10px;
}
@media screen and (max-width: 768px) {
  .lp section.kv .benefit-nav ul {
    grid-template-columns: repeat(2, 1fr);
    gap: calc(11 / var(--sp));
  }
}
.lp section.kv .benefit-nav ul li {
  grid-column: span 3;
  position: relative;
  height: 199px;
  padding-block: 20px;
  border: 1px solid #000035;
  background: #FFF;
}
@media screen and (max-width: 768px) {
  .lp section.kv .benefit-nav ul li {
    height: calc(153 / var(--sp));
    grid-column: span 1;
    padding-block: calc(12 / var(--sp));
  }
  .lp section.kv .benefit-nav ul li:nth-child(1) {
    grid-column: span 2;
    height: calc(123 / var(--sp));
  }
}
@media screen and (min-width: 769px) {
  .lp section.kv .benefit-nav ul li:nth-child(1), .lp section.kv .benefit-nav ul li:nth-child(2), .lp section.kv .benefit-nav ul li:nth-child(3) {
    grid-column: span 4;
  }
}
.lp section.kv .benefit-nav ul li::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 20px;
  width: 21px;
  aspect-ratio: 21/8;
  background-image: url(../img/arrow.svg);
  background-size: contain;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .lp section.kv .benefit-nav ul li::after {
    bottom: calc(12 / var(--sp));
    width: calc(14 / var(--sp));
  }
}
.lp section.kv .benefit-nav ul li .benefit-number {
  position: absolute;
  top: -20px;
  left: -20px;
  z-index: 1;
  width: 74px;
}
@media screen and (max-width: 768px) {
  .lp section.kv .benefit-nav ul li .benefit-number {
    top: calc(-10 / var(--sp));
    left: calc(-10 / var(--sp));
    width: calc(50 / var(--sp));
  }
}
.lp section.kv .benefit-nav ul li .icon {
  width: 70px;
  aspect-ratio: 1;
  margin-inline: auto;
  margin-bottom: 8px;
}
@media screen and (max-width: 768px) {
  .lp section.kv .benefit-nav ul li .icon {
    width: calc(55 / var(--sp));
    margin-bottom: calc(4 / var(--sp));
  }
}
.lp section.kv .benefit-nav ul li p {
  color: #000035;
  font-weight: 900;
  font-size: 14px;
  line-height: 1.75;
  vertical-align: bottom;
}
@media screen and (max-width: 768px) {
  .lp section.kv .benefit-nav ul li p {
    font-size: calc(12 / var(--sp));
    line-height: 1.3;
  }
}
.lp section.kv .benefit-nav ul li p span {
  color: #99752D;
  vertical-align: baseline;
}
.lp section.kv .benefit-nav ul li p i {
  vertical-align: baseline;
  color: #99752D;
  font-style: normal;
  font-size: 24px;
}
@media screen and (max-width: 768px) {
  .lp section.kv .benefit-nav ul li p i {
    font-size: calc(18 / var(--sp));
  }
}
.lp section.kv .benefit-nav ul li:nth-of-type(1) .icon {
  margin-bottom: 0;
}
.lp section.kv .benefit-nav ul li:nth-of-type(1) p {
  line-height: 25px;
}
@media screen and (max-width: 768px) {
  .lp section.kv .benefit-nav ul li:nth-of-type(1) p {
    line-height: calc(21 / var(--sp));
  }
}
@media screen and (max-width: 768px) {
  .lp section.kv .benefit-nav ul li:nth-child(n+2) .benefit-number {
    width: calc(40 / var(--sp));
  }
}
@media screen and (min-width: 769px) {
  .lp section.kv .benefit-nav ul li:nth-child(n+4) .benefit-number {
    width: 62px;
  }
}
.lp section.benefit-list {
  padding-block: 72px 120px;
  background-image: url(../img/background.webp);
  background-size: cover;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .lp section.benefit-list {
    padding-block: calc(50 / var(--sp)) calc(100 / var(--sp));
    background-image: url(../img/background-sp.webp);
  }
}
.lp section.benefit-list .benefit-detail {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  height: 378px;
  padding-block: 32px;
  text-align: center;
  background: #fff;
  scroll-margin-top: 64px;
}
@media screen and (max-width: 768px) {
  .lp section.benefit-list .benefit-detail {
    height: calc(344 / var(--sp));
    padding-block: calc(30 / var(--sp));
    scroll-margin-top: 50px;
  }
}
.lp section.benefit-list .benefit-detail + .benefit-detail {
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .lp section.benefit-list .benefit-detail + .benefit-detail {
    margin-top: calc(10 / var(--sp));
  }
}
.lp section.benefit-list .benefit-detail::before {
  content: "";
  position: absolute;
  top: 8px;
  left: 12px;
  width: 875px;
  height: 362px;
  background-image: url(../img/benefit-frame.svg);
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
}
@media screen and (max-width: 768px) {
  .lp section.benefit-list .benefit-detail::before {
    top: calc(4 / var(--sp));
    left: calc(7 / var(--sp));
    width: calc(331 / var(--sp));
    height: calc(336 / var(--sp));
    background-image: url(../img/benefit-frame-sp.svg);
  }
}
.lp section.benefit-list .benefit-detail .benefit-number {
  width: 62px;
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .lp section.benefit-list .benefit-detail .benefit-number {
    width: calc(50 / var(--sp));
    margin-bottom: calc(20 / var(--sp));
  }
}
.lp section.benefit-list .benefit-detail .icon {
  width: 70px;
}
@media screen and (max-width: 768px) {
  .lp section.benefit-list .benefit-detail .icon {
    width: calc(55 / var(--sp));
  }
}
.lp section.benefit-list .benefit-detail h3 {
  position: relative;
  margin-bottom: 30px;
  padding-inline: 21px;
  color: #754E00;
  font-size: 22px;
  line-height: 2;
  font-weight: 900;
}
@media screen and (max-width: 768px) {
  .lp section.benefit-list .benefit-detail h3 {
    margin-bottom: calc(20 / var(--sp));
    padding-inline: calc(26 / var(--sp));
    font-size: calc(18 / var(--sp));
    line-height: 1.4;
  }
}
.lp section.benefit-list .benefit-detail h3::before, .lp section.benefit-list .benefit-detail h3::after {
  content: "";
  position: absolute;
  top: 54%;
  transform: translateY(-50%);
  width: 11px;
  aspect-ratio: 1/1;
  background-image: url(../img/decoration.svg);
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
}
@media screen and (max-width: 768px) {
  .lp section.benefit-list .benefit-detail h3::before, .lp section.benefit-list .benefit-detail h3::after {
    top: 51%;
    width: calc(10 / var(--sp));
  }
}
.lp section.benefit-list .benefit-detail h3::before {
  left: 0;
}
.lp section.benefit-list .benefit-detail h3::after {
  right: 0;
}
.lp section.benefit-list .benefit-detail p {
  font-weight: 500;
  font-size: 14px;
  line-height: 1.75;
  color: #000035;
}
@media screen and (max-width: 768px) {
  .lp section.benefit-list .benefit-detail p {
    font-size: calc(14 / var(--sp));
    line-height: 1.65;
  }
}
.lp section.benefit-list .regist-btn {
  margin-top: 120px;
}
@media screen and (max-width: 768px) {
  .lp section.benefit-list .regist-btn {
    margin-top: calc(100 / var(--sp));
  }
}

@media (max-width: 767px) {
  .pc {
    display: none;
  }
}
@media (min-width: 768px) {
  .sp {
    display: none;
  }
}/*# sourceMappingURL=style.css.map */