@charset "UTF-8";
/* ------------------------------------
全体のレイアウト
-------------------------------------*/
body {
  font-family: "Shippori Mincho", serif;
  font-size: 3.2vw;
}

img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

@media screen and (min-width: 1024px) {
  body {
    font-size: 2.1333333333vw;
  }
}
/* ------------------------------------
contents
-------------------------------------*/
.contents {
  background-image: url(../../asset/image/sp/bg_01.jpg);
  background-repeat: repeat;
  background-position: top;
  background-size: cover;
}

@media screen and (min-width: 1024px) {
  .contents {
    background-image: url(../../asset/image/pc/bg_01.jpg);
    background-position: center;
  }
}
/* ------------------------------------
mv
-------------------------------------*/
/* ------------------------------------
content01
-------------------------------------*/
.content01 {
  background-color: #000;
  padding: 2.1333333333vw 0 3.4666666667vw;
}

.content01__text01 {
  font-size: 2.9vw;
  color: #fff;
  letter-spacing: 0.075em;
  line-height: 1.6;
  padding-left: 0.8vw;
  margin-bottom: 0.26vw;
  text-align: center;
}

.content01__text01-small {
  font-size: 4vw;
}

.content01__text01-mark {
  font-size: 2.6666666667vw;
  color: #808080;
  vertical-align: super;
}

.content01__text02 {
  font-size: 2.5333333333vw;
  color: #808080;
  text-align: center;
  padding-left: 1.6vw;
}

@media screen and (min-width: 1024px) {
  .content01 {
    padding: 18px 0 28px;
  }
  .content01__text01 {
    font-size: 34px;
    padding-left: 0;
    margin-bottom: 11px;
  }
  .content01__text01-small {
    font-size: 24px;
  }
  .content01__text01-mark {
    font-size: 18px;
  }
  .content01__text02 {
    font-size: 16px;
    padding-left: 0;
  }
}
/* ------------------------------------
content02
-------------------------------------*/
.content02 {
  padding: 21.0666666667vw 0 0;
  position: relative;
  z-index: 1;
}

.content02__text01 {
  width: 76.5333333333vw;
  margin: 0 auto 14.6666666667vw;
}

.content02__text02 {
  width: 67.4666666667vw;
  margin: 0 0 18.1333333333vw 15.7333333333vw;
}

@media screen and (min-width: 1024px) {
  .content02 {
    padding: 140px 0 0;
  }
  .content02__text01 {
    width: 698px;
    margin: 0 auto 60px;
  }
  .content02__text02 {
    width: 784px;
    margin: 0 auto 77px;
  }
  .content02__image01 {
    width: 674px;
    margin: 0 auto;
  }
}
/* ------------------------------------
content03
-------------------------------------*/
.content03 {
  padding: 27.7333333333vw 0 42.6666666667vw;
  position: relative;
  z-index: 1;
}

.content03__text01 {
  width: 60.9333333333vw;
  margin: 0 auto 7.4666666667vw;
}

.content03__text02 {
  width: 78.4vw;
  margin: 0 auto 13.6vw;
}

.content03__text03 {
  width: 54.5333333333vw;
  position: absolute;
  top: 70.4vw;
  left: 5.3333333333vw;
}

.content03__image01 {
  width: 86.2666666667vw;
  margin: 0 0 0 auto;
}

.content03__text04 {
  width: 65.4666666667vw;
  position: absolute;
  bottom: 21.0666666667vw;
  left: 29.0666666667vw;
}

