#leading {
  padding-top: calc(180 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #leading {
    padding-top: 18rem;
  }
}
#leading .lead {
  font-size: 2.8rem;
  font-family: var(--ff-shippori);
  line-height: 1.4166666667;
  text-align: center;
}
@media (768px <= width) {
  #leading .lead {
    font-size: 4.8rem;
    line-height: 1.4167;
  }
}
#leading .copy {
  margin-top: calc(55 / var(--spSize) * 100vw);
  padding-left: calc(30 / var(--spSize) * 100vw);
  padding-right: calc(30 / var(--spSize) * 100vw);
  text-align: center;
  font-size: 1.6rem;
  font-weight: 500;
}
@media (768px <= width) {
  #leading .copy {
    margin-top: 6rem;
    font-size: 2.4rem;
    line-height: 1.8333333333;
  }
}
#leading .figure {
  margin-top: calc(55 / var(--spSize) * 100vw);
  margin-left: auto;
  margin-right: auto;
  width: calc(690 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #leading .figure {
    margin-top: 4rem;
    width: auto;
    text-align: center;
  }
}
#leading .text {
  margin-top: calc(40 / var(--spSize) * 100vw);
  margin-left: auto;
  margin-right: auto;
  width: calc(690 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #leading .text {
    margin-top: 4.7rem;
    text-align: center;
    font-size: 2rem;
    line-height: 2.2;
  }
}

.headline {
  position: relative;
}
.headline__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (768px <= width) {
  .headline__img img {
    aspect-ratio: 2/1;
  }
}
.headline__label {
  position: absolute;
  left: 0;
  bottom: 20%;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(10 / var(--spSize) * 100vw) 0;
  color: #fff;
  line-height: 1;
}
@media (768px <= width) {
  .headline__label {
    gap: 2rem 0;
    top: 0;
    padding-top: 31.75%;
  }
}
.headline__label .en {
  font-size: 4.4rem;
  font-family: var(--ff-ci);
  letter-spacing: 0.06em;
}
@media (768px <= width) {
  .headline__label .en {
    font-size: 8.8rem;
  }
}
.headline__label .jp {
  font-size: 1.4rem;
  font-family: var(--ff-shippori);
}
@media (768px <= width) {
  .headline__label .jp {
    font-size: 2.8rem;
  }
}

