@charset "UTF-8";

/* ==========================================
    html（フォント）
   ========================================== */
/* 〜768px */
@media (max-width: 768px) {
  html {
    font-size: min(4.2666667vw, 24px);
  }
}

/* 769px〜1220px */
@media (min-width: 769px) and (max-width: 1220px) {
  html {
    font-size: calc(12px + (16 - 12) * (100vw - 769px) / (1220 - 769));
  }
}

/* 1220px〜 */
@media (min-width: 1180px) {
  html {
    font-size: 16px;
  }
}

/* ==========================================
    footer
   ========================================== */
@media (max-width: 768px) {
  footer p {
    font-size: 16px;
    font-family: "Noto Sans JP", sans-serif;
  }
}

header {
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.12em;
}

/* ==========================================
    横スクロール防止
   ========================================== */
@media (min-width: 769px) {
  #footerWrap {
    min-width: initial;
  }

  .w1200 {
    width: initial;
    max-width: 1240px;
    padding-inline: 20px;
    padding-inline: 1.25rem;
    margin-inline: auto;
  }
}

@media (min-width: 769px) and (max-width: 1180px) {
  .mainMenuIn ul {
    max-width: 470px;
    gap: 0.5rem;
  }

  header {
    letter-spacing: 0em;
  }

  #logo_img {
    width: 250px;
    width: 15.625rem;
    margin-top: 23px;
  }
}

/* ==========================================
    基本スタイル
   ========================================== */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

body {
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  letter-spacing: 0;
  color: var(--color-black);
  min-width: initial;
}

ul,
ol {
  padding: 0;
}

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

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 400;
}

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

ul,
ol {
  list-style: none;
}

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

a {
  text-decoration: none;
}

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

article > * + * {
  margin-top: 1em;
}

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

img:not([alt]) {
  -webkit-filter: blur(10px);
  filter: blur(10px);
}

input,
button,
select,
textarea {
  font: inherit;
  border: none;
  border-radius: 0;
  outline: none;
  background: transparent;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

textarea {
  resize: vertical;
}

input[type="submit"],
input[type="button"],
label,
button,
select {
  cursor: pointer;
}

select::-ms-expand {
  display: none;
}

a[href^="tel:"] {
  pointer-events: auto;
}

@media (min-width: 769px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}

a {
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

@media (any-hover: hover) {
  a:hover {
    opacity: 0.8;
  }
}

iframe {
  vertical-align: bottom;
  width: 100%;
  height: auto;
}

img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* WordPress 管理バーを下方に移動 */

#wpadminbar {
  position: fixed;
  bottom: 0;
  top: auto;
  /* 上部からの固定を無効化 */
  z-index: 9999;
  /* 他の要素の上に表示 */
  visibility: hidden;
}

/* 管理バーがある場合のみ適用 */

html {
  margin-top: 0 !important;
  /* 上部余白をリセット */
}

body.admin-bar {
  margin-bottom: 32px;
  /* 管理バーの高さ分の余白を追加 */
  margin-bottom: 0;
}

.splide__slide {
  -webkit-text-size-adjust: 100%;
}

/* ==========================================
    CSS変数
   ========================================== */
:root {
  --color-black: #000000;
  --color-text: #1a1311;
  --color-text02: #000e22;
  --color-text03: #333;
  --color-green: #43a949;
  --color-bg-green: #96b967;
  --color-bg-green2: #e6eedf;
  --color-orange: #f08d37;
  --color-white: #fff;
}

/* ==========================================
    改行
   ========================================== */
.u-sp {
  display: block;
}

.u-sm {
  display: block;
}

.u-pc {
  display: none;
}

.u-sp-lg {
  display: block;
}

@media (min-width: 525px) {
  .u-sm {
    display: none;
  }
}

@media (min-width: 769px) {
  .u-sp {
    display: none;
  }

  .u-pc {
    display: block;
  }

  .u-sp-lg {
    display: none;
  }
}

@media (min-width: 1220px) {
  .u-sp-lg {
    display: block;
  }
}

/* ==========================================
    インナー
   ========================================== */
.reien-inner {
  max-width: 650px;
  margin-inline: auto;
  padding-inline: 20px;
  padding-inline: 1.25rem;
}

@media (min-width: 769px) {
  .reien-inner {
    max-width: 1220px;
    /* max-width: 76.25rem; */
    padding-inline: 20px;
    padding-inline: 1.25rem;
  }
}

/* ==========================================
    FV
   ========================================== */
.reien-fv {
  padding-top: 16px;
  padding-top: 1rem;
  background-color: var(--color-bg-green2);
  overflow: hidden;
}

.reien-fv__title {
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: calc(24 / 17);
  text-align: center;
}

.reien-fv__image-wrapper {
  position: relative;
  width: 100%;
  margin-inline: auto;
  margin-top: 19.5px;
  margin-top: 1.21875rem;
}

.reien-fv__image {
  aspect-ratio: 67/38;
}

.reien-fv__sub-title {
  position: absolute;
  bottom: 27px;
  bottom: 1.6875rem;
  left: 8px;
  left: 0.5rem;
  z-index: 1;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: calc(27 / 15);
}

.reien-fv__sub-title .bg-beige {
  background-color: #f7f3e5;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  box-shadow: 0px 0.1875rem 0.375rem rgba(0, 0, 0, 0.16);
  padding: 3.5px 0px 3.5px 1.5px;
  padding: 0.21875rem 0 0.21875rem 0.09375rem;
  display: block;
  width: fit-content;
  line-height: 1;
}

.reien-fv__sub-title .bg-beige + .bg-beige {
  margin-top: 6px;
  margin-top: 0.375rem;
}

.reien-fv__sub-title .kerning {
  letter-spacing: -0.1em;
}

.reien-fv__decoration01-wrapper {
  position: absolute;
  left: -11.15px;
  left: -0.69375rem;
  top: -32.5px;
  top: -2.03125rem;
  width: 69.72px;
  width: 4.3575rem;
}

.reien-fv__decoration02-wrapper {
  position: absolute;
  top: -17.5px;
  top: -1.09375rem;
  right: 0;
  width: 63.79px;
  width: 3.986875rem;
}

@media (min-width: 769px) {
  .reien-fv {
    padding-top: 26.9px;
    padding-top: 1.68125rem;
  }

  .reien-fv__title {
    font-size: 36px;
    font-size: 2.25rem;
    line-height: calc(48 / 36);
  }

  .reien-fv__image-wrapper {
    margin-top: 54.9px;
    margin-top: 3.43125rem;
  }

  .reien-fv__image {
    aspect-ratio: 1180/435.26;
  }

  .reien-fv__sub-title-wrapper {
    max-width: 980px;
    /* max-width: 61.25rem; */
    margin-inline: auto;
    position: relative;
  }

  .reien-fv__sub-title {
    bottom: 182px;
    bottom: 11.375rem;
    left: 0;
    font-size: 30px;
    font-size: 1.875rem;
    line-height: calc(54 / 30);
  }

  .reien-fv__sub-title .bg-beige {
    padding: 6px 0 6px 9px;
    padding: 0.375rem 0 0.375rem 0.5625rem;
  }

  .reien-fv__sub-title .bg-beige + .bg-beige {
    margin-top: 12px;
    margin-top: 0.75rem;
  }

  .reien-fv__sub-title .kerning {
    letter-spacing: -0.3em;
  }

  .reien-fv__decoration01-wrapper {
    top: -96px;
    top: -6rem;
    left: -17px;
    left: -1.0625rem;
    width: 207.96px;
    width: 12.9975rem;
  }

  .reien-fv__decoration02-wrapper {
    top: -62px;
    top: -3.875rem;
    right: 0;
    width: 200px;
    width: 12.5rem;
  }
}

/* ==========================================
    ナビゲーション
   ========================================== */
.reien-navigation {
  padding: 12px 0 14.75px;
  padding: 0.75rem 0 0.921875rem;
  background-color: var(--color-white);
}

.reien-navigation__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  row-gap: 10px;
  row-gap: 0.625rem;
}

.reien-navigation__item a {
  font-size: 15px;
  font-size: 0.9375rem;
  line-height: calc(18.5 / 15);
  color: #000;
  text-align: center;
  padding-bottom: 4.5px;
  padding-bottom: 0.28125rem;
  border-bottom: 0.5px solid #707070;
  border-bottom: 0.03125rem solid #707070;
}

.reien-navigation__item {
  display: flex;
  justify-content: center;
}

.reien-navigation__item:nth-child(1),
.reien-navigation__item:nth-child(4) {
  width: 120px;
  width: 7.5rem;
}

.reien-navigation__item:nth-child(2),
.reien-navigation__item:nth-child(5) {
  width: 105px;
  width: 6.5625rem;
  border-left: 0.5px solid #96b967;
  border-left: 0.03125rem solid #96b967;
}

.reien-navigation__item:nth-child(3),
.reien-navigation__item:nth-child(6) {
  width: 110px;
  width: 6.875rem;
  border-left: 0.5px solid #96b967;
  border-left: 0.03125rem solid #96b967;
}

@media (min-width: 769px) {
  .reien-navigation {
    padding: 28px 0 29.3px;
    padding: 1.75rem 0 1.83125rem;
  }

  .reien-navigation__item {
    padding-inline: 20px;
    padding-inline: 1.25rem;
  }

  .reien-navigation__item:first-child {
    padding-left: 0;
  }

  .reien-navigation__item:last-child {
    padding-right: 0;
  }

  .reien-navigation__item:not(:first-child) {
    border-left: 1px solid #96b967;
    border-left: 0.0625rem solid #96b967;
  }

  .reien-navigation__item:nth-child(1),
  .reien-navigation__item:nth-child(2),
  .reien-navigation__item:nth-child(3),
  .reien-navigation__item:nth-child(4),
  .reien-navigation__item:nth-child(5),
  .reien-navigation__item:nth-child(6) {
    width: fit-content;
  }

  .reien-navigation__item a {
    font-size: 24px;
    font-size: 1.5rem;
    line-height: calc(30 / 24);
    width: fit-content;
    padding-bottom: 8px;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid #707070;
    border-bottom: 0.0625rem solid #707070;
  }
}

@media (min-width: 769px) and (max-width: 850px) {
  .reien-navigation__item {
    padding-inline: 10px;
    padding-inline: 0.625rem;
  }
}

@media (any-hover: hover) {
  .reien-navigation__item a:hover {
    opacity: 0.5;
  }
}

/* ==========================================
    CTA
   ========================================== */
.reien-cta {
  position: relative;
  padding: 10.25px 0 37.5px;
  padding: 0.640625rem 0 2.34375rem;
  background-color: #f7f0e8;
  overflow: hidden;
}

