/* ==================================================
  06 SHRINE
  神社での七五三撮影について
  ファイル名：06-shrine.css

  目的：
  - 06を確実に表示させる
  - 04 STYLE の見出しトーンを使いながら、06は軽めに見せる
  - 下部3つの写真メニューで、写真＋説明文を切り替える
  - スマホでは下部メニューも横並び3列
  - スマホでは「01 ルール」などを画像内に表示
================================================== */

.yp-shichigosan-shrine,
.yp-shichigosan-shrine * {
  box-sizing: border-box;
}

.yp-shichigosan-shrine {
  display: block !important;
  position: relative;
  width: 100%;
  padding: clamp(90px, 10vw, 140px) 0 clamp(100px, 11vw, 150px);
  background: #ffffff;
  color: #222;
  overflow: hidden;
}

/* ==================================================
  04 STYLE の見出し系を06内でも安定表示
================================================== */

.yp-shichigosan-shrine .yp-selected-reasons__inner {
  width: min(1120px, calc(100% - 40px));
  margin: 0 auto;
}

.yp-shichigosan-shrine .yp-selected-reasons__head {
  display: grid;
  grid-template-columns: minmax(260px, 0.8fr) minmax(0, 1.2fr);
  gap: clamp(32px, 6vw, 80px);
  align-items: end;
  margin-bottom: clamp(46px, 7vw, 80px);
}

.yp-shichigosan-shrine .yp-selected-reasons__title-wrap {
  position: relative;
}

.yp-shichigosan-shrine .yp-selected-reasons__label {
  margin: 0 0 14px !important;
  padding: 0 !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
  letter-spacing: 0.22em !important;
  color: #777 !important;
  font-weight: 400 !important;
}

.yp-shichigosan-shrine .yp-selected-reasons__title {
  margin: 0 !important;
  padding: 0 !important;
  font-size: clamp(30px, 4.2vw, 56px) !important;
  line-height: 1.45 !important;
  letter-spacing: 0.08em !important;
  font-weight: 400 !important;
  color: #222 !important;
  border: 0 !important;
  background: none !important;
  box-shadow: none !important;
}

.yp-shichigosan-shrine .yp-selected-reasons__title::before,
.yp-shichigosan-shrine .yp-selected-reasons__title::after {
  display: none !important;
  content: none !important;
}

.yp-shichigosan-shrine .yp-selected-reasons__sub-label {
  margin: 18px 0 0 !important;
  padding: 0 !important;
  font-size: 12px !important;
  line-height: 1.7 !important;
  letter-spacing: 0.18em !important;
  color: #999 !important;
}

.yp-shichigosan-shrine .yp-selected-reasons__lead p {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 14px !important;
  line-height: 2.2 !important;
  letter-spacing: 0.06em !important;
  color: #555 !important;
}

/* ==================================================
  06 切り替え本体
================================================== */

.yp-shrine-switcher {
  display: block !important;
  width: min(1120px, calc(100% - 40px));
  margin: 0 auto;
}

.yp-shrine-switcher__detail {
  display: block !important;
  position: relative;
  width: 100%;
}

.yp-shrine-switcher__panel {
  display: none !important;
  width: 100%;
}

.yp-shrine-switcher__panel.is-active {
  display: block !important;
}

.yp-shrine-switcher__content {
  display: grid !important;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(34px, 5vw, 70px);
  align-items: center;
}

.yp-shrine-switcher__text {
  display: block !important;
  padding: 10px 0;
}

.yp-shrine-switcher__number {
  margin: 0 0 16px !important;
  padding: 0 !important;
  font-size: 13px !important;
  line-height: 1 !important;
  letter-spacing: 0.2em !important;
  color: #777 !important;
  font-weight: 400 !important;
}

.yp-shrine-switcher__title {
  margin: 0 0 22px !important;
  padding: 0 !important;
  font-size: clamp(24px, 3.1vw, 40px) !important;
  line-height: 1.55 !important;
  letter-spacing: 0.08em !important;
  font-weight: 400 !important;
  color: #222 !important;
  border: 0 !important;
  background: none !important;
  box-shadow: none !important;
}

