main {
  margin: 0 0 0 0;
  max-width: 1920px;
  min-width: 1366px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: hidden;
}

img {
  max-width: 1920px;
}

.backgroundWaves {
  z-index: -2;
  position: absolute;
  width: 100%;
  min-width: 1366px;
  height: 6000px;
  overflow: hidden;
}

.backgroundWaves__item1 {
  z-index: -1;
  position: absolute;
  top: 1415px;
  left: 57%;
  width: 113%;
  overflow: hidden;
}

.backgroundWaves__item2 {
  z-index: -1;
  position: absolute;
  top: 2915px;
  left: -42.3%;
  width: 113%;
  transform: scaleX(-1);
}

.backgroundWaves__item3 {
  z-index: -1;
  position: absolute;
  top: 4480px;
  left: 52%;
  width: 113%;
  overflow: hidden;
}

.backgroundWaves__item4 {
  z-index: -1;
  position: absolute;
  width: 100%;
  top: 5460px;
  left: -5.2%;
  width: 113%;
  transform: scale(-1, -1);
}

.main__top {
  width: 100%;
  height: 200px;
  position: relative;
}

.main__top__title {
  position: absolute;
  top: 20px;
  left: 21%;
  color: #3b3b3b;
  font-size: 50px;
  font-family: "NotoSerifJP-Medium", "Noto Serif JP";
  font-weight: 300;
  letter-spacing: 0.08em;
}

.main__top__nav {
  position: absolute;
  top: 100px;
  left: 69%;
}

.main__top__nav__upperPages {
  color: #bfbfbf;
  font-size: 16px;
  font-family: "NotoSansJP-Medium", "Noto Sans JP";
}

.main__top__nav__thisPage {
  color: #222;
  font-size: 16px;
  font-family: "NotoSansJP-Medium", "Noto Sans JP";
}

.content {
  margin: 0 auto 0 auto;
  width: 1110px;
}

.content__section {
  margin: 160px 0 0 0;
  display: flex;
}

.content__number__container {
  width: 0;
  height: 0;
  position: relative;
}

.content__number {
  position: absolute;
  z-index: -1;
  color: #9f7b4f;
  font-size: 110px;
  font-family: "Cormorant-Light", "Cormorant";
  font-weight: 300;
  letter-spacing: -0.02em;
}

.content__number__1 {
  top: -166px;
  left: -46px;
}

.content__number__2 {
  top: -166px;
  left: -46px;
}

.content__number__3 {
  top: -184px;
  left: -51px;
  z-index: -1;
}

.content__number__4 {
  top: -188px;
  left: -43px;
}

.content__number__line {
  position: absolute;
  top: 28px;
  left: -39px;
  width: 130px;
  height: 1px;
  background: #000;
  transform: rotate(-44deg);
}

.content__image {
  max-width: 555px;
}

.content__filler {
  width: 100px;
}

.content__text {
  width: 465px;
}

.content__text__caption {
  margin-top: 150px;
  color: #3b3b3b;
  font-size: 35px;
  font-family: "NotoSerifJP-Medium", "Noto Serif JP";
  letter-spacing: 0.08em;
}

.content__text__p {
  margin-top: 40px;
  color: #222;
  font-size: 16px;
  font-family: "NotoSansJP-Regular", "Noto Sans JP";
  letter-spacing: 0.03em;
  line-height: 2.2;
}

.content__menu {
  margin-top: 150px;
}

.content__menu__upperLines {
  width: 100%;
  display: flex;
  align-items: center;
}

.content__menu__upperLines__line {
  width: 444px;
  height: 1px;
  background: #a23d3d;
}

.content__menu__upperLines__menu {
  width: 224px;
  color: #a23d3d;
  font-size: 50px;
  font-family: "RobotoCondensed-Light", "Roboto Condensed";
  font-weight: 300;
  letter-spacing: 0.08em;
  text-align: center;
}

