@charset 'UTF-8';

:root {
  --font-reross: "reross-quadratic", sans-serif;
  --font-satisfy: "Satisfy", serif;
  --font-noto-sans-jp: "Noto Sans JP", serif;
  --cBlack: #333;
  --cWhite: #fff;
  --cBase: #2f2f2f;
  --cMain: #f2f2f2;
  --cAccent: #159741;
}

body {
  line-height: 1.5;
  font-size: 16px;
  font-weight: 400;
  color: var(--cBlack);
  overflow-wrap: anywhere; /* 収まらない場合に折り返す */
  word-break: normal;
  overflow-x: hidden;
}

html {
  overflow-x: hidden;
}

/*-------------------------------
Common
--------------------------------*/
.inner {
  padding-inline: 16px;

  @media (768px <= width), print {
    margin-inline: auto;
    max-width: calc(1080px + 40px * 2);
    padding-inline: 40px;
  }
}

.bgHighlighted {
  background: var(--cAccent);
}
.textHighlighted {
  color: var(--cAccent);
}

.hidden-sp {
  display: none;
}
@media (768px <= width), print {
  .hidden-pc {
    display: none;
  }
}

/*-------------------------------
Header
--------------------------------*/
.header {
  background-color: var(--cBase);
}

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-inline: 16px;

  @media (768px <= width), print {
    padding-inline: 31px 71px;
    padding-block: 15px 12px;
  }
}

.header__logo {
  cursor: pointer;
  display: block;
  transition: opacity 0.3s;

  & img {
    @media (768px <= width), print {
      width: 115px;
      height: 63px;
    }
  }

  @media (any-hover: hover) {
    &:hover {
      opacity: 0.7;
      cursor: pointer;
    }
  }
}

.header_menu {
  display: flex;
  align-items: center;
  gap: 20px;

  @media (768px <= width), print {
    gap: 40px;
  }
}

.header__list {
  position: relative;
  display: block;
  text-transform: capitalize;
  color: var(--cWhite);
  font-family: var(--font-reross);
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.42px;
  padding-block: 22px 21px;
  line-height: calc(17 / 14);

  @media (768px <= width), print {
    font-size: 18px;
    letter-spacing: 0.54px;
    padding-block: 0;
  }

  &::after {
    background-color: var(--cAccent);
    bottom: -6px;
    content: "";
    height: 2px;
    left: 0;
    position: absolute;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform 0.3s;
    width: 100%;
  }

  @media (any-hover: hover) {
    &:hover::after {
      transform-origin: left top;
      transform: scale(1, 1);
    }
  }
}

/*-------------------------------
Mv
--------------------------------*/
.mv {
  background-color: var(--cBase);
}

.mv__inner {
  position: relative;
  z-index: 1;
  display: flex;
}

.mv__catch {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  padding-left: 16px;

  @media (576px <= width), print {
    padding-left: max(calc((100vw - 1080px) / 2 + 15px), 31px);
  }
}

.catch-en {
  color: var(--cWhite);
  font-family: var(--font-reross);
  font-size: 36px;
  font-weight: 400;

  @media (600px <= width), print {
    font-size: clamp(36px, 6.94vw, 100px); /*100px / 1080px * 100% */
    line-height: 1;
  }

  & span {
    display: block;
  }

  & span:nth-child(1) {
    line-height: calc(43 / 36);
  }

  & span:nth-child(n + 2) {
    line-height: 1;
  }
}

.catch-ja {
  margin-top: 15px;
  color: var(--cWhite);
  font-family: var(--font-noto-sans-jp);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.7px;
  line-height: calc(20 / 14);

  @media (600px <= width), print {
    margin-top: min(2.569vw, 37px);
    font-size: clamp(14px, 2.22vw, 32px);
    font-weight: 700;
    letter-spacing: 1.6px;
    line-height: calc(46 / 32);
  }

  & p + p {
    margin-top: 9px;
    width: fit-content;
    padding: 4px 8px 7px 0;

    @media (600px <= width), print {
      margin-top: min(2.08vw, 30px);
      padding-block: 0.625vw;
      padding-inline: 0 1.45vw;
    }
  }
}

.mv__img {
  width: max(80%, 308px);
  margin-left: auto;

  @media (768px <= width), print {
    max-width: 1080px;
  }

  & img {
    width: 100%;

    @media (768px <= width), print {
      aspect-ratio: 1080 / 650;
      max-height: 650px;
    }
  }
}