.reien-cta__inner {
  position: relative;
  z-index: 1;
}

.reien-cta__lead {
  position: relative;
  z-index: 1;
  text-align: center;
  font-size: 18px;
  font-size: 1.125rem;
  line-height: calc(20 / 18);
  color: var(--color-white);
}

.reien-cta__lead-highlight {
  display: block;
  margin-top: 5.75px;
  margin-top: 0.359375rem;
  font-size: 25px;
  font-size: 1.5625rem;
  font-weight: 800;
  line-height: calc(20 / 25);
  width: fit-content;
  margin-inline: auto;
  padding-bottom: 14px;
  padding-bottom: 0.875rem;
  border-bottom: 1px dotted var(--color-white);
  border-bottom: 0.0625rem dotted var(--color-white);
}

.reien-cta__body {
  margin-top: 45.3px;
  margin-top: 2.83125rem;
  text-align: center;
}

.reien-cta__number-label,
.reien-cta__web-label {
  position: relative;
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: calc(20 / 18);
  padding-bottom: 12.7px;
  padding-bottom: 0.79375rem;
  position: relative;
  left: -1px;
  left: -0.0625rem;
}

.reien-cta__number-label::after,
.reien-cta__web-label::after {
  position: absolute;
  content: "";
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 107.5px;
  width: 6.71875rem;
  height: 0.5px;
  height: 0.03125rem;
  background-color: var(--color-green);
}

.reien-cta__web-label::after {
  width: 185.5px;
  width: 11.59375rem;
}

.reien-cta__number-label span,
.reien-cta__web-label span {
  font-size: 21px;
  font-size: 1.3125rem;
  font-weight: 700;
  line-height: calc(20 / 21);
}

.reien-cta__number {
  margin-top: 8px;
  margin-top: 0.5rem;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  column-gap: 8.5px;
  column-gap: 0.53125rem;
}

.reien-cta__icon {
  width: 48.02px;
  width: 3.00125rem;
  margin-top: 6.6px;
  margin-top: 0.4125rem;
}

.reien-cta__tel {
  font-size: 38px;
  font-size: 2.375rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  line-height: calc(39.5 / 38);
  color: var(--color-green);
  font-family: "Noto Sans JP", sans-serif;
  text-wrap: nowrap;
}

.reien-cta__hours {
  margin-top: 1px;
  margin-top: 0.0625rem;
  font-size: 14px;
  font-size: 0.875rem;
  letter-spacing: 0.058em;
  line-height: calc(28.5 / 14);
  font-family: "Noto Sans JP", sans-serif;
  margin-top: 3px;
  margin-top: 0.1875rem;
}

.reien-cta__method--web {
  margin-top: 31.8px;
  margin-top: 1.9875rem;
  position: relative;
}

.reien-cta__web-description {
  margin-top: 6.25px;
  margin-top: 0.390625rem;
  font-size: 14px;
  font-size: 0.875rem;
  letter-spacing: 0.058em;
  line-height: calc(23 / 14);
  font-family: "Noto Sans JP", sans-serif;
}

.reien-cta__buttons {
  margin-top: 15px;
  margin-top: 0.9375rem;
  display: flex;
  flex-direction: column;
  row-gap: 10px;
  row-gap: 0.625rem;
}

.reien-cta__button {
  display: flex;
  align-items: center;
  padding: 13px 54.5px;
  padding: 0.8125rem
    clamp(51.5px, calc(54.5px + (71 * ((100vw - 375px) / 275))), 125.5px);
  border: 2px solid var(--color-white);
  border: 0.125rem solid var(--color-white);
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: calc(14 / 15);
  color: var(--color-white);
  text-wrap: nowrap;
}

.reien-cta__button--visit {
  background-color: var(--color-green);
}

.reien-cta__button-icon {
  width: 34.5px;
  width: 2.15625rem;
}

@media (any-hover: hover) {
  .reien-cta__button:hover {
    border: 4px solid var(--color-white);
  }
}

.reien-cta__button .large {
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: calc(14 / 20);
  color: var(--color-white);
  text-wrap: nowrap;
}

.reien-cta__button .position {
  position: relative;
  top: 2px;
  top: 0.125rem;
}

.reien-cta__button--visit .large {
  margin-left: 13px;
  margin-left: 0.8125rem;
}

.reien-cta__button--document .large {
  margin-left: 31px;
  margin-left: 1.9375rem;
}

.reien-cta__button--document {
  background-color: var(--color-orange);
  font-size: 13.5px;
  font-size: 0.84375rem;
  line-height: calc(16.5 / 13.5);
}

.reien-cta__decoration02-wrapper {
  position: absolute;
  top: -23px;
  top: -1.4375rem;
  left: 0;
  width: 59.38px;
  width: 3.71125rem;
}

.reien-cta__decoration01-wrapper {
  position: absolute;
  z-index: 1;
  top: 66.9px;
  top: 4.18125rem;
  right: 20px;
  right: 1.25rem;
  width: 96.455px;
  width: 6.028125rem;
}

.reien-cta__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

@media (min-width: 550px) and (max-width: 768px) {
  .reien-cta__bg {
    top: -45px;
    top: clamp(-45px, calc(-5px + (-40) * ((100vw - 550px) / 218)), -5px);
  }
}

