@charset "UTF-8";
#setup_210807 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  list-style: none;
  padding: 0;
  margin: 0;
  color: #000;
  overflow-x: hidden;
}

#setup_210807 a {
  display: block;
}

#setup_210807 img, #setup_210807 source, #setup_210807 svg {
  width: 100%;
  height: auto;
  position: relative;
}

.image_hover_bg {
  position: relative;
}

.image_hover_bg::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: #fff;
}

.bredlist.lp {
  min-width: auto;
  max-width: none;
  margin: 0 auto;
}

@media only screen and (min-width: 768px) {
  .bredlist.lp {
    width: calc(1200 *(100vw / 1400));
  }
}

@media only screen and (max-width: 767px) {
  .bredlist.lp {
    max-width: calc(700 *(100vw / 750));
  }
}

#setup_210807 picture,
#setup_210807 video {
  display: block;
}

.fade {
  -webkit-transition: opacity 1s;
  transition: opacity 1s;
  opacity: 0;
}

.fade_in {
  opacity: 1;
}

.pc {
  display: none;
}

@media only screen and (min-width: 768px), print {
  .sp {
    display: none;
  }
  .pc {
    display: block;
  }
}

/* content0---------------------------------------------- */
/* sp------------------------------------------------------- */
/* sp------------------------------------------------------- */
/* tab------------------------------------------------------- */
/* tab------------------------------------------------------- */
/* pc------------------------------------------------------- */
.main-area {
  max-width: 100vw;
}

#setup_210807 {
  margin-top: calc(40 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  #setup_210807 {
    margin-top: calc(35 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  #setup_210807 {
    margin-top: 35px;
  }
}

