@charset "UTF-8";
/* ----------------------------------------------------------------
kv
----------------------------------------------------------------- */
#years .kv {
  background-image: url(../img/years/kv.jpg); }

#years h2 {
  font-size: 3rem; }
  @media (max-width: 768px) {
    #years h2 {
      /*  768px  */
      font-size: 2.4rem; } }

#years h2 span {
  writing-mode: horizontal-tb;
  display: inline-block;
  margin-bottom: 1rem; }

/* ----------------------------------------------------------------
years
----------------------------------------------------------------- */
.years_inner {
  max-width: 1300px;
  width: 90%;
  margin: 0 auto;
  margin-bottom: 60px; }

/* ----------------------------------------------------------------
スライダー
----------------------------------------------------------------- */
.under-slider-wrapper {
  display: grid;
  gap: 4rem;
  grid-template-columns: repeat(3, 1fr); }
  @media (max-width: 768px) {
    .under-slider-wrapper {
      /*  768px  */
      gap: 0; } }

/* 画像のサイズ調整 */
.swiper-slide img {
  height: auto;
  width: 100%;
  border-radius: 10px; }

.under-slider, .under-slider {
  padding-bottom: 30px; }

.under-slider_image {
  position: relative; }

.under-slider_image:after {
  position: absolute;
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 18px solid #18513D;
  border-right: 0;
  top: 55%;
  right: -8%;
  transform: translateY(50%); }
  @media (max-width: 768px) {
    .under-slider_image:after {
      /*  768px  */
      display: none; } }

.under-slider_image:last-child:after {
  display: none; }

.whole-slider-wrapper {
  display: grid;
  gap: 4rem;
  grid-template-columns: repeat(3, 1fr); }
  @media (max-width: 768px) {
    .whole-slider-wrapper {
      /*  768px  */
      gap: 0; } }

/* 画像のサイズ調整 */
.swiper-slide img {
  height: auto;
  width: 100%;
  border-radius: 10px; }

.whole-slider, .whole-slider {
  padding-bottom: 30px; }

.whole-slider_image {
  position: relative; }

.whole-slider_image:after {
  position: absolute;
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 18px solid #18513D;
  border-right: 0;
  top: 55%;
  right: -8%;
  transform: translateY(50%); }
  @media (max-width: 768px) {
    .whole-slider_image:after {
      /*  768px  */
      display: none; } }

.whole-slider_image:last-child:after {
  display: none; }

/* ----------------------------------------------------------------
目次
----------------------------------------------------------------- */
.contents_wrap {
  border: 1px solid #ccc;
  background-color: #fff;
  padding: 3% 5%;
  border-radius: 10px;
  width: 600px;
  margin-inline: auto; }
  @media (max-width: 768px) {
    .contents_wrap {
      /*  768px  */
      width: 90%;
      padding: 10px 15px; } }

.contents_wrap p {
  border-bottom: 1px solid #ccc;
  padding-bottom: 1.5rem;
  font-size: 2rem; }
  @media (max-width: 768px) {
    .contents_wrap p {
      /*  768px  */
      font-size: 1.7rem;
      padding-bottom: 1rem; } }

.contents_lists {
  margin-top: 2rem; }
  @media (max-width: 768px) {
    .contents_lists {
      /*  768px  */
      margin-top: 1rem; } }

.contents_lists li {
  padding-left: 1.25em;
  position: relative;
  line-height: 1.7;
  margin: 3px 0;
  font-size: 1.8rem; }
  @media (max-width: 768px) {
    .contents_lists li {
      /*  768px  */
      font-size: 1.5rem; } }

.contents_lists li:before {
  position: absolute;
  top: calc(0.75em - 3px);
  left: 2px;
  display: block;
  width: 6px;
  height: 6px;
  color: inherit;
  background-color: currentColor;
  border-radius: 50%;
  content: ""; }

.contents_lists-sub li {
  position: relative;
  padding-left: 1.25em;
  font-size: 1.6rem; }
  @media (max-width: 768px) {
    .contents_lists-sub li {
      /*  768px  */
      font-size: 1.4rem; } }