/*-------------------------------
Concept
--------------------------------*/
.concept {
  padding-block: 48px 64px;
  background-color: var(--cBase);
  background-image: url(../img/text_concept_sp.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: bottom center;

  @media (768px <= width), print {
    padding-block: 120px 110px;
    background-image: url(../img/text_concept.png);
  }
}

.concept__inner {
  padding-inline: 30px;
  text-align: center;
  color: var(--cWhite);
  font-family: var(--font-noto-sans-jp);
}

.concept__message {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 1px;

  @media (768px <= width), print {
    font-size: 30px;
    letter-spacing: 1.5px;
  }
}

.concept__text {
  margin-top: 24px;
  letter-spacing: 0.48px;

  @media (768px <= width), print {
    margin-top: 48px;
    font-size: clamp(16px, 1.25vw, 18px);
    letter-spacing: 0.54px;
  }

  & p + p {
    margin-top: 1em;
  }
}

/*-------------------------------
About
--------------------------------*/
.about {
  padding-block: 64px;
  background-color: var(--cMain);
  position: relative;
  z-index: 1;
}

.about__inner {
  padding-inline: 12px;

  @media (768px <= width < 1280px), print {
    padding-inline: 30px;
  }
}

.heading__title {
  text-align: center;
}

.heading__sub {
  color: var(--cAccent);
  font-family: var(--font-noto-sans-jp);
  font-size: 14px;
  font-weight: 700;
  line-height: calc(20 / 14);
  letter-spacing: 0.7px;
  margin-bottom: 12px;

  @media (768px <= width), print {
    font-size: 18px;
    line-height: calc(26 / 18);
    letter-spacing: 0.9px;
  }
}

.heading__main {
  color: var(--cBlack);
  font-family: var(--font-reross);
  font-size: 32px;
  line-height: calc(38 / 32);
  letter-spacing: 1.6px;
  text-transform: capitalize;

  @media (768px <= width), print {
    font-size: 48px;
    line-height: calc(58 / 48);
    letter-spacing: 2.4px;
  }

  &::after {
    content: "";
    display: block;
    width: 50px;
    margin: 12px auto 0;
    border-top: 2px solid var(--cAccent);
  }
}

.about__boxes {
  margin-top: 56px;
  display: flex;
  flex-direction: column;
  gap: 56px;
}

.about__box {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  overflow: hidden;

  @media (768px <= width), print {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: min(4.51vw, 65px);
  }
}

.about__box.reverse {
  @media (768px <= width), print {
    flex-direction: row-reverse;
  }
}

.about__body {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  color: var(--cBlack);
  font-family: var(--font-noto-sans-jp);
  position: relative;

  @media (768px <= width), print {
    flex-grow: 1;
    justify-content: center;
    width: 565px;
    height: 288px;
    gap: 24px;
  }

  &::after {
    position: absolute;
    z-index: -1;
    right: 0;
    color: rgba(255, 255, 255, 0.8);
    font-family: var(--font-reross);
    font-size: 180px;
    line-height: calc(216 / 180);
  }
}

.about__box:nth-child(1) .about__body::after {
  content: "01";
  top: 5px;
}

.about__box:nth-child(2) .about__body::after {
  content: "02";
  top: 40px;
}

.about__box:nth-child(3) .about__body::after {
  content: "03";
  top: 15px;
}

.about__title {
  font-size: 23px;
  font-weight: 700;
  line-height: calc(35 / 24);
  letter-spacing: 1.2px;

  @media (390px <= width), print {
    font-size: 24px;
  }

  @media (768px <= width), print {
    font-size: 30px;
    letter-spacing: 1.5px;
    line-height: calc(43 / 30);
  }

  & .textHighlighted {
    font-weight: inherit;
  }
}

.about__text {
  letter-spacing: 0.48px;

  @media (768px <= width), print {
    width: 400px;
    font-size: 18px;
    letter-spacing: 0.54px;
  }
}

.about__img {
  flex-shrink: 0;

  @media (768px <= width), print {
    width: min(calc((450 / 1080) * 100%), 450px);
    max-height: 288px;
    flex-shrink: 0;
  }

  & img {
    width: 100%;
  }
}

/*-------------------------------
Paralax
--------------------------------*/
/* .parallax_box {
  position: relative;
  width: 100%;
  height: clamp(250px, 31.25vw, 450px);
  overflow: hidden;
} */
/* 
.parallax_img {
  width: 100%;
  height: 100%;
  object-fit: none;
  object-position: center top;

  & img {
    width: 100%;
  }
}

.parallax_img.parallaxImg1 {
  object-position: center bottom;
} */

.parallax__box {
  position: relative;
  width: 100%;
  height: clamp(250px, 31.25vw, 450px);
  overflow: hidden;
}

.parallax__wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.parallax__img {
  position: absolute;
  width: 100%;
  height: auto;
  top: 0;
  transform: none;

  &.parallaxImg1 {
    top: -90%;
    bottom: 0;

    @media (width < 768px), print {
      top: -20%;
    }

    @media (width < 400px), print {
      top: -10%;
    }
  }
}

.test {
  height: 500vh;
  background-color: var(--cBase);
}

/*-------------------------------
Menu
--------------------------------*/
.menu {
  background-color: var(--cBase);
  padding: 24px 16px;

  @media (768px <= width < 1280px), print {
    padding-inline: 30px;
  }

  @media (1040px <= width), print {
    padding: 72px;
  }
}
.menu__inner {
  border: 1px solid var(--cWhite);
  padding-block: calc(32px - 1px);
  padding-inline: 20px;
  margin-inline: 0;

  @media (1040px <= width), print {
    border: 2px solid var(--cWhite);
    padding-block: calc(80px - 2px) calc(100px - 2px);
  }
}
.menu__contents {
  margin-top: 48px;
  display: flex;
  flex-direction: column;

  @media (1040px <= width), print {
    margin-top: 54px;
  }
}

.menu__recommend-wrapper {
  position: relative;
}

._text-white {
  color: var(--cWhite);
}

.heading__main._border-white::after {
  border-color: var(--cWhite);
}

.menu__nutrition {
  margin-top: calc(48px - 2px);
  text-align: center;
  color: var(--cWhite);
  font-family: var(--font-noto-sans-jp);
  font-weight: 500;
  line-height: calc(23 / 16);
  letter-spacing: 0.48px;

  @media (width <= 320px), print {
    font-size: 14px;
    line-height: calc(21 / 14);
  }

  @media (1040px <= width), print {
    margin-top: calc(32px - 2px);
    font-size: 18px;
    line-height: calc(26 / 18);
    letter-spacing: 0.54px;
  }

  & span + span {
    margin-left: 1em;
  }
}

.menu__recommend {
  position: relative;
  z-index: 1;
  @media (1040px <= width), print {
    margin: 0 auto;
    max-width: calc(953px + 20px * 2);
    width: 100%;
    padding-inline: 20px;
  }
}

.menu__recommend-inner {
  padding-top: calc(111px - 1px);
  color: var(--cBlack);
  padding-inline: calc(10px - 1px);
  padding-bottom: calc(32px - 1px);
  text-align: center;
  border: 1px solid var(--cBlack);

  @media (1040px <= width), print {
    padding-top: calc(100px - 1px);
  }
}

.menu__recommend-card {
  padding: 10px;
  margin-top: -40px;
  position: relative;
  z-index: -1;
  background-color: var(--cMain);
  max-width: 300px;
  margin-inline: auto;

  @media (1040px <= width), print {
    padding: 13px 13px 13px 14px;
    margin-top: 0;
    z-index: 1;
    margin-left: 361px;
    top: 71px;
    max-width: 592px;
  }
}

.card {
  max-width: 525px;
  margin-inline: auto;
}

.menu__recommend-label {
  display: block;
  padding-inline: calc(50px - 2px);
  padding-block: 38px 16px;
  text-align: center;
  color: #fff;
  border: 2px solid var(--cAccent);
  background: var(--cAccent);
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;

  @media (1040px <= width), print {
    padding-inline: calc(52px - 2px) calc(51px - 2px);
    padding-block: calc(9px - 2px) calc(14px - 2px);
  }
}

.menu__recommend-label-en {
  font-family: var(--font-satisfy);
  font-size: 12px;
  text-transform: capitalize;
  line-height: calc(17 / 12);
  letter-spacing: 0.36px;

  @media (width <= 320px), print {
    font-size: 11px;
  }

  @media (1040px <= width), print {
    font-size: 14px;
    line-height: calc(20 / 14);
    letter-spacing: 0.42px;
  }
}

.menu__recommend-label-ja {
  font-family: var(--font-noto-sans-jp);
  font-size: 18px;
  font-weight: 500;
  line-height: calc(26 / 18);
  letter-spacing: 0.54px;

  @media (width <= 320px), print {
    font-size: 16px;
  }

  @media (1040px <= width), print {
    font-size: 24px;
    line-height: calc(35 / 24);
    letter-spacing: 0.72px;
  }
}

.card__title {
  font-family: var(--font-noto-sans-jp);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 2.4px;

  @media (width <= 320px), print {
    font-size: 20px;
    letter-spacing: 2px;
  }

  @media (1040px <= width), print {
    font-size: clamp(24px, 1.25vw, 30px);
    line-height: calc(43 / 30);
    letter-spacing: 3px;
  }
}

.card__price {
  font-family: var(--font-reross);
  text-align: center;
  font-size: 30px;
  line-height: calc(36 / 30);
  letter-spacing: 3px;
  margin-top: 16px;

  @media (width <= 320px), print {
    font-size: 26px;
    line-height: calc(32 / 26);
    letter-spacing: 2.6px;
  }

  @media (1040px <= width), print {
    margin-top: 20px;
    font-size: 40px;
    line-height: calc(48 / 40);
    letter-spacing: 4px;
  }

  & span:nth-child(1) {
    margin-right: 3px;
    margin-bottom: 4px;
    font-family: var(--font-reross);
    font-size: 18px;
    line-height: calc(22 / 18);
    letter-spacing: 1.8px;
    display: inline-block;

    @media (width <= 320px), print {
      font-size: 16px;
      line-height: calc(20 / 16);
      letter-spacing: 1.6px;
    }

    @media (1040px <= width), print {
      margin-right: 6px;
      margin-bottom: 6px;
      font-size: 24px;
      line-height: calc(29 / 24);
      letter-spacing: 2.4px;
    }
  }

  & span:nth-child(2) {
    margin-left: -5px;
    margin-bottom: 8px;
    font-family: var(--font-noto-sans-jp);
    font-size: 12px;
    font-weight: 500;
    line-height: calc(17 / 12);
    letter-spacing: 1.2px;
    display: inline-block;

    @media (width <= 320px), print {
      font-size: 11px;
      line-height: calc(16 / 11);
      letter-spacing: 1.1px;
    }

    @media (1040px <= width), print {
      margin-left: -4px;
      margin-bottom: 11px;
      font-size: 18px;
      line-height: calc(26 / 18);
      letter-spacing: 1.8px;
    }
  }
}

.card__nutrition {
  margin-top: 16px;
  font-family: var(--font-noto-sans-jp);
  font-size: 14px;
  line-height: calc(20 / 14);
  letter-spacing: 0.42px;

  @media (width <= 320px), print {
    font-size: 12px;
    line-height: calc(18 / 12);
    letter-spacing: 0.38px;
  }

  @media (1040px <= width), print {
    margin-top: 20px;
    font-size: clamp(14px, 1.71vw, 24px);
    line-height: calc(35 / 24);
    letter-spacing: 0.72px;
  }

  & span + span {
    margin-left: 0.6em;
  }
}

.menu__recommend-thumb {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: auto; /* 必要に応じて固定高さを指定 */
  text-align: center;

  @media (1040px <= width), print {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    width: 451px;
    /* margin-right: -90px; */
    /* margin-bottom: -50px; */
  }

  & img {
    height: auto;

    @media (1040px <= width), print {
      aspect-ratio: 451 / 445;
      width: 451px;
    }
  }
}

.menu__thumb {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: auto; /* 必要に応じて固定高さを指定 */
  text-align: center;

  @media (1040px <= width), print {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: auto; /* 必要に応じて指定 */
    z-index: 2;
    /* display: block; */
  }

  @media (768px <= width), print {
    .menu__thumb {
      width: 80%; /* 必要に応じて調整 */
    }
  }

  & img {
    @media (1040px <= width), print {
      max-width: none; /* カードの幅に影響されない */
      height: auto;
    }

    /* display: block;
    width: 100%;
    height: auto; */

    @media (width <= 320px), print {
      max-width: 92%;
    }
  }
}

.menu__items {
  display: flex;
  flex-direction: column;
  gap: 48px;

  flex-wrap: nowrap;
  justify-content: center;
  max-width: 1080px;
  margin: 48px auto 0;

  @media (1040px <= width), print {
    flex-direction: row;
    margin-top: calc(71px + 85px);
    max-width: calc(1080px + 20px * 2);
    padding-inline: 20px;
    padding-block: 0;
    margin-inline: auto;
    gap: 32px;
  }
}

.menu__item {
  position: relative;
  height: auto; /* コンテンツに応じた高さ */
  text-align: center;
  z-index: 1;

  @media (1040px <= width), print {
    padding-top: 220px; /* menu__thumb の高さに応じて調整 */
  }
}

.menu__item:nth-child(1) {
  & .menu__thumb img {
    @media (1040px <= width), print {
      width: 417px;
    }
  }
}

.menu__item:nth-child(2) {
  & .menu__thumb img {
    @media (1040px <= width), print {
      width: 427px;
    }
  }
}

.menu__card {
  margin-top: -40px;
  background-color: var(--cMain);
  padding: calc(10px - 1px);
  position: relative;
  z-index: -1;
  /* width: 524px; */
  margin-inline: auto;

  @media (1040px <= width), print {
    margin-top: 141px;
    width: 36.4vw;
    padding: calc(13px - 1px);
    z-index: 1;
    position: relative;
  }
}

.card__inner {
  color: var(--cBlack);
  border: 1px solid var(--cBlack);
  padding-top: 48px;
  /* padding-inline: calc(10px - 1px); */
  padding-bottom: calc(25px - 1px);
  text-align: center;
}

.menu__sns {
  margin-top: 48px;
  position: relative;

  @media (990px <= width), print {
    margin-top: 80px;
    max-width: calc(1080px + 20px * 2);
    padding-inline: 20px;
    margin-inline: auto;
  }
}

.sns__label {
  display: block;
  padding-inline: max(calc(9vw - 2px), calc(35px - 2px));
  padding-block: 10px 11px;
  text-align: center;
  color: #fff;
  border: 2px solid var(--cAccent);
  background: var(--cAccent);
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

.sns__title {
  font-family: var(--font-reross);
  font-size: 24px;
  text-transform: capitalize;
  line-height: calc(29 / 24);
  letter-spacing: 1.2px;
}

.sns__card {
  padding: 10px;
  background-color: var(--cMain);
  text-align: center;
  font-family: var(--font-noto-sans-jp);
  color: var(--cBlack);
  line-height: calc(23 / 16);

  @media (768px <= width), print {
    padding: 13px 14px 12px 13px;
  }
}

.sns__inner {
  border: 1px solid var(--cBlack);
  padding-block: 64px 24px;
  padding-inline: clamp(10px, 2.43vw, 35px);

  @media (768px <= width), print {
    padding-top: 88px;
  }
}

.sns__contents {
  margin-inline: auto;
}

.sns__text {
  letter-spacing: 0.8px;
  padding-inline: 22px;
  text-align: left;

  @media (768px <= width), print {
    font-size: clamp(17px, 1.25vw, 18px);
    line-height: calc(26 / 18);
    letter-spacing: 0.9px;
    padding-left: 51px;
    padding-right: 42px;
    position: relative;
    width: fit-content;
    margin: 0 auto;

    &::before,
    &::after {
      content: "";
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 35.8px;
      height: 1px;
      background: var(--cBlack);
    }

    &::before {
      left: 0;
      transform: rotate(60deg);
    }

    &::after {
      right: 0;
      transform: rotate(-60deg);
    }
  }
}

.sns__photosWrapper {
  overflow-x: auto;
}

.sns__photos {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr)); /* 2列の自動調整幅 */
  gap: 10px;
  max-width: 260px;
  margin: 24px auto 0;

  @media (768px <= width), print {
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    max-width: 972px;
  }
}