@media screen and (min-width: 1024px) {
  .content03 {
    max-width: 1220px;
    padding: 156px 0 800px;
    margin: 0 auto;
  }
  .content03__inner01 {
    margin: 0 10px;
  }
  .content03__text01 {
    width: 711px;
    margin: 0 auto 39px;
  }
  .content03__text02 {
    width: 524px;
    margin: 0 auto 0;
  }
  .content03__text03 {
    width: min(38.11vw, 465px);
    top: auto;
    bottom: min(49.66vw, 557px);
    left: auto;
    right: min(59.73vw, 745px);
  }
  .content03__image01 {
    width: min(71.72vw, 875px);
    margin: 0;
    position: absolute;
    bottom: 186px;
    right: 12px;
  }
  .content03__text04 {
    width: min(40.33vw, 492px);
    position: absolute;
    bottom: 130px;
    left: auto;
    right: 11px;
  }
}
/* ------------------------------------
content04
-------------------------------------*/
.content04 {
  padding: 66.6666666667vw 0 12vw;
  position: relative;
  z-index: 0;
}

.content04::before {
  content: "";
  width: 100vw;
  height: 123.1333333333vw;
  background-image: url(../../asset/image/sp/content04_bg_01.png);
  background-repeat: no-repeat;
  background-position: bottom;
  background-size: cover;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}

.content04__text01 {
  width: 80.1333333333vw;
  margin-left: 0.5333333333vw;
}

@media screen and (min-width: 1024px) {
  .content04 {
    max-width: 1440px;
    padding: max(23.78vw, 365px) 0 max(4.78vw, 76px);
    margin: 0 auto;
  }
  .content04::before {
    width: 100vw;
    height: 43.4vw;
    background-image: url(../../asset/image/pc/content04_bg_01.png);
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
  }
  .content04__text01 {
    width: 934px;
    margin-left: 83px;
  }
}
/* ------------------------------------
content05
-------------------------------------*/
.content05 {
  padding: 30.4vw 0 33.3333333333vw;
}

.content05__header {
  margin-bottom: 0.7vw;
}

.content05__text01 {
  font-size: 4.2666666667vw;
  color: #fff;
  text-align: center;
  padding-left: 3.4666666667vw;
  margin-bottom: 5.0666666667vw;
  position: relative;
}

.content05__text01-mark01 {
  font-size: 2.6666666667vw;
  color: #808080;
  margin-left: 1.8666666667vw;
  vertical-align: super;
}