.content__menu__grid__container {
  margin: 15px 0 40px 0;
  width: 100%;
  height: 465px;
  background: #faf9f7;
  display: flex;
  align-items: center;
  justify-content: center;
}

.content__menu__grid {
  margin: auto;
  width: 950px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.content__menu__grid__item {
  padding: 19px 0;
  width: 285px;
  border-bottom: #d6d4d1 1px solid;
  color: #222;
  font-size: 20px;
  font-family: "NotoSansJP-Regular", "Noto Sans JP";
  letter-spacing: 0.03em;
}

.content__menu__grid__item__middleDot {
  color: #9f7b4f;
}

.content__menu__grid__item span{
  font-size: 14px;
  font-family: "NotoSansJP-Regular", "Noto Sans JP";
}

.content__menu__lowerLine {
  width: 100%;
  height: 1px;
  background: #a23d3d;
}

.content__menu__note {
  margin-top: 15px;
  color: #6f6f6f;
  font-size: 13px;
  font-family: "NotoSansJP-Regular", "Noto Sans JP";
}

.visitArea {
  margin-top: 200px;
  width: 100%;
  height: 505px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.visitArea__image {
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
  width: 1920px;
}

.visitArea__image__mask {
  z-index: 2;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0.7;
}

.visitArea__content {
  z-index: 3;
  width: 350px;
  height: 350px;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
}

.visitArea__content__title {
  color: #fff;
  font-size: 30px;
  font-family: "RobotoCondensed-Light", "Roboto Condensed";
  font-weight: 300;
  letter-spacing: 0.08em;
}

.visitArea__content__title:before {
  content: "";
  position: absolute;
  width: 24px;
  height: 1px;
  background: #fff;
  transform: translate(-33px, 20px);
  transform-origin: left center;
}

.visitArea__content__title:after {
  content: "";
  position: absolute;
  width: 24px;
  height: 1px;
  background: #fff;
  transform: translate(3px, 20px);
  transform-origin: right center;
}

.visitArea__content__japaneseTitle {
  color: #fff;
  font-size: 40px;
  font-family: "NotoSerifJP-Medium", "Noto Serif JP";
  letter-spacing: 0.08em;
}

.visitArea__content__text {
  color: #fff;
  font-size: 20px;
  font-family: "NotoSansJP-Regular", "Noto Sans JP";
  letter-spacing: 0.03em;
}

.visitArea__content__button {
  width: 350px;
  height: 80px;
  background: #fff;
  color: #3b3b3b;
  font-size: 20px;
  font-family: "NotoSansJP-Regular", "Noto Sans JP";
  letter-spacing: 0.08em;
  position: relative;
  transition: all 0.3s;
}

.visitArea__content__button:hover {
  background: #9f7b4f;
  cursor: pointer;
  color: #fff;
}

.visitArea__content__button__arrow {
  position: absolute;
  top: 50%;
  right: 25px;
  transform: translate(0, -50%);
  width: 16.12px;
  height: 10.7px;
}

.visitArea__content__button:hover .visitArea__content__button__arrow__blackArrow {
  display: none;
}

.visitArea__content__button__arrow__whiteArrow {
  display: none;
}

.visitArea__content__button:hover .visitArea__content__button__arrow__whiteArrow {
  display: block;
}

.content__otherPages {
  margin: 200px auto;
  width: 860px;
  display: flex;
  justify-content: space-around;
}

.content__otherPages__item {
  width: 262px;
  height: 176px;
  display: flex;
  flex-direction: column;
  transition: opacity 0.5s;
}

.content__otherPages__item__image {
  width: 100%;
  height: 124px;
}

.content__otherPages__item__text {
  height: 52px;
  background: #9f7b4f;
  color: #fff;
  display: flex;
  align-items: center;
  padding-left: 15px;
  position: relative;
  font-family: "NotoSerifJP-Medium", "Noto Serif JP";
}

.content__otherPages__item__text__arrow {
  position: absolute;
  top: 50%;
  right: 15px;
  transform: translate(0, -50%);
  width: 16.12px;
  height: 10.7px;
}