.sns__photo {
  width: 100%;
  max-width: 125px;
  aspect-ratio: 1 / 1;
  overflow: hidden;

  @media (768px <= width), print {
    width: 231px;
    max-width: none;
  }

  & img {
    width: 100%;
    height: 100%;
    object-fit: cover;

    @media (768px <= width), print {
      width: 231px;
    }
  }
}

.sns__id {
  margin-top: 8px;
  letter-spacing: 0.8px;
  text-align: center;

  @media (768px <= width), print {
    font-size: clamp(17px, 1.25vw, 18px);
    line-height: calc(26 / 18);
    letter-spacing: 0.9px;
  }
}

.menu__more {
  margin: 24px auto 0;
  max-width: 300px;

  @media (768px <= width), print {
    margin-top: 26px;
  }
}

.menu__button {
  position: relative;
  font-weight: 700;
  letter-spacing: 0.48px;
  padding: 16px 20px 17px;
  border: 1px solid var(--cBlack);
  min-width: 260px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 22px;
  transition: background-color 0.3s, color 0.3s;

  @media (768px <= width), print {
    min-width: 300px;
    gap: 23px;

    & img {
      width: 22px;
      height: 22px;
    }
  }
  .button__icon path {
    fill: var(--cBlack);
    transition: fill 0.3s;
  }

  @media (any-hover: hover) {
    &:hover {
      cursor: pointer;
      color: var(--cWhite);
      background-color: var(--cBlack);

      & .button__icon path {
        fill: var(--cWhite);
      }
    }
  }
}

