@charset "UTF-8";
html {
  font-size: 0.4761904762vw;
}

@media screen and (min-width: 1400px) {
  html {
    font-size: 6.6666666667px;
  }
}
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
  box-sizing: border-box;
}

h1, h2, h3, h4, h5, h6, p, a {
  font-size: 100%;
  line-height: 1;
  transform: rotate(0.03deg);
  -moz-transform: rotate(0.03deg);
  -ms-transform: rotate(0.03deg);
  -o-transform: rotate(0.03deg);
  -webkit-transform: rotate(0.03deg);
}

.feature {
  box-sizing: border-box;
  width: 100%;
  margin: 0 auto;
  overflow: clip;
  position: relative;
  font-feature-settings: "palt" 1;
  font-family: "Yu Gothic", "游ゴシック", "YuGothic", "游ゴシック体", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #050505;
}

.feature a {
  transition: 0.3s;
  display: block;
  color: #050505;
  text-decoration: none;
  will-change: opacity;
}
.feature a:hover {
  opacity: 0.7;
  text-decoration: none;
}

.feature img, svg, video {
  width: 100%;
  height: auto;
  display: block;
  vertical-align: bottom;
}

.l-container {
  width: 100%;
  overflow: clip;
}

.l-footer {
  padding: 0;
}

.pc-footer {
  margin: 0;
}

* {
  box-sizing: border-box;
}

