*, *::before, *::after {
  box-sizing: border-box;
}

html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}

body, h1, h2, h3, h4, p, figure, blockquote, dl, dd {
  margin: 0;
}

ul[role=list], ol[role=list] {
  list-style: none;
}

body {
  min-height: 100vh;
  line-height: 1.5;
}

h1, h2, h3, h4, button, input, label {
  line-height: 1.1;
}

h1, h2, h3, h4 {
  text-wrap: balance;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
  color: currentColor;
}

img, picture {
  max-width: 100%;
  display: block;
}

input, button, textarea, select {
  font: inherit;
}

textarea:not([rows]) {
  min-height: 10em;
}

:target {
  scroll-margin-block: 5ex;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 0;
}

body {
  padding: 0;
  font-size: 15px;
  line-height: 1.5;
  font-family: "Shippori Mincho", serif;
  overflow-x: clip;
  background-color: #fff;
}

ul {
  margin: 0;
  padding-left: 0;
}

li {
  list-style: none;
}

a {
  color: inherit;
  text-decoration: none;
}

ol, ul, dl, dt, dd, p {
  margin-bottom: 0;
}

img {
  width: 100%;
  max-width: none;
  object-fit: cover;
}

picture {
  max-width: none;
}

h1, h2, h3, h4, h5, h6, dt {
  margin-bottom: 0;
  font-weight: 300;
}

button {
  padding: 0;
  display: block;
  width: 100%;
  box-shadow: none;
  color: inherit;
  background-color: inherit;
  border: none;
  text-align: left;
  cursor: pointer;
}

.page-top {
  position: fixed;
  bottom: 6vw;
  right: 4vw;
  width: 8vw;
  aspect-ratio: 1/1;
  z-index: 100;
}
@media screen and (min-width: 900px) {
  .page-top {
    bottom: 3.515625vw;
    right: 2.34375vw;
    width: 4.6875vw;
  }
}