/*-------------------------------
Shop
--------------------------------*/
.shop {
  padding-block: 64px;
  background-color: var(--cMain);

  @media (768px <= width), print {
    padding-block: 120px;
  }
}

.shop__inner {
  padding-inline: 16px;

  @media (768px <= width), print {
    padding-inline: 30px;
  }
}

.shop__map {
  margin-inline: calc(50% - 50vw);
}

.map__wrapper {
  overflow: hidden;
  max-width: 375px;
  margin-inline: auto;
  position: relative;
  margin-top: 56px;

  @media (768px <= width), print {
    max-width: 1440px;
    margin-top: 80px;
    height: 465px;
  }
}

.map__img {
  height: 250px;

  img {
    @media (768px <= width), print {
      width: 1440px;
      height: 465px;
      object-fit: cover;
    }
  }
}

.map__logo {
  position: absolute;
  left: calc(50% + 50px);
  bottom: min(16vw, 63px);
  display: block;

  @media (width <= 320px), print {
    left: auto;
    right: 16vw;
  }

  @media (768px <= width), print {
    width: 150px;
    height: auto;
    left: calc(50% + 175px);
    bottom: 156px;

    & img {
      width: 100%;
    }
  }
}

.shop__box {
  margin-top: 56px;
  position: relative;

  @media (768px <= width), print {
    margin-inline: auto;
    margin-top: 80px;
    max-width: calc(1080px + 20px * 2);
    padding-inline: 20px;
  }
}