.content05__text01::before {
  content: "";
  width: 61.6vw;
  height: 0.5333333333vw;
  background-image: url(../../asset/image/sp/content05_line_01.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  position: absolute;
  bottom: -1.6vw;
  left: 20.8vw;
}

.content05__title01 {
  font-size: 2.9vw;
  font-weight: 400;
  color: #fff;
  letter-spacing: 0.075em;
  text-align: center;
  padding-left: 1.0666666667vw;
}

.content05__title01-small {
  font-size: 4vw;
}

.content05__title01-mark01 {
  font-size: 2.6666666667vw;
  color: #808080;
  vertical-align: super;
}

.content05__list02 {
  margin: 0 0 14.9333333333vw;
}

.content05__item02 {
  width: 100%;
  font-size: 2.4vw;
  color: #808080;
  letter-spacing: -0.02em;
  line-height: 1.9;
  padding-left: 0;
  position: relative;
  text-align: center;
}

.content05__item02:not(:last-of-type) {
  margin-bottom: 2.4vw;
}

.content05__title02 {
  font-size: 4.5333333333vw;
  font-weight: 400;
  color: #fff;
  letter-spacing: 0.04em;
  text-align: center;
  margin-bottom: 5.0666666667vw;
}

.content05__list01 {
  width: 89.3333333333vw;
  margin: 0 auto;
}

.content05__item01 {
  width: 89.3333333333vw;
  position: relative;
  border: 0.1333333333vw solid #d8982b;
  -o-border-image: linear-gradient(-45deg, #d8982b, #f8db8c) 1;
     border-image: linear-gradient(-45deg, #d8982b, #f8db8c) 1;
}

.content05__item01:not(:last-of-type) {
  margin-bottom: 1.8666666667vw;
}

.content05__title03 {
  font-size: 3.4666666667vw;
  font-weight: 400;
  color: #fff;
  background-color: rgba(153, 124, 78, 0.14);
  padding: 0.8vw 0 0.5333333333vw 2.9333333333vw;
}

.content05__title03-small {
  font-size: 2.6666666667vw;
}

.content05__text04-1,
.content05__text04-2,
.content05__text04-3,
.content05__text04-4,
.content05__text04-5,
.content05__text04-6,
.content05__text04-7,
.content05__text04-8,
.content05__text04-9,
.content05__text04-10,
.content05__text04-11 {
  font-size: 3.1466666667vw;
  color: #fff;
  letter-spacing: -0.02em;
  padding: 1.8666666667vw 0 1.6vw 2.9333333333vw;
}

.content05__text04-3 {
  padding: 1.8666666667vw 0 2.1333333333vw 2.9333333333vw;
}

.content05__text04-5 {
  padding: 1.8666666667vw 0 1.8666666667vw 2.9333333333vw;
}

.content05__text04-6 {
  padding: 1.8666666667vw 0 1.8666666667vw 2.9333333333vw;
}

.content05__text04-7 {
  padding: 1.8666666667vw 0 1.8666666667vw 2.9333333333vw;
}

.content05__text04-8 {
  padding: 1.8666666667vw 0 1.8666666667vw 2.9333333333vw;
}

.content05__text04-9 {
  padding: 1.8666666667vw 0 1.8666666667vw 2.9333333333vw;
}

.content05__text04-10 {
  padding: 1.8666666667vw 0.5333333333vw 1.0666666667vw 2.6666666667vw;
}

.content05__text04-11 {
  padding: 1.8666666667vw 0 2.1333333333vw 2.9333333333vw;
}

.content05__text04-mark {
  font-size: 2.4vw;
  color: #808080;
  vertical-align: super;
}

.content05__text04-small01 {
  display: block;
  font-size: 2.6666666667vw;
  color: #808080;
}

.content05__text04-small02 {
  font-size: 2.6666666667vw;
}

.content05__text05 {
  font-size: 3.0666666667vw;
  color: #fff;
  padding: 1.8666666667vw 1.3333333333vw 0 2.6666666667vw;
}

@media screen and (min-width: 1024px) {
  .content05 {
    max-width: 1440px;
    padding: 156px 0 203px;
    margin: 0 auto;
  }
  .content05__header {
    width: 1024px;
    margin: 0 auto 10px;
  }
  .content05__text01 {
    font-size: 28px;
    letter-spacing: -0.01em;
    padding-left: 34px;
    margin-bottom: 26px;
  }
  .content05__text01-mark01 {
    font-size: 15px;
    margin-left: 0;
  }
  .content05__text01::before {
    content: "";
    width: 380px;
    height: 3px;
    background-image: url(../../asset/image/pc/content05_line_01.jpg);
    bottom: -6px;
    left: 339px;
  }
  .content05__title01 {
    font-size: 30px;
    letter-spacing: 0.06em;
    padding-left: 15px;
  }
  .content05__title01-small {
    font-size: 34px;
  }
  .content05__title01-mark01 {
    font-size: 19px;
    vertical-align: text-top;
  }
  .content05__list02 {
    max-width: 1200px;
    margin: 0 auto 108px;
  }
  .content05__item02 {
    width: auto;
    font-size: 15.5px;
    letter-spacing: -0.04em;
    padding-left: 0;
    margin: 0;
    text-align: center;
  }
  .content05__item02:not(:last-of-type) {
    margin-bottom: 6px;
  }
  .content05__title02 {
    font-size: 28px;
    margin-bottom: 38px;
  }
  .content05__list01 {
    max-width: 1200px;
    margin: 0 auto;
  }
  .content05__item01 {
    display: flex;
    max-width: 1200px;
    padding: 0 0 0 0;
    border: 1px solid #d8982b;
    -o-border-image: linear-gradient(-45deg, #d8982b, #f8db8c) 1;
       border-image: linear-gradient(-45deg, #d8982b, #f8db8c) 1;
  }
  .content05__item01::before {
    content: none;
  }
  .content05__item01:not(:last-of-type) {
    margin-bottom: 16px;
  }
  .content05__title03 {
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
    width: 253px;
    font-size: 20px;
    justify-content: center;
    align-items: center;
    background-color: rgba(153, 124, 78, 0.14);
    padding: 0;
    margin-bottom: 0;
  }
  .flex-row {
    flex-direction: row;
  }
  .content05__title03-small {
    font-size: 15px;
  }
  .content05__text04-1,
.content05__text04-2,
.content05__text04-3,
.content05__text04-4,
.content05__text04-5,
.content05__text04-6,
.content05__text04-7,
.content05__text04-8,
.content05__text04-9,
.content05__text04-10,
.content05__text04-11 {
    font-size: 19px;
    letter-spacing: 0;
    line-height: 1.7;
    padding: 18px 15px 17px 48px;
  }
  .content05__text04-mark {
    font-size: 12px;
  }
  .content05__text04-small01 {
    font-size: 16px;
  }
  .content05__text04-small02 {
    font-size: 18px;
  }
  .content05__text05 {
    font-size: 19px;
    line-height: 1.7;
    padding: 19px 15px 6px 46px;
    margin-bottom: 0;
  }
  .content05__box01 {
    width: 947px;
  }
  .content05__text04-2 {
    padding: 17px 15px 19px 49px;
  }
  .content05__text04-3 {
    padding: 18px 15px 19px 47px;
  }
  .content05__text04-4 {
    padding: 17px 15px 21px 47px;
  }
  .content05__text04-5 {
    padding: 18px 15px 18px 47px;
  }
  .content05__text04-6 {
    padding: 18px 15px 19px 47px;
  }
  .content05__text04-7 {
    padding: 17px 15px 21px 47px;
  }
  .content05__text04-8 {
    padding: 17px 15px 19px 47px;
  }
  .content05__text04-9 {
    padding: 19px 15px 19px 47px;
  }
  .content05__text04-10 {
    padding: 16px 15px 17px 46px;
  }
  .content05__text04-11 {
    padding: 17px 15px 22px 51px;
  }
}
/* ------------------------------------
footer
-------------------------------------*/
.footer {
  background-color: #000;
  padding: 2.9333333333vw 0 3.2vw;
}

.footer__list01 {
  display: flex;
  gap: 7.7333333333vw;
  justify-content: center;
  margin-bottom: 2.9333333333vw;
}

.footer__item01 {
  position: relative;
}

.footer__item01:nth-of-type(1):before {
  content: "";
  width: 0.2666666667vw;
  height: 3.2vw;
  background-color: #fff;
  position: absolute;
  top: 1.3333333333vw;
  right: -4.8vw;
}

.footer__item01:nth-of-type(2):before {
  content: "";
  width: 0.2666666667vw;
  height: 3.2vw;
  background-color: #fff;
  position: absolute;
  top: 1.3333333333vw;
  right: -2.9333333333vw;
}

.footer__link01 {
  font-size: 3.4666666667vw;
  color: #fff;
  text-decoration: none;
}

.footer__copyright {
  text-align: center;
}

.footer__link02 {
  font-size: 2.6666666667vw;
  color: #fff;
  letter-spacing: 0.06em;
  text-decoration: none;
  padding-left: 0.5333333333vw;
}

@media screen and (min-width: 1024px) {
  .footer {
    padding: 25px 0 11px;
  }
  .footer__list01 {
    gap: 44px;
    margin: 0 0 2px;
  }
  .footer__item01 {
    font-size: 16px;
  }
  .footer__item01:nth-of-type(1):before {
    width: 2px;
    height: 16px;
    top: 8px;
    right: -25px;
  }
  .footer__item01:nth-of-type(2):before {
    width: 2px;
    height: 16px;
    top: 8px;
    right: -18px;
  }
  .footer__link01 {
    font-size: 16px;
  }
  .footer__link02 {
    font-size: 14px;
    padding-left: 0;
  }
  .footer__link01:hover,
.footer__link02:hover {
    opacity: 0.89;
  }
}