.js-fade {
  opacity: 0;
  transform: translateY(6rem);
  visibility: hidden;
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.js-fade.is-show {
  opacity: 1;
  transform: none;
  visibility: visible;
}

section {
  scroll-margin-top: 100px;
}

.feature {
  background: #e5e1dc;
}

.feature__inner {
  width: 75rem;
  margin: 0 auto;
  position: relative;
  padding-bottom: 18rem;
  overflow: clip;
  background: #fff;
}

.main-visual {
  position: relative;
  padding-top: 8.5rem;
}
.main-visual .main-ttl {
  width: 52.4091rem;
  margin: 0 auto;
}
.main-visual .main-ph {
  width: 71rem;
  margin: 0 auto;
  margin-top: 3rem;
}
.main-visual .main-loop-wrap {
  position: relative;
  margin-top: 2.5rem;
}
.main-visual .main-loop-wrap .loop-pass {
  width: 75.132rem;
}
.main-visual .main-loop-wrap .loop-wrap {
  position: relative;
  margin-top: 1.8rem;
  margin-bottom: 1.5rem;
  width: -moz-fit-content;
  width: fit-content;
}
@keyframes anim_loopX {
  0% {
    transform: translateX(0%);
  }
  0% {
    transform: translateX(-100%);
  }
}
@keyframes anim_loopX2 {
  0% {
    transform: translateX(100%);
  }
  0% {
    transform: translateX(0%);
  }
}
.main-visual .main-loop-wrap .loop-wrap .loop-box {
  position: relative;
  display: flex;
}
.main-visual .main-loop-wrap .loop-wrap .loop-box .loop-txt {
  width: 49.6528rem;
  flex-shrink: 0;
  margin-left: 1.2rem;
}
.main-visual .main-loop-wrap .loop-wrap .loop-box.loop-box01 {
  animation: anim_loopX 25s linear infinite;
}
.main-visual .main-loop-wrap .loop-wrap .loop-box.loop-box02 {
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(100%);
  animation: anim_loopX2 25s linear infinite;
}

.main-contents {
  position: relative;
  margin-top: 10rem;
}
.main-contents .ph {
  position: relative;
  z-index: 2;
}
.main-contents .ph-box {
  position: relative;
}
.main-contents .ph-wrap {
  position: relative;
  display: flex;
}
.main-contents .credit {
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: 4rem;
       column-gap: 4rem;
  margin: 0 auto;
  margin-top: 1.8rem;
  position: relative;
  z-index: 2;
}
.main-contents .credit li {
  position: relative;
  font-family: ivyora-display, serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2.4rem;
  line-height: 1;
  text-decoration: none;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
}
.main-contents .credit li::after {
  content: "/";
  position: absolute;
  top: 50%;
  right: -2.3rem;
  color: #050505;
  font-size: 2.4rem;
  line-height: 1;
  transform: translateY(-50%);
}
.main-contents .credit li .price {
  margin-left: 1rem;
}
.main-contents .credit li a {
  font-family: ivyora-display, serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2.4rem;
  line-height: 1;
  text-decoration: none;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
}
.main-contents .credit li a .price {
  margin-left: 1rem;
}
.main-contents .credit .line-end::after, .main-contents .credit li:last-of-type::after {
  display: none;
}
.main-contents .ph-box01 {
  width: 64rem;
  margin: 0 auto;
  z-index: 1;
}
.main-contents .ph-box01 .credit {
  justify-content: center;
  -moz-column-gap: 4rem;
       column-gap: 4rem;
}
.main-contents .ph-box02 {
  width: 54rem;
  margin-top: 10.4rem;
}
.main-contents .ph-box02 .credit {
  margin-left: 2.2rem;
}
.main-contents .ph-box02 .ph-bg {
  width: 37.7rem;
  position: absolute;
  top: -19rem;
  left: 18.8rem;
}
.main-contents .ph-box03 {
  margin-top: 10.4rem;
}
.main-contents .ph-box03 .ph-wrap {
  background: #e5e1dc;
}
.main-contents .ph-box03 .credit {
  width: 30rem;
  justify-content: center;
  row-gap: 1.6rem;
}
.main-contents .ph-box04 {
  margin-top: 10.5rem;
}
.main-contents .ph-box04 .ph04 {
  width: 54rem;
  margin-left: auto;
}
.main-contents .ph-box04 .ph-bg {
  width: 37.7rem;
  position: absolute;
  top: 35.6rem;
  left: 0;
}
.main-contents .ph-box04 .credit {
  justify-content: flex-end;
  margin-right: 2.5rem;
}
.main-contents .ph-box05 {
  width: 64rem;
  margin: 0 auto;
  margin-top: 9.6rem;
}
.main-contents .ph-box05 .credit {
  justify-content: center;
  -moz-column-gap: 4rem;
       column-gap: 4rem;
}
.main-contents .ph-box06 {
  width: 45rem;
  margin: 0 auto;
  margin-top: 10.3rem;
}
.main-contents .ph-box06 .credit {
  justify-content: center;
  -moz-column-gap: 4rem;
       column-gap: 4rem;
}
.main-contents .ph-box07 {
  margin-top: 10.5rem;
}
.main-contents .ph-box07 .ph07 {
  width: 60rem;
}
.main-contents .ph-box07 .deco-txt {
  width: 4.21387rem;
  position: absolute;
  top: 0;
  right: 2.2rem;
}
.main-contents .ph-box07 .credit {
  margin-left: 2rem;
}
.main-contents .ph-box08 {
  margin-top: 10.3rem;
}
.main-contents .ph-box08 .ph08 {
  width: 60rem;
  margin-left: auto;
}
.main-contents .ph-box08 .credit {
  justify-content: flex-end;
  margin-right: 2rem;
}
.main-contents .ph-box09 {
  width: 70rem;
  margin: 0 auto;
  margin-top: 10rem;
}
.main-contents .ph-box09 .credit {
  justify-content: center;
}
.main-contents .ph-box10 {
  margin-top: 10.5rem;
}
.main-contents .ph-box10 .ph10 {
  width: 44rem;
}
.main-contents .ph-box10 .ph-bg {
  width: 37.7rem;
  position: absolute;
  top: -61rem;
  right: 0;
}
.main-contents .ph-box10 .credit {
  margin-left: 2rem;
}
.main-contents .ph-box11 {
  margin-top: 10.5rem;
}
.main-contents .ph-box11 .ph11 {
  width: 54rem;
  margin-left: auto;
}
.main-contents .ph-box11 .credit {
  justify-content: flex-end;
  margin-right: 2rem;
}
.main-contents .ph-box12 {
  width: 60rem;
  margin: 0 auto;
  margin-top: 10.2rem;
}
.main-contents .ph-box12 .credit {
  justify-content: center;
}
.main-contents .ph-box13 {
  margin-top: 10.4rem;
}
.main-contents .ph-box13 .credit {
  justify-content: center;
}
.main-contents .ph-box14 {
  margin-top: 10.6rem;
}
.main-contents .ph-box14 .ph14 {
  width: 56rem;
}
.main-contents .ph-box14 .credit {
  margin-left: 2rem;
}
.main-contents .ph-box15 {
  margin-top: 10.4rem;
}
.main-contents .ph-box15 .ph15 {
  width: 56rem;
  margin-left: auto;
}
.main-contents .ph-box15 .credit {
  justify-content: flex-end;
  margin-right: 2.2rem;
}
.main-contents .ph-box16 {
  width: 64rem;
  margin: 0 auto;
  margin-top: 10.1rem;
}
.main-contents .ph-box16 .credit {
  justify-content: center;
}
.main-contents .ph-box17 {
  margin-top: 10.6rem;
}
.main-contents .ph-box17 .ph17 {
  width: 46rem;
}
.main-contents .ph-box17 .credit {
  margin-left: 2rem;
}
.main-contents .ph-box17 .deco-txt {
  width: 4.21387rem;
  position: absolute;
  top: 0;
  right: 2.2rem;
}
.main-contents .ph-box18 {
  margin-top: 10.4rem;
}
.main-contents .ph-box18 .ph18 {
  width: 50rem;
  margin: 0 auto;
}
.main-contents .ph-box18 .credit {
  justify-content: center;
}
.main-contents .ph-box18 .ph-bg {
  width: 37.7rem;
  position: absolute;
  top: -21rem;
  left: 0;
}
.main-contents .ph-box19 {
  width: 50rem;
  margin-left: auto;
  margin-top: 10.4rem;
}
.main-contents .ph-box19 .credit {
  justify-content: flex-end;
  margin-right: 2.2rem;
}
.main-contents .ph-box20 {
  width: 66rem;
  margin: 0 auto;
  margin-top: 10rem;
}
.main-contents .ph-box20 .credit {
  justify-content: center;
}
.main-contents .ph-box21 {
  width: 48rem;
  margin: 0 auto;
  margin-top: 10.4rem;
}
.main-contents .ph-box21 .credit {
  justify-content: center;
}
.main-contents .outro {
  margin-top: 10.4rem;
  padding-top: 9.9rem;
  padding-bottom: 8.8rem;
  background: #a09f9f;
  text-align: center;
}
.main-contents .outro .outro-ttl {
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2.24rem;
  font-weight: 200;
  line-height: 1;
  color: #fff;
  margin-right: 1rem;
  letter-spacing: 0.04em;
}
.main-contents .outro .outro-ttl span {
  font-family: ivyora-display, serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2.24rem;
  line-height: 1;
}
.main-contents .outro .outro-txt {
  margin-top: 3.5rem;
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #fff;
  font-size: 1.92rem;
  font-weight: 200;
  line-height: 2.125;
  letter-spacing: 0.03em;
  margin-right: 1.2rem;
}
.main-contents .outro-all {
  width: 50rem;
  margin: 0 auto;
  margin-top: 10rem;
}
.main-contents .outro-brand {
  width: 9.9523rem;
  margin: 0 auto;
  margin-top: 10rem;
}

.ph-slider {
  margin-bottom: 0 !important;
}
.ph-slider .slick-dots {
  text-align: right;
  bottom: 4.2rem;
  left: -3.5rem;
  z-index: 20;
  width: -moz-fit-content;
  width: fit-content;
  display: flex !important;
  flex-direction: column;
  gap: 1.6rem;
}
.ph-slider .slick-dots li {
  width: 1.6rem;
  height: 1.6rem;
  margin: 0 1rem;
  padding: 0;
  background: #fff;
  border: 1px solid #000;
  opacity: 0.5;
}
.ph-slider .slick-dots li button {
  display: none;
}
.ph-slider .slick-dots .slick-active {
  border: 1px solid #cb2a25;
  background: #cb2a25;
  opacity: 1;
}/*# sourceMappingURL=style.css.map */