@media (min-width: 769px) {
  .reien-cta {
    padding: 23px 0 48px;
    padding: 1.4375rem 0 3rem;
  }

  .reien-cta__lead {
    font-size: 20px;
    font-size: 1.25rem;
    line-height: calc(40 / 20);
  }

  .reien-cta__lead-highlight {
    margin-top: -1.5px;
    margin-top: -0.09375rem;
    font-size: 30px;
    font-size: 1.875rem;
    line-height: calc(40 / 30);
    width: 360.62px;
    width: 22.53875rem;
    padding-bottom: 16.5px;
    padding-bottom: 1.03125rem;
    border-width: 2px;
    border-width: 0.125rem;
  }

  .reien-cta__body {
    margin-top: 72px;
    margin-top: 4.5rem;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 20px;
    column-gap: 1.25rem;
  }

  .reien-cta__method {
    background-color: var(--color-white);
    border-radius: 20px;
    border-radius: 1.25rem;
    text-align: center;
  }

  .reien-cta__method--tel {
    padding: 29.6px 72.5px 58.7px 84.5px;
    padding: 1.85rem 1rem 3.66875rem 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .reien-cta__number-label,
  .reien-cta__web-label {
    font-size: 26px;
    font-size: 1.625rem;
    line-height: calc(40 / 26);
    width: fit-content;
    margin-inline: auto;
    padding-bottom: 8.1px;
    padding-bottom: 0.50625rem;
  }

  .reien-cta__number-label {
    position: relative;
    left: -11px;
    left: -0.6875rem;
  }

  .reien-cta__web-label {
    padding-bottom: 3.9px;
    padding-bottom: 0.24375rem;
    position: relative;
    left: -7px;
    left: -0.4375rem;
  }

  .reien-cta__number-label::after {
    width: 152.5px;
    width: 9.53125rem;
  }

  .reien-cta__web-label::after {
    width: 249px;
    width: 15.5625rem;
  }

  .reien-cta__number-label span,
  .reien-cta__web-label span {
    font-size: 32px;
    font-size: 2rem;
    line-height: calc(40 / 32);
    padding-bottom: 12.1px;
    padding-bottom: 0.75625rem;
    border-width: 1px;
    border-width: 0.0625rem;
  }

  .reien-cta__number {
    margin-top: 11.7px;
    margin-top: 0.73125rem;
    column-gap: 10.6px;
    column-gap: 0.6625rem;
    position: relative;
    left: 4px;
    left: 0.25rem;
  }

  .reien-cta__icon {
    margin-top: 10.6px;
    margin-top: 0.6625rem;
    width: 59.43px;
    width: 3.714375rem;
  }

  .reien-cta__tel {
    font-size: 48px;
    font-size: 3rem;
    line-height: calc(60 / 48);
  }

  .reien-cta__hours {
    margin-top: 2px;
    margin-top: 0.125rem;
    font-size: 21px;
    font-size: 1.3125rem;
    line-height: calc(43 / 21);
    position: relative;
    left: -2px;
    left: -0.125rem;
  }

  .reien-cta__method--web {
    margin-top: 0;
    padding: 21.6px 23px 24.6px 22px;
    padding: 1.35rem 1.4375rem 1.5375rem 1.375rem;
  }

  .reien-cta__web-description {
    margin-top: 10.5px;
    margin-top: 0.65625rem;
    font-size: 15px;
    font-size: 0.9375rem;
    letter-spacing: 0;
    line-height: calc(35 / 15);
  }

  .reien-cta__buttons {
    margin-top: 14.5px;
    margin-top: 0.90625rem;
    flex-direction: row;
    justify-content: center;
    column-gap: 15px;
    column-gap: 0.9375rem;
  }

  .reien-cta__button {
    border-width: 4px;
    border-width: 0.25rem;
  }

  .reien-cta__button--visit {
    padding: 13.2px 19.9px 10.7px 20px;
    padding: 0.825rem 1.24375rem 0.66875rem 1.25rem;
    font-size: 13px;
    font-size: 0.8125rem;
    line-height: calc(14 / 13);
  }

  .reien-cta__button-icon {
    width: 36.63px;
    width: 2.289375rem;
  }

  .reien-cta__button--visit .large {
    font-size: 19px;
    font-size: 1.1875rem;
    line-height: calc(14 / 19);
    margin-left: 15.5px;
    margin-left: 0.96875rem;
  }

  .reien-cta__button--document {
    padding: 11.9px 35.8px 11.9px 36px;
    padding: 0.74375rem 2.2375rem 0.74375rem 2.25rem;
    font-size: 13px;
    font-size: 0.8125rem;
    line-height: calc(16 / 13);
  }

  .reien-cta__button--document .large {
    font-size: 19px;
    font-size: 1.1875rem;
    line-height: calc(16 / 19);
    margin-left: 15.1px;
    margin-left: 0.94375rem;
  }

  .reien-cta__decoration02-wrapper {
    display: none;
  }

  .reien-cta__decoration01-wrapper {
    top: 58px;
    top: 3.625rem;
    right: 120px;
    right: 7.5rem;
    width: 166.01px;
    width: 10.375625rem;
  }

  .reien-cta__bg {
  }
}

@media (min-width: 769px) and (max-width: 1220px) {
  .reien-cta__lead-highlight {
    padding-bottom: 0.5rem;
  }

  .reien-cta__method--tel {
    justify-content: center;
  }

  .reien-cta__method--web {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .reien-cta__buttons {
    column-gap: 0.5rem;
  }

  .reien-cta__button--visit,
  .reien-cta__button--document {
    padding-left: 1rem;
  }

  .reien-cta__button--visit .large,
  .reien-cta__button--document .large {
    font-size: 1.1rem;
    margin-left: 0.5rem;
  }
}

@media (min-width: 1000px) and (max-width: 1220px) {
  .reien-cta__bg {
    top: -0.5rem;
  }
}

@media (min-width: 1221px) and (max-width: 1351px) {
  .reien-cta__bg {
    top: -1rem;
  }
}

@media (min-width: 1441px) and (max-width: 2560px) {
  .reien-cta__bg {
    top: clamp(
      -135px,
      calc(0px + (-135) * ((100vw - 1440px) / (2560 - 1440))),
      0px
    );
  }
}

@media (min-width: 2561px) {
  .reien-cta__bg {
    top: -135px;
  }
}

/* ==========================================
    お墓選び、もっと自由でいい
   ========================================== */
.reien-select {
  padding: 30.5px 0 91.8px;
  padding: 1.90625rem 0 5.7375rem;
}

.reien-select__inner {
  text-align: center;
  color: var(--color-text);
  padding-inline: 18.5px;
  padding-inline: 1.15625rem;
}

.reien-select__decoration-wrapper {
  width: 213.945px;
  width: 13.371875rem;
  margin-inline: auto;
}

.reien-select__title {
  margin-top: 32.85px;
  margin-top: 2.053125rem;
  font-size: 23px;
  font-size: 1.4375rem;
  font-weight: 600;
  line-height: calc(25 / 23);
}

.reien-select__highlight {
  color: var(--color-green);
}

.reien-select__content {
  margin-top: 17.3px;
  margin-top: 1.08125rem;
  border-radius: 10px;
  border-radius: 0.625rem;
  border: 1px solid var(--color-green);
  overflow: hidden;
}

.reien-select__list {
  padding: 30.05px 16.5px 30.65px;
  padding: 1.878125rem 1.03125rem 1.915625rem;
  background-color: var(--color-bg-green2);
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 18px;
  row-gap: 1.125rem;
  border-radius: 10px 10px 0 0;
  border-radius: 0.625rem 0.625rem 0 0;
}

.reien-select__item {
  border-radius: 50px;
  border-radius: 3.125rem;
  background-color: var(--color-white);
  padding: 18.75px 24px 15.25px 28.05px;
  padding: 1.171875rem 1.5rem 0.953125rem 1.753125rem;
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: 19.85px;
  column-gap: 1.240625rem;
}

.reien-select__item:nth-child(2) {
  padding-left: 29px;
  padding-left: 1.8125rem;
  column-gap: 19.7px;
  column-gap: 1.23125rem;
}

.reien-select__item:nth-child(3) {
  padding-left: 29.35px;
  padding-left: 1.834375rem;
  column-gap: 14.45px;
  column-gap: 0.903125rem;
}

.reien-select__icon01-wrapper {
  width: 35.095px;
  width: 2.193125rem;
}

.reien-select__icon02-wrapper {
  width: 34.29px;
  width: 2.14313rem;
}

.reien-select__icon03-wrapper {
  width: 39.195px;
  width: 2.449688rem;
}

.reien-select__text {
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: 600;
  line-height: calc(23 / 18);
  text-wrap: nowrap;
  text-align: left;
}

.reien-select__message {
  padding: 28.25px 15px 23px 15px;
  padding: 1.765625rem 0.9375rem 1.4375rem 0.9375rem;
  background-color: var(--color-white);
  text-align: center;
  font-size: 23px;
  font-size: 1.4375rem;
  font-weight: 600;
  line-height: calc(34 / 23);
  border-radius: 0 0 10px 10px;
  border-radius: 0 0 0.625rem 0.625rem;
  position: relative;
  left: 2px;
  left: 0.125rem;
}

.reien-select__message-highlight {
  color: var(--color-green);
  padding-bottom: 0;
  border-bottom: 1px dotted var(--color-green);
}

@media (min-width: 769px) {
  .reien-select {
    padding: 50px 0 99.7px;
    padding: 3.125rem 0 6.23125rem;
  }

  .reien-select__inner {
    padding-inline: 20px;
    padding-inline: 1.25rem;
    max-width: 1224px;
    max-width: 76.5rem;
  }

  .reien-select__decoration-wrapper {
    width: 230px;
    width: 14.375rem;
    position: relative;
    left: 6px;
    left: 0.375rem;
  }

  .reien-select__title {
    margin-top: 15px;
    margin-top: 0.9375rem;
    font-size: 30px;
    font-size: 1.875rem;
    line-height: calc(50 / 30);
  }

  .reien-select__content {
    margin-top: 33.9px;
    margin-top: 2.11875rem;
    border-radius: 20px;
    border-radius: 1.25rem;
    border-width: 2px;
    border-width: 0.125rem;
  }

  .reien-select__list {
    padding: 30.3px 89px 31.8px 91px;
    padding: 1.89375rem 5.5625rem 1.9875rem 5.6875rem;
    border-radius: 20px 20px 0 0;
    border-radius: 1.25rem 1.25rem 0 0;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 20px;
    column-gap: 1.25rem;
  }

  .reien-select__item {
    padding: 18.8px 20px 20px 20px;
    padding: 1.175rem 1.25rem 1.25rem 1.25rem;
    border-radius: 100px;
    border-radius: 6.25rem;
    flex-direction: column;
    align-items: center;
    row-gap: 13.8px;
    row-gap: 0.8625rem;
  }

  .reien-select__item:nth-child(2) {
    padding: 19.9px 20px 20px 20px;
    padding: 1.24375rem 1.25rem 1.25rem 1.25rem;
    row-gap: 18px;
    row-gap: 1.125rem;
  }

  .reien-select__item:nth-child(3) {
    padding: 22.9px 20px 20px 20px;
    padding: 1.43125rem 1.25rem 1.25rem 1.25rem;
    row-gap: 16.3px;
    row-gap: 1.01875rem;
  }

  .reien-select__icon01-wrapper {
    width: 30.2px;
    width: 1.8875rem;
    position: relative;
    left: 2px;
  }

  .reien-select__icon02-wrapper {
    width: 32.41px;
    width: 2.025625rem;
    position: relative;
    left: 3px;
  }

  .reien-select__icon03-wrapper {
    width: 30px;
    width: 1.875rem;
    position: relative;
    left: 1px;
  }

  .reien-select__text {
    font-size: 18px;
    font-size: 1.125rem;
    line-height: calc(26 / 18);
    text-align: center;
  }

  .reien-select__text--01 {
    position: relative;
    left: 3px;
    left: 0.1875rem;
  }

  .reien-select__text--03 {
    position: relative;
    left: 6px;
    left: 0.375rem;
  }

  .reien-select__message {
    padding: 32.2px 20px 44px;
    padding: 2.0125rem 1.25rem 2.75rem;
    font-size: 30px;
    font-size: 1.875rem;
    line-height: calc(48 / 30);
    position: relative;
    left: -2px;
    left: -0.125rem;
  }

  .reien-select__message-highlight {
    padding-bottom: 1.2px;
    padding-bottom: 0.075rem;
    border-width: 2px;
    border-width: 0.125rem;
  }
}

@media (min-width: 769px) and (max-width: 1220px) {
  .reien-select__list {
    padding-inline: 32px;
    padding-inline: 2rem;
  }
}

/* ==========================================
    4つのポイント
   ========================================== */
.reien-point {
  position: relative;
  padding: 33.6px 0 38.1px;
  padding: 2.1rem 0 2.38125rem;
  background-color: var(--color-bg-green);
}

.reien-point__title {
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: calc(25 / 24);
  color: var(--color-white);
  text-align: center;
}

.reien-point__title .large {
  font-size: 35px;
  font-size: 2.1875rem;
}

.reien-point__list {
  margin-top: 23.8px;
  margin-top: 1.4875rem;
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 10px;
  row-gap: 0.625rem;
}

.reien-point__item {
  padding: 14.5px 15px 23px;
  padding: 0.90625rem 0.9375rem 1.4375rem;
  border-radius: 5px;
  border-radius: 0.3125rem;
  background-color: var(--color-white);
  border: 1px solid var(--color-green);
}

.reien-point__item:nth-child(2) {
  padding-bottom: 25px;
  padding-bottom: 1.5625rem;
}

.reien-point__item:nth-child(3) {
  padding-bottom: 25px;
  padding-bottom: 1.5625rem;
}

.reien-point__top {
  display: flex;
  align-items: flex-start;
  column-gap: 8px;
  column-gap: 0.5rem;
  padding-bottom: 13.25px;
  padding-bottom: 0.828125rem;
  border-bottom: 1px solid var(--color-green);
  border-radius: 5px 5px 0 0;
  border-radius: 0.3125rem 0.3125rem 0 0;
}

.reien-point__top--02 {
  padding-bottom: 9px;
  padding-bottom: 0.5625rem;
}

.reien-point__number {
  font-size: 45px;
  font-size: 2.8125rem;
  font-weight: 600;
  line-height: calc(45 / 45);
  color: var(--color-green);
  position: relative;
  left: -4px;
  left: -0.25rem;
}

.reien-point__heading {
  font-size: 19px;
  font-size: 1.1875rem;
  font-weight: 600;
  line-height: calc(25 / 19);
  color: var(--color-text02);
  text-wrap: nowrap;
}

.reien-point__heading--02 {
  position: relative;
  top: 5px;
  top: 0.3125rem;
}

.reien-point__heading .line {
  text-decoration: underline;
  text-decoration-color: #fffa7f;
  text-underline-offset: 0px;
  text-decoration-thickness: 11px;
  text-decoration-thickness: 0.6875rem;
}

.reien-point__text {
  margin-top: 11.25px;
  margin-top: 0.703125rem;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: calc(23 / 14);
  color: var(--color-text);
  border-radius: 0 0 5px 5px;
  border-radius: 0 0 0.3125rem 0.3125rem;
}

.reien-point__decoration-wrapper {
  position: absolute;
  top: -3px;
  top: -0.1875rem;
  left: 52%;
  transform: translate(-50%, -50%);
  width: 335px;
  width: 20.9375rem;
}

@media (min-width: 769px) {
  .reien-point {
    padding: 54.7px 0 44px;
    padding: 3.41875rem 0 2.75rem;
  }

  .reien-point__inner {
    max-width: 1025px;
    max-width: 64.0625rem;
  }

  .reien-point__title {
    font-size: 36px;
    font-size: 2.25rem;
    line-height: calc(29 / 36);
  }

  .reien-point__title .large {
    font-size: 48px;
    font-size: 3rem;
    line-height: calc(29 / 48);
  }

  .reien-point__list {
    margin-top: 32.3px;
    margin-top: 2.01875rem;
    grid-template-columns: repeat(2, 1fr);
    gap: 31px 32px;
    gap: 1.9375rem 2rem;
  }

  .reien-point__item {
    border-radius: 10px;
    border-radius: 0.625rem;
    border-width: 1px;
    padding: 24px 30px 31px;
    padding: 1.5rem 1.875rem 1.9375rem;
  }

  .reien-point__item:nth-child(3),
  .reien-point__item:nth-child(4) {
    padding-top: 30px;
    padding-top: 1.875rem;
  }

  .reien-point__top {
    column-gap: 37.5px;
    column-gap: 2.34375rem;
    padding-bottom: 16px;
    padding-bottom: 1rem;
    border-width: 1px;
  }

  .reien-point__number {
    font-size: 70px;
    font-size: 4.375rem;
    line-height: calc(70 / 70);
    left: 0;
  }

  .reien-point__heading {
    font-size: 26px;
    font-size: 1.625rem;
    line-height: calc(38 / 26);
  }

  .reien-point__heading .line {
    text-decoration-thickness: 14px;
    text-decoration-thickness: 0.875rem;
  }

  .reien-point__text {
    margin-top: 9px;
    margin-top: 0.5625rem;
    font-size: 16px;
    font-size: 1rem;
    line-height: calc(28 / 16);
  }

  .reien-point__heading--02 {
    top: -1px;
    top: -0.0625rem;
  }

  .reien-point__heading--03,
  .reien-point__heading--04 {
    position: relative;
    top: -5px;
    top: -0.3125rem;
  }

  .reien-point__decoration-wrapper {
    width: 300px;
    width: 18.75rem;
    left: 50%;
  }
}

@media (min-width: 769px) and (max-width: 1220px) {
  .reien-point__list {
    gap: 1rem;
  }
}

/* ==========================================
    お墓の種類
   ========================================== */
.reien-type {
  padding-top: 56px;
  padding-top: 3.5rem;
  overflow: hidden;
}

.reien-type__inner {
  text-align: center;
  color: var(--color-text);
  max-width: 700px;
}

.reien-type__title {
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: calc(26 / 24);
  position: relative;
  left: -2px;
  left: -0.125rem;
}

.reien-type__list {
  margin-top: 23.75px;
  margin-top: 1.484375rem;
  display: flex;
  column-gap: 25px;
  column-gap: 1.5625rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  width: 100vw;
  margin-right: calc(50vw - 50%);
  align-items: stretch;
  padding-right: 45px;
  padding-right: 12vw;
  padding-bottom: 8px;
  padding-bottom: 0.5rem;
}

.reien-type__item {
  scroll-snap-align: start;
  display: flex;
}

.reien-type__card {
  border-radius: 10px;
  border-radius: 0.625rem;
  background-color: #f7f0e8;
  padding: 30px 20px;
  padding: 1.875rem 1.25rem;
  width: 306px;
  width: 19.125rem;
}

.reien-type__label {
  padding: 8.5px;
  padding: 0.53125rem;
  background-color: var(--color-bg-green);
  border-radius: 5px;
  border-radius: 0.3125rem;
  font-size: 19px;
  font-size: 1.1875rem;
  font-weight: 600;
  line-height: calc(23 / 19);
  color: var(--color-white);
}

.reien-type__img-wrapper {
  margin-top: 20px;
  margin-top: 1.25rem;
}

.reien-type__img {
  aspect-ratio: 532/360;
}

.reien-type__text {
  margin-top: 14px;
  margin-top: 0.875rem;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: calc(25 / 14);
}

.reien-type__description {
  margin-top: 20px;
  margin-top: 1.25rem;
  padding: 17.6px 17.5px 17.9px;
  padding: 1.1rem 1.09375rem 1.11875rem;
  background-color: var(--color-white);
  border-radius: 10px;
  border-radius: 0.625rem;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: calc(23 / 14);
  letter-spacing: -0.02em;
  color: var(--color-text03);
  text-align: left;
  font-family: "Noto Sans JP", sans-serif;
}

@media (min-width: 769px) {
  .reien-type {
    padding: 52px 0 52px;
    padding: 3.25rem 0 3.25rem;
    overflow: hidden;
  }

  .reien-type__inner {
    max-width: 1220px;
    max-width: 76.25rem;
  }

  .reien-type__title {
    font-size: 35px;
    font-size: 2.1875rem;
    line-height: calc(51 / 35);
  }

  .reien-type__list {
    margin-top: 29.9px;
    margin-top: 1.86875rem;
    column-gap: 24.4px;
    column-gap: 1.525rem;
    width: 100%;
    margin-right: 0;
    overflow-x: hidden;
    padding-right: 0;
  }

  .reien-type__item {
    width: 100%;
  }

  .reien-type__card {
    width: 378px;
    width: 23.625rem;
    padding: 28px 20px 40.1px;
    padding: 1.75rem 1.25rem 2.50625rem;
  }

  .reien-type__label {
    padding: 8px 10px;
    padding: 0.5rem 0.625rem;
    border-radius: 10px;
    border-radius: 0.625rem;
    font-size: 29px;
    font-size: 1.8125rem;
    line-height: calc(44 / 29);
  }

  .reien-type__img-wrapper {
    margin-top: 35px;
    margin-top: 2.1875rem;
  }

  .reien-type__img {
    aspect-ratio: 335.55/300;
  }

  .reien-type__text {
    margin-top: 11px;
    margin-top: 0.6875rem;
    width: 295px;
    width: 18.4375rem;
    margin-inline: auto;
    font-size: 20px;
    font-size: 1.25rem;
    line-height: calc(36 / 20);
  }

  .reien-type__text span {
    display: inline-block;
  }

  .reien-type__text--02 {
    width: 300.02px;
    width: 18.75125rem;
  }

  .reien-type__text--03 {
    width: 303.97px;
    width: 18.998125rem;
  }

  .reien-type__description {
    margin-top: 18.9px;
    margin-top: 1.18125rem;
    padding: 23px 19.7px;
    padding: 1.4375rem 1.23125rem;
    border-radius: 20px;
    border-radius: 1.25rem;
    font-size: 16px;
    font-size: 1rem;
    letter-spacing: -0.02em;
    line-height: calc(36 / 16);
  }
}

@media (min-width: 769px) and (max-width: 1220px) {
  .reien-type__list {
    overflow-x: auto;
    padding-right: 20px;
    padding-right: 1.25rem;
  }
}

/* ==========================================
    お墓を建てるまでの流れ
   ========================================== */
.reien-step {
  padding: 44px 0 60px;
  padding: 2.75rem 0 3.75rem;
  overflow: hidden;
}

.reien-step__inner {
  max-width: 700px;
}

.reien-step__title {
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: calc(16 / 24);
  text-align: center;
}

.reien-step__list {
  margin-top: 36px;
  margin-top: 2.25rem;
  padding: 42.5px 20px 30px;
  padding: 2.65625rem 1.25rem 1.875rem;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  align-items: stretch;
  column-gap: 28px;
  column-gap: 1.75rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  background-color: var(--color-bg-green2);
  width: 100vw;
  margin-right: calc(50vw - 50%);
  border-radius: 15px;
  border-radius: 0.9375rem;
  padding-right: 40px;
  padding-right: 2.5rem;
}

.reien-step__item {
  scroll-snap-align: start;
  scroll-margin-inline: 20px;
  scroll-margin-inline: 1.25rem;
  position: relative;
  width: 160px;
  width: 10rem;
  padding: 51px 17px 12px;
  padding: 3.1875rem 1.0625rem 0.75rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #fff;
  border-radius: 10px;
  border-radius: 0.625rem;
}

.reien-step__item::after {
  content: "";
  position: absolute;
  bottom: 49%;
  right: 0;
  transform: translate(100%, 50%);
  width: 18px;
  width: 1.125rem;
  height: 50.35px;
  height: 3.146875rem;
  background-color: var(--color-orange);
  clip-path: polygon(100% 50%, 0 0, 0 100%);
}

.reien-step__item:last-of-type::after {
  display: none;
}

.reien-step__item:nth-child(2) {
  padding: 46px 10px 12px;
  padding: 2.875rem 0.625rem 0.75rem;
}

.reien-step__step-number {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 51px;
  width: 3.1875rem;
  height: 54px;
  height: 3.375rem;
  font-size: 26px;
  font-size: 1.625rem;
  font-weight: 500;
  line-height: calc(26 / 26);
  color: var(--color-white);
  background-color: var(--color-bg-green);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0.5px solid #fff;
  border: 0.03125rem solid #fff;
}

.reien-step__icon01-wrapper {
  width: 80px;
  width: 5rem;
  position: relative;
  left: 4px;
  left: 0.25rem;
}

.reien-step__icon02-wrapper,
.reien-step__icon03-wrapper,
.reien-step__icon04-wrapper,
.reien-step__icon05-wrapper {
  width: 89px;
  width: 5.5625rem;
}

.reien-step__content {
  margin-top: 22px;
  margin-top: 1.375rem;
}

.reien-step__content--02 {
  margin-top: 18px;
  margin-top: 1.125rem;
}

.reien-step__content--03,
.reien-step__content--04,
.reien-step__content--05 {
  margin-top: 12px;
  margin-top: 0.75rem;
}

.reien-step__heading {
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: calc(23 / 14);
  text-align: center;
}

.reien-step__text {
  margin-top: 11.5px;
  margin-top: 0.71875rem;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: calc(23 / 14);
  font-family: "Noto Sans JP", sans-serif;
}

.reien-step__text--02 {
  width: 126px;
  width: 7.875rem;
  margin-inline: auto;
}

@media (min-width: 525px) and (max-width: 768px) {
  .reien-step__list {
    padding-right: 4rem;
  }
}

@media (min-width: 769px) {
  .reien-step {
    padding: 60px 0 60px;
    padding: 3.75rem 0 3.75rem;
    background-color: var(--color-bg-green2);
  }

  .reien-step__inner {
    max-width: 1220px;
  }

  .reien-step__title {
    font-size: 36px;
    font-size: 2.25rem;
    line-height: calc(36 / 36);
  }

  .reien-step__list {
    margin-top: 59.2px;
    margin-top: 3.7rem;
    overflow-x: visible;
    column-gap: 43.1px;
    column-gap: 2.69375rem;
    background-color: transparent;
    width: 100%;
    margin-right: 0;
    padding-inline: 0;
    padding-bottom: 0;
  }

  .reien-step__item {
    padding: 81.8px 19.2px 59.1px 18.3px;
    padding: 5.1125rem 1.2rem 3.69375rem 1.14375rem;
    border-radius: 20px;
    border-radius: 1.25rem;
    width: 201.55px;
    width: 12.596875rem;
  }

  .reien-step__item::after {
    width: 24.66px;
    width: 1.54125rem;
    height: 54.97px;
    height: 3.435625rem;
    top: 35.5%;
  }

  .reien-step__item:nth-child(2) {
    padding: 81.8px 19.2px 59.1px 18.3px;
    padding: 5.1125rem 1.2rem 3.69375rem 1.14375rem;
  }

  .reien-step__step-number {
    width: 73.29px;
    width: 4.580625rem;
    height: 77.6px;
    height: 4.85rem;
    font-size: 44px;
    font-size: 2.75rem;
    line-height: calc(44 / 44);
    border-width: 1px;
    border-width: 0.0625rem;
  }

  .reien-step__content {
    margin-top: 34.6px;
    margin-top: 2.1625rem;
  }

  .reien-step__heading {
    font-size: 18px;
    font-size: 1.125rem;
    line-height: calc(34 / 18);
  }

  .reien-step__heading--03 {
    position: relative;
    left: 8px;
    left: 0.5rem;
  }

  .reien-step__text {
    margin-top: 16px;
    margin-top: 1rem;
    font-size: 16px;
    font-size: 1rem;
    line-height: calc(36 / 16);
  }

  .reien-step__icon01-wrapper,
  .reien-step__icon02-wrapper,
  .reien-step__icon03-wrapper {
    width: 91.61px;
    width: 5.725625rem;
  }

  .reien-step__icon04-wrapper {
    width: 95.28px;
    width: 5.955rem;
  }

  .reien-step__icon05-wrapper {
    width: 105.36px;
    width: 6.585rem;
  }

  .reien-step__content--02 {
    margin-top: 31px;
    margin-top: 1.9375rem;
  }

  .reien-step__text--02 {
    width: fit-content;
  }

  .reien-step__content--03 {
    margin-top: 28.6px;
    margin-top: 1.7875rem;
  }

  .reien-step__content--04 {
    margin-top: 29px;
    margin-top: 1.8125rem;
  }

  .reien-step__content--05 {
    margin-top: 25px;
    margin-top: 1.5625rem;
  }
}

@media (min-width: 769px) and (max-width: 1220px) {
  .reien-step__list {
    overflow-x: auto;
    padding-bottom: 8px;
    padding-bottom: 0.5rem;
    padding-right: 16px;
    padding-right: 1rem;
  }
}

/* ==========================================
    プラン・料金
   ========================================== */
.reien-plan {
  padding: 37px 0 50.2px;
  padding: 2.3125rem 0 3.1375rem;
  background-color: var(--color-bg-green2);
}

.reien-plan__title {
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: calc(24 / 24);
  text-align: center;
}

.reien-plan__block {
  margin-top: 24px;
  margin-top: 1.5rem;
}

.reien-plan__block + .reien-plan__block {
  margin-top: 87.55px;
  margin-top: 5.46875rem;
}

.plan-block {
  position: relative;
}

.plan-block__box {
  background-color: var(--color-white);
  /* padding: 15.5px 15px 22.5px; */
  /* padding: 15.5px 15px 40.5px; */
  padding: 15.5px 15px 50px;
  padding: 0.96875rem 0.9375rem 3.125rem;
}

.plan-block__img {
  aspect-ratio: 61/38;
}

.plan-block__img--03 {
  aspect-ratio: 61/44;
}

.plan-block__img-wrapper--short {
  width: 225px;
  width: 14.0625rem;
  margin-inline: auto;
}

.plan-block__img--short {
  aspect-ratio: 450/533;
}

.plan-block__label {
  padding: 9.5px 8.5px;
  padding: 0.59375rem 0.53125rem;
  background-color: #6a685e;
  color: var(--color-white);
  text-align: center;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 700;
  line-height: calc(16 / 16);
}

.plan-block__content {
  margin-top: 20.5px;
  margin-top: 1.28125rem;
}

.plan-block__name {
  font-size: 35px;
  font-size: 2.1875rem;
  font-weight: 500;
  line-height: calc(35 / 35);
  display: flex;
  align-items: center;
  column-gap: 5px;
}

.plan-block__name .ruby {
  font-size: 12px;
  font-size: 0.75rem;
  line-height: calc(12 / 12);
}

.plan-block__catch {
  margin-top: 13px;
  margin-top: 0.8125rem;
  margin-top: 8px;
  margin-top: 0.5rem;
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: 500;
  line-height: calc(29 / 18);
  padding-bottom: 10.5px;
  padding-bottom: 0.65625rem;
  padding-bottom: 4.5px;
  padding-bottom: 0.21875rem;
  border-bottom: 0.5px solid #999999;
}

.plan-block__catch--badge {
  margin-top: 4px;
  margin-top: 0.25rem;
  display: flex;
  align-items: flex-start;
  column-gap: 15px;
  column-gap: 0.9375rem;
  padding-bottom: 9px;
  padding-bottom: 0.5625rem;
}

.plan-block__badge {
  padding: 5px 10.85px 5px 11.65px;
  padding: 0.3125rem 0.678125rem 0.3125rem 0.728125rem;
  background-color: var(--color-bg-green);
  font-size: 14px;
  font-size: 0.875rem;
  line-height: calc(20 / 14);
  color: var(--color-white);
  font-family: "Noto Sans JP", sans-serif;
  position: relative;
  top: 2px;
  top: 0.125rem;
}

.plan-block__badge--short {
  margin-left: -12px;
  margin-left: -0.75rem;
}

.plan-block__desc {
  margin-top: 13px;
  margin-top: 0.8125rem;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: calc(25 / 14);
  font-family: "Noto Sans JP", sans-serif;
  padding-right: 2px;
  padding-right: 0.125rem;
}

.plan-block__price-box {
  margin-top: 18.9px;
  margin-top: 1.18125rem;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  column-gap: 6px;
  column-gap: 0.375rem;
}

.plan-block__price-label {
  padding: 6.5px 11px 7px 11.5px;
  padding: 0.40625rem 0.6875rem 0.4375rem 0.71875rem;
  background-color: #f7f0e8;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: calc(20 / 14);
  font-family: "Noto Sans JP", sans-serif;
  position: relative;
  top: 4px;
  top: 0.25rem;
}

.plan-block__price {
  display: flex;
  align-items: flex-end;
  font-size: 19px;
  font-size: 1.1875rem;
  font-weight: 500;
  line-height: calc(19 / 19);
}

.plan-block__price-num {
  font-size: 32px;
  font-size: 2rem;
  font-weight: 500;
  line-height: calc(32 / 32);
  position: relative;
  top: 2px;
  top: 0.125rem;
}

.plan-block__tax {
  font-size: 13px;
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: calc(13 / 13);
}

.plan-block__note {
  margin-top: 6px;
  margin-top: 0.375rem;
  font-size: 13px;
  font-size: 0.8125rem;
  line-height: calc(24 / 13);
  text-align: right;
  font-family: "Noto Sans JP", sans-serif;
}

.plan-block__note--another {
  padding-top: 27px;
  padding-top: 1.6875rem;
  text-align: left;
}

.plan-block__table-wrapper {
  margin-top: 31px;
  margin-top: 1.9375rem;
}

.plan-block__table-wrapper--another {
  margin-top: 12px;
  margin-top: 0.75rem;
}

.plan-block__table {
  font-family: "Noto Sans JP", sans-serif;
  border-spacing: 0;
}

.plan-block__tr {
  /* padding: 12.25px 12.5px 12.25px; */
  /* padding: 0.765625rem 0.78125rem 0.765625rem; */
  padding: 12px 12.5px;
  border-bottom: 0.5px solid #969696;
  border-bottom: 0.03125rem solid #000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 305px;
  width: 19.0625rem;
  width: min(81.33333333vw, 540px);
  margin-inline: auto;
}

.plan-block__tr--another {
  padding: 0;
  column-gap: 15px;
  column-gap: 0.9375rem;
}

.plan-block__tr--line {
  border-top: 0.5px solid #969696;
  border-top: 0.03125rem solid #969696;
}

.plan-block__tr--head {
  padding: 5.25px 12.5px 4.75px;
  padding: 0.328125rem 0.78125rem 0.296875rem;
  /* padding: 5.5px 12.5px 5px; */
  /* padding: 0.34375rem 0.78125rem 0.3125rem; */
  justify-content: center;
  background-color: var(--color-bg-green);
  width: 100%;
}

.plan-block__th--plan-title {
  color: var(--color-white);
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: calc(17 / 14);
  width: 100%;
}

.plan-block__tr--section {
  padding: 5.25px 12.5px 4.75px;
  padding: 0.328125rem 0.78125rem 0.296875rem;
  /* padding: 5.5px 12.5px 5px; */
  /* padding: 0.34375rem 0.78125rem 0.3125rem; */
  background-color: #f6f6f6;
}

.plan-block__th--section {
  font-size: 14px;
  font-size: 0.875rem;
  line-height: calc(17 / 14);
  color: var(--color-bg-green);
}

.plan-block__th--label {
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: calc(17 / 14);
  color: #434343;
}

.plan-block__th--another {
  padding: 12px 12.5px;
  padding: 0.75rem 0.78125rem;
  width: 100px;
  width: 6.25rem;
  height: inherit;
  background-color: #f0f0f0;
  text-align: left;
}

.plan-block__th--high {
  padding: 23px 12.5px;
  padding: 1.4375rem 0.78125rem;
}

.plan-block__td--price {
  font-size: 14px;
  font-size: 0.875rem;
  line-height: calc(17 / 14);
}

.plan-block__td--another {
  padding: 11px 12.5px 11px 0;
  padding: 0.6875rem 0.78125rem 0.6875rem 0;
  text-align: left;
  flex: 1;
}

.plan-block__small-note {
  margin-top: 17px;
  margin-top: 1.0625rem;
  font-size: 10px;
  font-size: 0.625rem;
  line-height: calc(20 / 10);
  text-align: left;
  font-family: "Noto Sans JP", sans-serif;
}

.plan-block__small-note--another {
  margin-top: 6px;
  margin-top: 0.375rem;
}

/* アコーディオン用 */
.plan-block__accordion-content {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.5s ease;
}

/* アコーディオン用ボタン */
/* 円形ボタン本体 */
.plan-block__accordion-open {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  row-gap: 5px;
  row-gap: 0.3125rem;
  width: 79px;
  width: 4.9375rem;
  height: 79px;
  height: 4.9375rem;
  border: none;
  border-radius: 50%;
  background: #96b967;
  color: var(--color-white);
  opacity: 1;
  cursor: pointer;
  overflow: hidden;
  border: 2px solid var(--color-white);
  border: 0.125rem solid var(--color-white);
  transition: opacity 0.3s ease;
}

@media (any-hover: hover) {
  .plan-block__accordion-open:hover {
    opacity: 0.7;
  }
}

.plan-block__accordion-icon {
  position: relative;
  width: 23px;
  width: 1.4375rem;
  height: 23px;
  height: 1.4375rem;
}

/* ＋の横線（::before）、縦線（::after） */
.plan-block__accordion-icon::before,
.plan-block__accordion-icon::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  background: var(--color-white);
  transform: translate(-50%, -50%);
  border-radius: 50vh;
}

/* 横線 */
.plan-block__accordion-icon::before {
  width: 100%;
  height: 2px;
  height: 0.125rem;
}

/* 縦線 */
.plan-block__accordion-icon::after {
  width: 2px;
  width: 0.125rem;
  height: 100%;
  transition: transform 0.3s ease; /* ← 縦線だけ回転アニメ */
  transform-origin: 50% 50%;
  transform: translate(-50%, -50%) rotate(0deg);
}

/* 開いた時：縦線だけ90°回転→横線に重なって「ー」になる */
.plan-block__accordion-open[aria-expanded="true"]
  .plan-block__accordion-icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

/* ラベル配置（円の下寄せに表示） */
.plan-block__btn-label {
  font-size: 10px;
  font-size: 0.625rem;
  font-weight: 700;
  line-height: calc(14.5 / 10);
  font-family: "Noto Sans JP", sans-serif;
}

/* 低モーション環境 */
@media (prefers-reduced-motion: reduce) {
  .plan-block__accordion-icon::after {
    transition: none;
  }
}

@media (min-width: 769px) {
  .reien-plan {
    padding: 52px 0 60px;
    padding: 3.25rem 0 3.75rem;
  }

  .reien-plan__inner {
    max-width: 1020px;
    max-width: 63.75rem;
  }

  .reien-plan__title {
    font-size: 36px;
    font-size: 2.25rem;
    line-height: calc(48 / 36);
  }

  .reien-plan__block {
    margin-top: 34.3px;
    margin-top: 2.14375rem;
  }

  .plan-block__label {
    font-size: 28px;
    font-size: 1.75rem;
    line-height: calc(28 / 28);
    padding: 11px 20px;
    padding: 0.6875rem 1.25rem;
  }

  .plan-block__box {
    padding: 33.7px 30px 50px;
    padding: 2.10625rem 1.875rem 3.125rem;
  }

  .plan-block__top {
    display: flex;
    align-items: flex-start;
    column-gap: 25px;
    column-gap: 1.5625rem;
  }

  .plan-block__img-wrapper {
    width: calc(480 / 920 * 100%);
  }

  .plan-block__img {
    aspect-ratio: 48/32;
  }

  .plan-block__content {
    margin-top: 0;
    flex: 1;
  }

  .plan-block__name {
    padding-left: 13px;
    padding-left: 0.8125rem;
    font-size: 55px;
    font-size: 3.4375rem;
    line-height: calc(55 / 55);
    column-gap: 8.4px;
    column-gap: 0.525rem;
  }

  .plan-block__name .ruby {
    font-size: 18px;
    font-size: 1.125rem;
    line-height: calc(18 / 18);
  }

  .plan-block__catch {
    margin-top: 9px;
    margin-top: 0.5625rem;
    font-size: 24px;
    font-size: 1.5rem;
    line-height: calc(45 / 24);
    padding-bottom: 9px;
    padding-bottom: 0.5625rem;
    border-width: 1px;
    padding-left: 11px;
    padding-left: 0.6875rem;
    margin-left: 11px;
    margin-left: 0.6875rem;
  }

  .plan-block__catch--badge {
    padding-bottom: 2px;
    padding-bottom: 0.125rem;
  }

  .plan-block__badge {
    padding: 13px 22px 14px 23px;
    padding: 0.8125rem 1.375rem 0.875rem 1.4375rem;
    font-size: 16px;
    font-size: 1rem;
    line-height: calc(24 / 16);
    top: -10px;
    top: -0.625rem;
  }

  .plan-block__badge--short {
    margin-left: -21px;
    margin-left: -1.3125rem;
    top: -6px;
    top: -0.375rem;
  }

  .plan-block__badge--short02 {
    margin-left: -10px;
  }

  .plan-block__desc {
    margin-top: 23px;
    margin-top: 1.4375rem;
    font-size: 16px;
    font-size: 1rem;
    letter-spacing: -0.02em;
    line-height: calc(36 / 16);
    padding-left: 14px;
    padding-left: 0.875rem;
  }

  .plan-block__price-box {
    margin-top: 25.2px;
    margin-top: 1.575rem;
    column-gap: 10px;
    column-gap: 0.625rem;
    justify-content: flex-start;
    padding-left: 12px;
    padding-left: 0.75rem;
  }

  .plan-block__price-label {
    padding: 13px 22px 14px 23px;
    padding: 0.8125rem 1.375rem 0.875rem 1.4375rem;
    font-size: 16px;
    font-size: 1rem;
    letter-spacing: -0.02em;
    line-height: calc(24 / 16);
    top: 0;
  }

  .plan-block__price {
    font-size: 27px;
    font-size: 1.6875rem;
    line-height: calc(27 / 27);
    position: relative;
    top: -4px;
    top: -0.25rem;
  }

  .plan-block__price-num {
    font-size: 46px;
    font-size: 2.875rem;
    line-height: calc(46 / 46);
  }

  .plan-block__tax {
    font-size: 19px;
    font-size: 1.1875rem;
    line-height: calc(19 / 19);
  }

  .plan-block__note {
    font-size: 14px;
    font-size: 0.875rem;
    line-height: calc(36 / 14);
    margin-top: -2.3px;
    margin-top: -0.14375rem;
    text-align: left;
    letter-spacing: -0.02em;
  }

  .plan-block__note--another {
    padding-top: 10px;
    padding-top: 0.625rem;
    padding-left: 5px;
    padding-left: 0.3125rem;
  }

  .plan-block__table-wrapper {
    margin-top: 44.1px;
    margin-top: 2.75625rem;
  }

  .plan-block__table-wrapper--another {
    margin-top: 10px;
  }

  .plan-block__table {
    width: 100%;
  }

  .plan-block__tr {
    max-width: 920px;
    max-width: 57.5rem;
    width: 100%;
    padding: 23px 57px 22px 23px;
    padding: 1.4375rem 3.5625rem 1.375rem 1.4375rem;
    border-width: 1px;
  }

  .plan-block__tr--head {
    padding: 12px 20px 11px;
    padding: 0.75rem 1.25rem 0.6875rem;
  }

  .plan-block__tr--another {
    padding: 0;
    column-gap: 60px;
    column-gap: 3.75rem;
  }

  .plan-block__th--plan-title {
    font-size: 20px;
    font-size: 1.25rem;
    line-height: calc(24 / 20);
  }

  .plan-block__tr--section {
    padding: 11.5px 24px;
    padding: 0.71875rem 1.5rem;
  }

  .plan-block__th--section {
    font-size: 20px;
    font-size: 1.25rem;
    line-height: calc(24 / 20);
  }

  .plan-block__th--label {
    font-size: 20px;
    font-size: 1.25rem;
    line-height: calc(29 / 20);
  }

  .plan-block__th--another {
    padding: 22px 22px 22px 76px;
    padding: 1.375rem 1.375rem 1.375rem 4.75rem;
    width: 250px;
    width: 15.625rem;
  }

  .plan-block__td--price {
    font-size: 20px;
    font-size: 1.25rem;
    line-height: calc(29 / 20);
  }

  .plan-block__td--another {
    flex: 1;
    font-size: 21px;
    font-size: 1.3125rem;
    line-height: calc(30 / 21);
  }

  .plan-block__small-note {
    margin-top: 26px;
    margin-top: 1.625rem;
    font-size: 14px;
    font-size: 0.875rem;
    letter-spacing: -0.02em;
    line-height: calc(28 / 14);
    width: 610px;
    width: 38.125rem;
  }

  .plan-block__accordion-open {
    width: 104px;
    width: 6.5rem;
    height: 104px;
    height: 6.5rem;
    row-gap: 7px;
    transform: translate(-50%, 50%);
  }

  .plan-block__accordion-icon {
    width: 22.86px;
    width: 1.429rem;
  }

  .plan-block__accordion-icon::before {
    height: 4px;
    height: 0.25rem;
  }

  .plan-block__accordion-icon::after {
    width: 4px;
    width: 0.25rem;
  }

  .plan-block__btn-label {
    font-size: 16px;
    font-size: 1rem;
    line-height: calc(24 / 16);
  }
}

/* 骨壷 */
.reien-plan__addon {
  margin-top: 87px;
  margin-top: 5.4375rem;
  padding: 34.5px 15px 33px;
  padding: 2.15625rem 0.9375rem 2.0625rem;
  background-color: var(--color-white);
}

.reien-plan__addon-heading {
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 600;
  line-height: calc(24 / 17);
  text-align: center;
}

.reien-plan__addon-figure {
  margin-top: 17.5px;
  margin-top: 1.09375rem;
  display: flex;
  flex-direction: column;
  row-gap: 18px;
  row-gap: 1.125rem;
}

.reien-plan__addon-img {
  aspect-ratio: 1/1;
}

.reien-plan__addon-caption-title {
  font-size: 16px;
  font-size: 1rem;
  font-weight: 500;
  line-height: calc(16 / 16);
  text-align: center;
}

.reien-plan__addon-caption-text {
  margin-top: 14.5px;
  margin-top: 0.90625rem;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 400;
  line-height: calc(25 / 14);
  font-family: "Noto Sans JP", sans-serif;
  text-align: center;
}

@media (min-width: 769px) {
  .reien-plan__addon {
    padding: 53px 81px 87.3px 138px;
    padding: 3.3125rem 5.0625rem 5.45625rem 8.625rem;
  }

  .reien-plan__addon-heading {
    font-size: 26px;
    font-size: 1.625rem;
    line-height: calc(40 / 26);
    position: relative;
    left: -31px;
    left: -1.9375rem;
  }

  .reien-plan__addon-figure {
    margin-top: 55.6px;
    margin-top: 3.475rem;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    column-gap: 47px;
    column-gap: 2.9375rem;
  }

  .reien-plan__addon-visual {
    width: 314px;
    width: 19.625rem;
  }

  .reien-plan__addon-img {
    aspect-ratio: 314/334;
  }

  .reien-plan__addon-caption {
    margin-top: 71px;
    margin-top: 4.4375rem;
    flex: 1;
  }

  .reien-plan__addon-caption-title {
    font-size: 24px;
    font-size: 1.5rem;
    line-height: calc(32 / 24);
    position: relative;
    left: -12px;
    left: -0.75rem;
  }

  .reien-plan__addon-caption-text {
    margin-top: 20px;
    margin-top: 1.25rem;
    font-size: 16px;
    font-size: 1rem;
    letter-spacing: -0.02em;
    line-height: calc(36 / 16);
    position: relative;
    left: -3px;
    left: -0.1875rem;
  }
}

/* ==========================================
    お寺について
   ========================================== */
.reien-about {
  padding: 30.15px 0 15.35px;
  padding: 1.884375rem 0 0.959375rem;
}

.reien-about__decoration-wrapper {
  width: 47.66px;
  width: 2.97875rem;
  margin-inline: auto;
}

.reien-about__title {
  margin-top: 22.25px;
  margin-top: 1.390625rem;
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: calc(24 / 24);
  text-align: center;
}

.reien-about__lead {
  margin-top: 18px;
  margin-top: 1.125rem;
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: 500;
  line-height: calc(30 / 20);
  text-align: center;
}

.reien-about__text {
  margin-top: 13px;
  margin-top: 0.8125rem;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: calc(25 / 14);
  font-family: "Noto Sans JP", sans-serif;
}

.reien-about__text--02 {
  margin-top: 17px;
  margin-top: 1.0625rem;
}

.reien-about__text--04 {
  margin-top: 24px;
  margin-top: 1.5rem;
}

.reien-about__text + .reien-about__text {
  margin-top: 24.5px;
  margin-top: 1.53125rem;
}

.reien-about__img01-wrapper,
.reien-about__img02-wrapper {
  margin-top: 18px;
  margin-top: 1.125rem;
}

.reien-about__img01,
.reien-about__img02 {
  aspect-ratio: 67/40;
}

.reien-about__subtitle {
  margin-top: 20px;
  margin-top: 1.25rem;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 500;
  line-height: calc(16 / 16);
  text-align: center;
}

@media (min-width: 769px) {
  .reien-about {
    padding: 60px 0 0;
  }

  .reien-about__inner {
    max-width: 1020px;
  }

  .reien-about__decoration-wrapper {
    width: 70px;
    position: relative;
    left: -13px;
  }

  .reien-about__title {
    margin-top: 52px;
    font-size: 36px;
    line-height: calc(48 / 36);
  }

  .reien-about__lead {
    margin-top: 43px;
    font-size: 24px;
    line-height: calc(48 / 24);
    position: relative;
    left: -5px;
  }

  .reien-about__text {
    margin-top: 20px;
    font-size: 16px;
    letter-spacing: -0.02em;
    line-height: calc(36 / 16);
    width: 694px;
    margin-inline: auto;
    position: relative;
    left: 13px;
  }

  .reien-about__text + .reien-about__text {
    margin-top: 37px;
  }

  .reien-about__img01-wrapper {
    margin-top: 60px;
  }

  .reien-about__img01,
  .reien-about__img02 {
    aspect-ratio: 98/40;
  }

  .reien-about__text--02 {
    margin-top: 44px;
    width: 700px;
  }

  .reien-about__text--03 {
    width: 700px;
  }

  .reien-about__img02-wrapper {
    margin-top: 53px;
  }

  .reien-about__subtitle {
    margin-top: 45px;
    font-size: 20px;
    line-height: calc(32 / 20);
  }

  .reien-about__text--04 {
    margin-top: 12px;
    position: relative;
    left: -4px;
  }
}

/* ==========================================
    アクセス
   ========================================== */
.reien-access {
  position: relative;
  padding: 20px 0 20px;
  padding: 1.25rem 0 1.25rem;
}

.reien-access__decoration-wrapper {
  width: 70.51px;
  width: 4.40688rem;
  margin-inline: auto;
}

.reien-access__title {
  margin-top: 2.15px;
  margin-top: 0.134375rem;
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: calc(24 / 24);
  text-align: center;
}

.reien-access__map-img01-wrapper {
  margin-top: 24px;
  margin-top: 1.5rem;
}

.reien-access__map-img01 {
  aspect-ratio: 670/574;
}

.reien-access__map-img02 {
  aspect-ratio: 669/421;
}

.reien-access__bottom {
  display: flex;
  flex-direction: column-reverse;
  row-gap: 24.25px;
  row-gap: 1.515625rem;
}

.reien-access__map-wrapper iframe {
  aspect-ratio: 670/402;
}

.reien-access__info {
  margin-top: 16.5px;
  margin-top: 1.03125rem;
}

.reien-access__place {
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 600;
  line-height: calc(24 / 17);
  padding-bottom: 14.05px;
  padding-bottom: 0.878125rem;
  border-bottom: 0.5px solid #707070;
}

.reien-access__list {
  margin-top: 6px;
  margin-top: 0.375rem;
}

.reien-access__row {
  font-size: 13px;
  font-size: 0.8125rem;
  line-height: calc(25 / 13);
  font-family: "Noto Sans JP", sans-serif;
}

@media (min-width: 769px) {
  .reien-access {
    padding: 54px 0 0;
    padding: 3.375rem 0 0;
  }

  .reien-access__inner {
    max-width: 1020px;
    max-width: 63.75rem;
    margin-inline: auto;
  }

  .reien-access__decoration-wrapper {
    width: 76.55px;
    width: 4.784375rem;
    position: relative;
    left: -5px;
    left: -0.3125rem;
  }

  .reien-access__title {
    margin-top: -0.2px;
    margin-top: -0.0125rem;
    font-size: 36px;
    font-size: 2.25rem;
    line-height: calc(48 / 36);
  }

  .reien-access__map-img01-wrapper {
    margin-top: 30px;
    margin-top: 1.875rem;
  }

  .reien-access__map-img01-wrapper,
  .reien-access__map-img02-wrapper {
    width: 670px;
    width: 41.875rem;
    margin-inline: auto;
  }

  .reien-access__map-img01 {
    aspect-ratio: 670/574;
  }

  .reien-access__map-img02 {
    aspect-ratio: 669/421;
  }

  .reien-access__bottom {
    margin-top: 50px;
    margin-top: 3.125rem;
    flex-direction: row;
    column-gap: 49.5px;
    column-gap: 3.09375rem;
  }

  .reien-access__map-wrapper {
    width: 480px;
    width: 30rem;
  }

  .reien-access__map-wrapper iframe {
    aspect-ratio: 48/29;
  }

  .reien-access__info {
    margin-top: 36px;
    margin-top: 2.25rem;
  }

  .reien-access__place {
    font-size: 20px;
    font-size: 1.25rem;
    line-height: calc(48 / 20);
    padding-bottom: 6px;
    padding-bottom: 0.375rem;
  }

  .reien-access__list {
    margin-top: 12px;
    margin-top: 0.75rem;
  }

  .reien-access__row {
    font-size: 16px;
    font-size: 1rem;
    line-height: calc(36 / 16);
  }
}

/* ==========================================
    交通アクセス
   ========================================== */
.reien-traffic-access {
  padding: 20px 0 50px;
  padding: 1.25rem 0 3.125rem;
}

.reien-traffic-access__title {
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: calc(24 / 24);
  text-align: center;
}

.reien-traffic-access__wrapper {
  display: flex;
  flex-direction: column;
}

.reien-traffic-access__top {
  display: contents;
}

.reien-traffic-access__image-wrapper {
  margin-top: 31px;
  margin-top: 1.9375rem;
  order: 1;
}

.reien-traffic-access__image {
  aspect-ratio: 670/599.65;
}

.reien-traffic-access__side {
  display: contents;
}

.reien-traffic-access__block-taxi {
  margin-top: 21.5px;
  margin-top: 1.34375rem;
  order: 2;
}

.reien-traffic-access__subtitle {
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 600;
  line-height: calc(24 / 17);
  padding-bottom: 14.05px;
  padding-bottom: 0.878125rem;
  border-bottom: 0.5px solid #707070;
}

.reien-traffic-access__list {
  margin-top: 7px;
  margin-top: 0.4375rem;
}

.reien-traffic-access__item {
  font-size: 13px;
  font-size: 0.8125rem;
  line-height: calc(25 / 13);
  text-indent: -1em;
  padding-left: 1em;
  font-family: "Noto Sans JP", sans-serif;
}

.reien-traffic-access__item span {
  display: inline-block;
  padding-left: 1em;
}

.reien-traffic-access__item--bus + .reien-traffic-access__item--bus {
  margin-top: 25px;
  margin-top: 1.5625rem;
}

.reien-traffic-access__block-car {
  margin-top: 32px;
  margin-top: 2rem;
  order: 4;
}

.reien-traffic-access__block-bus {
  margin-top: 32px;
  margin-top: 2rem;
  order: 3;
}

@media (min-width: 769px) {
  .reien-traffic-access {
    padding: 53px 0 73px;
    padding: 3.3125rem 0 4.5625rem;
  }

  .reien-traffic-access__inner {
    max-width: 1020px;
    max-width: 63.75rem;
  }

  .reien-traffic-access__title {
    font-size: 36px;
    font-size: 2.25rem;
    line-height: calc(48 / 36);
  }

  .reien-traffic-access__wrapper {
    display: block;
  }

  .reien-traffic-access__top {
    margin-top: 29px;
    margin-top: 1.8125rem;
    display: flex;
    align-items: flex-start;
    column-gap: 60px;
    column-gap: 3.75rem;
  }

  .reien-traffic-access__image-wrapper {
    margin-top: 0;
    width: 480px;
    width: 30rem;
    order: initial;
  }

  .reien-traffic-access__image {
    aspect-ratio: 48/43;
  }

  .reien-traffic-access__side {
    display: block;
    flex: 1;
  }

  .reien-traffic-access__block-taxi {
    margin-top: -14px;
    margin-top: -0.875rem;
    order: initial;
  }

  .reien-traffic-access__subtitle {
    font-size: 20px;
    font-size: 1.25rem;
    line-height: calc(48 / 20);
    padding-bottom: 5px;
    padding-bottom: 0.3125rem;
    border-width: 1px;
  }

  .reien-traffic-access__list {
    margin-top: 14px;
    margin-top: 0.875rem;
  }

  .reien-traffic-access__item {
    font-size: 16px;
    font-size: 1rem;
    line-height: calc(36 / 16);
  }

  .reien-traffic-access__item span {
    display: inline-block;
  }

  .reien-traffic-access__block-car {
    margin-top: 8px;
    margin-top: 0.5rem;
    order: initial;
  }

  .reien-traffic-access__block-bus {
    margin-top: 39px;
    margin-top: 2.4375rem;
    order: initial;
    padding-left: 17px;
    padding-left: 1.0625rem;
  }

  .reien-traffic-access__item--bus + .reien-traffic-access__item--bus {
    margin-top: 36px;
    margin-top: 2.25rem;
  }
}

/* ==========================================
    よくある質問
   ========================================== */
.reien-faq {
  padding: 27px 0 30px;
  padding: 1.6875rem 0 1.875rem;
  background-color: var(--color-bg-green2);
}

.reien-faq__decoration-wrapper {
  width: 101.675px;
  width: 6.354688rem;
  margin-inline: auto;
}

.reien-faq__title {
  margin-top: 18.15px;
  margin-top: 1.134375rem;
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: calc(24 / 24);
  text-align: center;
}

.reien-faq__group-title {
  margin-top: 32px;
  margin-top: 2rem;
  display: flex;
  align-items: center;
  column-gap: 4px;
  column-gap: 0.25rem;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 700;
  line-height: calc(25 / 16);
}

.reien-faq__group-title span {
  font-size: 13px;
  font-size: 0.8125rem;
  line-height: calc(25 / 13);
}

.reien-faq__list {
  margin-top: 14px;
  margin-top: 0.875rem;
}

.reien-faq__item {
  border-bottom: 1px solid #707070;
}

.reien-faq__toggle {
  position: relative;
  display: flex;
  align-items: flex-start;
  column-gap: 14px;
  column-gap: 0.875rem;
  padding: 9px 34.5px 16px 15px;
  padding: 11px 34.5px 11px 15px;
  background-color: var(--color-white);
  width: 100%;
  border-bottom: none;
}

.reien-faq__qmark {
  font-size: 19px;
  font-size: 1.1875rem;
  font-weight: 700;
  line-height: calc(25.5 / 19);
  color: var(--color-green);
  position: relative;
  top: 4px;
  top: 0.25rem;
  top: -1px;
  top: -0.0625rem;
}

.reien-faq__question {
  font-size: 16px;
  font-size: 1rem;
  font-weight: 700;
  line-height: calc(25 / 16);
  color: var(--color-green);
  text-align: left;
}

.reien-faq__icon {
  position: absolute;
  top: 54%;
  right: 15.25px;
  right: 0.953125rem;
  transform: translateY(-50%);
  width: 12px;
  width: 0.75rem;
  height: 12px;
  height: 0.75rem;
  z-index: 1;
}

/* プラス（横棒＋縦棒） */
.reien-faq__icon::before,
.reien-faq__icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 1px;
  background-color: var(--color-green);
  transition: transform 0.3s ease;
  z-index: 1;
}