.shop__body {
  @media (768px <= width), print {
    padding-block: 75px 76px;
  }
}

.shop__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;

  @media (768px <= width), print {
    flex-direction: row;
    gap: 0;
  }

  @media (768px <= width < 990px), print {
    flex-direction: column;
    align-items: flex-start;
  }
}

.shop__title--main {
  display: flex;
  gap: 4px;
  align-items: flex-end;
  font-family: var(--font-reross);
  font-size: 32px;
  line-height: 1;
  letter-spacing: 0.96px;

  @media (768px <= width), print {
    line-height: calc(28 / 32);
  }

  & span {
    text-transform: uppercase;
    font-size: 18px;

    @media (768px <= width), print {
      line-height: calc(22 / 18);
    }
  }
}

.shop__title--sub {
  font-family: var(--font-noto-sans-jp);
  line-height: calc(23 / 16);
  letter-spacing: 0.48px;

  @media (768px <= width), print {
    font-size: 18px;
    line-height: calc(26 / 18);
    letter-spacing: 0.54px;
  }
}

.shop__data {
  margin-top: 24px;
  margin-inline: auto;
  max-width: 319px;
  text-align: left;

  @media (768px <= width), print {
    margin-top: 25px;
    margin-inline: 0;
    width: 100%;
    max-width: calc(429 / 1080 * 100%);
  }
}

.shop__data1 {
}

.shop__data2 {
  margin-top: 5px;

  @media (768px <= width), print {
    margin-top: 17px;
  }

  & th,
  td {
    &:nth-child(1) {
      width: 75px;

      @media (768px <= width), print {
        width: 95px;
      }
    }
  }
}

