@charset "UTF-8";
/* font */
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500;700;900&display=swap");
/* media query */
/* SP縦から */
/* SP横から */
/* タブレット縦から */
/* フルワイド */
.buy {
  background: #EFEFEF;
  padding: 170px 0 110px;
}
@media all and (max-width: 896px) {
  .buy {
    padding: 100px 0 60px;
  }
}

.ttl_about {
  text-align: center;
  font-size: 3.4rem;
  color: #AB8D54;
  margin-bottom: 120px;
}
@media all and (max-width: 896px) {
  .ttl_about {
    font-size: 2.4rem;
    margin-bottom: 50px;
  }
}

.sec_order {
  padding-top: 80px;
  margin-top: -80px;
}

.sec_payment {
  padding-top: 80px;
  margin-top: -80px;
}

.block_about {
  box-sizing: border-box;
  background: #fff;
  border-top: 5px solid #AB8D54;
  max-width: 880px;
  padding: 50px 100px 100px;
  margin: 0 auto 80px;
}
@media all and (max-width: 896px) {
  .block_about {
    padding: 30px 20px 50px;
    margin-bottom: 40px;
  }
}

.block_about_mb0 {
  margin-bottom: 0;
}

.ttl_block_about {
  text-align: center;
  font-size: 2.8rem;
  color: #AB8D54;
  margin-bottom: 50px;
}
@media all and (max-width: 896px) {
  .ttl_block_about {
    font-size: 2rem;
    margin-bottom: 30px;
  }
}

.subttl_block_about {
  text-align: center;
  font-size: 2.1rem;
  color: #AB8D54;
  margin-bottom: 40px;
}
@media all and (max-width: 896px) {
  .subttl_block_about {
    font-size: 1.8rem;
    margin-bottom: 20px;
  }
}

.subttl_buy {
  font-size: 2.4rem;
  color: #AB8D54;
  margin-bottom: 30px;
}
@media all and (max-width: 896px) {
  .subttl_buy {
    font-size: 1.8rem;
  }
}
.subttl_buy span {
  box-sizing: border-box;
  display: inline-block;
  padding-bottom: 12px;
  border-bottom: 1px solid #AB8D54;
}

.txt_block_about {
  font-size: 1.8rem;
  line-height: 1.75;
}
@media all and (max-width: 896px) {
  .txt_block_about {
    font-size: 1.4rem;
  }
}
.txt_block_about a {
  border-bottom: 1px solid #000;
}

.txt_block_about_mb {
  margin-bottom: 50px;
}
@media all and (max-width: 896px) {
  .txt_block_about_mb {
    margin-bottom: 25px;
  }
}

.txt_note {
  font-size: 1.8rem;
  line-height: 1.75;
  padding-left: 1em;
  position: relative;
}
.txt_note::before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}
@media all and (max-width: 896px) {
  .txt_note {
    font-size: 1.4rem;
  }
}

.txt_note_mb {
  margin-bottom: 50px;
}
@media all and (max-width: 896px) {
  .txt_note_mb {
    margin-bottom: 30px;
  }
}

.link_buy {
  text-align: right;
  line-height: 1.75;
  margin-top: 10px;
}
.link_buy a {
  color: #AB8D54;
  font-size: 1.8rem;
}
@media all and (max-width: 896px) {
  .link_buy a {
    font-size: 1.4rem;
  }
}

.link_block_about {
  overflow-wrap: break-word;
  word-wrap: break-word;
}
.link_block_about a {
  color: #AB8D54;
  font-size: 1.8rem;
}
@media all and (max-width: 896px) {
  .link_block_about a {
    font-size: 1.4rem;
  }
}

.box_present_first {
  margin-bottom: 80px;
}
@media all and (max-width: 896px) {
  .box_present_first {
    margin-bottom: 40px;
  }
}

.box_present_second {
  margin-bottom: 120px;
}
@media all and (max-width: 896px) {
  .box_present_second {
    margin-bottom: 50px;
  }
}

.box_present_flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.txt_present {
  width: calc(100% - 320px);
}
@media all and (max-width: 480px) {
  .txt_present {
    width: 100%;
    margin-bottom: 20px;
  }
}

.img_present {
  width: 300px;
}
@media all and (max-width: 480px) {
  .img_present {
    width: 100%;
  }
}

.box_ticket_first {
  margin-bottom: 120px;
}
@media all and (max-width: 896px) {
  .box_ticket_first {
    margin-bottom: 50px;
  }
}

.box_ticket_second {
  margin-bottom: 20px;
}
@media all and (max-width: 896px) {
  .box_ticket_second {
    margin-bottom: 0;
  }
}

.list_design {
  margin: 0 0 0 20px;
  line-height: 1.75;
}
@media all and (max-width: 896px) {
  .list_design {
    margin: 0;
  }
}
.list_design > li {
  font-size: 1.8rem;
  padding-left: 2em;
  margin-bottom: 50px;
  position: relative;
}
@media all and (max-width: 896px) {
  .list_design > li {
    margin-bottom: 25px;
  }
}
.list_design > li::before {
  content: "●";
  color: #AB8D54;
  position: absolute;
  top: 0;
  left: 0;
}
@media all and (max-width: 896px) {
  .list_design > li {
    font-size: 1.4rem;
  }
}

.list_present {
  font-size: 1.8rem;
  line-height: 1.75;
}
@media all and (max-width: 896px) {
  .list_present {
    font-size: 1.4rem;
  }
}
.list_present > li {
  padding-left: 1.5em;
  position: relative;
}
.list_present > li::before {
  content: "▶";
  font-size: 1.2rem;
  position: absolute;
  top: 0.4em;
  left: 0;
}
@media all and (max-width: 896px) {
  .list_present > li::before {
    top: 0.2em;
  }
}
