@charset "UTF-8";
:root {
  --designwidth: 1368;
  --lp_font: "century-old-style-std", serif;
  --lp_font2: "century-gothic-std", sans-serif;
  --anime_duration: 0.6s;
  --color_base:#6F3E3F;
}
@media screen and (max-width:767px) {
  :root {
    --designwidth: 376;
  }
}

body {
  font-family: var(--lp_font);
  font-weight: 500;
  font-style: normal;
}
body.is-modal-open {
  position: relative;
  height: 100%;
  overflow: hidden;
}

.simple-footer {
  display: none !important;
}

@media screen and (max-width:767px) {
  .lp-u-show-pc {
    display: none !important;
  }
}

@media screen and (min-width:768px) {
  .lp-u-show-sp {
    display: none !important;
  }
}

.lp-u-block {
  container-type: inline-size;
}
.lp-u-block > :first-child {
  margin-top: 0 !important;
}
@media screen and (min-width:768px) {
  .lp-u-block {
    margin: 0 auto;
    width: calc(456 / 1368 * 100%);
    max-width: 456px;
  }
}

@media screen and (min-width:768px) {
  .lp-u-hover {
    transition: ease opacity 0.3s;
  }
  .lp-u-hover:hover {
    opacity: 0.7;
  }
}

.lp-u-mt0 {
  margin-top: 0 !important;
}

.lp-u-center {
  text-align: center !important;
}

.lp-l-wrapper {
  line-height: 2;
  font-weight: 400;
  font-size: calc(11 / 376 * 100cqw);
  color: var(--color_base);
  background-color: #fff;
}
.lp-l-wrapper img,
.lp-l-wrapper video {
  max-width: 100%;
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

.lp-l-contents {
  overflow: hidden;
}

.lp-c-inlinelink {
  text-decoration: underline;
  color: inherit;
}
.lp-c-inlinelink:hover {
  text-decoration: none;
}

.lp-c-paragraph {
  margin-top: 1em;
  font-size: calc(13 / 376 * 100cqw);
  line-height: 1.7;
}

.lp-fixnav {
  position: fixed;
  z-index: 100;
  bottom: calc(24 / var(--designwidth) * 100vw);
  left: calc(24 / var(--designwidth) * 100vw);
}
@media screen and (min-width:768px) {
  .lp-fixnav {
    bottom: 24px;
    left: auto;
    right: 80px;
  }
}

.lp-fixnav__button {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  aspect-ratio: 1/1;
  width: calc(70 / var(--designwidth) * 100vw);
  background-color: #771F21;
  color: #fff;
  text-decoration: none;
  transition: ease transform 0.2s;
}
@media screen and (min-width:768px) {
  .lp-fixnav__button {
    width: 104px;
    font-size: 16px;
  }
  :not(.is-scrolling) .lp-fixnav__button:hover {
    transform: scale(1.15);
  }
}
.is-scrolling .lp-fixnav__button {
  transform: scale(0.22);
  color: #771F21;
}

.lp-mv {
  position: relative;
  container-type: inline-size;
  overflow: hidden;
}

.lp-mv__title {
  position: absolute;
  z-index: 5;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(364 / 376 * 100cqw);
}
@media screen and (min-width:768px) {
  .lp-mv__title {
    width: calc(792 / 1368 * 100cqw);
  }
}
.lp-mv__title svg,
.lp-mv__title img {
  width: 100%;
}
.lp-mv__title g path {
  fill: #fff;
}
.lp-mv__title .st0 {
  fill: none;
  stroke: #fff;
  stroke-miterlimit: 10;
  stroke-width: 5px;
}

.lp-intro__inner {
  padding: calc(34 / 376 * 100cqw) 0 0;
  text-align: center;
}

.lp-intro__title {
  text-align: center;
  font-size: calc(24 / 376 * 100cqw);
  font-family: var(--lp_font2);
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.02em;
}

.lp-intro__text {
  margin-top: calc(20 / 376 * 100cqw);
  font-size: calc(10 / 376 * 100cqw);
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.05em;
}

.lp-intro__image {
  transform: rotate(1deg);
  margin: calc(40 / 376 * 100cqw) auto 0;
  width: calc(242 / 376 * 100cqw);
}

.lp-look__inner {
  padding-top: calc(70 / 376 * 100cqw);
}

.lp-look-figure {
  position: relative;
  display: block;
}

.lp-look-credit {
  display: grid;
  grid-template-columns: 100%;
  gap: calc(12 / 376 * 100cqw);
  margin-top: calc(20 / 376 * 100cqw);
  margin-left: auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding-right: calc(26 / 376 * 100cqw);
}

.lp-look-credit__link {
  display: flex;
  justify-content: flex-end;
  text-decoration: none;
  color: inherit;
  font-style: italic;
  font-size: calc(14 / 376 * 100cqw);
  font-style: italic;
  font-weight: 400;
  line-height: 1;
}
@media screen and (min-width:768px) {
  .lp-look-credit__link {
    transition: ease opacity 0.3s;
  }
  .lp-look-credit__link:hover {
    opacity: 0.7;
  }
}

.lp-look-credit__link__name:after {
  margin: 0 0.5em;
  content: "/";
}

.lp-look-credit__link__price:before {
  content: "¥";
}

.lp-look-credit__link__buy {
  padding-left: calc(20 / 376 * 100cqw);
  text-decoration: underline;
}

#look01 .lp-look-figure.is-item01 {
  transform: rotate(-2deg);
}
#look01 .lp-look-figure.is-item02 {
  margin: calc(7 / 376 * 100cqw) auto 0;
  width: calc(330 / 376 * 100cqw);
}