.kv {
  position: relative;
  background-color: #DBF2E0;
  padding-bottom: 43.3333333333vw;
}
@media screen and (min-width: 900px) {
  .kv {
    padding-bottom: 0;
  }
}
.kv__logo {
  position: absolute;
  top: 2.1333333333vw;
  left: 2.6666666667vw;
  width: 20vw;
  z-index: 1;
}
@media screen and (min-width: 900px) {
  .kv__logo {
    top: auto;
    bottom: min(3.90625vw, 50px);
    left: min(12.890625vw, 165px);
    width: min(11.71875vw, 150px);
  }
}
.kv__main-img-wrapper--sp {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (min-width: 900px) {
  .kv__main-img-wrapper--sp {
    display: none;
  }
}
.kv__main-img-wrapper--pc {
  display: none;
}
@media screen and (min-width: 900px) {
  .kv__main-img-wrapper--pc {
    display: block;
  }
}
.kv__main-img-pc {
  height: min(78.125vw, 1000px);
}
.kv__copy-img {
  position: absolute;
  width: 100%;
}
.kv__copy-img--sub {
  top: 72vw;
  left: 24vw;
  width: 53.3333333333vw;
  z-index: 1;
}
@media screen and (min-width: 900px) {
  .kv__copy-img--sub {
    top: min(28.125vw, 360px);
    left: min(6.875vw, 88px);
    width: min(24.0625vw, 308px);
  }
}
.kv__copy-img--border {
  top: 76.8vw;
  left: 22.6666666667vw;
  width: 26.6666666667vw;
  z-index: 0;
}
@media screen and (min-width: 900px) {
  .kv__copy-img--border {
    top: min(30.390625vw, 389px);
    left: min(6.484375vw, 83px);
    width: min(12.5vw, 160px);
  }
}
.kv__copy-img--01 {
  top: 80.6666666667vw;
  left: 5.8666666667vw;
  width: 47.6vw;
  z-index: 1;
}
@media screen and (min-width: 900px) {
  .kv__copy-img--01 {
    top: min(31.71875vw, 406px);
    left: min(2.890625vw, 37px);
    width: min(17.5vw, 224px);
  }
}
.kv__copy-img--02 {
  top: 91.8666666667vw;
  left: 23.4666666667vw;
  width: 44.4vw;
  z-index: 1;
}
@media screen and (min-width: 900px) {
  .kv__copy-img--02 {
    top: min(35.703125vw, 457px);
    left: min(9.296875vw, 119px);
    width: min(16.328125vw, 209px);
  }
}
.kv__copy-img--03 {
  top: 105.8666666667vw;
  left: 20vw;
  width: 48.4vw;
  z-index: 1;
}
@media screen and (min-width: 900px) {
  .kv__copy-img--03 {
    top: min(40.9375vw, 524px);
    left: min(8.046875vw, 103px);
    width: min(17.8125vw, 228px);
  }
}
.kv__copy-img--num {
  top: 98.1333333333vw;
  left: 68.8vw;
  width: 22.2666666667vw;
  z-index: 1;
}
@media screen and (min-width: 900px) {
  .kv__copy-img--num {
    top: min(37.890625vw, 485px);
    left: min(25.9375vw, 332px);
    width: min(8.203125vw, 105px);
  }
}

.about__inner {
  padding: 9.8666666667vw 6.6666666667vw 0;
  background-color: #DBF2E0;
}
@media screen and (min-width: 900px) {
  .about__inner {
    padding: min(4.0625vw, 52px) min(2.8125vw, 36px) min(3.125vw, 40px) min(5vw, 64px);
    background-color: #fff;
  }
}
.about__sub-title {
  display: grid;
  justify-content: center;
  grid-template-columns: 36vw;
}
@media screen and (min-width: 900px) {
  .about__sub-title {
    grid-template-columns: min(21.015625vw, 269px);
  }
}
.about__title {
  margin-top: 2.4vw;
  display: grid;
  justify-content: center;
  grid-template-columns: 63.6vw;
}
@media screen and (min-width: 900px) {
  .about__title {
    margin-top: min(1.25vw, 16px);
    grid-template-columns: min(37.265625vw, 477px);
  }
}
.about__text {
  margin-top: 4vw;
  font-size: 3.2vw;
  line-height: 6.6666666667vw;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 900px) {
  .about__text {
    margin-top: min(2.34375vw, 30px);
    font-size: min(1.875vw, 24px);
    line-height: min(3.90625vw, 50px);
  }
}
.about__img {
  margin-top: 8vw;
  display: grid;
  justify-content: center;
  grid-template-columns: 66.6666666667vw;
}
@media screen and (min-width: 900px) {
  .about__img {
    display: none;
  }
}
.about__img iframe {
  aspect-ratio: 9/16;
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

.index {
  padding: 10.9333333333vw 8vw 8.8vw;
  background-color: #DBF2E0;
}
@media screen and (min-width: 900px) {
  .index {
    padding: 0;
    position: absolute;
    top: 0;
    left: min(2.890625vw, 37px);
    width: min(31.71875vw, 406px);
  }
}
.index__title {
  display: grid;
  justify-content: center;
  grid-template-columns: 21.8666666667vw;
}
@media screen and (min-width: 900px) {
  .index__title {
    grid-template-columns: min(10.3125vw, 132px);
  }
}
.index__item-wrapper {
  margin-top: 4vw;
  display: flex;
  gap: 4vw 1.3333333333vw;
  justify-content: center;
  flex-wrap: wrap;
}
@media screen and (min-width: 900px) {
  .index__item-wrapper {
    margin-top: min(1.5625vw, 20px);
    gap: min(1.40625vw, 18px) min(0.15625vw, 2px);
  }
}
.index__item {
  padding-top: 5.3333333333vw;
  width: 20vw;
  position: relative;
  transition: opacity 0.6s ease-out;
}
@media (hover: hover) {
  .index__item:hover {
    opacity: 0.7;
  }
}
@media screen and (min-width: 900px) {
  .index__item {
    padding-top: min(3.125vw, 40px);
    width: min(7.8125vw, 100px);
  }
}
.index__item-num {
  position: absolute;
  bottom: 52.2666666667vw;
  left: 50%;
  transform: translateX(-50%);
  width: 5.3333333333vw;
  z-index: 1;
}
@media screen and (min-width: 900px) {
  .index__item-num {
    top: 0;
    bottom: auto;
    width: auto;
    height: min(3.125vw, 40px);
  }
  .index__item-num img {
    width: auto;
    height: 100%;
  }
}
.index__item-contents {
  height: 53.3333333333vw;
  position: relative;
  z-index: 0;
}
@media screen and (min-width: 900px) {
  .index__item-contents {
    height: min(20.703125vw, 265px);
  }
}
.index__item-img {
  height: 100%;
}
.index__item-img img {
  height: 100%;
  object-fit: cover;
}
.index__item-copy-bg {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  height: 12vw;
  background-color: #aaa;
  mix-blend-mode: multiply;
}
@media screen and (min-width: 900px) {
  .index__item-copy-bg {
    height: min(6.25vw, 90px);
  }
}
.index__item-copy {
  position: absolute;
  inset: 0;
  display: grid;
  place-content: center;
  font-size: 2.6666666667vw;
  line-height: 3.3333333333vw;
  font-weight: 500;
  color: #fff;
  text-align: center;
}
@media screen and (min-width: 900px) {
  .index__item-copy {
    font-size: min(1.25vw, 16px);
    line-height: min(1.5625vw, 20px);
  }
}

.item__inner {
  padding: 6.6666666667vw 0 6.6666666667vw;
}
@media screen and (min-width: 900px) {
  .item__inner {
    padding: min(4.6875vw, 60px) 0;
    background-color: #fff;
  }
}
.item__num {
  display: grid;
  justify-content: center;
  grid-template-columns: 14.8vw;
}
@media screen and (min-width: 900px) {
  .item__num {
    position: absolute;
    display: block;
    width: min(8.671875vw, 111px);
    top: min(3.90625vw, 50px);
    left: min(12.734375vw, 163px);
  }
  .item__num--index-01 {
    top: min(26.875vw, 344px);
  }
}
.item__title-wrapper {
  margin-top: 2.6666666667vw;
}
@media screen and (min-width: 900px) {
  .item__title-wrapper {
    margin-top: 0;
  }
}
.item__title-border {
  margin: 0 auto;
  width: 1px;
  height: 7.3333333333vw;
  background-color: #000;
}
@media screen and (min-width: 900px) {
  .item__title-border {
    display: none;
  }
}
.item__title {
  margin-top: 4vw;
  text-align: center;
  font-size: 5.3333333333vw;
  font-weight: 500;
  line-height: 8.6666666667vw;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 900px) {
  .item__title {
    margin-top: 0;
    font-size: min(3.125vw, 40px);
    line-height: min(5.078125vw, 65px);
  }
}
.item__title--point {
  display: inline-block;
  padding: 0 1.7333333333vw;
  margin-right: 1.2vw;
  position: relative;
}
@media screen and (min-width: 900px) {
  .item__title--point {
    padding: 0 min(0.78125vw, 10px);
    margin-right: min(0.78125vw, 10px);
  }
}
.item__title--point::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  height: 7.2vw;
  z-index: -1;
}
@media screen and (min-width: 900px) {
  .item__title--point::before {
    height: min(4.21875vw, 54px);
  }
}
.item__main-wrapper {
  margin-top: 6.6666666667vw;
  position: relative;
}
@media screen and (min-width: 900px) {
  .item__main-wrapper {
    margin-top: min(3.90625vw, 50px);
    position: static;
  }
}
.item__main-img {
  display: block;
  transition: opacity 0.3s ease-in-out;
}
@media (hover: hover) {
  .item__main-img:hover {
    opacity: 0.7;
  }
}
.item__main-en {
  position: absolute;
  z-index: 1;
}
.item__sub-wrapper {
  position: relative;
}
.item__sub-img {
  display: block;
  transition: opacity 0.3s ease-in-out;
}
@media (hover: hover) {
  .item__sub-img:hover {
    opacity: 0.7;
  }
}
.item__sub-copy-text {
  position: absolute;
}
.item__text-wrapper {
  padding: 6.6666666667vw 6.6666666667vw 0;
  font-size: 3.2vw;
  line-height: 6.6666666667vw;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 900px) {
  .item__text-wrapper {
    padding: min(2.34375vw, 30px) min(3.90625vw, 50px) 0;
    font-size: min(1.875vw, 24px);
    line-height: min(3.90625vw, 50px);
  }
}
.item__shop-wrapper {
  padding: 6.6666666667vw 6.6666666667vw 0;
}
@media screen and (min-width: 900px) {
  .item__shop-wrapper {
    padding: 0;
    position: absolute;
    bottom: min(3.90625vw, 50px);
    left: min(4.6875vw, 60px);
    width: min(28.125vw, 360px);
  }
}
.item[data-index="1"] .item__main-img {
  margin-left: 20vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="1"] .item__main-img {
    margin-left: min(11.71875vw, 150px);
  }
}
.item[data-index="1"] .item__main-en {
  top: -4.2666666667vw;
  left: 7.4666666667vw;
  width: 16.5333333333vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="1"] .item__main-en {
    top: min(45.3125vw, 580px);
    left: min(28.046875vw, 359px);
    width: min(9.6875vw, 124px);
  }
}
.item[data-index="1"] .item__sub-img {
  margin-right: 40vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="1"] .item__sub-img {
    margin-left: min(3.90625vw, 50px);
    margin-right: min(19.53125vw, 250px);
  }
}
.item[data-index="1"] .item__sub-copy-text--01 {
  width: 10.6666666667vw;
  top: 15.3333333333vw;
  left: 67.2vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="1"] .item__sub-copy-text--01 {
    width: min(6.25vw, 80px);
    top: min(12.265625vw, 157px);
    left: min(42.65625vw, 546px);
  }
}
.item[data-index="1"] .item__sub-copy-text--02 {
  width: 11.4666666667vw;
  top: 14.6666666667vw;
  left: 58.6666666667vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="1"] .item__sub-copy-text--02 {
    width: min(6.71875vw, 86px);
    top: min(11.875vw, 152px);
    left: min(37.578125vw, 481px);
  }
}
.item[data-index="2"] .item__main-img {
  margin-right: 20vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="2"] .item__main-img {
    margin-right: min(11.71875vw, 150px);
  }
}
.item[data-index="2"] .item__main-en {
  top: 5.8666666667vw;
  left: 72vw;
  width: 21.3333333333vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="2"] .item__main-en {
    top: min(50.546875vw, 647px);
    left: 0;
    width: min(12.5vw, 160px);
  }
}
.item[data-index="2"] .item__sub-img {
  margin-left: 40vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="2"] .item__sub-img {
    margin-left: min(19.53125vw, 250px);
    margin-right: min(3.90625vw, 50px);
  }
}
.item[data-index="2"] .item__sub-copy-text--01 {
  width: 11.2vw;
  top: 15.0666666667vw;
  left: 30vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="2"] .item__sub-copy-text--01 {
    width: min(6.5625vw, 84px);
    top: min(12.5vw, 113px);
    left: min(13.828125vw, 225px);
  }
}
.item[data-index="2"] .item__sub-copy-text--02 {
  width: 12vw;
  top: 15.7333333333vw;
  left: 22.2666666667vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="2"] .item__sub-copy-text--02 {
    width: min(7.03125vw, 90px);
    top: min(12.890625vw, 118px);
    left: min(9.375vw, 167px);
  }
}
.item[data-index="3"] .item__main-img {
  margin-left: 20vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="3"] .item__main-img {
    margin-left: min(11.71875vw, 150px);
  }
}
.item[data-index="3"] .item__main-en {
  top: 4.2666666667vw;
  left: 11.7333333333vw;
  width: 16.5333333333vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="3"] .item__main-en {
    top: min(41.171875vw, 527px);
    left: min(27.8125vw, 356px);
    width: min(9.6875vw, 124px);
  }
}
.item[data-index="3"] .item__sub-img {
  margin-right: 40vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="3"] .item__sub-img {
    margin-right: min(19.53125vw, 250px);
    margin-left: min(3.90625vw, 50px);
  }
}
.item[data-index="3"] .item__sub-copy-text--01 {
  width: 10.9333333333vw;
  top: 20.4vw;
  left: 65.3333333333vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="3"] .item__sub-copy-text--01 {
    width: min(6.40625vw, 82px);
    top: min(10.3125vw, 132px);
    left: min(42.03125vw, 538px);
  }
}
.item[data-index="3"] .item__sub-copy-text--02 {
  width: 9.8666666667vw;
  top: 19.7333333333vw;
  left: 58.6666666667vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="3"] .item__sub-copy-text--02 {
    width: min(5.78125vw, 74px);
    top: min(9.921875vw, 127px);
    left: min(38.125vw, 488px);
  }
}
.item[data-index="4"] .item__main-img {
  margin-right: 20vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="4"] .item__main-img {
    margin-right: min(11.71875vw, 150px);
  }
}
.item[data-index="4"] .item__main-en {
  top: -10.6666666667vw;
  left: 69.4666666667vw;
  width: 21.3333333333vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="4"] .item__main-en {
    top: min(63.28125vw, 810px);
    left: 0;
    width: min(12.5vw, 160px);
  }
}
.item[data-index="4"] .item__sub-img--01 {
  margin-left: 40vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="4"] .item__sub-img--01 {
    margin-left: min(19.53125vw, 250px);
    margin-right: min(3.90625vw, 50px);
  }
}
.item[data-index="4"] .item__sub-img--02 {
  margin-left: 6.6666666667vw;
  margin-right: 33.3333333333vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="4"] .item__sub-img--02 {
    margin-left: min(3.90625vw, 50px);
    margin-right: min(19.53125vw, 250px);
  }
}
.item[data-index="4"] .item__sub-copy-text--01-01 {
  width: 10.2666666667vw;
  top: 19.4666666667vw;
  left: 32.2666666667vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="4"] .item__sub-copy-text--01-01 {
    width: min(6.015625vw, 77px);
    top: min(10.9375vw, 140px);
    left: min(14.84375vw, 190px);
  }
}
.item[data-index="4"] .item__sub-copy-text--01-02 {
  width: 10.9333333333vw;
  top: 18.8vw;
  left: 24vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="4"] .item__sub-copy-text--01-02 {
    width: min(6.40625vw, 82px);
    top: min(10.546875vw, 135px);
    left: min(9.921875vw, 127px);
  }
}
.item[data-index="4"] .item__sub-copy-text--02-01 {
  width: 10.9333333333vw;
  top: 22.2666666667vw;
  left: 70.6666666667vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="4"] .item__sub-copy-text--02-01 {
    width: min(6.40625vw, 82px);
    top: min(12.65625vw, 162px);
    left: min(42.1875vw, 540px);
  }
}
.item[data-index="4"] .item__sub-copy-text--02-02 {
  width: 10.9333333333vw;
  top: 22.9333333333vw;
  left: 63.0666666667vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="4"] .item__sub-copy-text--02-02 {
    width: min(6.40625vw, 82px);
    top: min(13.046875vw, 167px);
    left: min(37.65625vw, 482px);
  }
}
.item[data-index="5"] .item__main-img {
  margin-left: 20vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="5"] .item__main-img {
    margin-left: min(11.71875vw, 150px);
  }
}
.item[data-index="5"] .item__main-en {
  top: -4vw;
  left: 7.6vw;
  width: 16.5333333333vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="5"] .item__main-en {
    top: min(26.328125vw, 337px);
    left: min(27.8125vw, 356px);
    width: min(9.6875vw, 124px);
  }
}
.item[data-index="6"] .item__main-img {
  margin-right: 20vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="6"] .item__main-img {
    margin-right: min(11.71875vw, 150px);
  }
}
.item[data-index="6"] .item__main-en {
  top: 15.6vw;
  left: 74.6666666667vw;
  width: 16.9333333333vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="6"] .item__main-en {
    top: min(59.296875vw, 759px);
    left: 0;
    width: min(9.921875vw, 127px);
  }
}
.item[data-index="6"] .item__sub-img {
  margin-left: 40vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="6"] .item__sub-img {
    margin-left: min(19.53125vw, 250px);
    margin-right: min(3.90625vw, 50px);
  }
}
.item[data-index="6"] .item__sub-copy-text--01 {
  width: 10.6666666667vw;
  top: 24.1333333333vw;
  left: 30.9333333333vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="6"] .item__sub-copy-text--01 {
    width: min(6.25vw, 80px);
    top: min(12.1875vw, 156px);
    left: min(14.140625vw, 181px);
  }
}
.item[data-index="6"] .item__sub-copy-text--02 {
  width: 10.8vw;
  top: 23.4666666667vw;
  left: 22.9333333333vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="6"] .item__sub-copy-text--02 {
    width: min(6.328125vw, 81px);
    top: min(11.796875vw, 151px);
    left: min(9.453125vw, 121px);
  }
}
.item[data-index="7"] .item__main-img {
  margin-left: 20vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="7"] .item__main-img {
    margin-left: min(11.71875vw, 150px);
  }
}
.item[data-index="7"] .item__main-en {
  top: 12.6666666667vw;
  left: 8.1333333333vw;
  width: 16.5333333333vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="7"] .item__main-en {
    top: min(54.84375vw, 702px);
    left: min(27.8125vw, 356px);
    width: min(9.6875vw, 124px);
  }
}
.item[data-index="7"] .item__sub-img {
  margin-right: 40vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="7"] .item__sub-img {
    margin-right: min(19.53125vw, 250px);
    margin-left: min(3.90625vw, 50px);
  }
}
.item[data-index="7"] .item__sub-copy-text--01 {
  width: 11.6vw;
  top: 20.9333333333vw;
  left: 65.3333333333vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="7"] .item__sub-copy-text--01 {
    width: min(6.796875vw, 87px);
    top: min(13.828125vw, 177px);
    left: min(42.421875vw, 543px);
  }
}
.item[data-index="7"] .item__sub-copy-text--02 {
  width: 9.8666666667vw;
  top: 21.6vw;
  left: 57.6vw;
}
@media screen and (min-width: 900px) {
  .item[data-index="7"] .item__sub-copy-text--02 {
    width: min(5.78125vw, 74px);
    top: min(14.21875vw, 182px);
    left: min(37.890625vw, 485px);
  }
}
.item[data-color=green] .item__title--point {
  color: #fff;
}
.item[data-color=green] .item__title--point::before {
  background-color: #39BE5D;
}
.item[data-color=yellow] .item__title--point {
  color: #000;
}
.item[data-color=yellow] .item__title--point::before {
  background-color: #F5FF03;
}

