#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);
  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 {
  font-size: 1.4rem;
  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;
  }
}

.subhead {
  position: relative;
  padding-left: 32px;
  font-size: 1.8rem;
  font-weight: 500;
  color: rgba(51, 51, 51, 0.8);
}
@media (768px <= width) {
  .subhead {
    font-size: 2.4rem;
  }
}
.subhead::before {
  content: "";
  width: 1.5rem;
  height: 1.5rem;
  background-color: var(--clr-blue);
  display: block;
  position: absolute;
  left: 0;
  top: 0.7em;
}

#price {
  margin-top: calc(190 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price {
    margin-top: 19rem;
  }
}
#price .columns {
  padding-top: calc(280 / var(--spSize) * 100vw);
  padding-bottom: calc(180 / var(--spSize) * 100vw);
}
@media (width < 768px) {
  #price .columns .column:first-child {
    margin-bottom: calc(70 / var(--spSize) * 100vw);
  }
  #price .columns.column5-11 {
    gap: calc(70 / var(--spSize) * 100vw) 0;
  }
}
@media (768px <= width) {
  #price .columns {
    padding-top: 28rem;
    padding-bottom: 18rem;
    display: grid;
    grid-template-columns: 715fr 725fr;
    gap: 0 10%;
  }
  #price .columns.column5-11 {
    grid-template-columns: 5fr 11fr;
    gap: 0;
  }
  #price .columns.center {
    align-items: center;
  }
}
#price .columns + .columns {
  padding-top: 0;
}
#price .columns:has(+ .columns) {
  padding-bottom: calc(80 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price .columns:has(+ .columns) {
    padding-bottom: 8rem;
  }
}
#price .columns.container {
  border-bottom: 1px solid #cac9c4;
  padding-bottom: calc(80 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price .columns.container {
    padding-bottom: 8rem;
  }
}
#price .columns.container + .container {
  padding-top: calc(80 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price .columns.container + .container {
    padding-top: 8rem;
  }
}
#price .price {
  position: relative;
  padding-left: calc(30 / var(--spSize) * 100vw);
  padding-right: calc(30 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price .price {
    padding-left: max(50% - 800px, 5rem);
    padding-right: max(50% - 800px, 5rem);
  }
}
@media (768px <= width) {
  #price .price .wide {
    grid-column: 1/3;
  }
}
#price .price::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) {
  #price .price::after {
    width: 30rem;
    left: max(50% - 800px, 5rem);
    right: max(50% - 800px, 5rem);
    top: 16rem;
  }
}
#price .price::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) {
  #price .price::before {
    width: auto;
    left: max(50% - 800px, 5rem);
    right: max(50% - 800px, 5rem);
    top: 16rem;
  }
}
#price .price:nth-child(even) {
  background-color: #eceae2;
}
#price .price .title {
  font-size: 2.4rem;
  font-family: var(--ff-shippori);
}
@media (768px <= width) {
  #price .price .title {
    font-size: 2.8rem;
  }
}
#price .heading .title {
  font-size: 2.8rem;
  font-family: var(--ff-shippori);
  line-height: 1.55;
}
@media (768px <= width) {
  #price .heading .title {
    font-size: 4rem;
  }
}
@media (width < 768px) {
  #price .heading .title br {
    display: none;
  }
}
#price .text {
  font-size: 1.4rem;
  line-height: 1.8333333333;
}
@media (768px <= width) {
  #price .text {
    font-size: 2rem;
  }
}
#price .text b {
  font-weight: 500;
  color: var(--clr-blue);
}
#price .lt {
  font-weight: 500;
  font-size: 2.4rem;
  font-family: var(--ff-shippori);
  color: var(--clr-text-light);
}
@media (768px <= width) {
  #price .lt {
    font-size: 2.8rem;
  }
}
@media (width < 768px) {
  #price .scrollarea {
    overflow-x: scroll;
    padding-bottom: 2rem;
  }
  #price .scrollarea table {
    width: 200vw !important;
  }
}

#price01 {
  margin-top: calc(160 / var(--spSize) * 100vw);
  padding-bottom: calc(160 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price01 {
    margin-top: 16rem;
    padding-bottom: 16rem;
  }
}
#price01 .img {
  margin-top: calc(100 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price01 .img {
    margin-top: 10rem;
  }
}
#price01 .text {
  margin-top: calc(40 / var(--spSize) * 100vw);
  color: #666;
  line-height: 1.8;
}
@media (768px <= width) {
  #price01 .text {
    margin-top: 4rem;
  }
}

