/* 下層ページのセクション共通スタイルを上書き */
body.sub-page section {
  margin-top: 0;
  padding: 0;
  background-color: transparent;
}

/* 下層ページのページタイトル */
body.sub-page .main-visual .page-title {
  position: absolute;
  top: 48%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: auto;
  max-width: 522px;
  z-index: 10;
}

body.sub-page .main-visual .page-title img {
  width: 100%;
  height: auto;
}

@media screen and (max-width: 834px) {
  body.sub-page .main-visual .page-title {
    max-width: 270px;
    top: calc(50% - 110px);
    transform: translate(-50%, -50%);
  }
}

@media screen and (max-width: 550px) {
  body.sub-page .main-visual .page-title {
    width: 165px;
  }
}

/* SP（480px以下）でのファーストビュー調整 */
@media screen and (max-width: 480px) {
  body.sub-page .main-visual .image-container {
    position: absolute !important;
    top: 0 !important;
    right: 6.5% !important;
    bottom: 200px !important;
    left: 6.5% !important;
    width: auto !important;
    height: auto !important;
    overflow: hidden !important;
    z-index: 5 !important;
  }
}

/* 下層ページのロゴ位置 */
body.sub-page .logo-container {
  position: absolute;
  top: 83px;
  left: 105px;
  z-index: 20;
}

body.sub-page .logo-lower {
  max-width: 90px;
  width: 90px;
}

@media screen and (max-width: 834px) {
  body.sub-page .logo-container {
    position: static;
    top: auto;
    left: auto;
    z-index: 20;
    margin-top: 22px;
  }

  body.sub-page .logo-lower {
    max-width: 104px;
    width: 104px;
    height: auto;
  }

  body.sub-page .hamburger-menu {
    top: 25px !important;
    right: 5% !important;
    width: 34px !important;
  }
}

/* SP（480px以下）でのヘッダー調整 */
@media screen and (max-width: 480px) {
  body.sub-page .sidebar-inner {
    width: 87% !important;
  }

  body.sub-page .hamburger-menu {
    top: 25px !important;
    right: 6% !important;
    width: 34px !important;
  }
}

/* タブレット以下でセクションの位置調整 */
@media screen and (max-width: 834px) {
  body.sub-page section:first-of-type {
    margin-top: calc(100vh - 82px);
  }

  /* アーカイブページ：セクションが見えないように調整 */
  body.archive-page .archive-section {
    margin-top: 98vh !important;
  }
}



/* タブレット（834px以下） */
@media screen and (max-width: 834px) {
  body.sub-page .floor-map-section {
    padding: 45px 0;
  }

  /* タブレットでのタイトル調整 */
  body.archive-page .archive-title {
    font-size: 36px;
    margin-bottom: 20px;
  }

  /* タブレットでの波線調整 */
  body.archive-page .archive-wave {
    margin-bottom: 15px;
  }

  body.archive-page .archive-wave .pc-image {
    display: none;
  }

  body.archive-page .archive-wave .tab-image {
    display: inline-block;
  }

  /* タブレットでのフッター調整 */
  body.archive-page .site-footer {
    width: 100%;
    padding: 90px 0 30px !important;
    position: relative;
  }
}

/* SP（480px以下） */
@media screen and (max-width: 480px) {
  body.sub-page .floor-map-section {
    padding: 50px 0;
  }

  /* ラップ幅の調整 */
  .wrapper-790,
  .wrapper-1172,
  .wrapper-1272 {
    width: 87%;
  }

  /* アーカイブセクションの余白調整 */
  body.archive-page .archive-section {
    padding: 50px 0 0px;
    margin-top: 89vh !important;
  }

  /* SPタイトル */
  body.archive-page .archive-title {
    font-size: clamp(18px, 5.33vw, 22px);
    margin-bottom: 13px;
  }

  /* SP波線 */
  body.archive-page .archive-wave {
    margin-bottom: 9px;
  }

  body.archive-page .archive-wave .pc-image {
    display: none;
  }

  body.archive-page .archive-wave .tab-image {
    display: none;
  }

  body.archive-page .archive-wave .sp-image {
    display: inline-block;
  }

  /* SP本文 */
  body.archive-page .archive-text {
    margin-bottom: 26px;
  }

  body.archive-page .archive-text p {
    font-size: 14px;
    text-align: left;
  }

  /* SPアイコン */
  body.archive-page .archive-icon {
    margin-bottom: 8px;
  }

  body.archive-page .archive-icon img {
    width: 33px;
    height: 33px;
  }

  /* SPフッター調整 */
  body.archive-page .site-footer {
    padding: 70px 0 30px !important;
  }
}

/* アーカイブセクション */
.archive-section {
  padding: 84px 0 70px;
  background-color: #ffffff;
  position: relative;
  margin-top: 100vh;
  z-index: 10;
  /* リロード時の表示を制御 */
  opacity: 0;
  animation: fadeInSection 0.3s ease-out 0.3s forwards;
}

/* セクションのフェードインアニメーション */
@keyframes fadeInSection {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/* アーカイブタイトル */
.archive-title {
  text-align: center;
  margin-bottom: 23px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  font-size: 40px;
  color: #474646;
  line-height: 1;
}

/* アーカイブ波線 */
.archive-wave {
  text-align: center;
  margin-bottom: 19px;
  line-height: 0;
}

.archive-wave img {
  width: auto;
  height: auto;
  display: inline-block;
}

.archive-wave .sp-image,
.archive-wave .tab-image {
  display: none;
}

/* アーカイブ本文 */
.archive-text {
  text-align: center;
  margin-bottom: 29px;
}

.archive-text p {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.8;
  color: #474646;
  margin: 0;
}

/* アーカイブアイコン */
.archive-icon {
  text-align: center;
  margin-bottom: 10px;
}

.archive-icon a {
  display: inline-block;
}

.archive-icon img {
  width: 44px;
  height: 44px;
  display: block;
}

/* アーカイブページ専用フッター設定 */
body.archive-page .site-footer {
  width: 100%;
  padding: 140px 0 30px;
  position: relative;
}

/* タブレット（834px以下）でフッターを上書き */
@media screen and (max-width: 834px) {
  body.archive-page .site-footer {
    padding: 90px 0 30px !important;
  }
}