.reien-faq__icon::before {
  transform: translate(-50%, -50%) rotate(0deg);
}

.reien-faq__icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

/* 展開時は縦棒を回転させて横棒に重ね、見た目が「−」になる */
.reien-faq__toggle[aria-expanded="true"] .reien-faq__icon::after {
  transform: translate(-50%, -50%) rotate(0deg);
}

/* パネル（アニメ開閉。初期は閉じ） */
.reien-faq__panel {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.45s ease;
  background-color: var(--color-white);
}

.reien-faq__answer-wrap {
  margin-top: -3px;
  margin-top: -0.1875rem;
  padding: 0 15px 12px 17px;
  padding: 0 0.9375rem 0.75rem 1.0625rem;
  display: flex;
  align-items: flex-start;
  column-gap: 14px;
  column-gap: 0.875rem;
}

.reien-faq__amark {
  font-size: 19px;
  font-size: 1.1875rem;
  font-weight: 700;
  line-height: calc(25.5 / 19);
  position: relative;
  top: 5px;
  top: 1px;
  top: 0.0625rem;
}

.reien-faq__text,
.reien-faq__answer-item {
  font-size: 14px;
  font-size: 0.875rem;
  line-height: calc(25 / 14);
  font-family: "Noto Sans JP", sans-serif;
}

