@import url('https://fonts.googleapis.com/css2?family=Zen+Old+Mincho:wght@400;500;600;700&display=swap');

.mincho {
  font-family: "Zen Old Mincho", serif;
  font-weight: 400;
  font-style: normal;
}

.gothic {
  font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}

#fair-det{
  /* width: 1200px; */
}
.content_block .inner {
  max-width: 940px;
  margin: auto;
  color: #000;
}

.content_block #visual {
  margin-bottom: 40px;
}

.content_block #visual p {
  text-align: center;
  padding-top: 50px;
  padding-bottom: 0px;
}
.content_block #visual p span{
  display: inline-block;
  font-weight: 600;
  font-size: 4.1rem;
  background: linear-gradient(transparent 70%, #F9DE4A 70%);
}
.content_block #visual p.holiday {
  margin-bottom: 50px;
  font-size: 3.3rem;
  padding-top: 15px;
}
.content_block #visual p.holiday a{
  color: #A10011;
}


.content_block #first {
  background-color: #5E3507;
  padding: 50px 0 70px 0;
}

.content_block #first h2 {
  background-color: #C16827;
  color: #fff;
  text-align: center;
  width: 720px;
  margin: auto;
  clip-path: polygon(0 0, 100% 0, calc(100% - 15px) 50%, 100% 100%, 0 100%, 15px 50%);
  padding: 5px;
  font-weight: 400;
  transform: translateY(50%);
  font-size: 2.7rem;
}

.content_block #first .first-wrap {
  border: solid 1px #D1CBB1;
  outline: solid 2px #D1CBB1;
  outline-offset: 5px;
  padding: 60px 30px 30px;
  text-align: center;
  color: #fff;
  max-width: 900px;
  margin: auto;
}

.content_block #first .first-wrap .line1 {
  font-size: 2.4rem;
  margin-bottom: 10px;
}

.content_block #first .first-wrap .line1 .price {
  position: relative;
  display: inline-block;
  vertical-align: -webkit-baseline-middle;
  font-size: 2.7rem;
  font-weight: 600;
  color: #F9DE4A;
}

.content_block #first .first-wrap .line1 .price b{
  background: linear-gradient(transparent 70%, #81623A 70%);
}

.content_block #first .first-wrap .line1 .price .tax {
  display: block;
  font-size: 1.5rem;
}

.content_block #first .first-wrap .line2 {
  font-size: 3.4rem;
  margin-bottom: 25px;
}

.content_block #first .first-wrap .line2 b {
  color: #F9DE4A;
  font-weight: 600;
}

.content_block #first .first-wrap .line2 span {
  background: linear-gradient(transparent 60%, #81623A 60%);

}

.content_block #first .first-wrap .line3 {
  font-size: 2.4rem;
  font-weight: 500;
}

.content_block #first .first-wrap .line3 b {
  font-size: 4.1rem;
  color: #F9DE4A;
  font-weight: 600;
}

.content_block #coupon {
  text-align: center;
  margin-bottom: 100px;
  padding-top: 50px;
}

.content_block #coupon .image1 {
  margin-bottom: 60px;
}

.content_block #coupon .image2 {
  margin-bottom: 30px;
}

.content_block .more-fair a{
  position: relative;
  display: inline-block;
  background-color: #4F380B;
  color: #fff;
  padding: 35px 85px 35px 55px;
  text-decoration: none;
  font-size: 1.8rem;
}

.content_block .more-fair a:hover {
  background-color: #795612;
}

.content_block .more-fair a::after {
  content: "";
  display: block;
  position: absolute;
  width: 10px;
  height: 10px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  top: 50%;
  right: 55px;
  transform: translateY(-50%) rotate(45deg);
}

.content_block #reason{
  margin-bottom: 80px;
}

.content_block #plan {
  text-align: center;
  max-width: 825px;
  margin: auto;
  padding-bottom: 20px;
}

.content_block #plan .title {
  position: relative;
}

.content_block #plan .title .no1 {
  width: 130px;
  position: absolute;
  left: 0;
  top: -10px;
}