.shop {
  display: grid;
  gap: 2.4vw;
}
@media screen and (min-width: 900px) {
  .shop {
    gap: min(1.40625vw, 18px);
  }
}
.shop__item {
  display: grid;
  grid-template-columns: 1fr 55.2vw;
  align-items: center;
  gap: 1.3333333333vw;
}
@media screen and (min-width: 900px) {
  .shop__item {
    grid-template-columns: 1fr min(18.75vw, 240px);
    gap: min(0.78125vw, 10px);
  }
}
.shop__name {
  font-size: 2.9333333333vw;
  line-height: 3.7333333333vw;
  font-family: "Noto Sans JP", serif;
  font-weight: 400;
}
@media screen and (min-width: 900px) {
  .shop__name {
    font-size: min(1.09375vw, 14px);
    line-height: min(1.5625vw, 20px);
  }
}
.shop__price {
  font-size: 2.9333333333vw;
  line-height: 3.7333333333vw;
  font-family: "Noto Sans JP", serif;
  font-weight: 400;
}
@media screen and (min-width: 900px) {
  .shop__price {
    font-size: min(1.09375vw, 14px);
    line-height: min(1.5625vw, 20px);
  }
}
.shop__price--unit {
  font-size: 2.6666666667vw;
  line-height: 3.7333333333vw;
  font-family: "Noto Sans JP", serif;
}
@media screen and (min-width: 900px) {
  .shop__price--unit {
    font-size: min(1.09375vw, 14px);
    line-height: min(1.5625vw, 20px);
  }
}
.shop__link-wrapper {
  display: flex;
  justify-content: space-between;
  gap: 1.3333333333vw;
}
@media screen and (min-width: 900px) {
  .shop__link-wrapper {
    gap: min(0.78125vw, 10px);
  }
}
.shop__link {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2.4vw;
  width: 50%;
  height: 8vw;
  background-color: #363636;
  position: relative;
  overflow: clip;
}
@media screen and (min-width: 900px) {
  .shop__link {
    height: min(3.125vw, 40px);
    gap: min(1.40625vw, 18px);
  }
}
.shop__link--double {
  width: 100%;
}
@media (hover: hover) {
  .shop__link:hover .shop__link-text {
    transform: translateX(0);
  }
  .shop__link:hover .shop__link-icon > img {
    transform: translateX(0);
  }
}
.shop__link-text {
  font-size: 4vw;
  font-weight: 500;
  color: #fff;
  font-family: "Noto Sans JP", serif;
  transition: transform 0.5s;
  transform: translateX(3.3333333333vw);
}
@media screen and (min-width: 900px) {
  .shop__link-text {
    font-size: min(1.25vw, 16px);
    transform: translateX(min(1.953125vw, 25px));
  }
}
.shop__link-icon {
  width: 4.2666666667vw;
  overflow: clip;
}
@media screen and (min-width: 900px) {
  .shop__link-icon {
    width: min(2.5vw, 32px);
  }
}
.shop__link-icon > img {
  transition: transform 0.5s;
  transform: translateX(-100%);
}
.shop__more {
  margin-top: 0;
}
@media screen and (min-width: 900px) {
  .shop__more {
    display: none;
  }
}
.shop__more-btn {
  display: grid;
  place-items: center;
  width: 100%;
  height: 7.3333333333vw;
  border: 0.2666666667vw solid #000;
  position: relative;
}
@media screen and (min-width: 900px) {
  .shop__more-btn {
    height: min(4.296875vw, 55px);
    border-width: min(0.15625vw, 2px);
  }
}
.shop__more-btn:before, .shop__more-btn:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 2.1333333333vw;
  width: 2.9333333333vw;
  height: 0.2666666667vw;
  background-color: #000;
  transition: transform 0.5s;
}
@media screen and (min-width: 900px) {
  .shop__more-btn:before, .shop__more-btn:after {
    width: min(1.71875vw, 22px);
    height: min(0.15625vw, 2px);
  }
}
.shop__more-btn:before {
  transform: translateY(-50%);
}
.shop__more-btn:after {
  transform: translateY(-50%) rotate(90deg);
}
.shop__more-btn[aria-expanded=true]:after {
  transform: translateY(-50%) rotate(0);
}
.shop__more-img {
  width: 20vw;
}
@media screen and (min-width: 900px) {
  .shop__more-img {
    width: min(11.71875vw, 150px);
  }
}
.shop__accordion {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.5s;
}
@media screen and (min-width: 900px) {
  .shop__accordion {
    grid-template-rows: 1fr;
  }
}
.shop__accordion[aria-hidden=false] {
  grid-template-rows: 1fr;
}
.shop__accordion-inner {
  overflow: hidden;
}

