@charset "utf-8";

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #000;
  line-height: 1.5em;
}

ul,
ol {
  list-style-type: none;
}

a:hover {
  opacity: 1.0;
}

a:focus {
  outline: none;
}

.content_wrap {
  max-width: 750px;
  margin: 0 auto;
  overflow: hidden;
}

.content_wrap img {
  height: auto;
  display: block;
  height: auto;
  vertical-align: top;
  border: 0;
  max-width: 100%;
  margin: 0;
}

.content_wrap video {
  width: 100%;
  display: block;
  height: auto;
  vertical-align: top;
  border: 0;
  outline: none;
}

.content_wrap a {
  display: block;
}

.content_wrap .rl {
  position: relative;
}

.content_wrap .btn01 {
  position: absolute;
  width: 95.73%;
  top: 62.6%;
  left: 2.4%;
}

.content_wrap .video01 {
  position: absolute;
  width: 88%;
  left: 6%;
  top: 21.3%;
}

.content_wrap .video01 video {
  border-radius: min(30px, 4vw);
}

.content_wrap .slide01 {
  position: absolute !important;
  width: 100%;
  top: 5.41%;
  left: 0;
}

.content_wrap .slide01 .slick-slide img {
  width: 93.3%;
  margin: 0 auto;
}

.content_wrap .slide01 .slick-prev {
  left: 3.2%;
  background: url(../images/sld01_prev.png) left top/100% no-repeat;
  background-size: 100%;
  content: "";
  width: 57px;
  height: 57px;
}

.content_wrap .slide01 .slick-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  outline: none;
  text-indent: -9999px;
  z-index: 100;
  cursor: pointer;
}

.content_wrap .slide01 .slick-next {
  right: 3.2%;
  background: url(../images/sld01_next.png) left 0 top 0 no-repeat;
  background-size: contain;
  content: "";
  width: 57px;
  height: 57px;
}

.content_wrap .sld {
  opacity: 0;
  transition: opacity .3s linear;
}

.content_wrap .sld.slick-initialized {
  opacity: 1;
}

.content_wrap .pt01-1 {
  position: absolute;
  z-index: 3;
  width: 92.8%;
  top: 2.7%;
  left: 3.06%;
}

.content_wrap .pt01-2 {
  position: absolute;
  z-index: 3;
  width: 92.8%;
  top: 64.24%;
  left: 3.06%;
}

.content_wrap .video02 {
  position: absolute;
  width: 40%;
  left: 30%;
  top: 36.9%;
  height: 516px;
}

.content_wrap .video02 video {
  border-radius: min(30px, 4vw);
  object-fit: cover;
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
}

.content_wrap .pt02 {
  position: absolute;
  width: 98.13%;
  right: 0;
  top: 43.88%;
}

.content_wrap .video03 {
  position: absolute;
  width: 41.4%;
  top: 54.9%;
  right: 7.6%;
  clip-path: inset(0 0 18.3% 0);
}

.content_wrap .video03 video {
  border-top-left-radius: min(30px, 4vw);
  border-top-right-radius: min(30px, 4vw);
}

.content_wrap .video04 {
  position: absolute;
  width: 66.8%;
  top: 28.1%;
  left: 16.6%;
}

.content_wrap .video04 video {
  border-radius: min(22px, 2.93vw);
}

.content_wrap .pt03 {
  position: absolute;
  width: 89.6%;
  top: 25.65%;
  right: 4.93%;
}

.content_wrap .video05 {
  position: absolute;
  width: 78.66%;
  top: 41.54%;
  left: 10.67%;
}

.content_wrap .slide02 {
  position: absolute;
  width: 100%;
  left: 0;
  top: 19.11%;
}

.content_wrap .slide02 .slick-prev {
  left: 1.6%;
  background: url(../images/sld02_prev.png) left top/100% no-repeat;
  background-size: 100%;
  content: "";
  width: 63px;
  height: 63px;
}

.content_wrap .slide02 .slick-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  outline: none;
  text-indent: -9999px;
  z-index: 100;
  cursor: pointer;
}