.reien-faq__answer-item {
  text-indent: -1em;
  padding-left: 1em;
}

.reien-faq__text a {
  color: var(--color-text);
}

.reien-faq__list + .reien-faq__group-title {
  margin-top: 25px;
}

@media (min-width: 769px) {
  .reien-faq {
    padding: 60px 0 60px;
  }

  .reien-faq__inner {
    max-width: 1020px;
  }

  .reien-faq__decoration-wrapper {
    width: 136.33px;
  }

  .reien-faq__title {
    margin-top: 34.6px;
    font-size: 36px;
    line-height: calc(48 / 36);
  }

  .reien-faq__group-title {
    margin-top: 17px;
    font-size: 26px;
    line-height: calc(50 / 26);
  }

  .reien-faq__group-title span {
    font-size: 26px;
    line-height: calc(50 / 26);
  }

  .reien-faq__list {
    margin-top: 8px;
  }

  .reien-faq__toggle {
    padding: 17px 74.8px 18px 40.7px;
    column-gap: 10px;
  }

  .reien-faq__qmark {
    font-size: 22px;
    line-height: calc(22 / 22);
    top: 1px;
    top: 0.0625rem;
  }

  .reien-faq__question {
    font-size: 18px;
    line-height: calc(25 / 18);
  }

  .reien-faq__icon {
    position: absolute;
    right: 44.8px;
    width: 24px;
    height: 24px;
  }

  .reien-faq__answer-wrap {
    padding: 5px 100.1px 20px 41.7px;
    column-gap: 13.2px;
  }

  .reien-faq__amark {
    font-size: 22px;
    line-height: calc(22 / 22);
    top: 0;
  }

  .reien-faq__text,
  .reien-faq__answer-item {
    font-size: 15px;
    line-height: calc(24 / 15);
  }

  .reien-faq__list + .reien-faq__group-title {
    margin-top: 22px;
  }
}