[data-color=green] .shop__link {
  background-color: #39BE5D;
}

[data-color=yellow] .shop__link {
  background-color: #A7AD1A;
}

[data-type=point] .shop__item {
  grid-template-columns: 1fr 49.3333333333vw;
}
@media screen and (min-width: 900px) {
  [data-type=point] .shop__item {
    grid-template-columns: 1fr min(14.921875vw, 191px);
  }
}
[data-type=point] .shop__item:nth-child(1) .shop__name-wrapper:before {
  background-image: url(../images/point_a_sp.png);
}
@media screen and (min-width: 900px) {
  [data-type=point] .shop__item:nth-child(1) .shop__name-wrapper:before {
    background-image: url(../images/point_a.png);
  }
}
[data-type=point] .shop__item:nth-child(2) .shop__name-wrapper:before {
  background-image: url(../images/point_b_sp.png);
}
@media screen and (min-width: 900px) {
  [data-type=point] .shop__item:nth-child(2) .shop__name-wrapper:before {
    background-image: url(../images/point_b.png);
  }
}
[data-type=point] .shop__item:nth-child(3) .shop__name-wrapper:before {
  background-image: url(../images/point_c_sp.png);
}
@media screen and (min-width: 900px) {
  [data-type=point] .shop__item:nth-child(3) .shop__name-wrapper:before {
    background-image: url(../images/point_c.png);
  }
}
[data-type=point] .shop__name-wrapper {
  padding-left: 6.6666666667vw;
  position: relative;
}
@media screen and (min-width: 900px) {
  [data-type=point] .shop__name-wrapper {
    padding-left: min(3.515625vw, 45px);
  }
}
[data-type=point] .shop__name-wrapper:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 4vw;
  aspect-ratio: 1/1;
  background-size: contain;
  background-repeat: no-repeat;
}
@media screen and (min-width: 900px) {
  [data-type=point] .shop__name-wrapper:before {
    width: min(2.34375vw, 30px);
  }
}
[data-type=point] .shop__link {
  background-color: #fff;
  color: #000;
  height: 7.4666666667vw;
}
@media screen and (min-width: 900px) {
  [data-type=point] .shop__link {
    background-color: #E8E6DB;
    height: min(3.125vw, 40px);
  }
}
[data-type=point] .shop__link-text {
  color: #000;
}