#resale,
.faq {
  margin-top: calc(190 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale,
  .faq {
    margin-top: 19rem;
  }
}
#resale .resale,
.faq .resale {
  position: relative;
  padding-top: calc(280 / var(--spSize) * 100vw);
  padding-bottom: calc(180 / var(--spSize) * 100vw);
  padding-left: calc(30 / var(--spSize) * 100vw);
  padding-right: calc(30 / var(--spSize) * 100vw);
  display: grid;
  gap: calc(150 / var(--spSize) * 100vw) 0;
}
@media (768px <= width) {
  #resale .resale,
  .faq .resale {
    padding-top: 28rem;
    padding-bottom: 18rem;
    padding-left: max(50% - 800px, 5rem);
    padding-right: max(50% - 800px, 5rem);
    display: grid;
    grid-template-columns: 715fr 725fr;
    gap: 0 10%;
  }
}
@media (768px <= width) {
  #resale .resale.column5-11,
  .faq .resale.column5-11 {
    grid-template-columns: 5fr 11fr;
    gap: 0;
  }
}
#resale .resale::after,
.faq .resale::after {
  content: "";
  width: 33%;
  height: 1px;
  background-color: var(--clr-blue);
  position: absolute;
  left: calc(30 / var(--spSize) * 100vw);
  top: calc(160 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale .resale::after,
  .faq .resale::after {
    width: 30rem;
    left: max(50% - 800px, 5rem);
    right: max(50% - 800px, 5rem);
    top: 16rem;
  }
}
#resale .resale::before,
.faq .resale::before {
  content: "";
  width: calc(690 / var(--spSize) * 100vw);
  height: 1px;
  position: absolute;
  left: calc(30 / var(--spSize) * 100vw);
  top: calc(160 / var(--spSize) * 100vw);
  border-top: 1px dotted #cac9c4;
}
@media (768px <= width) {
  #resale .resale::before,
  .faq .resale::before {
    width: auto;
    left: max(50% - 800px, 5rem);
    right: max(50% - 800px, 5rem);
    top: 16rem;
  }
}
#resale .resale:nth-child(even),
.faq .resale:nth-child(even) {
  background-color: #eceae2;
}
#resale .heading .label,
.faq .heading .label {
  background: var(--clr-blue);
  color: #fff;
  font-size: 1.1rem;
  font-family: var(--ff-shippori);
  border-radius: 5px;
  display: inline-block;
  padding: 0 calc(20 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale .heading .label,
  .faq .heading .label {
    font-size: 2.2rem;
    padding: 0 2rem;
  }
}
#resale .heading .title,
.faq .heading .title {
  font-size: 2rem;
  font-family: var(--ff-shippori);
  line-height: 1.55;
  margin-top: calc(20 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale .heading .title,
  .faq .heading .title {
    font-size: 4rem;
    margin-top: 3.6rem;
  }
}
#resale .subhead,
.faq .subhead {
  position: relative;
  padding-left: 32px;
  font-size: 1.8rem;
  font-weight: 500;
  color: rgba(51, 51, 51, 0.8);
}
@media (768px <= width) {
  #resale .subhead,
  .faq .subhead {
    font-size: 2.4rem;
    padding-left: 3.2rem;
  }
}
#resale .subhead::before,
.faq .subhead::before {
  content: "";
  width: 1.5rem;
  height: 1.5rem;
  background-color: var(--clr-blue);
  display: block;
  position: absolute;
  left: 0;
  top: 0.7em;
}
#resale .lead,
.faq .lead {
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.8333333333;
}
@media (768px <= width) {
  #resale .lead,
  .faq .lead {
    font-size: 2.4rem;
  }
}
#resale .text,
.faq .text {
  font-size: 1.4rem;
  line-height: 1.8333333333;
}
@media (768px <= width) {
  #resale .text,
  .faq .text {
    font-size: 2rem;
  }
}
#resale .balloon,
.faq .balloon {
  background-color: #b2b0a8;
  color: #fff;
  font-size: 1.4rem;
  line-height: 1.6;
  padding: calc(20 / var(--spSize) * 100vw) calc(40 / var(--spSize) * 100vw) calc(20 / var(--spSize) * 100vw) calc(40 / var(--spSize) * 100vw + 1em);
  text-indent: -1em;
  margin-top: calc(110 / var(--spSize) * 100vw);
  position: relative;
}
#resale .balloon::before,
.faq .balloon::before {
  content: "";
  background: #b2b0a8;
  height: calc(25 / var(--spSize) * 100vw);
  width: calc(25 / var(--spSize) * 100vw);
  clip-path: polygon(0 0, 100% 0, 0 100%);
  position: absolute;
  left: calc(30 / var(--spSize) * 100vw);
  bottom: calc(-20 / var(--spSize) * 100vw);
  pointer-events: none;
}
@media (768px <= width) {
  #resale .balloon::before,
  .faq .balloon::before {
    height: 2.5rem;
    width: 2.5rem;
    left: 3rem;
    bottom: -2rem;
  }
}
@media (768px <= width) {
  #resale .balloon,
  .faq .balloon {
    font-size: 2rem;
    text-align: center;
    padding: 1.5rem;
    margin-top: 11rem;
  }
}
#resale .accordion,
.faq .accordion {
  border-bottom: 1px solid #cac9c4;
}
#resale .accordion dt,
.faq .accordion dt {
  border-top: 1px solid #cac9c4;
  font-family: var(--ff-shippori);
  font-size: 2rem;
  line-height: 1.571;
  padding: calc(50 / var(--spSize) * 100vw) 0;
  padding-right: calc(150 / var(--spSize) * 100vw);
  position: relative;
}
@media (768px <= width) {
  #resale .accordion dt,
  .faq .accordion dt {
    font-size: 2.8rem;
    padding: 5rem 0;
    padding-right: 15rem;
  }
}
#resale .accordion dt::after,
.faq .accordion dt::after {
  content: "";
  width: calc(45 / var(--spSize) * 100vw);
  height: 1px;
  background-color: #333;
  position: absolute;
  right: calc(50 / var(--spSize) * 100vw);
  top: 50%;
}
@media (768px <= width) {
  #resale .accordion dt::after,
  .faq .accordion dt::after {
    width: 4.5rem;
    right: 5rem;
  }
}
#resale .accordion dt:not(.open)::before,
.faq .accordion dt:not(.open)::before {
  content: "";
  width: 1px;
  height: calc(45 / var(--spSize) * 100vw);
  background-color: #333;
  position: absolute;
  top: calc(50% - 22.5 / var(--spSize) * 100vw);
  right: calc(72.5 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale .accordion dt:not(.open)::before,
  .faq .accordion dt:not(.open)::before {
    height: 4.5rem;
    top: calc(50% - 2.25rem);
    right: 7.25rem;
  }
}
#resale .accordion dd,
.faq .accordion dd {
  padding-top: calc(60 / var(--spSize) * 100vw);
  padding-bottom: calc(60 / var(--spSize) * 100vw);
  margin-left: calc(40 / var(--spSize) * 100vw);
  border-top: 1px dotted #cac9c4;
  display: none;
  color: #666;
}
@media (768px <= width) {
  #resale .accordion dd,
  .faq .accordion dd {
    padding-top: 6rem;
    padding-bottom: 6rem;
    margin-left: 3rem;
    font-size: 2rem;
  }
}
#resale .accordion .title,
.faq .accordion .title {
  counter-increment: section;
  font-family: var(--ff-shippori);
  font-size: 2rem;
  line-height: 1.8;
  padding-left: 2em;
  position: relative;
  color: var(--clr-text-light);
}
@media (768px <= width) {
  #resale .accordion .title,
  .faq .accordion .title {
    font-size: 2.4rem;
  }
}
#resale .accordion .title:before,
.faq .accordion .title:before {
  content: counter(section);
  background-color: var(--clr-blue);
  border-radius: 50%;
  width: 1.5em;
  height: 1.5em;
  color: #fff;
  font-size: 1.8rem;
  font-family: var(--ff-ci);
  display: inline-block;
  margin-right: 0.5em;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  left: 0;
  top: 0.5em;
}
@media (768px <= width) {
  #resale .accordion .title:before,
  .faq .accordion .title:before {
    font-size: 2.2rem;
  }
}
#resale .accordion .content,
.faq .accordion .content {
  line-height: 1.8;
  margin-top: calc(20 / var(--spSize) * 100vw);
  color: #666;
}
#resale .accordion .content + .title,
.faq .accordion .content + .title {
  margin-top: calc(50 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale .accordion .content + .title,
  .faq .accordion .content + .title {
    margin-top: 5rem;
  }
}
#resale .accordion .lt,
.faq .accordion .lt {
  font-weight: 500;
  margin-top: calc(60 / var(--spSize) * 100vw);
  margin-bottom: calc(25 / var(--spSize) * 100vw);
  color: var(--clr-text-light);
}
@media (768px <= width) {
  #resale .accordion .lt,
  .faq .accordion .lt {
    margin-top: 6rem;
    margin-bottom: 2.5rem;
  }
}

#resale01 .lead {
  margin-top: calc(75 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale01 .lead {
    margin-top: 70px;
  }
}
#resale01 .text {
  margin-top: calc(30 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale01 .text {
    margin-top: 3rem;
  }
}
#resale01 table {
  margin-top: calc(50 / var(--spSize) * 100vw);
  width: 100%;
}
@media (768px <= width) {
  #resale01 table {
    margin-top: 3rem;
  }
}
#resale01 table tr {
  border-bottom: 1px solid #cac9c4;
}
#resale01 table th,
#resale01 table td {
  padding: 1rem;
  width: 30%;
}
@media (width < 768px) {
  #resale01 table th:nth-child(1),
  #resale01 table td:nth-child(1) {
    width: 40%;
  }
  #resale01 table th:nth-child(2),
  #resale01 table td:nth-child(2) {
    width: 30%;
  }
  #resale01 table th:nth-child(3),
  #resale01 table td:nth-child(3) {
    width: 30%;
  }
}
@media (768px <= width) {
  #resale01 table th,
  #resale01 table td {
    width: 40%;
    padding: 1.5rem 1rem;
    line-height: 1.5;
  }
}
#resale01 table th img[src*=triangle],
#resale01 table td img[src*=triangle] {
  width: calc(41 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale01 table th img[src*=triangle],
  #resale01 table td img[src*=triangle] {
    width: 4.1rem;
  }
}
#resale01 table th img[src*=double_circle],
#resale01 table td img[src*=double_circle] {
  width: calc(40 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale01 table th img[src*=double_circle],
  #resale01 table td img[src*=double_circle] {
    width: 4rem;
  }
}
#resale01 table th:nth-child(1),
#resale01 table td:nth-child(1) {
  padding-left: 0;
}
#resale01 table th:nth-child(2), #resale01 table th:nth-child(3),
#resale01 table td:nth-child(2),
#resale01 table td:nth-child(3) {
  text-align: center;
  width: 35%;
}
@media (768px <= width) {
  #resale01 table th:nth-child(2), #resale01 table th:nth-child(3),
  #resale01 table td:nth-child(2),
  #resale01 table td:nth-child(3) {
    width: 30%;
  }
}
#resale01 table th {
  font-size: 1.2rem;
  color: #fff;
}
@media (768px <= width) {
  #resale01 table th {
    font-size: 2.4rem;
  }
}
#resale01 table th:nth-child(2) {
  background-color: #b2b0a8;
}
#resale01 table th:nth-child(3) {
  background-color: #91b9c9;
}
#resale01 table td {
  font-size: 1.1rem;
}
@media (768px <= width) {
  #resale01 table td {
    font-size: 1.8rem;
  }
}
#resale01 table td strong {
  color: #91b9c9;
  font-size: 1.3rem;
  font-weight: bold;
  margin-right: 0.1em;
}
@media (768px <= width) {
  #resale01 table td strong {
    font-size: 1.7rem;
  }
}
#resale01 table td:nth-child(2), #resale01 table td:nth-child(3) {
  color: #666;
}
#resale01 table td:nth-child(1) {
  font-size: 1.1rem;
}
@media (768px <= width) {
  #resale01 table td:nth-child(1) {
    font-size: 2rem;
  }
}
#resale01 table td:nth-child(2) {
  background-color: #eceae2;
}
#resale01 table td:nth-child(3) {
  background-color: #e9eef0;
}