.content_block #plan .title h2 {
  font-weight: 400;
  margin-bottom: 30px;
}

.content_block #plan .title h2 .sub {
  display: inline-block;
  border: 1px solid #000;
  line-height: 1;
  padding: 10px 20px;
  font-size: 2.5rem;
  margin-bottom: 15px;
}

.content_block #plan .title h2 .main {
  font-size: 3.4rem;
    font-weight: 700;
}

.content_block #plan .image {}

.content_block #plan .image .note {
  text-align: right;
}

.content_block #plan p.lead {
  margin-bottom: 20px;
  font-size: 1.8rem;
}

.content_block #plan .price3{
  color: #A10011;
}
/*
.content_block #plan .price3 b{
  font-size: 6.0rem;
}
*/
.price1 {
  font-size: 1.8rem;
  margin-bottom: 10px;
  font-weight: 600;
}

.price1 b {
  font-size: 3.4rem;
  font-weight: 600;
}

.price1 .del {
  position: relative;
}

.price1 .del::after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 3px;
  background-color: #A10011;
  left: 0;
  top: 50%;
  transform: rotate(10deg);
}

.price1 .tax {
  font-size: 1.5rem;
}

.arrow {
  margin-bottom: 10px;
}

.label p{
  font-size: 1.8rem;
  color: #7F5512;
  margin-bottom: 5px;
}

.price2 {
  color: #A10011;
  font-size: 4.3rem;
  font-weight: 600;
}

.price2 b {
  font-size: 7.2rem;
  line-height: 1;
  font-weight: 600;
}

.price2.small {
  font-size: 3.2rem;
}
.price2.small b {
  font-size: 6rem;
}

.price2 .tax {
  font-size: 1.5rem;
}

.price3 {
  margin-bottom: 40px;
  font-size: 3rem;
  font-weight: 600;
}

.price3 b {
  font-size: 4.4rem;
  font-weight: 600;
  font-size: 6.0rem;
}

.price3 .tax {
  font-size: 1.3rem;
}

.note {
  font-size: 1.3rem;
  margin-bottom: 25px;
}

.more {
  font-size: 2.6rem;
  font-weight: 600;
}



.content_block #before-after {
  background-color: #E5ECEC;
  padding: 58px 0;
  text-align: center;
}

.content_block #before-after .inner {
  background-color: #fff;
  max-width: 920px;
  margin: auto;
  padding: 40px 40px;
}

.content_block #before-after .inner h2 {
  font-size: 3.2rem;
  margin-bottom: 20px;
  font-weight: 400;
}

.content_block #before-after .inner p {
  font-size: 2rem;
  margin-bottom: 35px;

}

.content_block #before-after .inner .image {
  text-align: center;
}

.content_block #combi3 {
  text-align: center;
  padding: 40px 0;
}

.content_block #combi3 h2 {
  font-size: 3.4rem;
  margin-bottom: 50px;
    font-weight: 700;
}

.content_block #combi3 .image {
  margin-bottom: 45px;
}

.content_block #combi3 .lead{
  font-size: 1.8rem;
}

.content_block #combi3 .label{
  margin: auto;
}

.content_block #combi3 .price3 {
  color: #A10011;
  font-size: 3rem;
}

.content_block #combi3 .more {
  margin-bottom: 0px;
}

.content_block .reserve {
  text-align: center;
}

.content_block .reserve p {
  font-size: 2.5rem;
  font-weight: 500;
  margin-bottom: 15px;
}

.content_block .reserve p span {
  display: inline-block;
  position: relative;
  padding: 0 25px;
}

.content_block .reserve p span::before {
  content: "";
  display: block;
  position: absolute;
  width: 25px;
  height: 1px;
  background-color: #000;
  left: 0;
  top: 50%;
  transform: rotate(45deg);
}

.content_block .reserve p span::after {
  content: "";
  display: block;
  position: absolute;
  width: 25px;
  height: 1px;
  background-color: #000;
  right: 0;
  top: 50%;
  transform: rotate(-45deg);
}