.contents_lists-sub li:before {
  position: relative;
  content: "";
  width: 15px;
  height: 1px;
  background-color: #333;
  top: 14px;
  left: -20px; }

.contents_lists-margin {
  margin-top: 16px !important; }

/* ----------------------------------------------------------------
イントロ
----------------------------------------------------------------- */
.intro {
  max-width: 800px;
  margin: 3rem 0 35px 0;
  margin-inline: auto; }
  @media (max-width: 768px) {
    .intro {
      /*  768px  */
      margin: 2rem 0 15px 0; } }

.intro h3 {
  font-size: 2.5rem;
  text-align: left;
  position: relative;
  font-weight: normal;
  font-weight: bold;
  border-bottom: solid 2px #cccccc;
  padding: 0 0 15px 0; }
  @media (max-width: 768px) {
    .intro h3 {
      /*  768px  */
      font-size: 1.8rem; } }

.intro h3:after {
  position: absolute;
  border: solid 1px #18513d;
  background-color: #18513d;
  bottom: -2px;
  left: 0;
  width: 75px;
  content: "";
  border-radius: 3px; }

.intro_text p {
  margin-top: 2rem;
  font-size: 1.8rem;
  text-align: justify; }
  @media (max-width: 768px) {
    .intro_text p {
      /*  768px  */
      font-size: 1.6rem; } }

.intro_link {
  margin-top: 4rem; }

.intro_link p {
  font-size: 2rem; }
  @media (max-width: 768px) {
    .intro_link p {
      /*  768px  */
      font-size: 1.8rem; } }

.intro_link-area p {
  margin-top: 0; }

.intro_link-area a {
  display: inline;
  color: #18513d;
  border-bottom: #18513d 1px solid;
  margin-top: 0;
  font-size: 1.8rem; }
  @media (max-width: 768px) {
    .intro_link-area a {
      /*  768px  */
      font-size: 1.6rem; } }

.intro_image {
  aspect-ratio: 680/611;
  max-width: 68rem;
  margin-inline: auto;
  margin-top: 5rem; }

.intro_image img {
  width: 100%;
  height: 100%;
  object-fit: cover; }

/* ----------------------------------------------------------------
各エリアの100年後
----------------------------------------------------------------- */
.area {
  margin-top: 3rem; }
  @media (max-width: 768px) {
    .area {
      /*  768px  */
      margin-top: 3rem; } }

.area_text {
  max-width: 800px;
  margin-inline: auto; }

.area h4 {
  font-size: 2.2rem;
  font-weight: 700;
  position: relative; }
  @media (max-width: 768px) {
    .area h4 {
      /*  768px  */
      font-size: 1.8rem; } }

.area h4:after {
  position: absolute;
  content: "";
  border: 1px solid #18513D;
  width: 4rem;
  top: 130%;
  left: 0; }
  @media (max-width: 768px) {
    .area h4:after {
      /*  768px  */
      top: 150%; } }

.area_desc {
  margin-top: 4rem; }

.years_slider {
  max-width: 1000px;
  margin-inline: auto; }
  @media (max-width: 768px) {
    .years_slider {
      /*  768px  */
      width: 90%; } }

.years100 {
  margin-top: 5rem; }
  @media (max-width: 768px) {
    .years100 {
      /*  768px  */
      margin-top: 2.5rem; } }

.years100.years100--first {
  margin-top: 8rem; }
  @media (max-width: 768px) {
    .years100.years100--first {
      /*  768px  */
      margin-top: 4rem; } }

.years100_progress {
  color: #18513d;
  font-size: 2rem;
  text-align: center; }
  @media (max-width: 768px) {
    .years100_progress {
      /*  768px  */
      font-size: 1.6rem; } }

.years100_explanation {
  font-size: 1.6rem;
  text-align: center;
  margin-bottom: 3rem; }
  @media (max-width: 768px) {
    .years100_explanation {
      /*  768px  */
      font-size: 1.4rem; } }

.years100_image.years100_image--first {
  margin-top: 3.5rem; }

.years100_desc {
  font-size: 1.6rem; }
  @media (max-width: 768px) {
    .years100_desc {
      /*  768px  */
      font-size: 1.4rem; } }