.yp-shrine-switcher__title::before,
.yp-shrine-switcher__title::after {
  display: none !important;
  content: none !important;
}

.yp-shrine-switcher__body {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 14px !important;
  line-height: 2.15 !important;
  letter-spacing: 0.055em !important;
  color: #555 !important;
}

.yp-shrine-switcher__image {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 100%;
  overflow: hidden;
  background: #f7f7f7;
}

.yp-shrine-switcher__image img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 3 / 2;
  object-fit: cover;
  border: 0 !important;
  box-shadow: none !important;
}

/* ==================================================
  下部 写真メニュー（PC）
================================================== */

.yp-shrine-switcher__nav {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(14px, 2.4vw, 26px);
  margin-top: clamp(36px, 5vw, 58px);
}

.yp-shrine-switcher__nav-button {
  display: block !important;
  position: relative;
  width: 100%;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: inherit !important;
  text-align: left;
  cursor: pointer;
  opacity: 0.48;
  transform: translateY(0);
  transition:
    opacity 0.28s ease,
    transform 0.28s ease;
}

.yp-shrine-switcher__nav-button:hover,
.yp-shrine-switcher__nav-button:focus {
  opacity: 0.85;
  outline: none;
}

.yp-shrine-switcher__nav-button.is-active {
  opacity: 1;
  transform: translateY(-4px);
}

.yp-shrine-switcher__nav-button img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 3 / 2;
  object-fit: cover;
  margin: 0 0 12px !important;
  padding: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  background: #f7f7f7;
}

.yp-shrine-switcher__nav-button span {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 13px !important;
  line-height: 1.8 !important;
  letter-spacing: 0.08em !important;
  color: #333 !important;
}

/* ==================================================
  SP
================================================== */

@media screen and (max-width: 767px) {
  .yp-shichigosan-shrine {
    padding: 82px 0 96px;
  }

  .yp-shichigosan-shrine .yp-selected-reasons__inner,
  .yp-shrine-switcher {
    width: calc(100% - 30px);
  }

  .yp-shichigosan-shrine .yp-selected-reasons__head {
    display: block;
    margin-bottom: 38px;
  }

  .yp-shichigosan-shrine .yp-selected-reasons__title {
    font-size: clamp(28px, 8vw, 38px) !important;
    line-height: 1.5 !important;
  }

  .yp-shichigosan-shrine .yp-selected-reasons__lead {
    margin-top: 28px;
  }

  .yp-shichigosan-shrine .yp-selected-reasons__lead p {
    font-size: 13px !important;
    line-height: 2.05 !important;
  }

  .yp-shrine-switcher__content {
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .yp-shrine-switcher__image {
    order: -1;
  }

  .yp-shrine-switcher__title {
    font-size: clamp(23px, 7vw, 32px) !important;
    line-height: 1.55 !important;
    margin-bottom: 16px !important;
  }

  .yp-shrine-switcher__body {
    font-size: 13px !important;
    line-height: 2.05 !important;
  }

  /* ==============================================
    ▼ スマホ画像メニュー 横並び3列
    ▼ テキストは画像内に表示
  ============================================== */

  .yp-shrine-switcher__nav {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-top: 30px;
  }

  .yp-shrine-switcher__nav-button {
    display: block !important;
    position: relative;
    opacity: 0.72;
    transform: none;
  }

  .yp-shrine-switcher__nav-button.is-active {
    opacity: 1;
    transform: none;
  }

  .yp-shrine-switcher__nav-button img {
    display: block !important;
    width: 100% !important;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    margin: 0 !important;
  }

  .yp-shrine-switcher__nav-button span {
    position: absolute;
    left: 8px;
    right: 8px;
    bottom: 8px;
    display: inline-block !important;
    margin: 0 !important;
    padding: 6px 8px !important;
    font-size: 11px !important;
    line-height: 1.4 !important;
    letter-spacing: 0.08em !important;
    color: #ffffff !important;
    background: rgba(0, 0, 0, 0.45);
    text-align: left;
    z-index: 2;
  }
}