#look02 .lp-look-figure.is-item02 {
  margin: 0 auto;
  width: calc(240 / 376 * 100cqw);
}
#look02 .lp-look-figure.is-item03 {
  margin-top: calc(40 / 376 * 100cqw);
}
#look02 .lp-look02-fiexdarea__child {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 5;
  aspect-ratio: 456/686;
  width: 100%;
  height: auto;
}

#look03 .lp-look__inner {
  padding-bottom: calc(80 / 376 * 100cqw);
}
#look03 .lp-look-figure.is-item01 {
  margin: 0 auto 0;
  width: calc(330 / 376 * 100cqw);
}
#look03 .lp-look-figure.is-item02 {
  margin: calc(16 / 376 * 100cqw) auto 0;
  width: calc(330 / 376 * 100cqw);
  transform: rotate(-2deg);
}

#look04 {
  background: url(../images/look04_bg01.jpg) no-repeat center top/cover;
  color: #D9D9D9;
  -webkit-clip-path: inset(0% 100% 0% 0%);
          clip-path: inset(0% 100% 0% 0%);
  transition: ease-in-out clip-path 0.8s;
}
@media screen and (min-width:768px) {
  #look04 {
    background: url(../images/look04_bg01_pc.jpg) no-repeat center top/cover;
  }
}
#look04.is-show {
  -webkit-clip-path: inset(0% 0% 0% 0%);
          clip-path: inset(0% 0% 0% 0%);
}
#look04.is-show .lp-look-figure.is-item01 {
  opacity: 1;
  filter: blur(0px);
  transition-delay: 0.6s;
}
#look04 .lp-look__inner {
  padding: calc(45 / 376 * 100cqw) 0 calc(80 / 376 * 100cqw);
}
#look04 .lp-look-figure.is-item01 {
  margin: 0 auto;
  width: calc(330 / 376 * 100cqw);
}
#look04 .lp-look-figure.is-item02 {
  margin-top: calc(50 / 376 * 100cqw);
  transform: rotate(1deg);
}
#look04 .lp-look-figure.is-item03 {
  position: relative;
  margin: calc(70 / 376 * 100cqw) auto 0;
  width: calc(330 / 376 * 100cqw);
}
#look04 .lp-look-figure.is-item03:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(140 / 330 * 100%);
  height: auto;
  aspect-ratio: 140/34;
  background: url(../images/look04_bg02.png) no-repeat center top/contain;
  mix-blend-mode: hard-light;
  -webkit-clip-path: inset(0% 100% 0% 0%);
          clip-path: inset(0% 100% 0% 0%);
  transition: ease-in-out clip-path var(--anime_duration) 0.3s;
}
#look04 .lp-look-figure.is-item03.is-show:before {
  -webkit-clip-path: inset(0% 0% 0% 0%);
          clip-path: inset(0% 0% 0% 0%);
}