.content_block .reserve .res-btn {
  display: inline-block;
  background-color: #684A28;
  padding: 17px 70px;
  color: #fff;
  font-size: 2rem;
  text-decoration: none;
  margin-bottom: 35px;
}

.content_block .set_block {
  padding: 60px 0;
  text-align: center;
}

.content_block .set_block h2 {
  font-size: 3.4rem;
  font-weight: 600;
  text-align: center;
  margin-bottom: 22px;
}

.content_block .set_block h2 .label {
  margin-bottom: 12px;
}

.content_block .set_block p.lead {
  margin-bottom: 40px;
  font-size: 1.8rem;
}

.content_block .set_block .layout1 {
  display: flex;
  gap: 45px;
  margin: auto;
  justify-content: center;
  margin-bottom: 15px;
}

.content_block .set_block .layout2 {
  display: flex;
  margin: auto;
  justify-content: center;
}

.content_block .set_block .layout2 p {
  width: 274px;
  font-size: 1.8rem;
}

.content_block .set_block .layout2 p .price {
  display: block;
  font-size: 2.8rem;
  line-height: 1;
  margin-bottom: 10px;
}

.content_block .set_block .layout2 p .price b {
  font-size: 4.5rem;
  line-height: 1;
  font-weight: 500;
}

.content_block .set_block .layout2 p .intax {
  display: block;
  font-size: 1.5rem;
  margin-bottom: 15px;
}

.content_block .set_block .layout2 .plus {
  width: 45px;
  position: relative;
}

.content_block .set_block .layout2 .plus::before {
  content: "";
  display: block;
  position: absolute;
  width: 25px;
  height: 2px;
  background-color: #000;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.content_block .set_block .layout2 .plus::after {
  content: "";
  display: block;
  position: absolute;
  width: 2px;
  height: 25px;
  background-color: #000;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.content_block .set_block .price2 {
  margin-bottom: 40px;
}

.content_block .set_block .more-fair{
  margin-top: 40px;
}

.content_block #pants {
  background-color: #E5ECEC;
  padding: 40px 0;
}

.content_block #pants .inner {
  background-color: #fff;
  padding: 50px 5%;
  max-width: 1280px;
  text-align: center;
  margin-bottom: 50px;
}

.content_block #pants h2 {
  font-size: 3.5rem;
  font-weight: 400;
  margin-bottom: 50px;
}

.content_block #pants .lead {
  margin-bottom: 70px;
  font-size: 1.8rem;
}

.content_block #pants .layout1 {
  display: flex;
  margin-bottom: 30px;
}

.content_block #pants .layout1 .box {
  position: relative;
  width: 25%;
}

.content_block #pants .layout1 .box .image {
  margin-bottom: 15px;
}

.content_block #pants .layout1 .box .new {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
}

.content_block #pants .layout2 {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-bottom: 35px;
}

.content_block #pants .layout2 .box {}

.content_block #pants .layout2 .box .image {
  width: 150px;
}


.content_block #cordinate {
  text-align: center;
}

.content_block #cordinate h3 {
  font-size: 2.5rem;
  font-weight: 400;
  margin-bottom: 15px;
}

.content_block #cordinate .layout {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
}

.content_block #cordinate .layout .box {}

.content_block #cordinate .layout .box span {
  display: inline-block;
  background-color: #1D416D;
  color: #fff;
  text-align: center;
  line-height: 1;
  padding: 2px 15px 4px;
  margin-bottom: 12px;
}

.content_block #cordinate .layout .box .image {
  width: 250px;
}


.content_block .links {
  padding: 50px 0;
  text-align: center;
}

.content_block .links a {
  display: inline-block;
  max-width: 588px;
  margin-bottom: 20px;
}

.content_block #order {
  text-align: center;
  margin-bottom: 50px;
}

.content_block #order p {
  font-size: 2.2rem;
  font-weight: 400;
  margin-bottom: 40px;
}

.content_block #order .image {
  margin-bottom: 30px;
}

.content_block #other {
  text-align: center;
  margin-bottom: 60px;
}

.content_block #other h2 {
  font-weight: 500;
  font-size: 2.5rem;
  margin-bottom: 10px;
}