/* ==========================================
    FVのアニメーション
   ========================================== */
.reien-fv .reien-fv__image {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1s ease-out 0.1s,
    transform 1s cubic-bezier(0.16, 0.84, 0.44, 1) 0.1s;
  will-change: opacity, transform;
}

.reien-fv.is-anim .reien-fv__image {
  opacity: 1;
  transform: translateY(0);
}

/* タイトル：距離を増やして余韻、開始を少し遅らせる */
.reien-fv .reien-fv__title {
  transform: translateY(18px);
  opacity: 0;
  transition: transform 800ms cubic-bezier(0.22, 0.61, 0.36, 1) 220ms,
    opacity 800ms ease 220ms;
}

/* サブタイトル：さらに遅らせて段階感を強める */
.reien-fv .reien-fv__sub-title {
  transform: translateY(14px);
  opacity: 0;
  transition: transform 800ms cubic-bezier(0.22, 0.61, 0.36, 1) 480ms,
    opacity 800ms ease 480ms;
}

/* ハイライト帯：少し長めに＆サブタイトル後にスタート */
.reien-fv .bg-beige {
  position: relative;
}
.reien-fv .bg-beige::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #efe3d2;
  transform-origin: left center;
  transform: scaleX(0);
  transition: transform 820ms cubic-bezier(0.22, 0.61, 0.36, 1) 560ms;
  z-index: -1;
}

