@charset "UTF-8";
#sec1 {
  padding-top: 10vw;
}
#sec1 .h2box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#sec1 .h2box .ttl {
  width: 63%;
}
#sec1 .h2box .img {
  -ms-flex-item-align: end;
      align-self: flex-end;
  width: 37%;
}
#sec1 .set {
  margin-top: 10px;
}
#sec1 .set .img1 {
  width: 90%;
  margin: 0 -3vw 0 auto;
}
#sec1 .set .img2 {
  margin-top: 3vw;
}
#sec1 .set .txt {
  margin-top: 3vw;
}

#sec2 {
  padding: 25vw 0 30vw;
  position: relative;
  z-index: 0;
}
#sec2::before {
  content: "";
  width: 100%;
  background: url("../img/pattern2.jpg");
  position: absolute;
  top: 65vw;
  bottom: 0;
  left: 0;
  z-index: -1;
}
#sec2 .wrap {
  position: relative;
  z-index: 0;
}
#sec2 .wrap::before {
  content: "";
  width: 50vw;
  height: 50vw;
  background: url("../img/special/sec2_deco1.png") 0 0/contain no-repeat;
  position: absolute;
  top: -20vw;
  left: 50%;
  z-index: -1;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
#sec2 h2.ttl {
  text-align: center;
}
#sec2 .set {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-top: 5vw;
  position: relative;
  z-index: 0;
}
#sec2 .set::before {
  content: "";
  width: 50vw;
  height: 50vw;
  background: url("../img/special/sec2_deco2.png") 0 0/contain no-repeat;
  position: absolute;
  bottom: -31vw;
  right: -5vw;
  z-index: -1;
}
#sec2 .set .ttl {
  margin: 0 -5px 0 2px;
}
#sec2 .set .ttlbox .txtnote {
  margin: 5vw 0 0 3vw;
  font-size: 13px;
  letter-spacing: 0;
  cursor: vertical-text;
  writing-mode: vertical-rl;
  -o-writing-mode: vertical-rl;
  -ms-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  -moz-writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  text-orientation: upright;
  word-wrap: break-word;
}
#sec2 .set .imgbox {
  margin-left: -3vw;
}
#sec2 .set .menubox {
  width: 90%;
  padding: 5vw;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background: url("../img/pattern1.jpg");
}
#sec2 .set .menubox dl {
  font-weight: 500;
  text-align: center;
  line-height: 1.5;
}
#sec2 .set .menubox dl dt {
  font-size: 24px;
  letter-spacing: 0.04em;
}
#sec2 .set .menubox dl dd {
  font-size: 20px;
}
#sec2 .set .menubox dl dd small {
  font-size: 18px;
}
#sec2 .set .menubox ul {
  width: 50%;
}
#sec2 .set .menubox ul li {
  padding-left: 20px;
  position: relative;
}
#sec2 .set .menubox ul li::before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}
#sec2 .set .menubox .list1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 7vw;
}
#sec2 .set .txtbox {
  width: 90%;
  margin-top: 3vw;
}
#sec2 .set .gr1 {
  width: 87%;
}
#sec2 .set .gr2 {
  width: 13%;
}

#sec3 {
  padding-top: 10vw;
}
#sec3 h2.ttl {
  margin: 0 -5vw;
}
#sec3 .menubox {
  margin-top: 5vw;
  text-align: center;
}
#sec3 .menubox dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
  font-weight: 500;
  font-size: 20px;
}
#sec3 .menubox dl small {
  font-size: 18px;
}
#sec3 .set1 .ttlbox .txtnote {
  text-align: right;
  font-size: 13px;
}
#sec3 .set1 .txtbox {
  margin-top: 7vw;
}
#sec3 .set2 {
  margin-top: 5vw;
  position: relative;
  z-index: 0;
}
#sec3 .set2::before {
  content: "";
  width: 100vw;
  height: 100vw;
  background: url("../img/special/sec3_deco.png") 0 0/contain no-repeat;
  position: absolute;
  top: 15vw;
  left: -5vw;
  z-index: -1;
}
#sec3 .set3 {
  margin-top: 10vw;
}
#sec3 .set3 .ttl {
  margin-bottom: 3vw;
  font-weight: 500;
  font-size: 6vw;
  letter-spacing: 0;
  text-align: center;
}
#sec3 .set3 dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 15px 0;
  border-bottom: 1px solid #c4b8a7;
}

#sec4 {
  padding: 15vw 0;
}
#sec4 .set {
  padding: 10vw 7vw;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background: url("../img/pattern5.jpg");
  position: relative;
  z-index: 0;
}
#sec4 .set::before {
  content: "";
  background: url("../img/pattern4.jpg");
  position: absolute;
  inset: 5px;
  z-index: -1;
}
#sec4 .set .ttl {
  text-align: center;
  position: relative;
  z-index: 1;
}
#sec4 .set .ttl img {
  width: 80%;
}
#sec4 .set .img {
  text-align: center;
  margin-top: -10px;
}
#sec4 .set .img img {
  width: 80%;
}
#sec4 .set .txt {
  margin-top: 10px;
}
#sec4 .set dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 20px;
  padding: 10px 0;
  border-top: 1px solid #c4b8a7;
  border-bottom: 1px solid #c4b8a7;
}
#sec4 .set .txtnote {
  margin-top: 15px;
  text-align: center;
}
#sec4 .set .tel {
  display: block;
  margin: 15px -3vw 0;
  padding: 5vw 4vw 7vw;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background: #98411a;
  color: #fff;
  text-align: center;
  position: relative;
  z-index: 0;
}
#sec4 .set .tel::before {
  content: "";
  border: 1px solid #fff;
  position: absolute;
  inset: 5px;
  z-index: -1;
}
#sec4 .set .tel a:link {
  color: #fff;
}
#sec4 .set .tel dt {
  font-size: 16px;
}
#sec4 .set .tel .tel-number {
  font-size: 28px;
  line-height: 1;
  letter-spacing: 0.04em;
}
#sec4 .set .tel .tel-txt {
  margin-top: 10px;
  font-size: 10px;
  letter-spacing: 0;
}