@charset "UTF-8";
.gothic {
  font-family: "Zen Kaku Gothic New", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  font-weight: normal;
}

.content_block#formal-ceremony-fair {
  max-width: 940px;
  margin: 0 auto;
  font-weight: 400;
}

#visual{
  position: relative;
  padding-bottom: 20px;
}
#visual::after {
    content: "";
    display: block;
    position: absolute;
    width: 200px;
    height: 1px;
    background: #DECAA9;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}

#visual .image {
  line-height: 0;
}
#visual .intro-section {
  position: relative;
  background: #eeede4;
  padding: 30px 10px;
  text-align: center;
  margin: 0 auto 50px;
  padding-bottom: 50px;
}
 #visual .intro-section .intro-main {
  font-weight: bold;
  font-size: 2.4rem;
  color: #663d36;
  margin-bottom: 10px;
}
#visual .intro-section .intro-text {
  font-size: 1.8rem;
  color: #663d36;
}
#visual .intro-section .intro-text p {
  margin: 0;
}
#visual .intro-section .intro-text p b{
  font-weight: normal;
}

#visual .intro-section .intro-highlight {
  font-size: 2rem;
}
#visual .intro-section .intro-note {
  font-size: 1.6rem;
}

.plan-section {
  position: relative;
  margin: 40px 0 80px;
  text-align: center;
}
.plan-section .plan-header {
  position: relative;
  max-width: 690px;
  margin: 0 auto 40px;
}
.plan-section .plan-header .plan-icon {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.plan-section .plan-header .plan-icon img {
  width: 109px;
}
.plan-section .plan-header .plan-category {
  font-size: 1.2rem;
  letter-spacing: 0.36px;
  color: #364E3C;
  margin-bottom: 10px;
}
.plan-section .plan-header .plan-title {
  font-weight: bold;
  font-size: 3rem;
  color: #364E3C;
  margin: 0;
}
.combi-plan .plan-header .plan-title{
  color: #885B3C;
}
.combi-plan .plan-header .plan-category{
  color: #885B3C;
}

.plan-section .plan-content {
  margin: 30px 0 0;
}
.plan-section .plan-description {
  font-size: 1.8rem;
  color: #000;
  margin: 0 auto 30px;
  font-weight: 400;
}
.plan-section .plan-image {
  margin: 30px 0;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}
.plan-section .plan-image img {
  max-width: 100%;
}
.plan-section .image-note {
  font-size: 1.4rem;
  color: #000;
  margin-top: 10px;
  text-align: left;
  font-weight: normal;
}
.plan-section .plan-note {
  font-size: 1.8rem;
  color: #000;
}

.plan-price {
  margin: 20px 0 30px 0;
  text-align: center;
}
.plan-price .price-main {
  font-weight: 600;
  color: #ae081c;
  line-height: 1;
}
.plan-price .price-label {
  font-size: 4.2rem;
  display: inline-block;
}
.plan-price .price-amount {
  font-size: 7.2rem;
  display: inline-block;
}
.plan-price .price-suffix {
  font-size: 3.5rem;
  display: inline-block;
}
.plan-price .price-tax {
  font-size: 1.8rem;
  color: #000;
  margin-top: 10px;
}

.price-per-item {
  display: inline-block;
  background: linear-gradient(transparent 70%, #FFEC6F 70%);
  line-height: 1;
}
.price-per-item .price-label {
  font-size: 2.8rem;
}
.price-per-item .price-amount {
  font-size: 4.6rem;
}

.plan-price-detail{
  font-weight: bold;
}


.price-line {
  margin: 20px 0;
  text-align: center;
}
.price-line img {
  max-width: 487px;
  width: 100%;
}

.plan-footer {
  font-size: 1.5rem;
  color: #000;
  margin: 30px 0;
  line-height: 1.6;
}
.plan-footer p {
  margin: 5px 0;
}
.plan-footer .plan-contact {
  font-weight: bold;
  font-size: 2.5rem;
  margin-top: 20px;
}

.links {
  max-width: 520px;
  margin: auto;
}
.links.border{
  position: relative;
  padding-bottom: 60px;
  margin-bottom: 60px;
}
.links.border::after{
  content: "";
  display: block;
  position: absolute;
  width: 200px;
  height: 1px;
  background: #DECAA9;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}

.kids-combi {
  margin: 80px 0;
}
.kids-combi .section-title {
  font-weight: bold;
  font-size: 3rem;
  color: #885b3c;
  margin-bottom: 40px;
}
.kids-combi .kids-layout {
  display: flex;
  gap: 60px;
}
.kids-combi .kids-layout .kids-col {
  width: 50%;
}
.kids-combi .kids-layout .kids-text {
  position: relative;
  display: flex;
  justify-content: space-between;
  gap: 10px;
}
.kids-combi .kids-layout .kids-text p {
  width: 50%;
  font-weight: bold;
}
.kids-combi .kids-layout .kids-text::before {
  content: "";
  display: block;
  position: absolute;
  width: 20px;
  height: 1px;
  background-color: #000;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.kids-combi .kids-layout .kids-text::after {
  content: "";
  display: block;
  position: absolute;
  height: 20px;
  width: 1px;
  background-color: #000;
  top: 50%;
  right: 50%;
  transform: translate(-50%, -50%);
}
.kids-combi .kids-images {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin: 30px 0 15px;
}
.kids-combi .kids-image-item {
  text-align: center;
}
.kids-combi .kids-image-item img {
  max-width: 375px;
  width: 100%;
}
.kids-combi .kids-image-item .image-label {
  font-weight: bold;
  font-size: 1.8rem;
  color: #000;
  margin-top: 10px;
}
.kids-combi .kids-arrow {
  width: 20px;
  height: 20px;
}
.kids-combi .kids-arrow img {
  width: 100%;
}

.business-combi {
  margin: 80px 0;
}
.business-combi .section-title {
  font-weight: bold;
  font-size: 3rem;
  color: #885b3c;
  margin-bottom: 10px;
}
.business-combi .section-subtitle {
  font-weight: bold;
  font-size: 3rem;
  color: #000;
  margin-bottom: 30px;
}
.business-combi .combi-content {
  margin: 40px 0;
}
.business-combi .combi-content .combi-image {
  text-align: center;
  margin-bottom: 0px;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}
.business-combi .combi-content .combi-image img {
  max-width: 100%;
  width: 100%;
}
.business-combi .combi-content .combi-details {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin: 15px 0;
}
.business-combi .combi-content .combi-details .combi-item {
  text-align: center;
}
.business-combi .combi-content .combi-details .combi-item .combi-label {
  font-size: 1.8rem;
  color: #000;
  margin-bottom: 0px;
}
.business-combi .combi-content .combi-details .combi-item .combi-price .price-main {
  line-height: 1;
  font-weight: bold;
}
.business-combi .combi-content .combi-details .combi-item .combi-price .price-label {
  font-size: 2.5rem;
}
.business-combi .combi-content .combi-details .combi-item .combi-price .price-amount {
  font-size: 4rem;
}
.business-combi .combi-content .combi-details .combi-item .combi-price .price-suffix {
  font-size: 3.5rem;
}
.business-combi .combi-content .combi-details .combi-arrow {
  width: 24px;
  height: 24px;
}
.business-combi .combi-content .combi-details .combi-arrow img {
  width: 100%;
}

.special-plan {
  margin: 80px 0;
  position: relative;
}
.special-plan .special-plan-frame {
  border: 1px solid #937e42;
  max-width: 840px;
  margin: 0 auto;
  padding: 0 0 60px 0;
  position: relative;
}
.special-plan .special-plan-frame .special-plan-header {
  text-align: center;
  margin-bottom: 10px;
  position: relative;
}
.special-plan .special-plan-frame .special-plan-header .special-plan-title-img {
  position: relative;
  z-index: 1;
  max-width: 195px;
  margin: 0 auto;
  transform: translateY(-50%);
}
.special-plan .special-plan-frame .special-plan-content {
  padding: 0 20px;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-title {
  font-weight: bold;
  font-size: 3rem;
  color: #000;
  text-align: center;
  margin-bottom: 35px;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main {
  margin: 40px 0;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-image {
  text-align: center;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-image img {
  max-width: 560px;
  width: 100%;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin: 10px 0 15px;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-item {
  text-align: center;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-item .special-plan-label {
  font-size: 1.8rem;
  color: #000;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-item .special-plan-price .price-main {
  line-height: 1;
  font-weight: bold;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-item .special-plan-price .price-label {
  font-size: 2.5rem;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-item .special-plan-price .price-amount {
  font-size: 4rem;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-item .special-plan-price .price-suffix {
  font-size: 3.5rem;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-arrow {
  width: 24px;
  height: 24px;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-arrow img {
  width: 100%;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes {
  margin-top: 40px;
  text-align: center;
  max-width: 460px;
  margin: auto;
  position: relative;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item {
  display: flex;
  align-items: last baseline;
    padding: 0;
    justify-content: center;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 14px;
  border-left: 1px solid #000;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item::after {
  content: "";
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
  width: 14px;
  border-right: 1px solid #000;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item .special-plan-shoes-brand {
  font-size: 1.6rem;
  color: #000;
  width: 100px;
  text-align: left;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item .price-main .price-label {
  font-size: 2rem;
  font-weight: bold;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item .price-main .price-amount {
  font-size: 3rem;
  font-weight: bold;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item .price-main .price-suffix {
  font-size: 3rem;
  font-weight: bold;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item .price-main .price-tax {
  font-size: 1.4rem;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-image {
  margin-top: 20px;
  text-align: center;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-image img {
  max-width: 459px;
  width: 100%;
}
.special-plan .special-plan-frame .special-plan-content .note {
  display: flex;
  justify-content: center;
  margin-top: 20px;
  text-align: left;
  font-size: 1.4rem;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-footer {
  font-size: 1.5rem;
  color: #000;
  margin: 30px 0;
  line-height: 1.6;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-footer p {
  margin: 5px 0;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-button {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #935b00;
  color: #fff;
  padding: 17px 111px;
  text-decoration: none;
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 1.6px;
  margin-top: 40px;
}
.special-plan .special-plan-frame .special-plan-content .special-plan-button img {
  width: 5.857px;
  height: 9.508px;
}

.fair-info-section {
  text-align: center;
  margin: 80px 0;
}
.fair-info-section .fair-info-title {
  font-weight: bold;
  font-size: 2rem;
  color: #885b3c;
  margin-bottom: 20px;
  line-height: 1.6;
}
.fair-info-section .fair-info-subtitle {
  font-weight: 500;
  font-size: 2rem;
  color: #000;
  letter-spacing: 2px;
  margin-bottom: 30px;
}
.fair-info-section .fair-info-banner {
  display: block;
  max-width: 520px;
  margin: 0 auto;
}
.fair-info-section .fair-info-banner img {
  width: 100%;
}

.reservation-section {
  text-align: center;
  margin: 80px 0;
  max-width: 670px;
  margin-left: auto;
  margin-right: auto;
}
.reservation-section .reservation-title {
  font-weight: 500;
  font-size: 2rem;
  color: #000;
  letter-spacing: 2px;
  margin-bottom: 20px;
}
.reservation-section .reservation-button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #684a28;
  color: #fff;
  padding: 11px 21px;
  text-decoration: none;
  font-size: 1.8rem;
  letter-spacing: 1.8px;
  margin-bottom: 30px;
}
.reservation-section .reservation-button img {
  width: 5.857px;
  height: 9.508px;
}
.reservation-section .reservation-banner {
  max-width: 670px;
  margin: 0 auto;
}
.reservation-section .reservation-banner img {
  width: 100%;
}

.customer-case-section {
  text-align: center;
  margin: 80px 0;
  max-width: 620px;
  margin-left: auto;
  margin-right: auto;
}
.customer-case-section .customer-case-title {
  font-weight: bold;
  font-size: 3rem;
  color: #56688b;
  margin-bottom: 40px;
}
.customer-case-section .customer-case-image img {
  width: 100%;
}

.scene-section {
  position: relative;
  margin: 80px 0;
}
.scene-section .scene-main-title {
  font-weight: bold;
  font-size: 3rem;
  color: #512b29;
  text-align: center;
  line-height: 1.482;
  margin-bottom: 40px;
}
.scene-section .scene-item {
  padding: 50px 10px;
}
.scene-section .scene-item.scene-wedding {
  background: #d1d8db;
}
.scene-section .scene-item.scene-graduation {
  background: #e5d4db;
}
.scene-section .scene-item.scene-funeral {
  background: #dddddd;
}
.scene-section .scene-item.scene-celebration {
  background: #d0c2ad;
}
.scene-section .scene-item .scene-content {
  max-width: 770px;
  margin: 0 auto;
  background: #fff;
  padding: 44px 10px;
}
.scene-section .scene-item .scene-content .scene-header {
  text-align: center;
  margin-bottom: 30px;
}
.scene-section .scene-item .scene-content .scene-header .scene-label {
  display: inline-block;
  background: linear-gradient(to right, #a57b71 0%, #c1a49d 50%, #a57b71 100%);
  color: #fff;
  font-weight: bold;
  font-size: 2.4rem;
  padding: 0 16px;
  height: 38px;
  line-height: 38px;
  min-width: 140px;
}
.scene-section .scene-item .scene-content .scene-image {
  text-align: center;
  margin-bottom: 30px;
}
.scene-section .scene-item .scene-content .scene-image img {
  max-height: 462px;
  width: auto;
  margin: auto;
}
.scene-funeral .scene-section .scene-item .scene-content .scene-image img, .scene-celebration .scene-section .scene-item .scene-content .scene-image img {
  max-width: 400px;
}
.scene-section .scene-item .scene-content .scene-text {
  text-align: center;
}
.scene-section .scene-item .scene-content .scene-text .scene-category {
  font-weight: bold;
  font-size: 2.4rem;
  color: #512b29;
  margin-bottom: 20px;
}
.scene-section .scene-item .scene-content .scene-text .scene-description {
  font-size: 1.6rem;
  color: #000;
  line-height: 1.6;
  margin-bottom: 20px;
}
.scene-section .scene-item .scene-content .scene-text .scene-description p {
  margin: 5px 0;
}
.scene-section .scene-item .scene-content .scene-text .scene-note {
  font-size: 1.4rem;
  color: #000;
  margin-top: 20px;
}

.reason-section {
  position: relative;
  margin: 80px 0;
  padding: 50px 10px;
  background: #4a6177 url(./assets/reason-bg.webp) no-repeat center bottom/cover;
}
.reason-section .reason-bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 0;
}
.reason-section .reason-bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.reason-section .reason-content {
  position: relative;
  z-index: 1;
  max-width: 940px;
  margin: 0 auto;
}
.reason-section .reason-content .reason-main-title {
  font-weight: bold;
  font-size: 3rem;
  color: #fff;
  text-align: center;
  margin-bottom: 40px;
}
.reason-section .reason-content .reason-main-title .sub {
  font-size: 2.4rem;
  padding-bottom: 10px;
  position: relative;
  background: url(./assets/title-line.svg) no-repeat center bottom;
  margin-bottom: 1.5rem;
}
.reason-section .reason-content .reason-main-title .main {
  line-height: 1;
}
.reason-section .reason-content .reason-main-title .main b {
  display: inline-block;
  border-bottom: 1px solid #A8A160;
}
.reason-section .reason-content .reason-subtitle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 20px;
}
.reason-section .reason-content .reason-subtitle img {
  width: 144px;
}
.reason-section .reason-content .reason-subtitle p {
  font-weight: bold;
  font-size: 2.4rem;
  color: #fff;
}
.reason-section .reason-content .reason-decorative {
  text-align: center;
  margin-bottom: 40px;
}
.reason-section .reason-content .reason-decorative img {
  max-width: 340px;
  width: 100%;
}
.reason-section .reason-content .reason-items {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.reason-section .reason-content .reason-items .reason-item {
  background: #fff;
  padding: 30px 0 40px;
  max-width: 770px;
  width: 100%;
  margin: 0 auto;
}
.reason-section .reason-content .reason-items .reason-item .reason-item-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 20px;
}
.reason-section .reason-content .reason-items .reason-item .reason-item-header img {
  width: 28px;
}
.reason-section .reason-content .reason-items .reason-item .reason-item-header .reason-item-title {
  font-weight: bold;
  font-size: 2.4rem;
  color: #9c6b1d;
  text-align: center;
}
.reason-section .reason-content .reason-items .reason-item .reason-item-content {
  display: flex;
  align-items: center;
  gap: 20px;
  max-width: 660px;
  margin: 0 auto;
  padding: 0 0;
}
.reason-section .reason-content .reason-items .reason-item .reason-item-content .reason-item-image {
  flex-shrink: 0;
  width: 260px;
}
.reason-section .reason-content .reason-items .reason-item .reason-item-content .reason-item-image img {
  width: 100%;
}
.reason-section .reason-content .reason-items .reason-item .reason-item-content .reason-item-text {
  font-size: 1.6rem;
  color: #000;
  line-height: 1.6;
}
.reason-section .reason-content .reason-items .reason-item .reason-item-content .reason-item-text p {
  margin: 5px 0;
}

.stylebook-section {
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
  margin: 80px 0;
  max-width: 635px;
  margin-left: auto;
  margin-right: auto;
}
.stylebook-section .stylebook-button {
  display: block;
  width: 100%;
}
.stylebook-section .stylebook-button img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .content_block#formal-ceremony-fair {
    padding: 0 10px;
  }
  #visual{
    padding-bottom: 10px;
  }
  #visual .intro-section{
    background: transparent;
    margin-bottom: 0;
    padding-bottom: 30px;
  }
  #visual .intro-section .intro-main {
    font-size: 5vw;
  }
  #visual .intro-section .intro-text {
    font-size: 3.4vw;
  }
  #visual .intro-section .intro-highlight {
    font-size: 2.666vw;
  }
  #visual .intro-section .intro-note {
    font-size: 2.1328vw;
  }
  .links{
    margin-bottom: 30px;
  }
.links.border{
  position: relative;
  padding-bottom: 30px;
  margin-bottom: 30px;
}
  .plan-section {
    margin-top: 30px;
    margin-bottom: 30px;
  }
  .plan-section .plan-header .plan-category {
    font-size: 2.8vw;
  }
  .plan-section .plan-header .plan-title {
    font-size: 6vw;
  }
  .plan-section .plan-header .plan-icon{
    width: 20%;
  }
  .plan-section .plan-description {
    font-size: 4vw;
  }
  .plan-section .plan-note {
      font-size: 2.5vw;
  }
  .plan-section .image-note {
    font-size: 3vw;
  }
  .plan-price .price-label {
    font-size: 7.0vw;
  }
  .plan-price .price-amount {
    font-size: 12vw;
  }
  .plan-price .price-suffix {
    font-size: 10vw;
    margin-left: -6px;
  }
  .plan-price .price-tax {
    display: block;
    font-size: 4vw;
    margin-bottom: 15px;
  }

  .plan-section .plan-price .price-label {
    font-size: 8.0vw;
  }
  .plan-section .plan-price .price-amount {
    font-size: 15vw;
  }
  .plan-section .plan-price .price-suffix {
    font-size: 11vw;
    margin-left: -6px;
  }
  .plan-section .plan-price .price-tax {
    display: block;
    font-size: 5vw;
    margin-bottom: 15px;
  }


  .price-per-item .price-label {
    font-size: 5vw;
  }
  .price-per-item .price-amount {
    font-size: 8vw;
  }
  .plan-footer {
    font-size: 2.5vw;
  }
  .plan-footer .plan-contact {
    font-size: 4vw !important;
  }
  .section-title {
    font-size: 4.5vw !important;
  }
  .kids-combi .section-title{
    font-size: 4.5vw;
    margin-bottom: 0;
  }
  .kids-combi .kids-images{
    margin-top: 10px;
  }
  .kids-combi .kids-layout{
    flex-direction: column;
    gap: 20px;
    padding: 0 3%;
  }
  .kids-combi .kids-layout .kids-col{
    width: 100%;
  }
  .section-subtitle {
    font-size:6vw !important;
  }
  .business-combi .section-subtitle{
    margin-bottom: 0;
  }
  .business-combi .combi-content{
    margin-top: 20px;
  }
  .business-combi .combi-content .combi-details{
    flex-direction: row;
  }
  .business-combi .combi-content .combi-details .combi-item .combi-label {
    font-size: 3vw;
  }
  .business-combi .combi-content .combi-details .combi-item .combi-price .price-label {
    font-size: 4vw;
  }
  .business-combi .combi-content .combi-details .combi-item .combi-price .price-amount {
    font-size: 6vw;
  }
  .business-combi .combi-content .combi-details .combi-item .combi-price .price-suffix {
    font-size: 5vw;
  }
  .business-combi .combi-content .combi-details .combi-item .combi-price .price-tax {
      font-size: 3.5vw;
  }
  .business-combi .plan-price .price-label {
    font-size: 6vw;
  }
  .business-combi .plan-price .price-amount {
    font-size: 13vw;
  }
  .business-combi .plan-price .price-suffix {
    font-size: 11vw;
  }
  .business-combi .plan-price .price-tax {
      font-size: 5vw;
  }

  .business-combi .combi-content .combi-details .combi-arrow{
    width: 15px;
  }
  .image-label {
    font-size: 4vw;
  }
  .combi-label {
    font-size: 4vw;
  }
  .combi-price .price-label {
    font-size: 4vw;
  }
  .combi-price .price-amount {
    font-size: 6vw;
  }
  .combi-price .price-suffix {
    font-size: 5.0vw;
  }
  .kids-images {
    flex-direction: column;
    gap: 10px;
  }
  .combi-details {
    flex-direction: column;
    gap: 10px;
  }
  .special-plan .special-plan-frame{
    padding-bottom: 30px;
  }
  .special-plan .special-plan-frame .special-plan-content{
    padding: 0 10px;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details{
    align-items: flex-end;
    gap: 10px;
  }
  .special-plan .special-plan-frame .special-plan-content .combi-arrow{
    padding-bottom: 2rem;
    width: 15px;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-title {
    font-size: 6vw;
    margin-bottom: 20px;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-main {
    margin-top: 20px;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-item .special-plan-label {
    display: block;
    font-size: 4vw;
    line-height: 1.2;
    margin-bottom: 0.5rem;
  }
  .shoes{
    padding-bottom: 1rem;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-item .special-plan-price .price-label {
    font-size: 4vw;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-item .special-plan-price .price-amount {
    font-size: 6vw;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-item .special-plan-price .price-suffix {
    font-size: 4.5vw;
    margin-left: -4px;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-details .special-plan-item .special-plan-price .price-tax {
    font-size: 3.5vw;
  }

  .special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item{
        justify-content: space-evenly;
        align-items: center;
        padding: 0 10px;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item .special-plan-shoes-brand{
    font-size: 4.5vw;
    padding-bottom: 0.5rem;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item .price-main .price-label {
    font-size: 4.5vw;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item .price-main .price-amount {
    font-size: 7vw;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item .price-main .price-suffix {
    font-size: 5vw;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-main .special-plan-shoes .special-plan-shoes-item .price-main .price-tax {
    font-size: 3vw;
    display: block;
    line-height: 1;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-shoes-brand {
    font-size: 4vw;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-footer {
    font-size: 2.5vw;
  }
  .special-plan .special-plan-frame .special-plan-content .special-plan-button {
    font-size: 4vw;
    padding: 10px 0;
    margin-top: 0;
    width: 100%;
    text-align: center;
    display: block;
  }
  .special-plan .special-plan-frame .special-plan-content .price-label{
    font-size: 6vw;
  }
  .special-plan .special-plan-frame .special-plan-content .price-amount{
    font-size: 12vw;
  }

  .fair-info-title {
    font-size: 2.666vw;
  }
  .fair-info-subtitle {
    font-size: 2.666vw;
  }
  .reservation-title {
    font-size: 2.666vw;
  }
  .reservation-button {
    font-size: 4vw;
  }
  .customer-case-section{
    margin: 40px 0 0;
  }
  .customer-case-section .customer-case-title {
    font-size: 6vw;
    margin-bottom: 20px;
  }
  .scene-section{
    margin: 40px 0 0;
  }
  .scene-section  .scene-main-title {
    font-size: 5vw;
    margin-bottom: 30px;
  }
  .scene-section .scene-item{
    padding: 40px 10px;
  }
  .scene-section .scene-item .scene-content{
    background: transparent;
    padding: 0;
  }
  .scene-section .scene-item .scene-content .scene-header .scene-label {
    font-size: 4vw;
    width: auto;
  }
  .scene-section .scene-item .scene-content .scene-text .scene-category {
    font-size: 4vw;
  }
  .scene-section .scene-item .scene-content .scene-text .scene-description {
    margin-bottom: 0;
  }
  .scene-section .scene-item .scene-content .scene-text .scene-description p{
    font-size: 3vw;
  }
  .scene-section .scene-item .scene-content .scene-text .scene-note {
    font-size: 2.5vw;
  }
  .stylebook-section{
    margin: 30px 0;
  }
  .reason-section{
    margin: 30px 0;
    padding-bottom: 0;
  }
  .reason-section .reason-content .reason-main-title .sub{
        font-size: 4.5vw;
        background-size: 70%;
  }
  .reason-section .reason-content .reason-main-title .main{
    font-size: 6vw;
  }
  .reason-subtitle p {
    font-size: 3.1992vw;
  }
.reason-section .reason-content .reason-items .reason-item .reason-item-header .reason-item-title{
    font-size: 5vw;
    text-align: left;
  }
  .reason-section .reason-content .reason-items .reason-item .reason-item-content .reason-item-text p{
    font-size: 3.5vw;
  }
  .special-plan-details {
  }
  .reason-item-content {
    flex-direction: column;
    text-align: center;
  }
  .reason-item-image {
    width: 100%;
    max-width: 260px;
    margin: 0 auto;
  }
}
.acordion-block {
  position: relative;
  overflow: hidden;
  height: 400px;
  transition: 0.3s height linear;
}

.scene-section .acordion-block {
  height: 680px;
  -webkit-mask-image: linear-gradient(to bottom, rgb(0, 0, 0) 0%, rgb(0, 0, 0) calc(100% - 200px), rgba(0, 0, 0, 0) 100%);
          mask-image: linear-gradient(to bottom, rgb(0, 0, 0) 0%, rgb(0, 0, 0) calc(100% - 200px), rgba(0, 0, 0, 0) 100%);
}

.reason-section .acordion-block {
  height: 380px;
  -webkit-mask-image: linear-gradient(to bottom, rgb(0, 0, 0) 0%, rgb(0, 0, 0) calc(100% - 200px), rgba(0, 0, 0, 0) 100%);
          mask-image: linear-gradient(to bottom, rgb(0, 0, 0) 0%, rgb(0, 0, 0) calc(100% - 200px), rgba(0, 0, 0, 0) 100%);
}
.reason-section .view span {
  border-color: #fff !important;
  color: #fff;
}
.reserve {
  text-align: center;
  margin-bottom: 30px;
  font-weight: normal;
}
.reserve p {
  font-size: 2.3rem;
  font-weight: 500;
  margin-bottom: 15px;
}
@media (max-width: 767px) {
  .reserve p {
    font-size: 4.615vw;
  }
}
.reserve p span {
  display: inline-block;
  position: relative;
  padding: 0 25px;
}
.reserve p span::before {
  content: "";
  display: block;
  position: absolute;
  width: 25px;
  height: 1px;
  background-color: #000;
  left: 0;
  top: 50%;
  transform: rotate(45deg);
}

.reserve p span::after {
  content: "";
  display: block;
  position: absolute;
  width: 25px;
  height: 1px;
  background-color: #000;
  right: 0;
  top: 50%;
  transform: rotate(-45deg);
}
.reserve .res-btn {
  display: inline-block;
  background-color: #684A28;
  padding: 17px 70px;
  color: #fff;
  font-size: 1.8rem;
  text-decoration: none;
  margin-bottom: 35px;
}

#other {
  text-align: center;
  margin-block: 60px;
}
#other p{
  margin-bottom: 30px;
  font-size: 2rem;
}

#other h2 {
  margin-bottom: 20px;
}
@media (max-width: 767px) {
  .reserve .res-btn {

    padding: 15px 40px;
  }
  #other{
    margin-block: 30px;
  }
  #other h2 {
    font-size: 4.615vw;
  }
}
#other .pc img{
  max-width: 545px;
}

.acordion-block.open {
  height: auto;
  -webkit-mask-image: none;
          mask-image: none;
}


.acordion-block.open::before {
  opacity: 0;
  visibility: hidden;
}

.acordion-block + .view {
  width: 100%;
  position: absolute;
  bottom: 40px;
  z-index: 1;
  text-align: center;
}

.acordion-block + .view.open {
  position: static;
  padding: 30px 0;
}

.acordion-block + .view span {
  display: inline-block;
  border: 1px solid #000;
  line-height: 1;
  padding: 15px 30px;
  font-size: 1.6rem;
  cursor: pointer;
  width: 255px;
  transition: background-color 0.3s, color 0.3s;
}

.acordion-block + .view span:hover {
  background-color: #4B3F2C;
  color: #fff;
}

@media (max-width: 767px) {
  #other p{
    font-size: 3.4vw;
    margin-bottom: 10px;
  }


}