.bg {
  position: relative;
  background-color: #dbdbd2;
  padding-bottom: calc(1 *(100vw / 750));
  width: 100vw;
  margin-bottom: calc(200 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .bg {
    margin-bottom: calc(160 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .bg {
    margin-bottom: 160px;
  }
}

.key__box {
  width: calc(750 *(100vw / 750));
  margin: auto;
}

@media only screen and (min-width: 768px), print {
  .key__box {
    width: calc(1400 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .key__box {
    width: 100%;
  }
}

.key__text {
  text-align: center;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-weight: 500;
  font-size: calc(26 *(100vw / 750));
  line-height: 2.53846;
  margin-top: calc(92 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .key__text {
    font-size: calc(16 *(100vw / 1400));
    line-height: 2.875;
    margin-top: calc(65 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .key__text {
    font-size: 16px;
    margin-top: 65px;
  }
}

.ct01__box {
  margin-top: calc(150 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct01__box {
    margin-top: calc(110 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct01__box {
    margin-top: 110px;
  }
}

@media only screen and (min-width: 768px), print {
  .ct01__mini_box {
    width: calc(1010 *(100vw / 1400));
    max-width: 1010px;
    margin: auto;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.ct01__img01 {
  width: calc(750 *(100vw / 750));
  margin: auto;
}

@media only screen and (min-width: 768px), print {
  .ct01__img01 {
    width: calc(530 *(100vw / 1400));
    max-width: 530px;
    margin: 0;
  }
}

.ct01__tax_box {
  font-family: baskerville-poster-pt, serif;
  font-weight: 400;
  font-style: normal;
  margin-top: calc(60 *(100vw / 750));
  margin-left: calc(30 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct01__tax_box {
    margin-top: calc(50 *(100vw / 1400));
    margin-left: calc(380 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct01__tax_box {
    margin-top: 50px;
    margin-left: 380px;
  }
}

.ct01__tax {
  position: relative;
  display: inline-block;
  font-size: calc(22 *(100vw / 750));
  letter-spacing: 0.03em;
  margin-top: calc(20 *(100vw / 750));
}

.ct01__tax:nth-of-type(1) {
  margin-top: 0;
}

@media only screen and (min-width: 768px), print {
  .ct01__tax {
    font-size: calc(12 *(100vw / 1400));
    margin-top: calc(13 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct01__tax {
    font-size: 12px;
    margin-top: 13px;
  }
}

.ct01__tax::before {
  content: "";
  position: absolute;
  bottom: calc(0 *(100vw / 750));
  left: 0;
  width: 100%;
  height: calc(1 *(100vw / 750));
  background-color: #000;
}

@media only screen and (min-width: 768px), print {
  .ct01__tax::before {
    bottom: calc(0 *(100vw / 1400));
    height: calc(1 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct01__tax::before {
    bottom: 0;
    height: 1px;
  }
}

.ct01__img02 {
  width: calc(525 *(100vw / 750));
  margin-left: auto;
  margin-right: calc(30 *(100vw / 750));
  margin-top: calc(100 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct01__img02 {
    width: calc(400 *(100vw / 1400));
    max-width: 400px;
    margin-top: calc(300 *(100vw / 1400));
    margin-right: 0;
  }
}

@media only screen and (min-width: 1400px) {
  .ct01__img02 {
    margin-top: 300px;
  }
}

.ct01__img03 {
  width: calc(750 *(100vw / 750));
  margin: auto;
  margin-top: calc(78 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct01__img03 {
    width: calc(800 *(100vw / 1400));
    max-width: 800px;
    margin-top: calc(73 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct01__img03 {
    margin-top: 73px;
  }
}

.ct02__box {
  width: calc(690 *(100vw / 750));
  margin: auto;
  margin-top: calc(168 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct02__box {
    width: calc(1010 *(100vw / 1400));
    max-width: 1010px;
    margin: auto;
    margin-top: calc(154 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct02__box {
    margin-top: 154px;
  }
}

.ct02__head {
  font-family: baskerville-poster-pt, serif;
  font-weight: 400;
  font-style: normal;
  text-align: left;
  display: inline-block;
  color: #663824;
  font-size: calc(106 *(100vw / 750));
  letter-spacing: 0.04em;
}

@media only screen and (min-width: 768px), print {
  .ct02__head {
    font-size: calc(72 *(100vw / 1400));
    margin-left: calc(30 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct02__head {
    font-size: 72px;
    margin-left: 30px;
  }
}

.ct02__mini_head_box {
  display: inline-block;
  margin-left: calc(12 *(100vw / 750));
  -webkit-transform: translateY(calc(-15 *(100vw / 750)));
          transform: translateY(calc(-15 *(100vw / 750)));
}

@media only screen and (min-width: 768px), print {
  .ct02__mini_head_box {
    margin-left: calc(24 *(100vw / 1400));
    -webkit-transform: translateY(calc(-10 *(100vw / 1400)));
            transform: translateY(calc(-10 *(100vw / 1400)));
  }
}

@media only screen and (min-width: 1400px) {
  .ct02__mini_head_box {
    margin-left: 24px;
    -webkit-transform: translateY(-10px);
            transform: translateY(-10px);
  }
}

.ct02__mini_head_top {
  font-family: baskerville-poster-pt, serif;
  font-weight: 400;
  font-style: normal;
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #663824;
  width: calc(210 *(100vw / 750));
  line-height: calc(40 *(100vw / 750));
  z-index: 1;
  letter-spacing: 0.04em;
  font-size: calc(30 *(100vw / 750));
  color: #fff;
}

@media only screen and (min-width: 768px), print {
  .ct02__mini_head_top {
    font-weight: 300;
    font-size: calc(18 *(100vw / 1400));
    width: calc(120 *(100vw / 1400));
    max-width: 120px;
    padding-top: calc(1 *(100vw / 1400));
    line-height: calc(24 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct02__mini_head_top {
    padding-top: 1px;
    font-size: 18px;
    line-height: 24px;
  }
}

.ct02__mini_head_btm {
  font-size: calc(28 *(100vw / 750));
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho Pro", serif;
  -webkit-transform: translate(calc(0 *(100vw / 750)), calc(16 *(100vw / 750)));
          transform: translate(calc(0 *(100vw / 750)), calc(16 *(100vw / 750)));
}

@media only screen and (min-width: 768px), print {
  .ct02__mini_head_btm {
    font-size: calc(17 *(100vw / 1400));
    -webkit-transform: translate(calc(0 *(100vw / 1400)), calc(12 *(100vw / 1400)));
            transform: translate(calc(0 *(100vw / 1400)), calc(12 *(100vw / 1400)));
  }
}

@media only screen and (min-width: 1400px) {
  .ct02__mini_head_btm {
    font-size: 17px;
    -webkit-transform: translate(0px, 12px);
            transform: translate(0px, 12px);
  }
}

.ct02__mini_box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}

@media only screen and (min-width: 768px), print {
  .ct02__mini_box {
    display: block;
  }
}

.ct02__img_box {
  -webkit-box-ordinal-group: 3;
  -webkit-order: 2;
      -ms-flex-order: 2;
          order: 2;
}

@media only screen and (min-width: 768px), print {
  .ct02__img_box {
    margin-top: calc(47 *(100vw / 1400));
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

@media only screen and (min-width: 1400px) {
  .ct02__img_box {
    margin-top: 47px;
  }
}

.ct02__img01 {
  width: calc(690 *(100vw / 750));
  margin: auto;
  margin-top: calc(90 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct02__img01 {
    -webkit-box-ordinal-group: 3;
    -webkit-order: 2;
        -ms-flex-order: 2;
            order: 2;
    width: calc(500 *(100vw / 1400));
    max-width: 500px;
    margin: 0;
  }
}

.ct02__img02 {
  width: calc(690 *(100vw / 750));
  margin: auto;
  margin-top: calc(20 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct02__img02 {
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
        -ms-flex-order: 1;
            order: 1;
    width: calc(500 *(100vw / 1400));
    max-width: 500px;
    margin: 0;
  }
}

.ct02__text {
  -webkit-box-ordinal-group: 2;
  -webkit-order: 1;
      -ms-flex-order: 1;
          order: 1;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-weight: 500;
  line-height: 1.75;
  font-size: calc(24 *(100vw / 750));
  margin-top: calc(47 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct02__text {
    font-weight: 500;
    line-height: 1.71429;
    font-size: calc(14 *(100vw / 1400));
    text-align: left;
    margin-top: calc(56 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct02__text {
    font-size: 14px;
    margin-top: 56px;
  }
}

.ct02__tax_box {
  -webkit-box-ordinal-group: 4;
  -webkit-order: 3;
      -ms-flex-order: 3;
          order: 3;
  margin-left: 0;
}

@media only screen and (min-width: 768px), print {
  .ct02__tax_box {
    text-align: left;
    margin-top: calc(37 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct02__tax_box {
    margin-top: 37px;
  }
}

.ct03__box {
  width: auto;
}

@media only screen and (min-width: 768px), print {
  .ct03__box {
    width: calc(1010 *(100vw / 1400));
    max-width: 1010px;
    margin: auto;
    margin-top: calc(148 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct03__box {
    margin-top: 148px;
  }
}

@media only screen and (min-width: 768px), print {
  .ct03__top_box {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.ct03__head_box {
  margin-left: calc(30 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct03__head_box {
    margin-left: 0;
    -webkit-transform: translateY(calc(8 *(100vw / 1400)));
            transform: translateY(calc(8 *(100vw / 1400)));
  }
}

@media only screen and (min-width: 1400px) {
  .ct03__head_box {
    margin-left: 0px;
    -webkit-transform: translateY(8px);
            transform: translateY(8px);
  }
}

.ct03__head {
  margin-left: 0;
}

.ct03__mini_head_box {
  margin-left: calc(19 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct03__mini_head_box {
    margin-left: calc(25 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct03__mini_head_box {
    margin-left: 25px;
  }
}

.ct03__text {
  line-height: 1.75;
  text-align: left;
}

@media only screen and (min-width: 768px), print {
  .ct03__text {
    margin-top: calc(50 *(100vw / 1400));
    line-height: 2;
  }
}

@media only screen and (min-width: 1400px) {
  .ct03__text {
    margin-top: 50px;
  }
}

.ct03__img01 {
  width: calc(675 *(100vw / 750));
  margin-left: auto;
  margin-top: calc(88 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct03__img01 {
    width: calc(530 *(100vw / 1400));
    max-width: 530px;
    margin-top: 0;
  }
}

@media only screen and (min-width: 768px), print {
  .ct03__btm_box {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
        -ms-flex-align: end;
            align-items: flex-end;
    -webkit-box-pack: start;
    -webkit-justify-content: flex-start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}

.ct03__img02 {
  width: calc(750 *(100vw / 750));
  margin: auto;
  margin-top: calc(80 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct03__img02 {
    width: calc(700 *(100vw / 1400));
    max-width: 700px;
    margin: 0;
    margin-top: calc(80 *(100vw / 1400));
    margin-right: calc(68 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct03__img02 {
    margin-top: 80px;
    margin-right: 68px;
  }
}

@media only screen and (min-width: 768px), print {
  .ct03__tax_box {
    margin-left: 0;
  }
}

@media only screen and (min-width: 768px), print {
  .ct03__tax {
    text-align: left;
  }
}

.ct04__box {
  position: relative;
  margin-top: calc(175 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct04__box {
    margin-top: calc(156 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct04__box {
    margin-top: 156px;
  }
}

.ct04__head {
  font-family: baskerville-poster-pt, serif;
  font-weight: 400;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: calc(64 *(100vw / 750));
  text-align: center;
  color: #663824;
}

@media only screen and (min-width: 768px), print {
  .ct04__head {
    font-size: calc(54 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct04__head {
    font-size: 54px;
  }
}

.ct04__top_box {
  margin-top: calc(62 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct04__top_box {
    max-width: 502px;
    width: calc(502 *(100vw / 1400));
    margin: auto;
    position: relative;
    margin-top: calc(50 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct04__top_box {
    margin-top: 50px;
  }
}

.ct04__img_box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  width: calc(605 *(100vw / 750));
  margin: auto;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media only screen and (min-width: 768px), print {
  .ct04__img_box {
    width: calc(500 *(100vw / 1400));
    max-width: 500px;
  }
}

.ct04__img01 {
  width: calc(280 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct04__img01 {
    width: calc(220 *(100vw / 1400));
    max-width: 220px;
  }
}

.ct04__img01:nth-of-type(2) {
  margin-top: calc(90 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct04__img01:nth-of-type(2) {
    margin-top: calc(70 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct04__img01:nth-of-type(2) {
    margin-top: 70px;
  }
}

.ct04__name {
  font-family: baskerville-poster-pt, serif;
  font-weight: 400;
  font-style: normal;
  font-size: calc(28 *(100vw / 750));
  letter-spacing: 0.03em;
  text-align: center;
  margin-top: calc(25 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct04__name {
    margin-top: calc(22 *(100vw / 1400));
    font-size: calc(18 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct04__name {
    margin-top: 22px;
    font-size: 18px;
  }
}

.ct04__sub_head {
  font-family: baskerville-poster-pt, serif;
  font-weight: 400;
  font-style: normal;
  position: absolute;
  text-align: right;
  top: calc(219 *(100vw / 750));
  right: calc(-55 *(100vw / 750));
  display: inline-block;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  color: #663824;
  font-size: calc(38 *(100vw / 750));
  letter-spacing: 0.04em;
}

@media only screen and (min-width: 768px), print {
  .ct04__sub_head {
    top: calc(65 *(100vw / 1400));
    right: calc(-107 *(100vw / 1400));
    font-size: calc(26 *(100vw / 1400));
    white-space: nowrap;
  }
}

@media only screen and (min-width: 1400px) {
  .ct04__sub_head {
    top: 65px;
    right: -107px;
    font-size: 26px;
  }
}

.ct04__sub_head::before {
  content: "";
  position: absolute;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  top: calc(-190 *(100vw / 750));
  left: calc(235 *(100vw / 750));
  background-color: #663824;
  width: calc(1 *(100vw / 750));
  height: calc(465 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct04__sub_head::before {
    top: calc(-150 *(100vw / 1400));
    left: calc(178 *(100vw / 1400));
    width: calc(1 *(100vw / 1400));
    max-width: 1px;
    height: calc(364 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct04__sub_head::before {
    top: -150px;
    left: 178px;
    height: 364px;
  }
}

.ct04__mini_box {
  width: calc(720 *(100vw / 750));
  margin: auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media only screen and (min-width: 768px), print {
  .ct04__mini_box {
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: calc(1120 *(100vw / 1400));
    max-width: 1120px;
  }
}

.ct04__btm_box {
  margin-top: calc(59 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct04__btm_box {
    margin-top: calc(60 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct04__btm_box {
    margin-top: 60px;
  }
}

.ct04__img_box_2 {
  width: calc(360 *(100vw / 750));
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

@media only screen and (min-width: 768px), print {
  .ct04__img_box_2 {
    width: calc(350 *(100vw / 1400));
    max-width: 350px;
  }
}

.ct04__img02 {
  width: 50%;
}

.ct04__img02:nth-of-type(2) {
  margin-top: calc(80 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct04__img02:nth-of-type(2) {
    margin-top: calc(90 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct04__img02:nth-of-type(2) {
    margin-top: 90px;
  }
}

@media only screen and (min-width: 768px), print {
  .ct04__left2_left {
    -webkit-transform: translateX(calc(12 *(100vw / 1400)));
            transform: translateX(calc(12 *(100vw / 1400)));
  }
}

@media only screen and (min-width: 1400px) {
  .ct04__left2_left {
    -webkit-transform: translateX(12px);
            transform: translateX(12px);
  }
}

@media only screen and (min-width: 768px), print {
  .ct04__right2_right {
    -webkit-transform: translateX(calc(-10 *(100vw / 1400)));
            transform: translateX(calc(-10 *(100vw / 1400)));
  }
}

@media only screen and (min-width: 1400px) {
  .ct04__right2_right {
    -webkit-transform: translateX(-10px);
            transform: translateX(-10px);
  }
}

.ct04__red_t {
  -webkit-transform: translateX(calc(20 *(100vw / 750)));
          transform: translateX(calc(20 *(100vw / 750)));
}

@media only screen and (min-width: 768px), print {
  .ct04__red_t {
    -webkit-transform: translate(0);
            transform: translate(0);
  }
}

.ct05__box {
  width: calc(690 *(100vw / 750));
  margin: auto;
  margin-top: calc(160 *(100vw / 750));
  border: 1px solid #663824;
}

@media only screen and (min-width: 768px), print {
  .ct05__box {
    width: calc(850 *(100vw / 1400));
    max-width: 850px;
    margin-top: calc(145 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct05__box {
    margin-top: 145px;
  }
}

.ct05__head {
  text-align: center;
  color: #663824;
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho Pro", serif;
  margin-top: calc(52 *(100vw / 750));
  letter-spacing: 0.04em;
  font-size: calc(34 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct05__head {
    font-weight: 500;
    margin-top: calc(38 *(100vw / 1400));
    font-size: calc(25 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct05__head {
    margin-top: 38px;
    font-size: 25px;
  }
}

.ct05__big_list {
  margin-left: calc(145 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct05__big_list {
    margin-left: 0;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
        -ms-flex-align: end;
            align-items: flex-end;
    padding-bottom: calc(35 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct05__big_list {
    padding-bottom: 35px;
  }
}

.ct05__list_box {
  margin-top: calc(24 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct05__list_box {
    margin-top: calc(35 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct05__list_box {
    margin-top: 35px;
  }
}

.ct05__list {
  position: relative;
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho Pro", serif;
  font-size: calc(28 *(100vw / 750));
  margin-bottom: calc(37 *(100vw / 750));
}

.ct05__list:nth-of-type(4) {
  margin-bottom: calc(60 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct05__list {
    font-size: calc(18 *(100vw / 1400));
    line-height: normal;
    margin-bottom: 0;
  }
  .ct05__list:nth-of-type(n+2) {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    margin-top: calc(14 *(100vw / 1400));
    margin-bottom: 0;
  }
}

@media only screen and (min-width: 1400px) {
  .ct05__list {
    font-size: 18px;
  }
  .ct05__list:nth-of-type(n+2) {
    margin-top: 14px;
  }
}

.ct05__list::before {
  content: "";
  position: absolute;
  top: calc(12 *(100vw / 750));
  left: calc(-40 *(100vw / 750));
  width: calc(8 *(100vw / 750));
  height: calc(8 *(100vw / 750));
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  background-color: #663824;
}

@media only screen and (min-width: 768px), print {
  .ct05__list::before {
    top: calc(12 *(100vw / 1400));
    left: calc(-26 *(100vw / 1400));
    width: calc(4 *(100vw / 1400));
    max-width: 4px;
    height: calc(4 *(100vw / 1400));
  }
  .ct05__list::before:nth-of-type(1) {
    top: calc(18 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .ct05__list::before {
    top: 12px;
    left: -26px;
    height: 4px;
  }
  .ct05__list::before:nth-of-type(1) {
    top: 18px;
  }
}

.ct05__list::before:nth-of-type(4) {
  background-color: #dbdbd2;
}

.ct05__text_box {
  display: block;
}

@media only screen and (min-width: 768px), print {
  .ct05__text_box {
    display: inline-block;
    margin-left: 2.2rem;
  }
}

.ct05__text {
  font-family: baskerville-poster-pt, serif;
  font-weight: 400;
  font-style: normal;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: calc(28 *(100vw / 750));
  color: #fff;
  background-color: #663824;
  width: calc(320 *(100vw / 750));
  line-height: calc(40 *(100vw / 750));
  margin-top: calc(20 *(100vw / 750));
}

@media only screen and (min-width: 768px), print {
  .ct05__text {
    font-size: calc(16 *(100vw / 1400));
    width: calc(180 *(100vw / 1400));
    max-width: 180px;
    line-height: calc(22 *(100vw / 1400));
    padding-top: calc(2 *(100vw / 1400));
    margin-top: 0;
  }
}

@media only screen and (min-width: 1400px) {
  .ct05__text {
    font-size: 16px;
    line-height: 22px;
    padding-top: 2px;
  }
}

.all_item_btn {
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-weight: 500;
  width: calc(676 *(100vw / 750));
  height: calc(120 *(100vw / 750));
  line-height: calc(120 *(100vw / 750));
  margin: auto;
  text-align: center;
  margin-top: calc(160 *(100vw / 750));
  margin-bottom: calc(200 *(100vw / 750));
  font-weight: 500;
  letter-spacing: 0.06em;
  font-size: calc(28 *(100vw / 750));
  background-color: #663824;
  color: #fff;
}

@media only screen and (min-width: 768px), print {
  .all_item_btn {
    width: calc(380 *(100vw / 1400));
    max-width: 380px;
    height: calc(64 *(100vw / 1400));
    line-height: calc(64 *(100vw / 1400));
    font-size: calc(18 *(100vw / 1400));
    margin-top: calc(150 *(100vw / 1400));
    margin-bottom: calc(160 *(100vw / 1400));
  }
}

@media only screen and (min-width: 1400px) {
  .all_item_btn {
    height: 64px;
    line-height: 64px;
    font-size: 18px;
    margin-top: 150px;
    margin-bottom: 160px;
  }
}
/*# sourceMappingURL=style.css.map */