.content_block #reserve2{
  margin-bottom: 100px;
}

.content_block #summer {
  margin-block: 70px;
}

.content_block #news {
  background-color: #E8DECF;
  padding: 50px 0;
  text-align: center;
}

.content_block #news h2 {
  font-weight: 400;
  font-size: 3.2rem;
  margin-bottom: 25px;
}

.content_block #news .box {
  background-color: #fff;
  max-width: 800px;
  padding: 25px 50px;
  display: flex;
  gap: 40px;
  margin: auto;
  align-items: center;
}

.content_block #news .box .text {
  width: 60%;
    text-align: center;
}

.content_block #news .box h3 {
  font-size: 2.2rem;
  font-weight: 400;
  padding-bottom: 10px;
  margin-bottom: 15px;
  border-bottom: 1px solid #000;
}

.content_block #news .box p {
  font-size: 1.8rem;
}

.content_block #news .box .image {
  width: 40%;
}

.content_block #flowbody {
  background-color: #EDEDED;
  padding: 50px 0;
}

.content_block #flowbody h2 {
  text-align: center;
  font-size: 3.4rem;
  font-weight: 400;
  margin-bottom: 50px;
}

.content_block #flowbody .flow-wrap {
  position: relative;
  overflow: hidden;
  height: 480px;
  transition: 0.3s height linear;
}

.content_block #flowbody .flow-wrap.open {
  height: auto;
}

.content_block #flowbody .flow-wrap::before {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 430px;
  top: 80px;
  left: 0;
  background: linear-gradient(0deg, rgba(237, 237, 237, 1) 0%, rgba(237, 237, 237, 0) 100%);
  transition: 0.2s opacity linear;
}

.content_block #flowbody .flow-wrap.open::before {
  opacity: 0;
  visibility: hidden;
}

.content_block #flowbody .howto {
  position: relative;
  width: 900px;
  display: flex;
  justify-content: space-between;
  margin: auto;
}

.content_block #flowbody .howto::after {
  content: "";
  display: block;
  position: absolute;
  width: 1px;
  height: calc(100% - 95px);
  bottom: -16px;
  left: 25px;
  background-color: #4B3F2C;
}

.content_block #flowbody .howto.last {
  margin-bottom: 50px;
}

.content_block #flowbody .howto.last::after {
  content: none;
}

.content_block #flowbody .howto .step {
  text-align: center;
  margin-right: 30px;
  padding-top: 30px;
}

.content_block #flowbody .howto .step .num {
  display: block;
  font-size: 4.8rem;
  line-height: 1;
}

.content_block #flowbody .howto .body {
  padding: 30px 0;
  flex: 1;
}

.content_block #flowbody .howto .layout {
  display: flex;
  justify-content: space-between;
  ;
  align-items: flex-start;
}

.content_block #flowbody .howto .layout .text {
  flex: 1;
  padding-right: 40px;
  padding-top: 20px;
}

.content_block #flowbody .howto .layout .text h3 {
  font-size: 2.5rem;
  font-weight: 500;
  margin-bottom: 1.5rem;
}

.content_block #flowbody .howto .layout .text p {
  font-size: 1.4rem;
}

.content_block #flowbody .howto .layout .image {
  width: 176px;
  line-height: 0;
}

.content_block #flowbody .howto .layout.white {
  background-color: #fff;
  padding: 20px;
  margin-top: 30px;
  border: 1px solid #4B3F2C;
  align-items: center;
}

.content_block #flowbody .howto .layout.white h3 {
  font-size: 1.8rem;
}

.content_block #flowbody .howto .layout.white .text {
  padding-top: 0;
}

.content_block #flowbody .howto .layout.white .image {
  width: 147px;
}

.stepbtn {
  position: relative;
  display: inline-block;
  background-color: #3c1e00;
  color: #fff;
  padding: 8px 25px 8px 10px;
  line-height: 100%;
  font-size: 13px;
  font-size: 1.3rem;
  text-decoration: none;
  margin-top: 1rem;
}