.content_wrap .slide02 .slick-next {
  right: 1.6%;
  background: url(../images/sld02_next.png) left top/100% no-repeat;
  background-size: 100%;
  content: "";
  width: 63px;
  height: 63px;
}

.content_wrap .slide02 .slick-dots {
  left: 50%;
  display: flex;
  position: absolute;
  bottom: -3%;
  transform: translateX(-50%);
  width: auto !important;
}

.content_wrap .slide02 .slick-dots button {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 1px solid #902d27;
  outline: none;
  background: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  text-indent: -9999px;
  cursor: pointer;
}

.content_wrap .slide02 .slick-dots button:focus {
  border: 1px solid #902d27;
  outline: none;
}

.content_wrap .slide02 .slick-dots li {
  margin: 0 10px;
  width: auto !important;
}

.content_wrap .slide02 .slick-dots .slick-active button {
  background: #902d27;
}

.content_wrap .pt04 {
  position: absolute;
  width: 91.73%;
  top: 17.2%;
  left: 4.53%;
}

.content_wrap .slider03_1 {
  position: absolute;
  width: 100%;
  top: 27.4%;
  left: 0;
}

.content_wrap .slider03_2 {
  position: absolute;
  width: 100%;
  top: 40.5%;
  left: 0;
}

.content_wrap .slider03_3 {
  position: absolute;
  width: 100%;
  top: 53.7%;
  left: 0;
}

.content_wrap .slider03_wrap .slider .slick-slide img {
  width: 89%;
  margin: 0 auto;
}

.content_wrap .pt05 {
  position: absolute;
  width: 98.53%;
  top: 62.75%;
  right: 0;
}

.content_wrap .q_wrap {
  background: #faf6ef;
  padding-bottom: 60px;
}

.content_wrap .q_wrap .qa {
  padding-left: min(30px, 4vw);
  padding-right: min(30px, 4vw);
}

.content_wrap .q_wrap .qa dl {
  padding-top: min(40px, 5.33vw);
  padding-bottom: min(40px, 5.33vw);
  background: url(../images/qa_dot.png) left bottom/100% no-repeat;
}

.content_wrap .q_wrap .qa dl:nth-last-of-type(1) {
  background: none;
}

.content_wrap .q_wrap .qa dl dt {
  position: relative;
  padding-left: min(109px, 14.53vw);
  padding-right: min(17px, 2.26vw);
  font-size: min(29px, 3.86vw);
  color: #000;
  line-height: 1.6em;
  cursor: pointer;
  letter-spacing: 0.1em;
}

.content_wrap .q_wrap .qa .accordionlist dt:before {
  position: absolute;
  content: "";
  top: 0;
  width: min(30px, 4vw);
  background: #000;
  height: 1px;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -ms-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  top: 50%;
  right: min(17px, 2.26vw);
  transition: .3s all;
}

.content_wrap .q_wrap .qa .accordionlist dt:after {
  position: absolute;
  content: "";
  top: 0;
  width: min(30px, 4vw);
  background: #000;
  height: 1px;
  -webkit-transform: rotate(90deg);
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  -o-transform: rotate(90deg);
  top: 50%;
  right: min(17px, 2.26vw);
  transition: .3s all;
}

.content_wrap .q_wrap .qa .accordionlist dt.active:before {
  display: none;
}

.content_wrap .q_wrap .qa .accordionlist dt.active:after {
  transform: rotate(180deg);
  -webkit-transform: rotate(180deg);
  -moz-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  -o-transform: rotate(180deg);
}

.content_wrap .q_wrap .qa dl dd {
  text-align: justify;
  font-size: min(21px, 3vw);
  line-height: 1.7em;
  display: none;
  padding-left: min(17px, 2.26vw);
  padding-right: min(17px, 2.26vw);
  padding-top: min(20px, 2.66vw);
}

.content_wrap .q_wrap .qa dl dd .lnk a {
  color: #000;
  text-decoration: underline;
}

.content_wrap .q_wrap .qa dl dt .qa_num {
  position: absolute;
  width: 8.93%;
  top: 11%;
  left: min(17px, 2.26vw);
}