.point__inner {
  padding: 5.6vw 6.6666666667vw 6.6666666667vw;
  background-color: #E8E6DB;
}
@media screen and (min-width: 900px) {
  .point__inner {
    padding: min(3.28125vw, 42px) min(3.90625vw, 50px) min(3.90625vw, 50px);
  }
}
.point__title {
  display: grid;
  justify-content: center;
  position: relative;
  z-index: 2;
}
.point__img-wrapper {
  position: relative;
  margin: 0 -6.6666666667vw;
  width: calc(100% + 13.3333333333vw);
  display: grid;
  justify-content: center;
}
@media screen and (min-width: 900px) {
  .point__img-wrapper {
    margin: 0 max(-3.90625vw, -50px);
    width: calc(100% + min(7.8125vw, 100px));
  }
}
.point__img-num {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  object-fit: contain;
}
.point__text {
  font-size: 3.2vw;
  line-height: 6.6666666667vw;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 900px) {
  .point__text {
    font-size: min(1.875vw, 24px);
    line-height: min(3.90625vw, 50px);
  }
}
.point__text-wrapper {
  position: relative;
  z-index: 2;
}
.point__shop-wrapper {
  margin-top: 8vw;
}
@media screen and (min-width: 900px) {
  .point__shop-wrapper {
    margin-top: 0;
    position: absolute;
    bottom: min(3.125vw, 40px);
    left: min(4.6875vw, 60px);
    width: min(28.125vw, 360px);
  }
}
.point[data-index=point-1] .point__title {
  grid-template-columns: 67.0666666667vw;
}
@media screen and (min-width: 900px) {
  .point[data-index=point-1] .point__title {
    grid-template-columns: min(39.296875vw, 503px);
  }
}
.point[data-index=point-1] .point__img-wrapper {
  margin-top: -2.5333333333vw;
}
@media screen and (min-width: 900px) {
  .point[data-index=point-1] .point__img-wrapper {
    margin-top: max(-1.484375vw, -19px);
  }
}
.point[data-index=point-1] .point__img,
.point[data-index=point-1] .point__img-num {
  width: 85.0666666667vw;
}
@media screen and (min-width: 900px) {
  .point[data-index=point-1] .point__img,
  .point[data-index=point-1] .point__img-num {
    width: min(49.84375vw, 638px);
  }
}
.point[data-index=point-1] .point__text {
  margin-top: -1.6vw;
}
@media screen and (min-width: 900px) {
  .point[data-index=point-1] .point__text {
    margin-top: max(-2.03125vw, -26px);
  }
}
.point[data-index=point-2] .point__title {
  grid-template-columns: 80.8vw;
}
@media screen and (min-width: 900px) {
  .point[data-index=point-2] .point__title {
    grid-template-columns: min(47.34375vw, 606px);
  }
}
.point[data-index=point-2] .point__img-wrapper {
  margin-top: -0.8vw;
}
@media screen and (min-width: 900px) {
  .point[data-index=point-2] .point__img-wrapper {
    margin-top: max(-0.46875vw, -6px);
  }
}
.point[data-index=point-2] .point__img,
.point[data-index=point-2] .point__img-num {
  width: 97.7333333333vw;
}
@media screen and (min-width: 900px) {
  .point[data-index=point-2] .point__img,
  .point[data-index=point-2] .point__img-num {
    width: min(57.265625vw, 733px);
  }
}
.point[data-index=point-2] .point__text {
  margin-top: -3.0666666667vw;
}
@media screen and (min-width: 900px) {
  .point[data-index=point-2] .point__text {
    margin-top: max(-3.125vw, -40px);
  }
}
.point[data-index=point-3] .point__title {
  grid-template-columns: 61.8666666667vw;
}
@media screen and (min-width: 900px) {
  .point[data-index=point-3] .point__title {
    grid-template-columns: min(36.25vw, 464px);
  }
}
.point[data-index=point-3] .point__img-wrapper {
  margin-top: -4vw;
}
@media screen and (min-width: 900px) {
  .point[data-index=point-3] .point__img-wrapper {
    margin-top: max(-2.34375vw, -30px);
  }
}
.point[data-index=point-3] .point__img,
.point[data-index=point-3] .point__img-num {
  width: 87.4666666667vw;
}
@media screen and (min-width: 900px) {
  .point[data-index=point-3] .point__img,
  .point[data-index=point-3] .point__img-num {
    width: min(51.25vw, 656px);
  }
}
.point[data-index=point-3] .point__text {
  margin-top: -4vw;
}
@media screen and (min-width: 900px) {
  .point[data-index=point-3] .point__text {
    margin-top: max(-3.59375vw, -46px);
  }
}