.stepbtn::after {
  content: "";
  position: absolute;
  display: block;
  width: 6px;
  height: 6px;
  right: 10px;
  top: 50%;
  margin-top: -5px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.stepbtn:hover {
  color: #fff;
}

.content_block #flowbody .flow-btn {
  text-align: center;
}

.content_block #flowbody .flow-btn span {
  display: inline-block;
  border: 1px solid #000;
  padding: 18px 45px;
  line-height: 1;
  font-size: 1.8rem;
  cursor: pointer;
  transition: background-color 0.3s, color 0.3s;
}

.content_block #flowbody .flow-btn span:hover {
  background-color: #4B3F2C;
  color: #fff;
}


.content_block #finish {
  padding: 80px 0 65px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
}

.content_block #finish .links {
  padding-bottom: 0;
}

.content_block #finish .links a {
  position: relative;
  display: inline-block;
  background-color: #935B00;
  color: #fff;
  padding: 20px 20px;
  font-size: 1.5rem;
  text-decoration: none;
  max-width: 354px;
  width: 100%;
}
.content_block #finish .links a.book1{
  background-color: #1B244D;
}
.content_block #finish .links a.book2{
  background-color: #671031;
}

.content_block #finish .links a:hover.book1{
  background-color: #2d3b7e;
}
.content_block #finish .links a:hover.book2{
  background-color: #971849;
}


.content_block #finish .links a::after {
  content: "";
  display: block;
  position: absolute;
  width: 10px;
  height: 10px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  top: 50%;
  right: 30px;
  transform: translateY(-50%) rotate(45deg);
}


.content_block #variation {}

.content_block #variation h2 {
  margin-bottom: 35px;
  text-align: center;
}

.content_block #variation h2 .eng {
  font-size: 1.7rem;
  font-weight: 400;
}

.content_block #variation h2 .jp {
  font-size: 4.2rem;
  font-weight: 400;
}

.content_block #variation .table {
  max-width: 700px;
  margin: 0 auto 35px;
}

.content_block #variation .table h3 {
  background-color: #1B244D;
  text-align: center;
  padding: 20px;
}

.content_block #variation .table table {
  border: 1px solid #000;
  margin-bottom: 35px;
}

.content_block #variation .table table th {
  border-bottom: 1px dashed #000;
  padding: 25px;
  font-size: 2.0rem;
  font-weight: 400;
  text-align: center;
  vertical-align: middle;
}

.content_block #variation .table table th small {
  font-size: 1.5rem;
}

.content_block #variation .table table td {
  text-align: center;
  font-size: 2.2rem;
  background-color: #EDEEF1;
  border-bottom: 1px dashed #000;
  padding: 25px;
}

.content_block #variation .table table td b {
  font-weight: 400;
  font-size: 4.5rem;
}

.content_block #variation .table table td .c2 {
  font-size: 2rem;
  margin-bottom: 5px;
}

.content_block #variation .table table td .c2 .price {
  position: relative;
  font-size: 4.5rem;
  display: inline-block;
  vertical-align: -26px;
}

.content_block #variation .table table td .c2 .price .tax {
  display: block;
  font-size: 1.4rem;
}

.content_block #variation .table table td .c1 {
  font-size: 2rem;
}

.content_block #variation .table table td .c1 .price {
  font-size: 3rem;
}

.content_block #variation .table table td .c1 .tax {
  font-size: 1.2rem;
}

.content_block #variation .table .note {
  text-align: center;
  font-size: 1.7rem;
  margin-bottom: 70px;
}

.content_block #custom {
  text-align: center;
  margin-bottom: 70px;
}

.content_block #custom a {
  margin-top: 40px;
  margin-bottom: 30px;
  display: inline-block;
  background-color: #1B244D;
  color: #fff;
  padding: 20px 50px;
  font-size: 1.8rem;
  text-decoration: none;
}

.comb3-shop{
  text-align: center;
  margin-bottom: 20px;
}

@media screen and (max-width: 768px) {
  html {
    font-size: 62.5%;
  }

  .content_block #visual {
    margin-bottom: 25px;
  }