/* デコ：距離を増やし、わずかに縮小から戻す。個別にディレイ差でリズム */
.reien-fv .reien-fv__decoration01,
.reien-fv .reien-fv__decoration02 {
  opacity: 0;
  transform: translateY(16px) scale(0.96);
  transition: transform 840ms cubic-bezier(0.22, 0.61, 0.36, 1),
    opacity 840ms ease;
  will-change: transform, opacity;
}
.reien-fv .reien-fv__decoration01 {
  transition-delay: 640ms;
}
.reien-fv .reien-fv__decoration02 {
  transition-delay: 720ms;
}

/* ===== ゴール（.is-anim） ===== */
.reien-fv.is-anim .reien-fv__image {
  transform: translateY(0) scale(1);
  filter: blur(0);
  opacity: 1;
}
.reien-fv.is-anim .reien-fv__title,
.reien-fv.is-anim .reien-fv__sub-title {
  transform: none;
  opacity: 1;
}
.reien-fv.is-anim .bg-beige::before {
  transform: scaleX(1);
}
.reien-fv.is-anim .reien-fv__decoration01,
.reien-fv.is-anim .reien-fv__decoration02 {
  transform: none;
  opacity: 1;
}

/* 低モーション：即時表示 */
@media (prefers-reduced-motion: reduce) {
  .reien-fv .reien-fv__image,
  .reien-fv .reien-fv__title,
  .reien-fv .reien-fv__sub-title,
  .reien-fv .reien-fv__decoration01,
  .reien-fv .reien-fv__decoration02,
  .reien-fv .bg-beige::before {
    transition: none !important;
    transform: none !important;
    filter: none !important;
    opacity: 1 !important;
  }
}