.staff__inner {
  padding-top: 4vw;
}
@media screen and (min-width: 900px) {
  .staff__inner {
    padding-top: min(3.90625vw, 50px);
    background-color: #fff;
    display: grid;
  }
}
.staff__shop-link {
  display: grid;
  justify-content: center;
}
.staff__shop-link-btn {
  display: grid;
  place-items: center;
  position: relative;
  width: 49.3333333333vw;
  height: 8vw;
  border: 1px solid #000;
  font-size: 2.9333333333vw;
  font-family: "Noto Sans JP", serif;
  transition: background-color 0.5s, color 0.5s;
}
@media screen and (min-width: 900px) {
  .staff__shop-link-btn {
    width: min(28.90625vw, 370px);
    height: min(4.6875vw, 60px);
    font-size: min(1.71875vw, 22px);
  }
}
@media (any-hover: hover) {
  .staff__shop-link-btn:hover {
    background-color: #AAAAAA;
    color: #fff;
  }
  .staff__shop-link-btn:hover .staff__shop-link-border {
    transform: translate(1.3333333333vw, -50%);
  }
}
@media screen and (any-hover: hover) and (min-width: 900px) {
  .staff__shop-link-btn:hover .staff__shop-link-border {
    transform: translate(min(0.78125vw, 10px), -50%);
  }
}
.staff__shop-link-border {
  position: absolute;
  top: 50%;
  left: -5.8666666667vw;
  transform: translate(0, -50%);
  width: 9.7333333333vw;
  transition: transform 0.5s;
}
@media screen and (min-width: 900px) {
  .staff__shop-link-border {
    left: max(-3.4375vw, -44px);
    width: min(5.703125vw, 73px);
  }
}
.staff__img {
  margin-top: 6.6666666667vw;
}
@media screen and (min-width: 900px) {
  .staff__img {
    margin-top: min(3.90625vw, 50px);
  }
}
.staff__staff {
  padding: 7.3333333333vw 0;
  font-size: max(2vw, 10px);
  line-height: 2;
  letter-spacing: 0.1em;
  text-align: center;
  font-style: italic;
  font-family: "Bodoni Moda", serif;
}
@media screen and (min-width: 900px) {
  .staff__staff {
    padding: min(3.90625vw, 50px) 0 min(6.25vw, 80px);
    font-size: min(1.171875vw, 15px);
    line-height: min(2.34375vw, 30px);
  }
}