.content_block #visual p {
  padding-top: 10px;
    padding-bottom: 0px;
    line-height: 1.5;
}
.content_block #visual p span{
  font-size: 5vw;
}
.content_block #visual p.holiday {
    font-size: 4vw;
    margin-bottom: 20px;
    padding-top: 10px;
}

  .content_block #first {
    text-align: center;
    padding: 25px 3%;
  }

  .content_block #first h2 {
    position: relative;
    clip-path: none;
    width: auto;
    display: inline-block;
    padding: 8px 20px;
    transform: none;
    font-size: 3.5vw;
    margin-bottom: 30px;
  }

  .content_block #first h2::after {
    content: "";
    display: block;
    position: absolute;
    background-color: #C16827;
    width: 16px;
    height: 16px;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 100%);
    clip-path: polygon(0 0, 100% 0, 50% 100%);
  }

  .content_block #first .first-wrap {
    border: none;
    outline: none;
    padding: 0;
  }

  .content_block #first .first-wrap .line1 {
    font-size: 3vw;
  }

  .content_block #first .first-wrap .line1 .price {
    font-size: 4vw;
  }

  .content_block #first .first-wrap .line1 .price .tax {
    font-size: 2vw;
  }

  .content_block #first .first-wrap .line2 {
    font-size: 4.8vw;
  }

  .content_block #first .first-wrap .line3 {
    font-size: 3.5vw;
  }

  .content_block #first .first-wrap .line3 b {
    font-size: 5vw;
  }

  .content_block #coupon {
    padding: 0 5%;
    margin-bottom: 40px;
    padding-top: 40px;
  }

  .content_block #coupon .image1 {
    margin-bottom: 12px;
  }

  .content_block .more-fair a{
    font-size: 4vw;
    padding: 15px 45px 15px 20px
  }

  .content_block .more-fair a::after {
    right: 25px;
  }

  .content_block #reason{
    margin-bottom: 40px;
  }
  .content_block #plan {
    padding: 0 5% 35px;
  }

  .content_block #plan .title .no1 {
    width: 18%;
    left: -3%;
    top: 50%;
    transform: translateY(-50%);
  }

  .content_block #plan .title h2 {
    margin-bottom: 10px;
    padding-left: 10%;
  }

  .content_block #plan .title h2 .sub {
    font-size: 3.5vw;
  }

  .content_block #plan .title h2 .main {
    font-size: 5vw;
  }

  .content_block #plan p.lead {
    text-align: center;
    font-size: 3.0vw;
  }

  .price1 {
    font-size: 3.5vw;
  }

  .price1 b {
    font-size: 6vw;
  }

  .price1 .tax {
    font-size: 2.8vw;
  }

  .label p{
    font-size: 3.8vw;
    color: #7F5512;
    margin-bottom: 5px;
  }

  .label img {
    width: 75%;
  }

  .price2 {
    font-size: 6.5vw;
  }

  .price2 b {
    font-size: 11vw;
  }

  .price2 .tax {
    font-size: 3vw;
  }

  .price3 {
    font-size: 5vw !important;
  }

  .price3 b {
    font-size: 8.5vw !important;
  }

  .price3 .tax {
    font-size: 3vw;
  }


  .pb {
    position: relative;
    display: inline-block;
    vertical-align: middle;
  }

  .pb .tax {
    display: block;
    text-align: center;
  }

  .note {
    font-size: 2.8vw;
    margin-bottom: 15px;
  }

  .more {
    font-size: 3.4vw;
  }


  .content_block #before-after {
    padding: 20px 3%;
  }

  .content_block #before-after .inner {
    padding: 22px 16px;
  }

  .content_block #before-after .inner h2 {
    font-size: 4.2vw;
  }

  .content_block #before-after .inner p {
    font-size: 2.8vw;
  }

  .content_block #before-after .inner .image {
    max-width: 90%;
    margin: auto;
  }

  .content_block #combi3 {
    padding: 24px 5%;
  }

  .content_block #combi3 h2 {
    font-size: 4.5vw;
    margin-bottom: 25px;
  }

  .content_block #combi3 .lead {
    margin-bottom: 20px;
    font-size: 3.2vw;
    text-align: center;
  }

  .content_block #combi3 .label{
    width: auto;
  }
  .content_block #combi3 .label img{
    width: 70%;
  }

  .content_block #combi3 .more {
    margin-bottom: 20px;
  }

  .content_block #combi3 .image {
    margin-bottom: 20px;
  }

  .content_block .set_block {
    padding: 25px 5%;
  }

  .content_block .set_block h2 {
    font-size: 4.5vw;
  }

  .content_block .set_block h2 .label img {
    width: 60%;
  }

  .content_block .set_block p.lead {
    text-align: center;
    font-size: 3vw;
    margin-bottom: 15px;
  }

  .content_block .set_block .layout2 p {
    width: calc(50% - 8px);
    font-size: 3.0vw;
  }

  .content_block .set_block .layout2 p .price {
    font-size: 4.5vw;
  }

  .content_block .set_block .layout2 p .price b {
    font-size: 8vw;
  }

  .content_block .set_block .layout2 p .intax {
    font-size: 3vw;
  }

  .content_block .set_block .layout2 .plus {
    width: 16px;
  }

  .content_block .set_block .layout2 .plus::before {
    width: 16px;
  }

  .content_block .set_block .layout2 .plus::after {
    height: 16px;
  }

  .content_block #pants {
    padding: 20px 3%;
  }

  .content_block #pants .inner {
    padding: 20px 5%;
  }

  .content_block #pants h2 {
    font-size: 5vw;
    margin-bottom: 30px;
  }

  .content_block #pants .lead {
    text-align: center;
    font-size: 3vw;
    margin-bottom: 20px;
  }

  .content_block #pants .layout1 {
    flex-wrap: wrap;
    justify-content: center;
  }

  .content_block #pants .layout1 .box {
    width: 50%;
    margin-bottom: 20px;
    border-bottom: 1px solid #1D416D;
    padding-bottom: 1rem;
  }

  .content_block #pants .layout1 .box p {
    font-size: 2.5vw;
  }

  .content_block #pants .layout2 {
    gap: 10px;
  }

  .content_block #pants .layout2 .box {
    width: 25%;
  }

  .content_block #pants .layout2 .box .image {
    width: 100%;
  }

  .content_block #pants .layout1 .box .new {
    width: 50%;
    padding-top: 2rem;
  }

  .content_block #pants .layout2 .box p {
    font-size: 2.5vw;
  }

  .content_block #cordinate .layout {
    gap: 5px;
  }

  .content_block #cordinate .layout .box {
    width: calc(50% - 20px);
  }

  .content_block #cordinate .layout .box .image {
    width: 100%;
  }

  .content_block #cordinate .layout .arrow {
    width: 40px;
    text-align: center;
    padding: 0 5px;
  }

  .content_block .links {
    padding: 30px 5%;
    margin-bottom: 0px;
  }

  .content_block section .links{
    padding-inline: 0;
  }

  .content_block #order {
    padding: 0px 5%;
  }

  .content_block #order p {
    font-size: 3vw;
    margin-bottom: 20px;
  }

  .content_block #order p.lead {
    margin-bottom: 20px;
    text-align: center;
  }

  .content_block #order .image {
    margin-bottom: 20px;
  }

  .content_block #other {
    padding: 0 5%;
    margin-bottom: 35px;
  }

  .content_block #other h2 {
    font-size: 4.5vw;
    margin-bottom: 20px;
  }

  .content_block #reserve2{
  margin-bottom: 50px;
  }

  .content_block .reserve {
    padding: 0 5%;
  }

  .content_block #summer {
    margin-block: 35px 0;
    line-height: 0;
  }

  .content_block #news {
    padding: 20px 5%;
  }

  .content_block #news .box {
    display: block;
    padding: 25px;
  }

  .content_block #news .box .text {
    width: 100%;
  }

  .content_block #news .box h3 {
    font-size: 3.5vw;
    text-align: center;
  }

  .content_block #news .box p {
    font-size: 2.8vw;
    text-align: center;
    margin-bottom: 15px;
  }

  .content_block #news .box .image {
    width: 70%;
    margin: auto;
  }

  .content_block #flowbody {
    padding: 20px 5%;
  }

  .content_block #flowbody h2 {
    font-size: 4.5vw;
    margin-bottom: 0;
  }

  .content_block #flowbody .howto {
    width: 100%;
  }

  .content_block #flowbody .howto .step {
    margin-right: 15px;
    font-size: 1.2rem;
  }

  .content_block #flowbody .howto .step .num {
    font-size: 3rem;
  }

  .content_block #flowbody .howto .layout {
    display: block;
  }

  .content_block #flowbody .howto .layout .text {
    padding: 0;
  }

  .content_block #flowbody .howto .layout .text h3 {
    font-size: 2rem;
  }

  .content_block #flowbody .howto .layout .image {
    width: 100%;
    text-align: center;
    margin-top: 20px;
  }

  .content_block #flowbody .howto .layout .image img {
    max-width: 100%;
    max-width: 218px;
  }

  .content_block #flowbody .howto .layout.white h3 {
    font-size: 1.6rem;
  }

  .content_block #flowbody .howto .layout.white p {
    font-size: 1.2rem;
  }

  .content_block #flowbody .howto .layout.white .image {
    width: 100%;
    text-align: center;
  }

  .content_block #finish {
    padding: 20px 3%;
  }

    .content_block #finish .links{
      padding-top: 0;
    }
  .content_block #finish .links a {
  }

  .content_block #variation {
    padding: 0px 3%;
  }

  .content_block #variation h2 .eng {
    font-size: 3vw;
  }

  .content_block #variation h2 .jp {
    font-size: 5vw;
  }

  .content_block #variation .table table th {
    font-size: 3.2vw;
    width: 40%;
    padding: 20px 0px;
  }

  .content_block #variation .table table th small {
    font-size: 2.4vw;
  }

  .content_block #variation .table table td {
    font-size: 3.2vw;
    width: 60%;
    padding: 20px 0px;
  }

  .content_block #variation .table table td b {
    font-size: 6vw;
  }

  .content_block #variation .table table td .c2 {
    font-size: 3.2vw;
  }

  .content_block #variation .table table td .c2 .price {
    font-size: 6vw;
  }

  .content_block #variation .table table td .c2 .price .tax {
    font-size: 2.4vw;
  }

  .content_block #variation .table table td .c1 {
    font-size: 2.4vw;
  }

  .content_block #variation .table table td .c1 .price {
    font-size: 4.8vw;
  }

  .content_block #variation .table table td .c1 .tax {
    font-size: 2.4vw;
  }

  .content_block #variation .table table td .c1 .pb {
    position: relative;
    display: inline-block;
    vertical-align: middle;
  }

  .content_block #variation .table table td .c1 .pb .tax {
    display: block;
    text-align: center;
  }

  .content_block #variation .table .note {
    font-size: 3.0vw;
    margin-bottom: 50px;
  }

  .content_block #custom {
    margin-bottom: 0;
  }

  .content_block .reserve p {
    font-size: 3vw;
  }

  .content_block .reserve .res-btn {
    display: block;
    font-size: 4vw;
    padding: 15px 20px 15px 20px;
  }

  .comb3-shop{
    display: block !important;
  padding-top: 20px;    
  margin-bottom: 10px;
}

}

/* GROND OPEN
--------------------------------*/
#message{
  padding: 60px 0;
  background: url('./image/grandopen-bg.webp') no-repeat center center;
  background-size: cover;
  text-align: center;
}
#message h2{
  margin-bottom: 20px;
}
#message h2 span{
  font-size: 3.5rem;
  color: #a10011;
  font-weight: 600;
  display: inline-block;
  border-bottom: 2px solid #a10011;
  padding: 0 15px;
 }
 #message p{
  font-size: 2.1rem;
}


@media screen and (max-width: 768px) {
  #message{
    padding: 30px 0;
  }
#message h2 span{
  font-size: 5.5vw;
}
 #message p{
  font-size: 3.5vw;
 }
}