/* ==========================================
    ナビゲーションのアニメーション
   ========================================== */
/* 初期：少し下＋透明（高さは崩さない） */
.reien-navigation .reien-navigation__item {
  opacity: 0;
  transform: translateY(10px);
  transition: transform 600ms cubic-bezier(0.22, 0.61, 0.36, 1),
    opacity 600ms ease;
}

/* 画面内に入ったら表示 */
.reien-navigation.is-revealed .reien-navigation__item {
  opacity: 1;
  transform: none;
}

/* ステップ表示（ディレイ）※項目数に合わせて調整可 */
.reien-navigation.is-revealed .reien-navigation__item:nth-child(1) {
  transition-delay: 100ms;
}
.reien-navigation.is-revealed .reien-navigation__item:nth-child(2) {
  transition-delay: 200ms;
}
.reien-navigation.is-revealed .reien-navigation__item:nth-child(3) {
  transition-delay: 300ms;
}
.reien-navigation.is-revealed .reien-navigation__item:nth-child(4) {
  transition-delay: 400ms;
}
.reien-navigation.is-revealed .reien-navigation__item:nth-child(5) {
  transition-delay: 500ms;
}
.reien-navigation.is-revealed .reien-navigation__item:nth-child(6) {
  transition-delay: 600ms;
}

/* 低モーション環境は即時表示 */
@media (prefers-reduced-motion: reduce) {
  .reien-navigation .reien-navigation__item {
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
  }
}

/* ==========================================
    アニメーション共通
   ========================================== */
/* 下からふわっと表示アニメーション */
.js-fade-in-up {
  opacity: 0;
  transform: translateY(50px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.js-fade-in-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* 低モーション環境ではアニメーションを無効化 */
@media (prefers-reduced-motion: reduce) {
  .js-fade-in-up {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