#look05 .lp-look-figure.is-item01 {
  margin: 0 auto 0;
  width: calc(320 / 376 * 100cqw);
  transform: rotate(1deg);
}
#look05 .lp-look-figure.is-item02 {
  margin: calc(10 / 376 * 100cqw) auto 0;
}

#look06 .lp-look-figure.is-item01 {
  margin: 0 auto 0;
  width: calc(240 / 376 * 100cqw);
}
#look06 .lp-look-figure.is-item02 {
  margin: calc(15 / 376 * 100cqw) auto 0;
  width: calc(330 / 376 * 100cqw);
}

#look07 {
  margin-bottom: calc(50 / 376 * 100cqw);
}
#look07 .lp-look-figure.is-item01 {
  margin: 0 auto;
  width: calc(330 / 376 * 100cqw);
}
#look07 .lp-look-figure.is-item02 {
  margin: calc(64 / 376 * 100cqw) auto 0;
  width: calc(240 / 376 * 100cqw);
  opacity: 0;
  filter: blur(10px);
  transform: translateX(-10%) rotate(0deg);
  transition: ease-out var(--anime_duration);
  transition-property: opacity, filter, transform;
}
#look07 .lp-look-figure.is-item02.is-show {
  opacity: 1 !important;
  transform: none;
  filter: blur(0px);
}
#look07 .lp-look-figure.is-item03 {
  margin: calc(64 / 376 * 100cqw) auto 0;
  transform: rotate(1deg);
}

.lp-footer {
  position: relative;
  overflow: hidden;
  color: #fff;
}

.lp-footer__detail {
  position: absolute;
  z-index: 2;
  width: 100%;
  top: 0;
  left: 0;
  padding-top: calc(48 / 376 * 100cqw);
  container-type: inline-size;
}
@media screen and (min-width:768px) {
  .lp-footer__detail {
    left: 50%;
    transform: translateX(-50%);
    width: calc(456 / 1368 * 100%);
  }
}

.lp-footer__title {
  margin: 0 auto;
  width: calc(242 / 376 * 100cqw);
}

.lp-footer__subtitle {
  margin-top: calc(20 / 376 * 100cqw);
  font-size: calc(14 / 376 * 100cqw);
  font-family: var(--lp_font2);
  letter-spacing: 0.02em;
  text-align: center;
}

.lp-footer__credit {
  margin-top: calc(20 / 376 * 100cqw);
  font-size: calc(14 / 376 * 100cqw);
  line-height: 1.7143;
  text-align: center;
  list-style: none;
}

.lp-footer__copyright {
  position: absolute;
  z-index: 5;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 0 calc(24 / 376 * 100cqw) calc(24 / 376 * 100cqw);
  font-size: calc(10 / 376 * 100cqw);
  text-align: center;
  letter-spacing: 0.05em;
}
@media screen and (min-width:768px) {
  .lp-footer__copyright {
    padding: 0 calc(24 / var(--designwidth) * 100vw) calc(24 / var(--designwidth) * 100vw);
    font-size: calc(12 / var(--designwidth) * 100vw);
  }
}

.animation-fadein {
  opacity: 0;
  transition: ease-out var(--anime_duration);
  filter: blur(10px);
  transition-property: opacity, filter;
}
.animation-fadein.is-show {
  opacity: 1 !important;
  filter: blur(0px);
}

.animation-fadeup {
  opacity: 0;
  transform: translateY(10px);
  transition: ease-out var(--anime_duration);
  transition-property: opacity, transform;
}
.animation-fadeup.is-show {
  opacity: 1 !important;
  transform: translateY(0px);
}

.animation-fadedown {
  opacity: 0;
  transform: translateY(-10px);
  transition: ease-out var(--anime_duration);
  transition-property: opacity, transform;
}
.animation-fadedown.is-show {
  opacity: 1 !important;
  transform: translateY(0px);
}

.animation-fadeleft {
  opacity: 0;
  transform: translateX(10px);
  transition: ease-out var(--anime_duration);
  transition-property: opacity, transform;
}
.animation-fadeleft.is-show {
  opacity: 1 !important;
  transform: translateY(0px);
}

.animation-clip {
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
  transition: ease-out var(--anime_duration);
  transition-property: -webkit-clip-path;
  transition-property: clip-path;
  transition-property: clip-path, -webkit-clip-path;
}
.animation-clip.is-show {
  -webkit-clip-path: inset(0 0 0 0);
          clip-path: inset(0 0 0 0);
}