#price02 .pricetable .label {
  color: #fff;
  font-family: var(--ff-shippori);
  text-align: center;
  background-color: #d3b477;
  text-align: center;
  line-height: 1.5;
  padding: 1rem 2rem 15px;
  font-size: 2rem;
}
#price02 .pricetable .label strong {
  font-weight: normal;
  font-size: 3rem;
}
@media (768px <= width) {
  #price02 .pricetable .label {
    font-size: 3.2rem;
    line-height: 1;
  }
  #price02 .pricetable .label strong {
    font-size: 4.8rem;
  }
}
#price02 .pricetable table {
  width: 100%;
  margin-top: 4rem;
}
#price02 .pricetable table tr {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0 1rem;
}
#price02 .pricetable table tr + tr {
  margin-top: 1rem;
}
#price02 .pricetable table th,
#price02 .pricetable table td {
  display: inline-flex;
  justify-content: center;
  line-height: 1.2727272727;
}
@media (768px <= width) {
  #price02 .pricetable table th,
  #price02 .pricetable table td {
    font-size: 2rem;
  }
}
#price02 .pricetable table th.center,
#price02 .pricetable table td.center {
  text-align: center;
}
#price02 .pricetable table th.white,
#price02 .pricetable table td.white {
  background-color: #fff;
  border-radius: 1px;
  color: #999;
  padding: 1rem 1.5rem;
  font-weight: 600;
}
#price02 .pricetable table th.blue,
#price02 .pricetable table td.blue {
  background-color: #91b9c9;
  border-radius: 1px;
  color: #fff;
  padding: 1rem 1.5rem;
  font-weight: 600;
}
#price02 .pricetable table th.va,
#price02 .pricetable table td.va {
  align-self: center;
  justify-content: left;
}
#price02 .pricetable table th {
  font-size: 2rem;
  font-weight: 500;
}
@media (768px <= width) {
  #price02 .pricetable table th {
    font-size: 2.4rem;
  }
}
#price02 .text {
  margin-top: calc(80 / var(--spSize) * 100vw);
  color: #666;
}
@media (768px <= width) {
  #price02 .text {
    margin-top: 8rem;
  }
}

#price03 table {
  width: 100%;
  border: 1px solid #cac9c4;
}
#price03 table th,
#price03 table td {
  border: 1px solid #cac9c4;
  text-align: center;
  width: 25%;
}
#price03 table th {
  background-color: #dedcd4;
  color: #666;
  padding: 10px;
  font-weight: 500;
  font-size: 1.6rem;
}
@media (768px <= width) {
  #price03 table th {
    font-size: 2rem;
  }
}
#price03 table td:nth-child(1) {
  line-height: 1.3;
  padding: 2rem;
  font-weight: 500;
}
#price03 table tr:nth-child(2) td {
  font-size: 1.6rem;
}
@media (768px <= width) {
  #price03 table tr:nth-child(2) td {
    font-size: 2rem;
  }
}
#price03 table tr:nth-child(2) td:nth-child(1) {
  background-color: #b2b0a8;
  color: #fff;
}
#price03 table tr:nth-child(2) td:not(:nth-child(1)) {
  color: #666;
  background-color: #fff;
}
#price03 table tr:nth-child(3) td:nth-child(1) {
  background-color: #91b9c9;
  color: #fff;
  font-size: 1.6rem;
}
@media (768px <= width) {
  #price03 table tr:nth-child(3) td:nth-child(1) {
    font-size: 2rem;
  }
}
#price03 table tr:nth-child(3) td:not(:nth-child(1)) {
  color: #91b9c9;
  background-color: #e9eef0;
  font-weight: 600;
  font-size: 1.8rem;
}
@media (768px <= width) {
  #price03 table tr:nth-child(3) td:not(:nth-child(1)) {
    font-size: 2.2rem;
  }
}
#price03 .text {
  margin-top: calc(80 / var(--spSize) * 100vw);
  color: #666;
}
@media (768px <= width) {
  #price03 .text {
    margin-top: 8rem;
  }
}

#price04 .text {
  margin-top: calc(80 / var(--spSize) * 100vw);
  color: #666;
}
@media (768px <= width) {
  #price04 .text {
    margin-top: 8rem;
  }
}
#price04 .text a {
  color: var(--clr-blue);
  text-decoration: underline;
}

#price05 .text {
  color: #666;
}
#price05 .text a {
  color: var(--clr-blue);
  text-decoration: underline;
}