.content_wrap .q_wrap .acc02 {
  padding-left: min(30px, 4vw);
  padding-right: min(30px, 4vw);
  margin-top: min(30px, 4vw);
}

.content_wrap .q_wrap .acc02 dl {
  padding-top: min(40px, 5.33vw);
  padding-bottom: min(40px, 5.33vw);

}

.content_wrap .q_wrap .acc02 dl dt {
  position: relative;
  padding-left: min(56px, 7.46vw);
  padding-right: min(56px, 7.46vw);
  line-height: 1.0em;
  cursor: pointer;
}

.content_wrap .q_wrap .acc02 .accordionlist dt:before {
  position: absolute;
  content: "";
  top: 0;
  width: min(30px, 4vw);
  background: #000;
  height: 1px;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -ms-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  top: 50%;
  right: min(100px, 13.33vw);
  transition: .3s all;
}

.content_wrap .q_wrap .acc02 .accordionlist dt:after {
  position: absolute;
  content: "";
  top: 0;
  width: min(30px, 4vw);
  background: #000;
  height: 1px;
  -webkit-transform: rotate(90deg);
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  -o-transform: rotate(90deg);
  top: 50%;
  right: min(100px, 13.33vw);
  transition: .3s all;
}

.content_wrap .q_wrap .acc02 .accordionlist dt.active:before {
  display: none;
}

.content_wrap .q_wrap .acc02 .accordionlist dt.active:after {
  transform: rotate(180deg);
  -webkit-transform: rotate(180deg);
  -moz-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  -o-transform: rotate(180deg);
}

.content_wrap .q_wrap .acc02 .accordionlist dd {
  text-align: justify;
  font-size: min(21px, 3vw);
  line-height: 1.7em;
  display: none;
  padding-left: min(17px, 2.26vw);
  padding-right: min(17px, 2.26vw);
  padding-top: min(30px, 4vw);
}

.content_wrap .video06 {
  position: absolute;
  width: 58.66%;
  top: 38%;
  left: 6.7%;
  z-index: -1;
}

.content_wrap .video07 {
  position: absolute;
  width: 58.66%;
  top: 9.94%;
  right: 4%;
  z-index: -1;
}

.content_wrap .video08 {
  position: absolute;
  width: 58.66%;
  top: 8.1%;
  left: 2%;
  z-index: -1;
}

.content_wrap .video09 {
  position: absolute;
  width: 58.66%;
  top: 6.5%;
  right: 1%;
  z-index: -1;
}

@media(max-width:749px) {
  .content_wrap img {
    width: 100%;
  }

  .content_wrap .slide01 .slick-prev {
    width: 8vw;
    height: 8vw;
  }

  .content_wrap .slide01 .slick-next {
    width: 8vw;
    height: 8vw;
  }

  .content_wrap .video02 {
    height: 68.8vw;
  }

  .content_wrap .slide02 .slick-prev {
    width: 8.4vw;
    height: 8.4vw;
  }

  .content_wrap .slide02 .slick-next {
    width: 8.4vw;
    height: 8.4vw;
  }

  .content_wrap .slide02 .slick-dots {
    bottom: -5.5%;
  }

  .content_wrap .slide02 .slick-dots button {
    width: 8px;
    height: 8px;
  }

  .content_wrap .slide02 .slick-dots li {
    margin: 0 6px;
  }

  .content_wrap .q_wrap {
    padding-bottom: 8vw;
  }
}

/* フローティングバナー */
#floatingBanner {
  position: fixed;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%) translateY(30px);
  max-width: 370px;
  width: 90%;
  opacity: 0;
  transition: all 0.6s ease;
  z-index: 9999;
}

@media screen and (min-width: 768px) {
  #floatingBanner {
    left: auto;
    right: 16px;
    bottom: 32px;
    transform: translateY(30px);
  }
}

#floatingBanner img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* 非表示用クラス */
#floatingBanner.hidden {
  opacity: 0 !important;
  pointer-events: none;
  transform: translateY(30px);
}