.shop__data1,
.shop__data2 {
  & th,
  td {
    font-family: var(--font-noto-sans-jp);
    line-height: 1.7;
    letter-spacing: 0.48px;

    @media (768px <= width), print {
      font-size: 16px;
    }

    @media (900px <= width), print {
      font-size: 18px;
      line-height: 2;
      letter-spacing: 0.54px;
    }
  }
}
.shop__thumb {
  /* margin-top: 40px; */
  margin-inline: auto;

  @media (768px <= width), print {
    /* margin-top: 80px; */
    margin-inline: 0;
    position: absolute;
    top: 0;
    left: calc(50% + 20px);
    max-width: 700px;
    width: 100%;
  }

  & img {
    width: 100%;

    @media (768px <= width), print {
      width: 700px;
    }
  }
}

.shop__message {
  margin-top: 98px;
  background: #fff;
  box-shadow: 0px 4px 20px 0px rgb(161 159 159 / 0.6);

  @media (768px <= width), print {
    margin-top: 80px;
    max-width: 1146px;
    margin-inline: auto;
  }
}

.message-box {
  padding: 18px 10px 113px;
  position: relative;

  @media (768px <= width), print {
    padding: 30px 30px 41px 30px;
  }

  @media (768px <= width < 990px), print {
    padding-bottom: 13%;
  }
  @media (990px <= width < 1080px), print {
    padding-bottom: 10%;
  }
}

.message__images {
  display: flex;
  flex-direction: column;

  @media (768px <= width), print {
    flex-direction: row;
    max-width: 1080px;
    margin-inline: auto;
  }
}

.message__image {
  position: relative;

  @media (768px <= width), print {
    max-height: 430px;
    overflow: hidden;
  }

  &::after {
    content: "";
    display: block;
    border: solid 1px var(--cWhite);
    width: 91.3%;
    height: 90.7%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);

    @media (768px <= width), print {
      height: 91.1%;
    }
  }

  & img {
    width: 100%;
  }
}

.message__deco--stamp {
  position: absolute;
  top: -39px;
  left: -16px;

  @media (768px <= width), print {
    top: -71px;
    left: -97px;

    & img {
      width: 288px;
    }
  }
}

.message__body {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  position: relative;

  @media (768px <= width), print {
    margin-top: 27px;
    flex-direction: row;
    gap: 53px;
  }
}

.message__title {
  text-transform: capitalize;
  font-family: var(--font-satisfy);
  font-size: 30px;
  line-height: calc(43 / 30);
  letter-spacing: 1.5px;

  @media (768px <= width), print {
    font-size: 48px;
    line-height: calc(69 / 48);
    letter-spacing: 2.4px;
    flex-shrink: 0;
  }
}