#price06 .text {
  color: #666;
  margin-top: calc(50 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price06 .text {
    margin-top: 5rem;
  }
}
#price06 .text a {
  color: var(--clr-blue);
  text-decoration: underline;
}
#price06 .img {
  margin-top: calc(70 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price06 .img {
    margin-top: 7rem;
  }
}
#price06 .container {
  border-bottom: 1px solid #cac9c4;
  padding: calc(80 / var(--spSize) * 100vw) 0;
}
@media (768px <= width) {
  #price06 .container {
    padding: 8rem 0;
  }
}
#price06 .container .coution {
  color: #be6e6e;
}
#price06 .wrap {
  background-color: var(--clr-lightYellow1);
  padding: calc(30 / var(--spSize) * 100vw) calc(50 / var(--spSize) * 100vw) calc(40 / var(--spSize) * 100vw);
  margin-top: calc(40 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price06 .wrap {
    padding: 3rem 5rem 4rem;
    margin-top: 4rem;
    display: grid;
    grid-template-columns: auto 35rem;
    align-items: start;
    gap: 0 5rem;
  }
}
#price06 .wrap + .wrap {
  margin-top: 2rem;
}
#price06 .wrap .box p {
  margin-top: calc(10 / var(--spSize) * 100vw);
  color: #666;
}
@media (768px <= width) {
  #price06 .wrap .box p {
    margin-top: 2rem;
    font-size: 2rem;
  }
}
#price06 .wrap .graph {
  background-color: #fff;
  padding: calc(20 / var(--spSize) * 100vw);
  margin-top: calc(30 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price06 .wrap .graph {
    padding: 2rem;
    margin-top: 0;
  }
}
#price06 .wrap .graph .label {
  text-align: center;
  background-color: #91b9c9;
  color: #fff;
  font-weight: 500;
}
@media (768px <= width) {
  #price06 .wrap .graph .label {
    font-size: 2rem;
  }
}
#price06 .wrap .graph .con {
  text-align: center;
  font-size: 2.2rem;
  font-weight: 500;
  color: #91b9c9;
  margin-top: calc(10 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price06 .wrap .graph .con {
    font-size: 2.6rem;
    margin-top: 1rem;
  }
}
#price06 .wrap .graph .split {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: calc(20 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price06 .wrap .graph .split {
    margin-top: 2rem;
  }
}
#price06 .wrap .graph .split div {
  text-align: center;
  color: #666;
  font-size: 1.4rem;
  line-height: 1;
}
@media (768px <= width) {
  #price06 .wrap .graph .split div {
    font-size: 1.8rem;
  }
}
#price06 .wrap .graph .split div:nth-child(1) {
  border-right: 1px dotted #cac9c4;
}
#price06 .wrap .graph .split div span {
  font-size: 2.4rem;
  font-weight: 500;
  color: #91b9c9;
  display: inline-block;
  margin-top: calc(20 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price06 .wrap .graph .split div span {
    font-size: 2.8rem;
    margin-top: 2rem;
  }
}

#price07 .text {
  color: #666;
}
#price07 .buttonarea {
  margin-top: calc(50 / var(--spSize) * 100vw);
}
@media (768px <= width) {
  #price07 .buttonarea {
    margin-top: 5rem;
  }
}
#price07 .buttonarea a {
  display: block;
  background-color: var(--clr-blue);
  color: #fff;
  padding: calc(20 / var(--spSize) * 100vw) calc(30 / var(--spSize) * 100vw);
  font-family: var(--ff-shippori);
  position: relative;
}
@media (768px <= width) {
  #price07 .buttonarea a {
    padding: 1.5rem 3rem;
    font-size: 2rem;
    width: 40rem;
  }
}
@media (hover: hover) and (width >= 768px) {
  #price07 .buttonarea a {
    transition: all var(--speed) ease-in-out;
  }
  #price07 .buttonarea a:hover {
    opacity: 0.7;
  }
}
#price07 .buttonarea a::before {
  content: "";
  width: calc(62 / var(--spSize) * 100vw);
  height: calc(40 / var(--spSize) * 100vw);
  position: absolute;
  right: 0;
  top: calc(50% - 20 / var(--spSize) * 100vw);
  border-left: 1px dotted rgba(255, 255, 255, 0.3);
  background: url(../images/common/icon_arrow_white.svg) center/calc(7 / var(--spSize) * 100vw) auto no-repeat;
}
@media (768px <= width) {
  #price07 .buttonarea a::before {
    background-size: 0.7rem auto;
    width: 6.2rem;
    height: 4.2rem;
    top: calc(50% - 2rem);
  }
}