/* ----------------------------------------------------------------
各エリアの100年後　全体のイメージ
----------------------------------------------------------------- */
.whole {
  max-width: 800px;
  margin: 3rem 0 35px 0;
  margin-inline: auto; }
  @media (max-width: 768px) {
    .whole {
      /*  768px  */
      margin: 2rem 0 15px 0; } }

.whole h3 {
  font-size: 2.5rem;
  text-align: left;
  position: relative;
  font-weight: normal;
  font-weight: bold;
  border-bottom: solid 2px #cccccc;
  padding: 0 0 15px 0; }
  @media (max-width: 768px) {
    .whole h3 {
      /*  768px  */
      font-size: 1.8rem; } }

.whole h3:after {
  position: absolute;
  border: solid 1px #18513d;
  background-color: #18513d;
  bottom: -2px;
  left: 0;
  width: 75px;
  content: "";
  border-radius: 3px; }

.whole p {
  margin-top: 2rem; }

.whole_imageBox {
  display: flex;
  align-items: center;
  gap: 4.5rem;
  width: 90%;
  margin-inline: auto; }
  @media (max-width: 768px) {
    .whole_imageBox {
      /*  768px  */
      flex-direction: column;
      gap: 2rem; } }

.whole_image {
  position: relative;
  margin-top: 4rem; }

.whole_image:after {
  position: absolute;
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 18px solid #18513D;
  border-right: 0;
  top: 40%;
  right: -10%;
  transform: translateY(50%); }
  @media (max-width: 768px) {
    .whole_image:after {
      /*  768px  */
      display: none; } }

.whole_image:last-child:after {
  display: none; }

.whole_image img {
  width: 100%;
  height: 100%;
  object-fit: cover; }

.whole_image p {
  text-align: center;
  font-size: 1.4rem;
  margin-top: 0; }

.sp-swiper {
  display: none; }
  @media (max-width: 768px) {
    .sp-swiper {
      /*  768px  */
      display: block; } }

@media (max-width: 768px) {
  .pc-whole_image {
    /*  768px  */
    display: none; } }

.whole-slider {
  padding-bottom: 60px; }

/* ----------------------------------------------------------------
ドイツ型樹木葬　リンク
----------------------------------------------------------------- */
.germany {
  max-width: 800px;
  margin-top: 8rem;
  margin-inline: auto; }
  @media (max-width: 768px) {
    .germany {
      /*  768px  */
      max-width: 90%; } }

.germany_head {
  text-align: center;
  color: #18513D;
  position: relative;
  width: 200px;
  margin-inline: auto; }

.germany_head:before {
  content: '';
  position: absolute;
  width: 10px;
  height: 5px;
  left: -10px;
  top: 14px;
  border-left: 2px solid #18513D;
  border-bottom: 2px solid #18513D;
  transform: rotate(-45deg); }

.germany_wrap {
  border: 1px solid #18513D;
  padding: 3% 2%;
  margin-top: 2rem; }
  @media (max-width: 768px) {
    .germany_wrap {
      /*  768px  */
      padding: 6%;
      margin-top: 1rem; } }

.germany a {
  display: flex;
  align-items: center;
  gap: 4rem; }
  @media (max-width: 768px) {
    .germany a {
      /*  768px  */
      flex-direction: column;
      gap: 1rem; } }

.germany_image {
  aspect-ratio: 5/3; }
  @media (max-width: 768px) {
    .germany_image {
      /*  768px  */
      aspect-ratio: 5/2; } }

.germany_image img {
  width: 100%;
  height: 100%;
  object-fit: cover; }

.germany_text p {
  font-size: 1.6rem; }
  @media (max-width: 768px) {
    .germany_text p {
      /*  768px  */
      font-size: 1.5rem; } }

#article01, #article02, #article03, #article04, #article05, #article06, #article07 {
  padding-top: 60px; }
  @media (max-width: 768px) {
    #article01, #article02, #article03, #article04, #article05, #article06, #article07 {
      /*  768px  */
      padding-top: 30px; } }