.section {
  scroll-margin-top: 0;
}
.section__inner {
  max-width: 1280px;
  margin: 0 auto;
}
@media screen and (min-width: 900px) {
  .section__inner {
    position: relative;
    padding-left: min(480px, 37.5vw);
    padding-right: min(50px, 3.90625vw);
  }
}
@media screen and (min-width: 900px) {
  .section[data-pc-bg=green] {
    background-color: #DBF2E0;
  }
}
@media screen and (min-width: 900px) {
  .section[data-pc-bg=white] {
    background-color: #fff;
  }
}

.p-footer {
  padding-top: 21.3333333333vw;
  padding-bottom: 5.3333333333vw;
}

.p-footer img {
  height: auto;
  object-fit: unset;
}

@media (min-width: 901px) {
  .p-footer {
    background-color: #c0ecc9;
    padding-top: min(12.5vw, 160px);
    padding-bottom: min(3.125vw, 40px);
  }
}
.p-footer__inner {
  margin-inline: auto;
}

@media (min-width: 901px) {
  .p-footer__inner {
    width: min(76.5625vw, 980px);
  }
}
@media (max-width: 900px) {
  .p-footer__inner {
    width: 86.6666666667vw;
  }
}
.p-footer__unit--underline {
  margin-bottom: 13.3333333333vw;
  padding-bottom: 16vw;
  border-bottom: 1px solid #39BE5D;
}
@media (min-width: 901px) {
  .p-footer__unit--underline {
    margin-bottom: min(7.8125vw, 100px);
    padding-bottom: min(9.375vw, 120px);
  }
}

.p-footer__snsNav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16vw;
}
@media screen and (min-width: 900px) {
  .p-footer__snsNav {
    gap: min(9.375vw, 120px);
  }
}

@media (max-width: 900px) {
  .p-footer__snsNav {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.p-footer__snsItem {
  display: block;
  height: auto;
}

@media (min-width: 901px) {
  .p-footer__snsItem--website {
    width: min(12.734375vw, 163px);
  }
}
@media (max-width: 900px) {
  .p-footer__snsItem--website {
    width: 28vw;
  }
}
@media (min-width: 901px) {
  .p-footer__snsItem--instagram {
    width: min(6.25vw, 80px);
  }
}
@media (max-width: 900px) {
  .p-footer__snsItem--instagram {
    width: 14.4vw;
  }
}
.p-footer__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  max-width: 102.6666666667vw;
  margin-inline: auto;
}

@media (min-width: 901px) {
  .p-footer__link {
    max-width: min(60.15625vw, 770px);
    gap: min(2.34375vw, 30px);
  }
}
@media (max-width: 900px) {
  .p-footer__link {
    gap: 3.2vw;
  }
}
.p-footer__linkItem {
  position: relative;
  overflow: hidden;
}

@media (min-width: 901px) {
  .p-footer__linkItem {
    width: calc(50% - min(1.171875vw, 15px));
  }
}
@media (max-width: 900px) {
  .p-footer__linkItem {
    width: calc(50% - 1.6vw);
  }
}
.p-footer__linkInner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  background-color: #39BE5D;
}

@media (min-width: 901px) {
  .p-footer__linkInner {
    height: min(8.59375vw, 110px);
  }
}
@media (max-width: 900px) {
  .p-footer__linkInner {
    height: 18.6666666667vw;
  }
}
.p-footer__linkInner svg {
  display: block;
  width: auto;
  height: 100%;
}

.p-footer__linkInner path {
  fill: #ffffff;
}

.p-footer__note {
  margin-top: 16vw;
}
@media (min-width: 901px) {
  .p-footer__note {
    margin-top: min(9.375vw, 120px);
  }
}

@media (min-width: 901px) {
  .p-footer__note {
    text-align: center;
    font-size: max(1.09375vw, 10px);
    line-height: 1.8571428571;
  }
}
@media (max-width: 900px) {
  .p-footer__note {
    text-align: justify;
    font-size: max(3.2vw, 10px);
    line-height: 1.875;
  }
}
.p-footer__logo {
  display: block;
  margin-inline: auto;
}

@media (min-width: 901px) {
  .p-footer__logo--instagram {
    width: min(3.75vw, 48px);
    margin-top: min(6.25vw, 80px);
  }
}
@media (max-width: 900px) {
  .p-footer__logo--instagram {
    width: 8.5333333333vw;
    margin-top: 16vw;
  }
}
@media (min-width: 901px) {
  .p-footer__logo--corporate {
    width: min(14.0625vw, 180px);
    margin-top: min(3.75vw, 48px);
  }
}
@media (max-width: 900px) {
  .p-footer__logo--corporate {
    width: 32vw;
    margin-top: 10.6666666667vw;
  }
}
.p-footer__copyright {
  text-align: center;
}

@media (min-width: 901px) {
  .p-footer__copyright {
    margin-top: min(3.75vw, 48px);
    font-size: max(1.171875vw, 10px);
    line-height: 1;
  }
}
@media (max-width: 900px) {
  .p-footer__copyright {
    margin-top: 10.6666666667vw;
    font-size: max(2.6666666667vw, 10px);
    line-height: 1;
  }
}
.u-hover {
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
}

.u-hover:hover {
  opacity: 0.8;
}

@media (min-width: 901px) {
  .u-pcNone {
    display: none !important;
  }
}
@media (max-width: 900px) {
  .u-spNone {
    display: none !important;
  }
}
@media screen and (min-width: 420px) {
  .br__420 {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .br__sp {
    display: none;
  }
}
.br__pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .br__pc {
    display: block;
  }
}

.block {
  display: block;
}

.inline-block {
  display: inline-block;
  white-space: nowrap;
}

.word-break {
  display: block;
  word-break: keep-all;
}

@media screen and (min-width: 768px) {
  .sp {
    display: none;
  }
}

.pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .pc {
    display: block;
  }
}

[data-clip-path-to-right] {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1.5s cubic-bezier(0.33, 1, 0.68, 1);
  will-change: clip-path;
}
[data-clip-path-to-right].is-inview {
  clip-path: inset(0 0 0 0);
}

[data-clip-path-to-right-fast] {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1s cubic-bezier(0.33, 1, 0.68, 1);
}
[data-clip-path-to-right-fast].is-inview {
  clip-path: inset(0 0 0 0);
}

