@charset "UTF-8";
/*--------------------------------------*
 * foundation
 *--------------------------------------*/
/*--------------------------------------*
 * project
 *--------------------------------------*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap");
@keyframes kirakiraTwinkle {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) rotate(var(--kirakira-rotation, 45deg)) scale(0.2);
  }
  35% {
    opacity: 1;
    transform: translate(-50%, -50%) rotate(var(--kirakira-rotation, 45deg)) scale(var(--kirakira-scale-max, 1));
  }
  60% {
    opacity: 0.8;
    transform: translate(-50%, -50%) rotate(var(--kirakira-rotation, 45deg)) scale(calc(var(--kirakira-scale-max, 1) * 0.7));
  }
  100% {
    opacity: 0;
    transform: translate(-50%, -50%) rotate(var(--kirakira-rotation, 45deg)) scale(0.2);
  }
}
body {
  overflow: clip !important;
}
body:not(.is-active) {
  height: 100vh;
  overflow: hidden !important;
}
@media (min-width: 640px) {
  body:not(.is-active) {
    height: calc(100vh + 99px + 45px);
  }
}

.contents-main {
  background-color: #000;
}

@media (min-width: 640px) {
  .is-sp {
    display: none;
  }
}

@media (max-width: 639.98px) {
  .is-pc {
    display: none;
  }
}

.inner {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  position: relative;
}
@media (min-width: 640px) {
  .inner {
    max-width: min(1080px, 75vw);
  }
}

a.button {
  width: 33.8461538462vw;
  height: 7.4794871795vw;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 3.0769230769vw;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  color: #fff;
  font-weight: 500;
  line-height: 1;
  background-color: #000;
  border-radius: 3.7435897436vw;
}
@media (min-width: 640px) {
  a.button {
    width: min(152px, 10.5555555556vw);
    height: min(35px, 2.4305555556vw);
    font-size: min(15px, 1.0416666667vw);
    border-radius: min(17.5px, 1.2152777778vw);
    transition: all 0.3s ease-out;
  }
  a.button:hover {
    text-decoration: none;
    background-color: #921014;
  }
}

.section__title {
  font-size: 9.2307692308vw;
  text-align: center;
  color: #921014;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0em;
}
@media (min-width: 640px) {
  .section__title {
    font-size: min(60px, 4.1666666667vw);
  }
}

.contents {
  width: 100%;
  position: relative;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
  color: #fff;
  background-color: #000;
}

.opening {
  width: 100%;
  height: calc(100vh - 24.1025641026vw);
  position: absolute;
  overflow: hidden;
  z-index: 20;
  transition: all 0.25s ease-in-out;
}
@media (min-width: 640px) {
  .opening {
    height: calc(100vh - 83px);
  }
}
.is-active .opening {
  opacity: 0;
  filter: blur(20px);
  scale: 1.5;
  pointer-events: none;
}
.opening__contents {
  width: 100%;
  height: 100%;
  position: relative;
  background-repeat: no-repeat;
  background-position: center 10.2564102564vw;
  background-size: 100%;
  background-image: url(/sp/tannou/img/opening-bg-sp.png);
}
@media (min-width: 640px) {
  .opening__contents {
    background-position: center;
    background-size: min(1326px, 92.0833333333vw);
    background-image: url(/sp/tannou/img/opening-bg.png);
  }
}
.opening__contents {
  opacity: 0;
  filter: blur(10px);
  transform: translateX(-50px) scale(1.15);
  transition: all 0.25s ease-in 0.5s;
}
.is-opening .opening__contents {
  opacity: 1;
  filter: blur(0);
  transform: translateX(0px) scale(1);
}
.opening__inner {
  margin: auto;
  width: 69.2307692308vw;
  height: max-content;
  max-height: 100%;
  position: absolute;
  top: 21.7948717949vw;
  left: 0;
  right: 0;
  display: flex;
  flex-direction: row-reverse;
}
@media (min-width: 640px) {
  .opening__inner {
    width: min(614px, 42.6388888889vw);
    padding-top: min(50px, 3.4722222222vw);
    top: 0;
    bottom: 0;
  }
}
.opening__text {
  display: block;
  writing-mode: vertical-rl;
  font-feature-settings: "vert" on;
  font-weight: 700;
  color: #E7BD85;
  font-size: 11.5820512821vw;
  line-height: 1.3;
  white-space: nowrap;
}
@media (min-width: 640px) {
  .opening__text {
    font-size: min(80.29px, 5.5756944444vw);
  }
}
.opening__text {
  opacity: 0;
  filter: blur(10px);
  transition: all 0.5s ease-in;
  scale: 1.1;
}
.is-opening .opening__text {
  opacity: 1;
  filter: blur(0);
  transform: translateX(0px);
  scale: 1;
}
.opening__text.is-text1 {
  transition-delay: 1s;
}
@media (min-width: 640px) {
  .opening__text.is-text1 {
    transform: translateX(40px);
  }
}
.opening__text.is-text2 {
  transition-delay: 1.25s;
}
.opening__skip {
  position: fixed;
  z-index: 30;
  right: 5.8974358974vw;
  bottom: 5.8974358974vw;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: 5.1282051282vw;
  text-underline-offset: 1.5384615385vw;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  text-decoration: underline;
  pointer-events: auto;
  background-color: transparent;
  border: none;
}
@media (min-width: 640px) {
  .opening__skip {
    right: min(100px, 6.9444444444vw);
    bottom: min(100px, 6.9444444444vw);
    font-size: min(30px, 2.0833333333vw);
    text-underline-offset: min(10px, 0.6944444444vw);
  }
}
.opening canvas {
  mix-blend-mode: screen;
}

.kirakira-layer {
  pointer-events: none;
  position: absolute;
  inset: 0;
  overflow: visible;
  z-index: 2;
}
.kirakira-layer__particle {
  position: absolute;
  width: 1.2820512821vw;
  height: 1.2820512821vw;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.2) 60%, rgba(255, 255, 255, 0) 90%);
  opacity: 0;
  transform: translate(-50%, -50%) rotate(var(--kirakira-rotation, 45deg)) scale(0.4);
  animation-name: kirakiraTwinkle;
  animation-iteration-count: infinite;
  animation-timing-function: ease-in-out;
  filter: drop-shadow(0 0 4px rgba(255, 255, 255, 0.9));
}
@media (min-width: 640px) {
  .kirakira-layer__particle {
    width: min(5px, 0.3472222222vw);
    height: min(5px, 0.3472222222vw);
  }
}
.kirakira-layer__particle[data-shape=star] {
  width: 1.2820512821vw;
  height: 1.2820512821vw;
  border-radius: 15%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.95) 0%, rgba(255, 255, 255, 0.3) 55%, rgba(255, 255, 255, 0) 80%);
  filter: drop-shadow(0 0 6px rgba(255, 255, 255, 0.9));
}
@media (min-width: 640px) {
  .kirakira-layer__particle[data-shape=star] {
    width: min(10px, 0.6944444444vw);
    height: min(10px, 0.6944444444vw);
  }
}
.kirakira-layer__particle[data-shape=star]::before, .kirakira-layer__particle[data-shape=star]::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2px;
  height: 140%;
  background: linear-gradient(180deg, transparent 0%, rgba(255, 255, 255, 0.95) 45%, rgba(255, 255, 255, 0.95) 55%, transparent 100%);
  transform: translate(-50%, -50%);
  border-radius: 999px;
}
.kirakira-layer__particle[data-shape=star]::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.sizzle {
  width: 100%;
  padding-bottom: 51.2820512821vw;
  position: relative;
  opacity: 0;
  background: linear-gradient(211deg, rgba(146, 16, 20, 0) 43.96%, #921014 99.73%);
  transition: opacity 0.3s ease-out 0.8s;
}
@media (min-width: 640px) {
  .sizzle {
    padding-bottom: min(360px, 25vw);
    background: linear-gradient(196deg, rgba(146, 16, 20, 0) 55.48%, #921014 99.73%);
  }
}
.is-active .sizzle {
  opacity: 1;
}
.sizzle__inner {
  margin: auto;
  width: 86.4282051282vw;
  max-width: 100%;
  height: max-content;
  position: sticky;
  z-index: 1;
  top: 34.358974359vw;
}
@media (max-width: 639.98px) {
  .sizzle__inner {
    padding-bottom: 71.7948717949vw;
  }
}
@media (min-width: 640px) {
  .sizzle__inner {
    width: min(619.46px, 43.0180555556vw);
    height: min(580px, 40.2777777778vw);
    top: calc(50vh - min(327px, 22.7083333333vw));
    bottom: min(300px, 20.8333333333vw);
  }
}
.sizzle__inner > * {
  position: absolute;
}
.sizzle__tare {
  z-index: 1;
  margin-left: auto;
  margin-right: auto;
  width: 86.4282051282vw;
  left: 0;
  right: 0;
  top: 0;
}
@media (min-width: 640px) {
  .sizzle__tare {
    width: min(580px, 40.2777777778vw);
  }
}
.sizzle__tare {
  opacity: 0;
  scale: 0.3;
  transition: all 0.6s cubic-bezier(0.64, -0.45, 0.68, 1.43) 1.2s;
}
body:not(.is-opening) .sizzle__tare {
  opacity: 1;
  scale: 1;
}
.sizzle__meat {
  width: 47.1230769231vw;
  top: 6.4076923077vw;
  left: 18.2897435897vw;
  z-index: 3;
}
@media (min-width: 640px) {
  .sizzle__meat {
    width: min(317px, 22.0138888889vw);
    top: min(43px, 2.9861111111vw);
    left: min(143px, 9.9305555556vw);
  }
}
.sizzle__meat {
  opacity: 0;
  scale: 2;
  rotate: 10deg;
  transition: all 0.5s cubic-bezier(0.64, -0.45, 0.68, 1.43) 1.2s;
}
body:not(.is-opening) .sizzle__meat {
  opacity: 1;
  scale: 1;
  rotate: 0deg;
}
.sizzle__yakiniku {
  width: 25.4769230769vw;
  top: 14.6538461538vw;
  right: 6.5384615385vw;
  z-index: 4;
}
@media (min-width: 640px) {
  .sizzle__yakiniku {
    width: min(170.98px, 11.8736111111vw);
    right: min(62.23px, 4.3215277778vw);
    top: min(89.35px, 6.2048611111vw);
  }
}
html:not(.is-up) .is-start .sizzle__yakiniku {
  transition-delay: 1s;
}
body:not(.is-start) .sizzle__yakiniku, .is-up .scroll02 .sizzle__yakiniku {
  transition-delay: 0s;
}
.sizzle__tannou {
  width: 25.1282051282vw;
  left: 6.3205128205vw;
  top: 14.6358974359vw;
  z-index: 2;
}
@media (min-width: 640px) {
  .sizzle__tannou {
    width: min(168.63px, 11.7104166667vw);
    left: min(63.07px, 4.3798611111vw);
    top: min(98.21px, 6.8201388889vw);
  }
}
html:not(.is-up) .is-start .sizzle__tannou {
  transition-delay: 1s;
}
body:not(.is-start) .sizzle__tannou, .is-up .scroll02 .sizzle__tannou {
  transition-delay: 0.1s !important;
}
.sizzle__text {
  filter: drop-shadow(0 0 3.3333333333vw #480003);
}
@media (min-width: 640px) {
  .sizzle__text {
    filter: drop-shadow(0 0 min(13px, 0.9027777778vw) #480003);
  }
}
.sizzle__text {
  opacity: 0;
  scale: 1.2;
  transition-duration: 0.3s;
}
.is-active .sizzle__text {
  opacity: 1;
  scale: 1;
  transition-timing-function: cubic-bezier(0.64, -0.45, 0.68, 1.43);
}
body:not(.is-start) .sizzle__text {
  transform: translate(0, -100px);
  opacity: 0;
}
.sizzle__smoke {
  margin: auto;
  width: 102.5641025641vw;
  height: 153.8461538462vw;
  translate: 7.6923076923vw;
  display: block;
  position: absolute;
  overflow: hidden;
  z-index: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: 100%;
  mix-blend-mode: screen;
}
@media (min-width: 640px) {
  .sizzle__smoke {
    width: min(448px, 31.1111111111vw);
    height: min(1000px, 69.4444444444vw);
    translate: max(-165px, -11.4583333333vw);
  }
}
.sizzle__smoke-canvas {
  position: absolute;
  inset: 0;
  opacity: 0.6;
  width: 100%;
  height: 100%;
  mix-blend-mode: screen;
}

.mv {
  width: 100%;
  position: relative;
  display: flex;
  align-items: bottom;
  opacity: 0;
  transition: opacity 0.3s ease-out 2s;
}
.is-active .mv {
  opacity: 1;
}
.mv .inner {
  height: max-content;
}
@media (min-width: 640px) {
  .mv .inner {
    margin-top: min(200px, 13.8888888889vw);
    padding-bottom: min(40px, 2.7777777778vw);
  }
}
.mv__list {
  margin-top: -25.641025641vw;
  margin-left: auto;
  margin-right: auto;
  width: max-content;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2.5641025641vw;
}
@media (min-width: 640px) {
  .mv__list {
    margin-top: auto;
    gap: min(28px, 1.9444444444vw);
  }
}
.mv__item {
  width: 20.5128205128vw;
  position: relative;
}
@media (min-width: 640px) {
  .mv__item {
    width: min(180px, 12.5vw);
  }
}
.mv__item a {
  color: #fff;
  transition: color 0.3s ease-out;
}
@media (min-width: 640px) {
  .mv__item a:hover {
    text-decoration: none;
    color: rgba(255, 255, 255, 0.5);
  }
}
.mv__img {
  margin-left: auto;
  margin-right: auto;
  width: 15.1282051282vw;
  filter: drop-shadow(0 0 1.8974358974vw white);
}
@media (min-width: 640px) {
  .mv__img {
    width: min(100px, 6.9444444444vw);
    filter: drop-shadow(0 0 min(5.41px, 0.3756944444vw) white);
  }
}
.mv__text {
  margin-top: 5.1282051282vw;
  width: 20.5128205128vw;
  height: 12.8205128205vw;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3.5897435897vw;
  text-align: center;
  font-weight: 700;
  line-height: 1.2;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  background-image: url(/sp/tannou/img/name-bg-sp.svg);
}
@media (min-width: 640px) {
  .mv__text {
    margin-top: min(36px, 2.5vw);
    width: min(180px, 12.5vw);
    height: min(60px, 4.1666666667vw);
    font-size: min(20px, 1.3888888889vw);
    line-height: 1;
    background-image: url(/sp/tannou/img/name-bg.svg);
  }
}
.mv .inner {
  z-index: 1;
}

.catch {
  width: 100%;
  height: 190.5128205128vw;
  opacity: 0;
  transition: opacity 0.3s ease-out 2s;
}
.is-active .catch {
  opacity: 1;
}
@media (min-width: 640px) {
  .catch {
    height: min(840px, 58.3333333333vw);
  }
}
@media (max-width: 639.98px) {
  .catch .inner {
    z-index: 2;
  }
}
.catch__title {
  height: max-content;
  position: absolute;
  top: 24.1025641026vw;
  right: 9.0358974359vw;
  writing-mode: vertical-rl;
  font-feature-settings: "vert" on;
  font-size: 10.2564102564vw;
  font-weight: 700;
  line-height: 1.25;
  color: #E7BD85;
}
@media (min-width: 640px) {
  .catch__title {
    font-size: min(60px, 4.1666666667vw);
    top: min(144px, 10vw);
    right: max(-7px, -0.4861111111vw);
  }
}
.catch__text {
  width: max-content;
  height: max-content;
  position: absolute;
  writing-mode: vertical-rl;
  font-feature-settings: "vert" on;
  font-weight: 700;
  font-size: 4.1025641026vw;
  line-height: 1.8125;
  opacity: 0;
  filter: blur(10px);
  transition: all 0.3s ease-out;
}
@media (min-width: 640px) {
  .catch__text {
    font-size: min(24px, 1.6666666667vw);
    line-height: min(44px, 3.0555555556vw);
  }
}
.catch__text.is-in {
  opacity: 1;
  filter: blur(0);
}
.catch__text.is-text1 {
  top: 43.3333333333vw;
}
@media (max-width: 639.98px) {
  .catch__text.is-text1 {
    left: 10.7692307692vw;
  }
}
@media (min-width: 640px) {
  .catch__text.is-text1 {
    top: min(227px, 15.7638888889vw);
    right: min(174px, 12.0833333333vw);
  }
}
.catch__text.is-text2 {
  top: 129.2307692308vw;
  z-index: 2;
}
@media (max-width: 639.98px) {
  .catch__text.is-text2 {
    right: 10.7897435897vw;
  }
}
@media (min-width: 640px) {
  .catch__text.is-text2 {
    top: min(513px, 35.625vw);
    left: min(177px, 12.2916666667vw);
  }
}
.catch__text.is-text3 {
  top: 167.1794871795vw;
  left: 22.8205128205vw;
  font-size: 5.1282051282vw;
  z-index: 2;
}
@media (min-width: 640px) {
  .catch__text.is-text3 {
    top: min(718px, 49.8611111111vw);
    left: min(102px, 7.0833333333vw);
    font-size: min(28px, 1.9444444444vw);
  }
}
.catch__text.is-text4 {
  font-size: 8.9743589744vw;
  top: 167.1794871795vw;
  left: 10vw;
  z-index: 1;
}
@media (min-width: 640px) {
  .catch__text.is-text4 {
    font-size: min(48px, 3.3333333333vw);
    top: min(721px, 50.0694444444vw);
    left: min(41px, 2.8472222222vw);
  }
}
.catch__text.is-text4::before {
  content: "";
  width: 73.5205128205vw;
  height: 42.0307692308vw;
  display: block;
  position: absolute;
  left: -30.7538461538vw;
  top: 9.1102564103vw;
  z-index: -1;
  mask-repeat: no-repeat;
  mask-image: url(/sp/tannou/img/catch-paint.svg);
  mask-position: 73.5205128205vw -28.0205128205vw;
  mask-size: 73.5205128205vw;
  background-image: url(/sp/tannou/img/catch-paint.svg);
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
  rotate: 3deg;
  transition: all 0.3s ease-out 0.5s;
}
@media (min-width: 640px) {
  .catch__text.is-text4::before {
    width: min(393.49px, 27.3256944444vw);
    height: min(224.95px, 15.6215277778vw);
    left: max(-156.07px, -10.8381944444vw);
    top: min(85.04px, 5.9055555556vw);
    mask-position: min(393.49px, 27.3256944444vw) max(-149.9666666667px, -10.4143518519vw);
    mask-size: min(393.49px, 27.3256944444vw);
    rotate: 0deg;
  }
}
.catch__text.is-text4.is-in::before {
  mask-position: 0 0;
}

@media (min-width: 640px) {
  .about {
    background-repeat: no-repeat;
    background-position: calc(50% - min(142px, 9.8611111111vw)) top;
    background-size: min(1815px, 126.0416666667vw);
    background-image: url(/sp/tannou/img/about-bg.jpg);
  }
}
.about .inner {
  padding-top: 18.041025641vw;
  padding-bottom: 133.3333333333vw;
}
@media (max-width: 639.98px) {
  .about .inner {
    background-repeat: no-repeat;
    background-position: left 50% bottom 25.641025641vw;
    background-size: 100%;
    background-image: url(/sp/tannou/img/about-bg-sp.jpg);
  }
}
@media (min-width: 640px) {
  .about .inner {
    max-width: 1110px;
    min-height: min(800px, 55.5555555556vw);
    padding-top: min(148px, 10.2777777778vw);
    padding-bottom: min(100px, 6.9444444444vw);
  }
}
@media (max-width: 639.98px) {
  .about__description {
    margin-left: auto;
    margin-right: auto;
    width: max-content;
    max-width: 100%;
    height: max-content;
    white-space: nowrap;
    display: flex;
    flex-direction: row-reverse;
    gap: 2.0512820513vw;
    translate: -0.7692307692vw;
  }
}
.about__title {
  writing-mode: vertical-rl;
  font-feature-settings: "vert" on;
  font-weight: 700;
  color: #E7BD85;
  font-size: 4.6153846154vw;
  line-height: 1.5;
}
@media (min-width: 640px) {
  .about__title {
    font-size: min(26px, 1.8055555556vw);
    position: absolute;
    right: 0;
    top: min(150px, 10.4166666667vw);
    line-height: min(68px, 4.7222222222vw);
  }
}
.about__title strong {
  margin-top: -0.64em;
  font-size: 12.3076923077vw;
}
@media (min-width: 640px) {
  .about__title strong {
    font-size: min(72px, 5vw);
  }
}
.about__title span {
  font-weight: 700;
  margin-top: -0.7em;
  font-size: 7.6923076923vw;
}
@media (min-width: 640px) {
  .about__title span {
    font-size: min(48px, 3.3333333333vw);
  }
}
.about__text {
  writing-mode: vertical-rl;
  font-feature-settings: "vert" on;
  font-weight: 700;
  color: #fff;
  line-height: 2;
}
@media (min-width: 640px) {
  .about__text {
    font-size: min(20px, 1.3888888889vw);
    position: absolute;
    top: min(150px, 10.4166666667vw);
    right: min(160px, 11.1111111111vw);
    line-height: 2.1;
  }
}
.about__box {
  margin-left: auto;
  margin-right: auto;
  width: max-content;
  z-index: 1;
}
@media (max-width: 639.98px) {
  .about__box {
    margin-top: 10.2564102564vw;
    display: flex;
    flex-direction: column;
    gap: 5.1564102564vw;
    align-items: center;
    justify-content: center;
    position: relative;
  }
}
@media (min-width: 640px) {
  .about__box {
    margin-top: auto;
    min-width: min(150px, 10.4166666667vw);
    height: min(510px, 35.4166666667vw);
    position: absolute;
    display: block;
    top: min(154px, 10.6944444444vw);
    left: 0;
    right: 0;
    bottom: auto;
  }
}
.about__box-title {
  height: max-content;
  position: relative;
  font-size: 6.4769230769vw;
  writing-mode: vertical-rl;
  font-feature-settings: "vert" on;
  font-weight: 700;
  letter-spacing: -0.05em;
  white-space: nowrap;
}
@media (max-width: 639.98px) {
  .about__box-title {
    line-height: 1.5;
  }
}
@media (min-width: 640px) {
  .about__box-title {
    font-size: min(30px, 2.0833333333vw);
  }
}
.about__box-title.is-title1::before {
  width: 88.8282051282vw;
  height: 50.0333333333vw;
  top: 3.8871794872vw;
  left: -31.9256410256vw;
  mask-image: url(/sp/tannou/img/about-paint1.svg);
  mask-size: 88.8282051282vw;
  background-image: url(/sp/tannou/img/about-paint1.svg);
  background-size: 100% 100%;
  background-position: -88.8282051282vw 25.0166666667vw;
}
@media (min-width: 640px) {
  .about__box-title.is-title1::before {
    width: min(392.9px, 27.2847222222vw);
    height: min(221.31px, 15.36875vw);
    top: min(2px, 0.1388888889vw);
    left: max(-137px, -9.5138888889vw);
    mask-size: min(392.9px, 27.2847222222vw);
    background-position: max(-392.9px, -27.2847222222vw) min(110.655px, 7.684375vw);
  }
}
.about__box-title.is-title1 strong::before {
  content: "・・・";
}
@media (min-width: 640px) {
  .about__box-title.is-title2 {
    margin-top: min(132px, 9.1666666667vw);
  }
}
.about__box-title.is-title2::before {
  width: 78.2923076923vw;
  height: 55.3820512821vw;
  top: -9.1923076923vw;
  left: -27.7743589744vw;
  mask-image: url(/sp/tannou/img/about-paint2.svg);
  background-image: url(/sp/tannou/img/about-paint2.svg);
  background-size: 100% 100%;
  transition-delay: 0.4s;
  mask-size: 78.2923076923vw;
  background-position: -78.2923076923vw -27.691025641vw;
}
@media (min-width: 640px) {
  .about__box-title.is-title2::before {
    width: min(346.3px, 24.0486111111vw);
    height: min(244.96px, 17.0111111111vw);
    top: max(-45px, -3.125vw);
    left: max(-126px, -8.75vw);
    mask-size: min(346.3px, 24.0486111111vw);
    background-position: max(-346.3px, -24.0486111111vw) max(-122.48px, -8.5055555556vw);
  }
}
.is-in .about__box-title.is-title2::before {
  background-position: 0 0;
}
.about__box-title.is-title2 strong::before {
  content: "・・";
}
.about__box-title::before {
  content: "";
  width: 0%;
  margin: auto;
  display: block;
  position: absolute;
  z-index: -1;
  mask-repeat: no-repeat;
  mask-position: left;
  background-repeat: no-repeat;
  background-position: -100% bottom;
  transition-duration: 0.4s;
  transition-timing-function: ease-in-out;
}
.is-in .about__box-title::before {
  background-position: 0 0;
}
.about__box-title strong {
  margin-right: 5.1282051282vw;
  display: block;
  font-size: 11.2282051282vw;
  line-height: 1.1;
  letter-spacing: 0.06em;
  position: relative;
}
@media (min-width: 640px) {
  .about__box-title strong {
    margin-right: min(38px, 2.6388888889vw);
    font-size: min(52px, 3.6111111111vw);
  }
}
.about__box-title strong::before {
  display: block;
  position: absolute;
  top: 0;
  right: -0.75em;
  font-size: 0.7em;
  text-indent: 0.1em;
  letter-spacing: 0.65em;
}
@media (min-width: 640px) {
  .about__box-title strong::before {
    right: max(-37px, -2.5694444444vw);
  }
}
.about__icon {
  margin: auto;
  width: 10.5641025641vw;
  height: 10.5743589744vw;
  display: block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url(/sp/tannou/img/about-icon.svg);
  opacity: 0;
  rotate: -90deg;
  scale: 1.2;
  transition: all 0.4s ease-in-out 0.7s;
}
@media (min-width: 640px) {
  .about__icon {
    width: min(60.16px, 4.1777777778vw);
    height: min(60.2px, 4.1805555556vw);
    position: absolute;
    inset: 0;
  }
}
.is-in .about__icon {
  opacity: 1;
  rotate: 0deg;
  scale: 1;
}
.about__list {
  width: 100%;
}
@media (max-width: 639.98px) {
  .about__list {
    display: none;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
    grid-template-rows: 1fr auto;
  }
}
@media (min-width: 640px) {
  .about__list {
    display: flex;
    align-items: center;
  }
}
@media (max-width: 639.98px) {
  ul .about__item:nth-child(1) {
    grid-column: 1/4;
    grid-row: 1;
  }
  ul .about__item:nth-child(2) {
    grid-column: 1/3;
    grid-row: 2;
  }
  ul .about__item:nth-child(3) {
    grid-column: 4/7;
    grid-row: 1;
  }
  ul .about__item:nth-child(4) {
    grid-column: 3/5;
    grid-row: 2;
  }
  ul .about__item:nth-child(5) {
    grid-column: 5/7;
    grid-row: 2;
  }
}

.lineup {
  width: 100%;
  padding-top: 12.3076923077vw;
  position: relative;
  background-color: #F2EDE2;
}
@media (min-width: 640px) {
  .lineup {
    padding-top: min(100px, 6.9444444444vw);
  }
}
.lineup__nav {
  margin-left: auto;
  margin-right: auto;
  height: 100%;
  position: absolute;
  top: 0;
  left: 5.2564102564vw;
  z-index: 1;
  pointer-events: none;
}
@media (min-width: 640px) {
  .lineup__nav {
    width: min(1080px, 75vw);
    height: 100%;
    left: 0;
    right: 0;
  }
}
.lineup__nav-list {
  width: max-content;
  height: max-content;
  padding-top: 20vh;
  padding-bottom: 20vh;
  position: sticky;
  top: 20%;
  display: flex;
  gap: 7.1794871795vw;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  pointer-events: auto;
}
@media (min-width: 640px) {
  .lineup__nav-list {
    padding-top: min(50px, 3.4722222222vw);
    height: min(514px, 35.6944444444vw);
    padding-bottom: min(0px, 0vw);
    gap: min(20px, 1.3888888889vw);
    top: min(50px, 3.4722222222vw);
  }
}
:where(.lineup__nav-list) .lineup__nav-item:nth-child(-n+3) {
  width: 11.3333333333vw;
}
@media (min-width: 640px) {
  :where(.lineup__nav-list) .lineup__nav-item:nth-child(-n+3) {
    width: min(47.32px, 3.2861111111vw);
  }
}
:where(.lineup__nav-list) .lineup__nav-item:nth-child(n+3) {
  width: 5.4615384615vw;
}
@media (min-width: 640px) {
  :where(.lineup__nav-list) .lineup__nav-item:nth-child(n+3) {
    width: min(21.3px, 1.4791666667vw);
  }
}
.lineup__nav-item {
  position: relative;
}
.lineup__nav-item::before {
  content: "";
  width: 24.5vw;
  height: 14.0076923077vw;
  display: block;
  position: absolute;
  top: 2.0974358974vw;
  left: -10.2948717949vw;
  z-index: -1;
  mask-repeat: no-repeat;
  mask-size: contain;
  mask-position: center;
  mask-image: url(/sp/tannou/img/paint.svg);
  transition: opacity 0.4s ease-in-out;
  opacity: 0;
}
@media (min-width: 640px) {
  .lineup__nav-item::before {
    width: min(115.87px, 8.0465277778vw);
    height: min(66.34px, 4.6069444444vw);
    top: 0;
    left: max(-35px, -2.4305555556vw);
  }
}
.lineup__nav-item.is-current::before {
  opacity: 1;
}
.lineup__nav-item.is-amauma::before {
  background-color: #DFCCA3;
}
.lineup__nav-item.is-aburi::before {
  background-color: #BFBFBF;
}
.lineup__nav-item.is-baisen::before {
  background-color: #99ADDA;
}
.lineup__nav-item.is-koumi::before {
  background-color: #E39FAE;
}
.lineup__nav-item button {
  padding: 0;
  border: none;
  background: none;
}
.lineup__contents {
  width: 100%;
  position: relative;
}
.lineup__section {
  width: 100%;
  position: sticky;
  top: 12.8205128205vw;
  background-color: #F2EDE2;
}
@media (max-width: 639.98px) {
  .lineup__section {
    padding: 21.1538461538vw 5.1282051282vw 15.3846153846vw 23.0769230769vw;
  }
}
@media (min-width: 640px) {
  .lineup__section {
    top: min(82.5px, 5.7291666667vw);
  }
}
.lineup__section::after {
  content: "";
  margin: auto;
  width: 100%;
  height: 59.3641025641vw;
  display: block;
  position: absolute;
  top: 8.5333333333vw;
  right: 0;
  left: 0;
  z-index: 0;
  mask-repeat: no-repeat;
  mask-size: 106.2564102564vw;
  mask-position: 19.7871794872vw top;
  mask-image: url(/sp/tannou/img/paint.svg);
  background-color: #000;
}
@media (min-width: 640px) {
  .lineup__section::after {
    width: min(587.81px, 40.8201388889vw);
    height: min(336.04px, 23.3361111111vw);
    top: 0;
    bottom: 0;
    mask-size: contain;
    mask-position: center;
  }
}
.lineup__section::before {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  inset: 0;
  z-index: 0;
}
@media (min-width: 640px) {
  .lineup__section.is-amauma {
    margin-top: min(41px, 2.8472222222vw);
  }
}
.lineup__section.is-amauma::before {
  background: linear-gradient(192deg, rgba(223, 204, 163, 0) 32.49%, #DFCCA3 82.44%);
}
@media (min-width: 640px) {
  .lineup__section.is-amauma::before {
    background: linear-gradient(200deg, rgba(223, 204, 163, 0) 50.31%, #DFCCA3 83.69%);
  }
}
.lineup__section.is-amauma::after {
  background-color: #DFCCA3;
}
.lineup__section.is-aburi::before {
  background: linear-gradient(192deg, rgba(191, 191, 191, 0) 32.49%, #BFBFBF 82.44%);
}
@media (min-width: 640px) {
  .lineup__section.is-aburi::before {
    background: linear-gradient(200deg, rgba(191, 191, 191, 0) 50.31%, #BFBFBF 83.69%);
  }
}
.lineup__section.is-aburi::after {
  background-color: #BFBFBF;
}
.lineup__section.is-baisen::before {
  background: linear-gradient(192deg, rgba(153, 173, 218, 0) 32.49%, #99ADDA 82.44%);
}
@media (min-width: 640px) {
  .lineup__section.is-baisen::before {
    background: linear-gradient(200deg, rgba(153, 173, 218, 0) 50.31%, #99ADDA 83.69%);
  }
}
.lineup__section.is-baisen::after {
  background-color: #99ADDA;
}
.lineup__section.is-koumi::before {
  background: linear-gradient(192deg, rgba(227, 159, 174, 0) 32.49%, #E39FAE 82.44%);
}
@media (min-width: 640px) {
  .lineup__section.is-koumi::before {
    background: linear-gradient(200deg, rgba(227, 159, 174, 0) 50.31%, #E39FAE 83.69%);
  }
}
.lineup__section.is-koumi::after {
  background-color: #E39FAE;
}
.lineup__section .inner {
  display: flex;
  flex-direction: column;
  gap: 8.2051282051vw;
}
@media (min-width: 640px) {
  .lineup__section .inner {
    padding-top: min(76px, 5.2777777778vw);
    padding-bottom: min(75px, 5.2083333333vw);
    padding-left: min(166px, 11.5277777778vw);
    flex-direction: row;
    align-items: center;
    gap: min(90px, 6.25vw);
  }
}
:where(.lineup__section) .inner {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  color: #000;
}
.lineup .inner {
  z-index: 1;
}
.lineup__list {
  width: 100%;
  display: flex;
  gap: 4.1025641026vw;
  justify-content: center;
  align-items: baseline;
  position: relative;
}
@media (min-width: 640px) {
  .lineup__list {
    width: min(324px, 22.5vw);
    gap: min(20px, 1.3888888889vw);
  }
}
.lineup__list::before {
  content: "";
  margin: auto;
  display: block;
  position: absolute;
  z-index: -1;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.is-amauma .lineup__list::before, .is-aburi .lineup__list::before {
  width: 30.7692307692vw;
  height: 30.7692307692vw;
  top: 0;
  left: 0;
  right: 0;
  background-image: url(/sp/tannou/img/lineup-new1.svg);
}
@media (min-width: 640px) {
  .is-amauma .lineup__list::before, .is-aburi .lineup__list::before {
    width: min(128px, 8.8888888889vw);
    height: min(128px, 8.8888888889vw);
  }
}
.is-koumi .lineup__list::before, .is-baisen .lineup__list::before {
  width: 23.0769230769vw;
  height: 23.0769230769vw;
  top: -6.4102564103vw;
  left: 10.2564102564vw;
  background-image: url(/sp/tannou/img/lineup-new2.svg);
}
@media (min-width: 640px) {
  .is-koumi .lineup__list::before, .is-baisen .lineup__list::before {
    width: min(100px, 6.9444444444vw);
    height: min(100px, 6.9444444444vw);
    top: max(-37px, -2.5694444444vw);
    left: min(48px, 3.3333333333vw);
  }
}
.lineup__item {
  margin-top: auto;
  width: 33.8461538462vw;
  text-align: center;
}
@media (min-width: 640px) {
  .lineup__item {
    width: min(152px, 10.5555555556vw);
  }
}
.lineup__item-img {
  margin-left: auto;
  margin-right: auto;
  width: 23.0769230769vw;
}
@media (min-width: 640px) {
  .lineup__item-img {
    width: min(92.71px, 6.4381944444vw);
  }
}
.lineup__caption {
  margin-top: 2.0512820513vw;
  font-weight: 500;
  font-size: 3.3333333333vw;
}
@media (min-width: 640px) {
  .lineup__caption {
    margin-top: min(10px, 0.6944444444vw);
    font-size: min(14px, 0.9722222222vw);
  }
}
.lineup .button {
  margin-top: 5.1282051282vw;
}
@media (min-width: 640px) {
  .lineup .button {
    margin-top: min(24px, 1.6666666667vw);
  }
}
.lineup__description {
  width: 100%;
}
@media (min-width: 640px) {
  .lineup__description {
    width: min(440px, 30.5555555556vw);
  }
}
.lineup__section-title {
  font-weight: 700;
  font-size: 5.641025641vw;
}
@media (min-width: 640px) {
  .lineup__section-title {
    font-size: min(32px, 2.2222222222vw);
  }
}
.lineup__text {
  margin-top: 2.0512820513vw;
  line-height: 2;
  font-size: 3.5897435897vw;
}
@media (min-width: 640px) {
  .lineup__text {
    margin-top: min(34px, 2.3611111111vw);
    font-size: min(16px, 1.1111111111vw);
  }
}

.gradation {
  width: 100%;
  padding-bottom: 25.641025641vw;
  position: relative;
  background: linear-gradient(180deg, rgba(158, 0, 0, 0) 0%, #9E0000 100%);
}
@media (min-width: 640px) {
  .gradation {
    padding-bottom: min(120px, 8.3333333333vw);
  }
}
.gradation .section__title {
  color: #E7BD85;
}

.recipe {
  width: 100%;
  padding-top: 12.3076923077vw;
  position: relative;
}
@media (min-width: 640px) {
  .recipe {
    padding-top: min(120px, 8.3333333333vw);
  }
}
.recipe > * {
  position: relative;
  z-index: 1;
}
.recipe::before {
  content: "";
  margin: auto;
  width: 100vw;
  height: 100vw;
  display: block;
  position: absolute;
  top: 10vw;
  left: 0;
  right: 0;
  z-index: 0;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url(/sp/tannou/img/tare.png);
  opacity: 0.4;
}
@media (min-width: 640px) {
  .recipe::before {
    width: min(660px, 45.8333333333vw);
    height: min(660px, 45.8333333333vw);
    top: min(40px, 2.7777777778vw);
  }
}
.recipe__slider {
  margin-top: 10.2564102564vw;
  align-items: center;
}
@media (min-width: 640px) {
  .recipe__slider {
    margin-top: min(60px, 4.1666666667vw);
  }
}
.recipe .splide__list {
  padding-top: 7.6923076923vw !important;
}
@media (min-width: 640px) {
  .recipe .splide__list {
    padding-top: min(30px, 2.0833333333vw) !important;
  }
}
.recipe__list {
  min-height: 92.3076923077vw;
}
@media (min-width: 640px) {
  .recipe__list {
    min-height: min(482px, 33.4722222222vw);
  }
}
.recipe__item {
  width: 82.0512820513vw;
  transition: all 0.3s ease-out;
  transform-origin: center;
}
@media (min-width: 640px) {
  .recipe__item {
    width: 33.3333333333%;
  }
}
.recipe__item:not(.is-active) {
  translate: 0 0;
}
.recipe__img img {
  margin: auto;
  display: block;
}
.recipe__link {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}
li:not(.is-active) .recipe__link {
  scale: 0.85;
}
@media (min-width: 640px) {
  li:not(.is-active) .recipe__link {
    scale: 0.8;
  }
}
.recipe__subtitle {
  margin-top: 2.8717948718vw;
  color: #fff;
  font-weight: 700;
  font-size: 3.5897435897vw;
  line-height: 1;
  opacity: 0;
}
@media (min-width: 640px) {
  .recipe__subtitle {
    margin-top: min(21px, 1.4583333333vw);
    font-size: min(18px, 1.25vw);
  }
}
.recipe__item.is-active .recipe__subtitle {
  opacity: 1;
}
.recipe__text {
  margin-top: 2.1538461538vw;
  font-size: 3.3333333333vw;
  color: #fff;
  font-weight: 400;
  line-height: 1.8;
  opacity: 0;
}
@media (min-width: 640px) {
  .recipe__text {
    margin-top: min(15px, 1.0416666667vw);
    font-size: min(16px, 1.1111111111vw);
  }
}
.recipe__item.is-active .recipe__text {
  opacity: 1;
}
.recipe__controls {
  margin-top: -2.5641025641vw;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5.1282051282vw;
}
@media (min-width: 640px) {
  .recipe__controls {
    margin-top: min(28px, 1.9444444444vw);
    gap: min(33px, 2.2916666667vw);
  }
}
.recipe__arrow {
  width: 3.1051282051vw;
  position: relative;
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 1;
}
@media (min-width: 640px) {
  .recipe__arrow {
    width: min(16.14px, 1.1208333333vw);
  }
}
.recipe__arrow:hover {
  opacity: 0.7;
}
.recipe .splide__pagination {
  margin-top: auto;
  margin-bottom: auto;
  width: max-content;
  height: max-content;
  position: relative;
  inset: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5.4179487179vw;
}
@media (min-width: 640px) {
  .recipe .splide__pagination {
    gap: min(28px, 1.9444444444vw);
  }
}
.recipe .splide__pagination__page {
  margin: 0;
  width: 2.3230769231vw;
  height: 2.3230769231vw;
  opacity: 1;
  border: 1px solid #D9D9D9;
  background-color: #D9D9D9;
}
@media (min-width: 640px) {
  .recipe .splide__pagination__page {
    width: min(12px, 0.8333333333vw);
    height: min(12px, 0.8333333333vw);
  }
}
.recipe .splide__pagination__page.is-active {
  transform: scale(1);
  background-color: #000;
  border-color: #fff;
}
.recipe .button {
  margin-top: 6.6666666667vw;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 640px) {
  .recipe .button {
    margin-top: min(32px, 2.2222222222vw);
  }
}

.cm {
  margin-top: 25.641025641vw;
  margin-left: auto;
  margin-right: auto;
  width: 89.7435897436vw;
}
@media (min-width: 640px) {
  .cm {
    margin-top: min(116px, 8.0555555556vw);
    width: min(800px, 55.5555555556vw);
  }
}
.cm__img {
  margin-top: 10.2564102564vw;
}
@media (min-width: 640px) {
  .cm__img {
    margin-top: min(60px, 4.1666666667vw);
  }
}