#resale02 .img {
  margin-top: calc(90 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale02 .img {
    margin-top: 9rem;
  }
}
#resale02 .text {
  margin-top: calc(30 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale02 .text {
    margin-top: 3rem;
  }
}
#resale02 .accordion {
  margin-top: calc(60 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #resale02 .accordion {
    margin-top: 6rem;
  }
}

#timeshareresale {
  padding: calc(185 / var(--spSize) * 100vw) calc(30 / var(--spSize) * 100vw) calc(200 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #timeshareresale {
    padding: 20rem max(50% - 800px, 5rem);
  }
}
#timeshareresale .title {
  text-align: center;
  font-family: var(--ff-shippori);
  line-height: 1;
  padding-bottom: calc(45 / var(--spSize) * 100vw);
  position: relative;
}
@media (768px <= width) {
  #timeshareresale .title {
    padding-bottom: 4.5rem;
  }
}
#timeshareresale .title::after {
  content: "";
  width: calc(102 / var(--spSize) * 100vw);
  height: 1px;
  border-bottom: 1px dotted #cac9c4;
  position: absolute;
  bottom: 0;
  left: calc(50% - 51 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #timeshareresale .title::after {
    width: 10.2rem;
    left: calc(50% - 5.1rem);
  }
}
#timeshareresale .title .sub {
  font-size: 1.6rem;
}
@media (768px <= width) {
  #timeshareresale .title .sub {
    font-size: 3.2rem;
  }
}
#timeshareresale .title .label {
  font-size: 3.1rem;
  line-height: 1.323;
  margin-top: calc(30 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #timeshareresale .title .label {
    font-size: 6.2rem;
    margin-top: 3rem;
  }
}
#timeshareresale .text {
  margin-top: calc(90 / var(--spSize) * 100vw);
  color: #666;
  font-size: 1.4rem;
  line-height: 1.8;
}
@media (768px <= width) {
  #timeshareresale .text {
    margin-top: 9rem;
    font-size: 2rem;
    text-align: center;
  }
}
#timeshareresale .band {
  text-align: center;
  font-size: 2.4rem;
  font-family: var(--ff-shippori);
  color: #fff;
  margin-top: calc(100 / var(--spSize) * 100vw);
  background-color: var(--clr-blue);
}
@media (768px <= width) {
  #timeshareresale .band {
    font-size: 3.2rem;
    margin-top: 10rem;
    margin-left: 10rem;
    margin-right: 10rem;
  }
}
#timeshareresale .secret {
  display: grid;
  gap: calc(120 / var(--spSize) * 100vw) 0;
  margin-top: calc(60 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #timeshareresale .secret {
    gap: 6rem 0;
    margin-left: 10rem;
    margin-right: 10rem;
    margin-top: 6rem;
  }
}
#timeshareresale .secret .group {
  display: grid;
  gap: calc(60 / var(--spSize) * 100vw) 0;
  counter-increment: number;
}
@media (768px <= width) {
  #timeshareresale .secret .group {
    grid-template-columns: 40rem auto;
    align-items: center;
    gap: 0 8rem;
  }
}
#timeshareresale .secret .group__wrap {
  position: relative;
}
#timeshareresale .secret .group__wrap::after {
  content: "0" counter(number);
  color: #eceae2;
  font-size: 7rem;
  font-family: var(--ff-ci);
  line-height: 1;
  position: absolute;
  top: 0;
  right: 0;
  pointer-events: none;
}
@media (768px <= width) {
  #timeshareresale .secret .group__wrap::after {
    font-size: 14rem;
  }
}
#timeshareresale .secret .group__label {
  font-size: 2.4rem;
  font-family: var(--ff-shippori);
  line-height: 1.625;
  position: relative;
  z-index: 2;
}
@media (768px <= width) {
  #timeshareresale .secret .group__label {
    font-size: 3.2rem;
  }
}
#timeshareresale .secret .group__label u {
  text-decoration-color: #e5d2c2;
  text-decoration-thickness: 10px;
  text-underline-offset: -0.3em;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
}
#timeshareresale .secret .group__text {
  font-size: 1.4rem;
  line-height: 1.8;
  margin-top: calc(30 / var(--spSize) * 100vw);
  color: #666;
  position: relative;
  z-index: 2;
}
@media (768px <= width) {
  #timeshareresale .secret .group__text {
    font-size: 2rem;
    margin-top: 3rem;
  }
}

.faq {
  position: relative;
  padding-top: calc(280 / var(--spSize) * 100vw);
  margin-top: 0;
  display: grid;
  gap: calc(150 / var(--spSize) * 100vw) 0;
}
@media (768px <= width) {
  .faq {
    padding-top: 28rem;
    display: grid;
    grid-template-columns: 500fr 1100fr;
    gap: 0 10%;
  }
}
.faq::after {
  content: "";
  width: 33%;
  height: 1px;
  background-color: var(--clr-blue);
  position: absolute;
  top: calc(160 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  .faq::after {
    width: 30rem;
    top: 16rem;
  }
}
.faq::before {
  content: "";
  width: calc(690 / var(--spSize) * 100vw);
  height: 1px;
  position: absolute;
  top: calc(160 / var(--spSize) * 100vw);
  border-top: 1px dotted #cac9c4;
}
@media (768px <= width) {
  .faq::before {
    width: 100%;
    top: 16rem;
  }
}
.faq h3 {
  font-size: 2.8rem;
  font-family: var(--ff-shippori);
  line-height: 1.55;
}
@media (768px <= width) {
  .faq h3 {
    font-size: 4rem;
  }
}