.message__text {
  background-image: linear-gradient(180deg, #c4c4c4 1px, transparent 1px);
  background-size: 100% 40px;
  padding-bottom: 1px;
  color: #4f4f4f;
  font-family: var(--font-noto-sans-jp);
  line-height: 2.5;

  @media (768px <= width), print {
    margin-top: 18px;
    max-width: 595px;
    flex-grow: 1;
  }
}

.message__deco {
  padding-bottom: 6px;
  position: absolute;
  bottom: -45px;
  right: 0;
  font-family: var(--font-satisfy);
  color: var(--cAccent);
  border-bottom: 1px solid currentColor;
  font-size: 36px;
  line-height: calc(52 / 36);
  letter-spacing: 1.8px;
  transform: rotate(-6.175deg);

  @media (768px <= width), print {
    bottom: 0;
    font-size: 40px;
    letter-spacing: 2px;
  }

  @media (768px <= width < 990px), print {
    bottom: -30%;
  }

  @media (990px <= width < 1080px), print {
    bottom: -35%;
  }

  &::after {
    content: "";
    display: block;
    width: 100%;
    margin: -12px auto 0;
    border-top: 1px solid var(--cAccent);
  }
}

/*-------------------------------
Contact
--------------------------------*/

.contact {
  background-image: url(../img/bg_contact.jpg);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  padding-block: 64px;

  @media (768px <= width), print {
    padding-block: 130px;
  }
}

.contact__inner {
  background-color: var(--cMain);
  padding-block: 64px;
  padding-inline: 14px;
  margin-inline: auto;
  max-width: 800px;

  @media (768px <= width), print {
    padding-bottom: 72px;
  }
}

.contact__form {
  margin-top: 48px;

  @media (768px <= width), print {
    margin: 32px auto 0;
    max-width: 520px;
  }
}

.contact__text {
  font-family: var(--font-noto-sans-jp);
  line-height: calc(23 / 16);
  letter-spacing: 0.48px;

  @media (768px <= width), print {
    text-align: center;
  }
}

.contact__fields {
  margin-top: 32px;
  display: flex;
  flex-direction: column;
  gap: 32px;

  @media (768px <= width), print {
    margin-top: 48px;
  }
}

.contact__field {
}

.form-field {
}

.form-field__head {
  display: flex;
  gap: 10px;
  align-items: center;

  @media (768px <= width), print {
    gap: 16px;
  }
}

.form-field__label {
  font-family: var(--font-noto-sans-jp);
  line-height: calc(23 / 16);
  letter-spacing: 0.48px;

  @media (768px <= width), print {
    line-height: calc(22 / 18);
    font-size: 18px;
  }
}

.form-field__requreid {
  font-family: var(--font-noto-sans-jp);
  color: var(--cWhite);
  line-height: calc(17 / 12);
  font-size: 12px;
  border-radius: 6px;
  background: var(--cAccent);
  padding: 1px 7px 3px 8px;
}

.form-field__input {
  margin-top: 6px;

  @media (768px <= width), print {
    margin-top: 4px;
  }
}

.form-text {
  border: 1px solid var(--cBase);
  background: var(--cWhite);
  padding: 16px 13px 17px 16px;
  width: 100%;
  color: inherit;
  font-family: inherit;
  transition: border-color 0.3s, box-shadow 0.3s;

  @media (768px <= width), print {
    padding: 13px 23px 14px;
  }

  @media (hover: hover) {
    &:hover {
      border-color: var(--cAccent);
      box-shadow: 0px 0px 4px 0px var(--cAccent);
      outline: none;
    }
  }

  &:focus {
    border-color: var(--cAccent);
    box-shadow: 0px 0px 4px 0px var(--cAccent);
    outline: none;
  }
}

.form-field__input {
}

.form-textarea {
  border: 1px solid var(--cBase);
  background: var(--cWhite);
  padding: 16px 13px 17px 16px;
  width: 100%;
  color: inherit;
  font-family: inherit;
  resize: vertical;
  height: 160px;
  transition: border-color 0.3s, box-shadow 0.3s;

  @media (any-hover: hover) {
    &:hover {
      border-color: var(--cAccent);
      box-shadow: 0px 0px 4px 0px var(--cAccent);
      outline: none;
    }
  }

  &:focus {
    border-color: var(--cAccent);
    box-shadow: 0px 0px 4px 0px var(--cAccent);
    outline: none;
  }
}

.contact__privacy {
  margin-top: 32px;
  text-align: center;
}

.form-checkbox {
}

.form-checkbox__input {
  width: 1px;
  height: 1px;
  position: absolute;
  clip: rect(0, 0, 0, 0);
  overflow: hidden;
  transition: border-color 0.3s, box-shadow 0.3s;

  &:checked {
    + .form-checkbox__text {
      &::after {
        opacity: 1;
      }
    }
  }

  @media (hover: hover) {
    &:hover {
      & + .form-checkbox__text::before {
        border-color: var(--cAccent);
        box-shadow: 0px 0px 4px 0px var(--cAccent);
        outline: none;
      }
    }
  }

  &:focus {
    + .form-checkbox__text::before {
      border-color: var(--cAccent);
      box-shadow: 0px 0px 4px 0px var(--cAccent);
      outline: none;
    }
  }
}

.form-checkbox__text {
  font-family: var(--font-noto-sans-jp);
  line-height: 1.5;
  letter-spacing: 0.8px;
  position: relative;
  padding-left: calc(13px + 30px);
  transition: border-color 0.3s, box-shadow 0.3s;

  @media (768px <= width), print {
    font-size: 18px;
    letter-spacing: 0.9px;
  }
  & button {
    color: var(--cAccent);
    text-decoration-line: underline;
    font-family: inherit;
    transition: opacity 0.3s, border-color 0.3s, box-shadow 0.3s;

    @media (any-hover: hover) {
      &:hover {
        opacity: 0.7;
        cursor: pointer;
      }
    }

    &:focus {
      border-color: var(--cAccent);
      box-shadow: 0px 0px 4px 0px var(--cAccent);
      outline: none;
    }
  }

  &::before,
  &::after {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
  }

  &::before {
    width: 30px;
    height: 30px;
    border-radius: 1px;
    border: 1px solid var(--cBase);
    background-color: var(--cWhite);
    transition: border-color 0.3s, box-shadow 0.3s;
  }

  &::after {
    width: 24px;
    height: 18px;
    left: 3px;
    background: url(../img/icon_check.png) no-repeat center center / contain;
    opacity: 0;
  }
}

.contact__submit {
  margin: 40px auto 0;
  text-align: center;
  max-width: 300px;

  @media (768px <= width), print {
    max-width: 239px;
  }
}

.contact__btn {
  padding: calc(15px - 1px) calc(20px - 1px) calc(14px - 1px);
  width: 100%;
  font-family: var(--font-noto-sans-jp);
  color: var(--cWhite);
  font-size: 18px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.9px;
  background-color: var(--cAccent);
  transition: opacity 0.3s, background-color 0.3s;

  [aria-disabled="true"] {
    cursor: not-allowed;
    background: #bdbdbd;
  }

  @media (any-hover: hover) {
    &:hover {
      opacity: 0.7;
      cursor: pointer;
    }
  }

  &:focus {
    border-color: var(--cAccent);
    box-shadow: 0px 0px 4px 0px var(--cAccent);
    outline: none;
  }
}

.is-disabled {
  cursor: not-allowed;
  background: #bdbdbd;
}

/*-------------------------------
Footer
--------------------------------*/
.footer {
  background: var(--cMain);
  padding: 48px 20px 10px;
  position: relative;

  @media (768px <= width), print {
    padding-block: 56px 9px;
  }
}

.footer__contents {
  display: flex;
  flex-direction: column-reverse;
}

.footer__nav {
  margin-top: 41px;
}

.footer__navItems {
  display: flex;
  gap: 32px;
  align-items: center;
  justify-content: center;

  @media (768px <= width), print {
    gap: 40px;
  }
}

.footer__link {
  position: relative;
  font-family: var(--font-reross);
  line-height: calc(19 / 16);
  letter-spacing: 0.48px;
  text-transform: capitalize;
  /* transition: opacity 0.3s; */

  @media (768px <= width), print {
    font-size: 18px;
    line-height: calc(22 / 18);
    letter-spacing: 0.54px;
  }

  &::after {
    background-color: var(--cAccent);
    bottom: -6px;
    content: "";
    height: 2px;
    left: 0;
    position: absolute;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform 0.3s;
    width: 100%;
  }

  @media (any-hover: hover) {
    &:hover::after {
      transform-origin: left top;
      transform: scale(1, 1);
    }
  }
}

.footer__sns {
  display: flex;
  gap: 40px;
  justify-content: center;
}

.sns__icon {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background-color: var(--cBase);
  display: grid;
  place-items: center;
  transition: color 0.3s, background-color 0.3s;

  @media (768px <= width), print {
    width: 40px;
    height: 40px;
  }

  @media (any-hover: hover) {
    &:hover {
      border: 2px solid var(--cBase);
      background-color: var(--cWhite);
      cursor: pointer;
    }
  }

  @media (any-hover: hover) {
    &:hover {
      .twitter-icon,
      .instagram-icon,
      .tiktok-icon {
        color: var(--cBase);
      }
    }
  }
}

.twitter-icon {
  font-size: 39px;
  color: var(--cWhite);

  @media (768px <= width), print {
    font-size: 31px;
  }
}

.instagram-icon {
  font-size: 33px;
  color: var(--cWhite);

  @media (768px <= width), print {
    font-size: 26px;
  }
}

.tiktok-icon {
  font-size: 26px;
  color: var(--cWhite);

  @media (768px <= width), print {
    font-size: 21px;
  }
}

.footer__logo {
  margin-top: 34px;
  text-align: center;
  transition: opacity 0.3s;

  @media (768px <= width), print {
    margin-top: 36px;
  }

  @media (any-hover: hover) {
    &:hover {
      opacity: 0.7;
      cursor: pointer;
    }
  }

  img {
    margin-inline: auto;
  }
}

.footer__copyright {
  margin-top: 29px;
  text-align: center;
  font-family: var(--font-noto-sans-jp);
  font-size: 12px;
  line-height: calc(14 / 12);
  letter-spacing: 0.36px;

  @media (768px <= width), print {
    margin-top: 20px;
  }
}

.page-top {
  position: absolute;
  top: -35px;
  right: 16px;
  display: grid;
  place-items: center;
  width: 70px;
  height: 70px;
  border-radius: 50%;
  border: 2px solid var(--cBlack);
  background-color: var(--cWhite);

  @media (768px <= width), print {
    top: -60px;
    width: 120px;
    height: 120px;
  }
}

.page-top__icon {
  width: 32px;
  height: 32px;

  @media (768px <= width), print {
    width: 49px;
    height: 49px;
  }
}

.page-top__text {
  margin-top: -15px;
  font-family: var(--font-reross);
  font-size: 12px;
  line-height: calc(14 / 12);
  letter-spacing: 0.36px;

  @media (768px <= width), print {
    margin-top: -40px;
    font-size: 16px;
    line-height: calc(19 / 16);
    letter-spacing: 0.48px;
  }
}

/*-------------------------------
modal
--------------------------------*/
.contact-modal {
  background: var(--cWhite);
  box-shadow: 0px 4px 30px 0px rgba(0, 0, 0, 0.25);
  position: fixed;
  inset: 0;
  margin: auto;
  max-width: calc(100% - 15px * 2);
  height: calc(100svh - 20px * 2);
  overflow: auto;
  padding-block: 35px;
  border: none;
  z-index: 60;

  @media (768px <= width), print {
    max-width: 929px;
  }

  &::backdrop {
    opacity: 0.3;
    background: var(--cWhite);
  }
}
.contact-modal__head {
  position: relative;
  padding-inline: 23px;

  .heading__main {
    font-size: 24px;
    line-height: calc(29 / 24);

    &::after {
      margin-top: 10px;
    }
  }

  .heading__sub {
    font-size: 12px;
    line-height: calc(14 / 12);
    margin-bottom: 8px;
  }
}
.contact-modal__close-icon {
  position: absolute;
  top: 0;
  right: 0;
}

.contact-modal__body {
  margin-top: 40px;

  p + p {
    margin-top: 8px;
  }

  & h3 {
    font-weight: 600;
    font-size: 18px;

    &:nth-child(n + 2) {
      margin-top: 20px;
    }
  }

  @media (768px <= width), print {
    padding-inline: 62px;
  }
}
