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

@media screen and (min-width: 1400px) {
  html {
    font-size: 6.8px;
  }
}
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-pr6n, "Yu Gothic", "游ゴシック", "YuGothic", "游ゴシック体", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", sans-serif;
  font-weight: 400;
  font-style: normal;
  background: #9e2129;
}

.feature a {
  transition: 0.3s;
  display: block;
  text-decoration: none;
}
.feature a:hover {
  opacity: 0.7;
  text-decoration: none;
}

.feature a img {
  transition: 0.3s;
  will-change: opacity;
}
.feature a img:hover {
  opacity: 0.7;
}

.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 {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  transition: opacity 1.5s ease;
}

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

.js-fadeUp {
  visibility: hidden;
  opacity: 0;
  transform: translateY(8rem);
  pointer-events: none;
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.js-fadeUp.is-show {
  visibility: visible;
  opacity: 1;
  transform: none;
  pointer-events: inherit;
}

.feature {
  display: flex;
}

.pc-left {
  position: sticky;
  top: 80px;
  width: 100%;
  height: calc(100vh - 80px);
  order: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}
.pc-left .pc-ttl {
  width: 21.4285714286vw;
  max-width: 300px;
}

.pc-right {
  position: sticky;
  top: 80px;
  width: 100%;
  height: calc(100vh - 80px);
  order: 3;
  display: flex;
  justify-content: center;
  align-items: center;
}
.pc-right .pc-allitem {
  width: 15.5832142857vw;
  max-width: 218.165px;
}

.feature__inner {
  width: 75rem;
  margin: 0 auto;
  position: relative;
  order: 2;
  background: #ece7dc;
}

.movie-area {
  width: 100%;
  position: relative;
}
.movie-area .sound-btn {
  background: url(../img/sound_off.svg);
  background-size: cover;
  background-repeat: no-repeat;
  position: absolute;
  top: 2.8rem;
  right: 3rem;
  height: 3rem;
  width: 16.57rem;
  z-index: 10;
}
.movie-area .sound-btn.on {
  background: url(../img/sound_on.svg);
  background-size: cover;
  background-repeat: no-repeat;
  position: absolute;
  top: 2.9rem;
  right: 5.1rem;
  height: 2.76rem;
  width: 14.5rem;
}

.main-visual {
  position: relative;
  padding-bottom: 15rem;
}
.main-visual .main-ttl-area .main-leadbg {
  width: 75rem;
  margin: 0 auto;
}
.main-visual .main-ttl-area .main-ttl {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-top: 10.7rem;
  row-gap: 1.6rem;
}
.main-visual .main-ttl-area .main-ttl .txt1 {
  width: 27.3rem;
}
.main-visual .main-ttl-area .main-ttl .txt2 {
  width: 65rem;
}
.main-visual .main-lead-ph {
  width: 35rem;
  margin: 0 auto;
  margin-top: 8rem;
}
.main-visual .line-txt {
  display: flex;
  align-items: center;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: rotate(-90deg);
  transform-origin: top left;
  margin-bottom: -8rem;
  margin-left: 2.8rem;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  z-index: 1;
  pointer-events: none;
}
.main-visual .line-txt .line-txt-txt {
  font-family: degular, sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.8rem;
  line-height: 1.7653571429;
  letter-spacing: 0.06em;
  color: #ae252e;
}
.main-visual .line-txt .line-txt-line {
  display: block;
  width: 16rem;
  height: 1px;
  background: #ae252e;
  clip-path: inset(0 0 0 100%);
  transition: clip-path 1.2s ease;
}
.main-visual .line-txt.is-show .line-txt-line {
  clip-path: inset(0);
}

.section {
  position: relative;
}
.section .item-description {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.section .item-description .detail {
  width: 67rem;
  display: flex;
  margin: 0 auto;
  justify-content: space-between;
}
.section .item-description .detail .num {
  font-family: degular, sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.8rem;
  line-height: 1.7653571429;
  letter-spacing: 0.06em;
}
.section .item-description .detail .ex {
  font-family: degular, sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.8rem;
  line-height: 1.7653571429;
  letter-spacing: 0.06em;
}
.section .item-description .overview {
  font-family: "ivypresto-display", serif;
  font-weight: 300;
  font-style: normal;
  font-size: 11rem;
  line-height: 1.0545454545;
  letter-spacing: 0.015em;
  margin-top: 2rem;
}
.section .item-description .description-txt {
  font-family: degular, sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.4rem;
  line-height: 1.25;
  letter-spacing: 0.06em;
  width: 60rem;
  margin-top: 2.8rem;
}
.section .credit {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  margin-top: 3.2rem;
}
.section .credit li {
  font-family: degular, sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.2rem;
  line-height: 1.5;
  letter-spacing: 0.06em;
}
.section .credit li a {
  font-family: degular, sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.2rem;
  line-height: 1.5;
  letter-spacing: 0.06em;
}

.section.item01 .ph01 {
  width: 75rem;
}
.section.item01 .item-description {
  color: #ae252e;
  margin-top: 7rem;
}
.section.item01 .credit {
  width: 53rem;
}
.section.item01 .credit li {
  color: #ae252e;
}
.section.item01 .credit li a {
  color: #ae252e;
}
.section.item01 .ph02 {
  width: 64rem;
  margin: 0 auto;
  margin-top: 8rem;
}
.section.item02 {
  margin-top: 19.5rem;
}
.section.item02 .ph03 {
  width: 75rem;
}
.section.item02 .ph-box {
  position: relative;
  padding-top: 12rem;
}
.section.item02 .ph-box .ph-bg {
  width: 75rem;
  position: absolute;
  top: 0;
  left: 0;
}
.section.item02 .ph-box .ph04 {
  width: 64rem;
  margin: 0 auto;
}
.section.item02 .ph-box .credit {
  width: 64rem;
  justify-content: flex-start;
  margin-top: 3.4rem;
}
.section.item02 .ph-box .credit li {
  color: #2f507f;
}
.section.item02 .ph-box .credit li a {
  color: #2f507f;
}
.section.item03 {
  margin-top: 19.5rem;
}
.section.item03 .ph05 {
  width: 68.6rem;
  margin-left: auto;
}
.section.item03 .ph-box {
  position: relative;
  margin-top: 6rem;
}
.section.item03 .ph-box .ph06 {
  width: 65rem;
}
.section.item03 .ph-box .credit {
  width: 48rem;
  justify-content: flex-start;
  margin-top: 3.4rem;
  margin-left: 4rem;
}
.section.item03 .ph-box .credit li {
  color: #ae252e;
}
.section.item03 .ph-box .credit li a {
  color: #ae252e;
}
.section.item03 .ph-box .line-txt {
  display: flex;
  align-items: center;
  position: absolute;
  top: 0;
  right: 0;
  transform: rotate(90deg);
  transform-origin: top right;
  margin-top: 41rem;
  margin-right: 1.9rem;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  z-index: 1;
  pointer-events: none;
}
.section.item03 .ph-box .line-txt .line-txt-txt {
  font-family: degular, sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.8rem;
  line-height: 1.7653571429;
  letter-spacing: 0.06em;
  color: #ae252e;
}
.section.item03 .ph-box .line-txt .line-txt-line {
  display: block;
  width: 18.74rem;
  height: 1px;
  background: #ae252e;
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1.2s ease;
}
.section.item03 .ph-box .line-txt.is-show .line-txt-line {
  clip-path: inset(0);
}
.section.item03 .sub-ph-box {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: 15rem;
}
.section.item03 .sub-ph-box .sub-ph-catch {
  width: 47.26rem;
}
.section.item03 .sub-ph-box .sub-ph {
  width: 38rem;
  margin-top: -2.8rem;
}
.section.item03 .sub-ph-box .sub-ph-txt {
  font-family: degular, sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.4rem;
  line-height: 1.25;
  letter-spacing: 0.06em;
  text-align: center;
  color: #ae252e;
  margin-top: 2.8rem;
}
.section.item04 {
  margin-top: 19.7rem;
}
.section.item04 .ph-box01 {
  position: relative;
}
.section.item04 .ph-box01 .ph07 {
  width: 75rem;
  position: relative;
}
.section.item04 .ph-box01 .ph07 .ph-txt {
  font-family: degular, sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.8rem;
  line-height: 1;
  letter-spacing: 0.04em;
  color: #2f507f;
  position: absolute;
  top: 9rem;
  left: 0;
  right: 0;
  margin: 0 auto;
  pointer-events: none;
  width: -moz-fit-content;
  width: fit-content;
}
.section.item04 .ph-box01 .ph-deco {
  position: absolute;
  pointer-events: none;
}
.section.item04 .ph-box01 .ph-deco.deco01 {
  width: 17rem;
  top: -4rem;
  right: 0;
}
.section.item04 .ph-box01 .ph-deco.deco02 {
  width: 12rem;
  bottom: -3rem;
  left: 4rem;
}
.section.item04 .item-description {
  color: #2f507f;
  margin-top: 7rem;
}
.section.item04 .ph-box02 {
  position: relative;
}
.section.item04 .ph-box02 .ph08 {
  width: 64rem;
  margin: 0 auto;
  margin-top: 8rem;
}
.section.item04 .ph-box02 .ph-deco {
  width: 17rem;
  position: absolute;
  top: 2.7rem;
  right: 2.7rem;
  pointer-events: none;
}
.section.item04 .ph-box02 .credit {
  width: 59rem;
}
.section.item04 .ph-box02 .credit li {
  color: #2f507f;
}
.section.item04 .ph-box02 .credit li:nth-of-type(2) {
  margin-right: 1rem;
}
.section.item04 .ph-box02 .credit li a {
  color: #2f507f;
}
.section.item05 {
  margin-top: 19.7rem;
}
.section.item05 .ph-box {
  position: relative;
  width: 40rem;
  margin: 0 auto;
}
.section.item05 .ph-box .ph-deco {
  width: 17rem;
  position: absolute;
  top: -5.5rem;
  left: -4.5rem;
  pointer-events: none;
}
.section.item05 .ph-box .credit li {
  color: #2f507f;
}
.section.item05 .ph-box .credit li a {
  color: #2f507f;
}
.section.item06 {
  margin-top: 19.5rem;
}
.section.item06 .ph10 {
  width: 71.6rem;
}
.section.item06 .ph-box {
  position: relative;
  margin-top: 6rem;
}
.section.item06 .ph-box .ph11 {
  width: 62rem;
  margin-left: auto;
}
.section.item06 .ph-box .credit {
  width: 48rem;
  justify-content: flex-end;
  margin-top: 3.4rem;
  margin-right: 4rem;
}
.section.item06 .ph-box .credit li {
  color: #ae252e;
}
.section.item06 .ph-box .credit li a {
  color: #ae252e;
}
.section.item06 .ph-box .line-txt {
  display: flex;
  align-items: center;
  position: absolute;
  top: 0;
  right: 0;
  transform: rotate(-90deg);
  transform-origin: top left;
  margin-top: 40.8rem;
  margin-right: 33.1rem;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  z-index: 1;
  pointer-events: none;
}
.section.item06 .ph-box .line-txt .line-txt-txt {
  font-family: degular, sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.8rem;
  line-height: 1.7653571429;
  letter-spacing: 0.06em;
  color: #ae252e;
}
.section.item06 .ph-box .line-txt .line-txt-line {
  display: block;
  width: 18.74rem;
  height: 1px;
  background: #ae252e;
  clip-path: inset(0 0 0 100%);
  transition: clip-path 1.2s ease;
}
.section.item06 .ph-box .line-txt.is-show .line-txt-line {
  clip-path: inset(0);
}
.section.item06 .sub-ph-box {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: 15rem;
}
.section.item06 .sub-ph-box .sub-ph-catch {
  width: 47.26rem;
}
.section.item06 .sub-ph-box .sub-ph {
  width: 38rem;
  margin-top: -2.8rem;
}
.section.item06 .sub-ph-box .sub-ph-txt {
  font-family: degular, sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.4rem;
  line-height: 1.25;
  letter-spacing: 0.06em;
  text-align: center;
  color: #ae252e;
  margin-top: 2.8rem;
}
.section.item07 {
  margin-top: 19.5rem;
}
.section.item07 .ph-txt {
  width: 25rem;
  margin: 0 auto;
}
.section.item07 .ph-box {
  position: relative;
  width: 69rem;
  margin: 0 auto;
  margin-top: 6rem;
  display: flex;
  justify-content: space-between;
}
.section.item07 .ph-box.is-show .ph {
  visibility: visible;
  opacity: 1;
  transform: none;
  pointer-events: inherit;
}
.section.item07 .ph-box .ph {
  width: 33.8rem;
  visibility: hidden;
  opacity: 0;
  transform: translateY(8rem);
  pointer-events: none;
  transition: opacity 0.8s ease, transform 0.8s ease;
}
.section.item07 .ph-box .ph.ph13 {
  transition-delay: 0.5s;
}
.section.item07 .credit {
  width: 45rem;
}
.section.item07 .credit li {
  color: #2f507f;
}
.section.item07 .credit li a {
  color: #2f507f;
}
.section.outro {
  margin-top: 14.8rem;
}
.section.outro .outro-bear {
  width: 38rem;
  margin: 0 auto;
}
.section.outro .allitem {
  width: 61.48rem;
  margin-top: 0.4rem;
  margin-left: 5rem;
}
.section.outro .outro-txt {
  font-family: degular, sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 3rem;
  line-height: 1.5;
  letter-spacing: 0.06em;
  color: #ae252e;
  text-align: center;
  margin-top: 2.4rem;
  will-change: opacity;
}
.section.outro .outro-bg {
  width: 75rem;
  margin-top: 11.6rem;
}/*# sourceMappingURL=style.css.map */