[data-clip-path-to-left] {
  clip-path: inset(0 0 0 100%);
  transition: clip-path 2s cubic-bezier(0.33, 1, 0.68, 1);
  will-change: clip-path;
}
[data-clip-path-to-left].is-inview {
  clip-path: inset(0 0 0 0);
}

[data-clip-path-to-left-fast] {
  clip-path: inset(0 0 0 100%);
  transition: clip-path 1s cubic-bezier(0.33, 1, 0.68, 1);
}
[data-clip-path-to-left-fast].is-inview {
  clip-path: inset(0 0 0 0);
}

[data-clip-path-to-bottom] {
  clip-path: inset(0 0 100% 0);
  transition: clip-path 2s cubic-bezier(0.33, 1, 0.68, 1);
}
[data-clip-path-to-bottom].is-inview {
  clip-path: inset(0 0 0 0);
}

[data-clip-path-to-bottom-fast] {
  clip-path: inset(0 0 100% 0);
  transition: clip-path 1s cubic-bezier(0.33, 1, 0.68, 1);
}
[data-clip-path-to-bottom-fast].is-inview {
  clip-path: inset(0 0 0 0);
}

[data-clip-path-to-top] {
  clip-path: inset(100% 0 0 0);
  transition: clip-path 2s cubic-bezier(0.33, 1, 0.68, 1);
}
[data-clip-path-to-top].is-inview {
  clip-path: inset(0 0 0 0);
}

[data-clip-path-to-top-fast] {
  clip-path: inset(100% 0 0 0);
  transition: clip-path 1s cubic-bezier(0.33, 1, 0.68, 1);
}
[data-clip-path-to-top-fast].is-inview {
  clip-path: inset(0 0 0 0);
}

[data-clip-path-to-side] {
  clip-path: inset(0 100% 0 100%);
  transition: clip-path 2s cubic-bezier(0.33, 1, 0.68, 1);
}
[data-clip-path-to-side].is-inview {
  clip-path: inset(0 0 0 0);
}

[data-opacity] {
  opacity: 0;
  transition: opacity 2s ease-out;
}
[data-opacity].is-inview {
  opacity: 1;
}

[data-slide-to-up] {
  overflow: clip;
}
[data-slide-to-up] > * {
  display: block;
  transform: translateY(calc(100% + 10px));
  transition: transform 0.6s ease-out;
}
[data-slide-to-up].is-inview > * {
  transform: translateY(0);
}

[data-slide-to-up-fast] {
  overflow: clip;
}
[data-slide-to-up-fast] > * {
  display: block;
  transform: translateY(calc(100% + 10px));
  transition: transform 0.3s ease-out;
}
[data-slide-to-up-fast].is-inview > * {
  transform: translateY(0);
}

[data-bounce-up] > * {
  display: block;
  opacity: 0;
  transform: translateY(calc(100% + 10px));
}
[data-bounce-up].is-inview > * {
  animation: undefined-easeOutElastic 1s ease-out forwards;
}

@keyframes undefined-easeOutElastic {
  0% {
    opacity: 0;
    transform: translateY(25%);
  }
  16% {
    opacity: 0.3;
    transform: translateY(-10%);
  }
  28% {
    opacity: 0.6;
    transform: translateY(5%);
  }
  44% {
    opacity: 1;
    transform: translateY(0%);
  }
  59% {
    opacity: 1;
    transform: translateY(0%);
  }
  100% {
    opacity: 1;
    transform: translateY(0%);
  }
}
[data-fade-in-up] {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
[data-fade-in-up].is-inview {
  opacity: 1;
  transform: translateY(0);
}

[data-scale-img] {
  overflow: clip;
}
[data-scale-img] > img {
  transition: scale 0.8s ease-out, opacity 0.8s ease-out;
  scale: 1.2;
  opacity: 0;
  will-change: scale, opacity;
}
[data-scale-img].is-inview > img {
  scale: 1;
  opacity: 1;
}

[data-fade-in-to-up] {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
[data-fade-in-to-up].is-inview {
  opacity: 1;
  transform: translateY(0);
}

[data-border-horizontal]::before, [data-border-horizontal]::after {
  transform-origin: top left;
  transition: scale 0.8s 0.4s ease-out;
  scale: 0;
}
[data-border-horizontal].is-inview::before, [data-border-horizontal].is-inview::after {
  scale: 1;
}

[data-border-vertical]::before, [data-border-vertical]::after {
  transform-origin: top left;
  transition: scale 0.8s ease-out;
  scale: 0;
}
[data-border-vertical].is-inview::before, [data-border-vertical].is-inview::after {
  scale: 1;
}

[data-title] {
  -webkit-text-stroke: 0.5px #000;
  text-stroke: 0.5px #000;
  position: relative;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  transition: opacity 0.6s ease-in-out;
  opacity: 0;
}
[data-title]::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 0%;
  color: #000;
  overflow: hidden;
  white-space: nowrap;
  z-index: 2;
  transition: width 1s 0.6s linear;
}
[data-title].is-inview {
  opacity: 1;
}
[data-title].is-inview::after {
  width: 100%;
}

[data-title-white] {
  -webkit-text-stroke: 0.5px #fff;
  text-stroke: 0.5px #fff;
  position: relative;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  transition: opacity 0.6s ease-in-out;
  opacity: 0;
}
[data-title-white]::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 0%;
  color: #fff;
  overflow: hidden;
  white-space: nowrap;
  z-index: 2;
  transition: width 1s 0.6s linear;
}
[data-title-white].is-inview {
  opacity: 1;
}
[data-title-white].is-inview::after {
  width: 100%;
}

[data-scale-image] {
  overflow: clip;
}
[data-scale-image] > img {
  transition: scale 2s ease-out;
  scale: 1.1;
}
[data-scale-image].is-inview > img {
  scale: 1;
}

[data-scale-opacity-image] {
  overflow: clip;
}
[data-scale-opacity-image] > img {
  transition: scale 2s ease-out, opacity 2s ease-out;
  scale: 1.1;
  opacity: 0;
  will-change: scale, opacity;
}
[data-scale-opacity-image].is-inview > img {
  scale: 1;
  opacity: 1;
}