@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500&display=swap');
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond&display=swap');

/* common
==========================================================*/

body { font-size: 15px; line-height: 2; font-family: 'Noto Serif JP','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif; margin:0; padding: 0; letter-spacing:0.1em; color:#000; -webkit-text-size-adjust: 100%; background: #f1f1f1; }
@media screen and (max-width: 1000px) {
    body { font-size: 14px;}
}
@media screen and (max-width: 750px) {
    body { font-size: 13px; line-height: 1.8;}
}

a { text-decoration: none; color: #000; outline: none; -webkit-transition: all .3s; transition: all .3s;}
a *,
a:after,
.trans03{-webkit-transition: all .3s; transition: all .3s; }
a:hover { text-decoration: none; -webkit-transition: all .3s; transition: all .3s;}
.hoverbig:hover { transform: scale(1.1);}
@media screen and (max-width: 800px){
    .hoverbig:hover { transform: scale(1);}
}
img { -ms-interpolation-mode: bicubic; max-width: 100%; height: auto; max-width: 100%; height: auto; vertical-align: bottom;}
:focus { outline: 0; }
* { box-sizing: border-box}

.tellink { pointer-events: none;}
@media screen and (max-width: 750px){
    .tellink { pointer-events: auto;}
}  
    
.flex { display: flex; flex-wrap: wrap; }
.flex-nowrap { display: flex; }
.flex-jcs {display: flex; justify-content: space-between; flex-wrap: wrap; }
.flex-jca { display: flex; justify-content: space-around; flex-wrap: wrap; }
.flex-center {display: flex; justify-content: center; align-items: center; flex-wrap: wrap; }
.flex-aic { display: flex; align-items: center; flex-wrap: wrap; }
.flex-jcc { display: flex; justify-content: center; flex-wrap: wrap; }

.centerposi { position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); /* Safari用 */ transform: translate(-50%, -50%); }
.centertate { position: absolute; top: 50%; -webkit-transform: translateY(-50%); /* Safari用 */ transform: translateY(-50%); } 
.centeryoko { position: absolute; left: 50%; -webkit-transform: translateX(-50%); /* Safari用 */ transform: translateX(-50%); } 

.inner{width: calc(100% - 40px); margin: 0 auto;}
.inner800 { max-width: 800px; width: calc(100% - 40px); margin: 0 auto;}
.inner1000{ max-width: 1000px; width: calc(100% - 40px); margin: 0 auto;}
.inner1200{ max-width: 1200px; width: calc(100% - 40px); margin: 0 auto;}

.fs11{ font-size: calc(11em / 15);}
.fs12{ font-size: calc(12em / 15);}
.fs13{ font-size: calc(13em / 15);}
.fs16{ font-size: calc(16em / 15);}
.fs18{ font-size: calc(18em / 15);}
.fs20{ font-size: calc(20em / 15);}
.fs25{ font-size: calc(25em / 15);}
.fs28{ font-size: calc(28em / 15);}
.fs32{ font-size: calc(32em / 15);}
.fs33{ font-size: calc(33em / 15);}
.fs35{ font-size: calc(35em / 15);}

.fc-r { color: #C1272D; }
.fc-b { color: #000;}
.fc-w,
.fc-w a{ color: #fff;}

.Garamond {font-family: 'EB Garamond', serif;}

#wrapper { overflow: hidden;}

.after,
.before{ position: relative;} 
.after:after,
.before:before { content: ""; position: absolute; }

.tate {-webkit-writing-mode: vertical-rl; -ms-writing-mode: tb-rl; writing-mode: vertical-rl;}
.clamp { display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; overflow:hidden; }



.sp-show{display: none;}
@media screen and (max-width: 950px) {
    .sp-hide950{display: none;}
}
@media screen and (max-width: 880px) {
    .sp-hide880{display: none;}
}
@media screen and (max-width: 600px) {
    .sp-hide{display: none;}
    .sp-show{display: block;}
}



/* header
==========================================================*/

header {}
.headlogo{ top: 30px; left: 20px; width: 97px; z-index: 2; position: absolute; }
.page-ind .headlogo { position: fixed; }
.fp-viewing-0-0 .headlogo{ opacity: 0;}
.fp-viewing-6-0 .headlogo,
.page-nomain .headlogo{ background: url(../images/common/logo-b.png?a) no-repeat center; background-size: cover;}
.fp-viewing-6-0 .headlogo img,
.page-nomain .headlogo img { opacity: 0;}
.gnavwrap{ justify-content: flex-end; position: absolute; top: 0; right: 0; z-index: 2;}
.page-ind .gnavwrap{ position: fixed; }
.gnavul{ margin-right: 40px;}
.gnavul li{}
.gnavul li a { height: 90px; padding: 0 18px; display: flex; align-items: center;}
.fp-viewing-6-0 .gnavul li a,
.page-nomain .gnavul li a{ color: #000;}
.headbtn{}
.headbtn a{ width: 200px; height: 90px; background: #000;}
.navInner { display: none;}
@media screen and (max-width:1000px){
    .headlogo{ top: 20px; left: 0; width: 80px; }
    .gnavul{ margin-right: 10px;}
    .gnavul li{}
    .gnavul li a { height: 70px; padding: 0 10px;}
    .headbtn a{ width: 120px; height: 70px; }
}
@media screen and (max-width:750px){
    .headlogo{ top: 20px;  width: 60px;}
    .gnavwrap{ width: 100%; height: 100%; align-items: center; justify-content: center; flex-direction: column; position: inherit; top: 0; font-size: 13px;}
    .gnavwrap a { color: #000; }
    .gnavul{ display: block; margin-right: 0; text-align: center; width: 100%;}
    .gnavul li a { height: 50px; display: flex; justify-content: center;}
    .headbtn a{ width: 100%; height: 50px; background: none;}
    
    #menu { width: 100%; height: 100%; right: 0; top: 0; display: none; position: fixed; background: #fff; -webkit-overflow-scrolling: touch; overflow-scrolling: touch; z-index: 9901 !important; overflow: scroll !important; }
    .navInner { display: block; width: 60px; height: 60px; top: 0; right: 0; z-index: 9999; cursor: pointer; display: block; position: fixed; background: #000;}
    .menu-trigger { width: 100%; height: 100%; line-height: inherit; cursor: pointer; position: relative; display: inline-block; transition: all .3s; }
    .menu-trigger .menutxt  { text-align: center; position: absolute; bottom: 8px; left: 0; width: 100%;}
    .menu-trigger span { width: 26px; height: 1px; left: 17px; display: inline-block; transition: all .3s; position: absolute; background: #fff;  }
    .menu-trigger span:nth-of-type(1) { top: 15px; }
    .menu-trigger span:nth-of-type(2) { top: 28px; }
    .menu-trigger:not(.active):hover span:nth-of-type(1) { top: 16px; }
    .menu-trigger:not(.active):hover span:nth-of-type(2) { top: 27px; }
    .menu-trigger.active span {}
    .menu-trigger.active span:nth-of-type(1) { transform: translateY(6.5px) rotate(-45deg); }
    .menu-trigger.active span:nth-of-type(2) { transform: translateY(-6.5px) rotate(45deg); }
}


    
/* footer
==========================================================*/

footer{ padding: 70px 0; padding-right: 100px; background: #000; z-index: 2;}
.footlogo{ width: 140px; top: 70px; left: 140px; position: absolute;}
.foot-r{ flex-direction: column; align-content: flex-end;}
.foot-rnav{ margin-bottom: 60px; justify-content: flex-end;}
.foot-rnav li{ margin-left: 30px;}
.foot-rnav li a{}
.footbtnul{ margin-bottom: 100px; justify-content: flex-end;}
.footbtnul li{ margin-left: 40px;}
.footbtnul li a { width: 380px; height: 110px; padding-bottom: 0.5em; border: 1px solid #fff; flex-direction: column;}
.footbtnul li a:hover { background: #fff; color: #000;}
.footbtnul li p { line-height: 1;}
.footbtnul li p:nth-child(2) { margin-top: 12px;}
.footcopy{ text-align: right;}
.foot_napwrap{margin-bottom: 30px; display: flex;  justify-content: end;}

@media screen and (max-width:1300px){
    .footlogo{ width: 100px; top: 70px; left: 70px; }
}
@media screen and (max-width:1160px){
    .foot-rnav { width: 580px;}
}
@media screen and (max-width:1000px){
    footer{ padding-inline: 7%;}
    .footlogo{ left: 6%; }
    .footbtnul li{ margin-left: 20px;}
}
@media screen and (max-width:850px){
    footer{ padding: 50px 20px 30px;}
    .footlogo{ width: 90px; top: 0; left: 0; margin: 0 auto 50px; position: inherit;}
    .foot-r{ align-content:center;}
    .foot-rnav { width: 100%; margin-bottom: 30px; margin-left: -30px; justify-content: center;}
    .foot-rnav li { margin-bottom: 10px;}
    .footbtnul { margin-left: -10px; margin-bottom: 40px; justify-content: center;}
    .footbtnul li{ margin-left: 10px; margin-bottom: 10px; width: 100%;}
    .footbtnul li a { width: 100%; max-width: 320px; margin-inline: auto; height: 90px;}
    .footcopy{ text-align: center;}
    .foot_napwrap{text-align: center; justify-content: center;}
}

/* index
==========================================================*/

#fullpage{}
#fullpage .section{}
#fp-nav.right { right: 50px;}
#fp-nav ul li, .fp-slidesNav ul li { width: 8px; height: 25px; margin: 0; }
#fp-nav ul li a span, .fp-slidesNav ul li a span { margin: 0;width:0; height:0; top: 0; background: #fff; }
#fp-nav ul li a.active span, #fp-nav ul li:hover a.active span, .fp-slidesNav ul li a.active span, .fp-slidesNav ul li:hover a.active span,
#fp-nav ul li:hover a span, .fp-slidesNav ul li:hover a span{ margin: 0; width: 8px; height: 8px;}
#fp-nav:after { content: ""; width: 1px; height: calc(100% - 20px); background: #fff; top: 0; left:calc(50% + 4px); position: absolute;}
.fp-viewing-6-0 #fp-nav ul li a span,
.fp-viewing-6-0 .fp-slidesNav ul li a span,
.fp-viewing-6-0 #fp-nav:after { background: #000;}
@media screen and (max-width:1000px){
    #fp-nav.right { right: 30px;}   
}
@media screen and (max-width:750px){
    .fp-viewing-6-0 #fp-nav.right { display: none;}
}

.indmainlogo{ width: 184px; left: calc(50% - 184px / 2); top: calc(50% - 298px / 2); z-index: 2; }
#mainslide{width: 100%; height: 100%;} 
#mainslide .swiper-wrapper{}
#mainslide .swiper-slide01{ background: url(../images/index/indbg01-01.jpg?ab) no-repeat center; background-size: cover;}
#mainslide .swiper-slide02{ background: url(../images/index/indbg01-02.jpg?ab) no-repeat center; background-size: cover;}
#mainslide .swiper-slide03{ background: url(../images/index/indbg01-03.jpg?ab) no-repeat center; background-size: cover;}
#mainslide .swiper-pagination{ justify-content: flex-end; bottom: 20px; left: inherit; right: 20px;}
#mainslide .swiper-pagination-bullet { width: 4px;height: 4px; margin: 0; margin-left: 12px; opacity: 1; background: #999;}
#mainslide .swiper-pagination-bullet-active { background: #fff; }
@media screen and (max-width:750px){
    .indmainlogo{ width: 120px; left: calc(50% - 120px / 2); top: calc(50% - 194px / 2); }
}
    
.indslideinner{ flex-direction: column; width: 100%; height: 100%; min-height: 600px;}
#fullpage .slide02 .indslideinner{background: url(../images/index/indbg_about.jpg?a) no-repeat center; background-size: cover;}
#fullpage .slide03 .indslideinner{background: url(../images/index/indbg_keidai.jpg?a) no-repeat center; background-size: cover;}
#fullpage .slide04 .indslideinner{background: url(../images/index/indbg_event.jpg?a) no-repeat center; background-size: cover;}
#fullpage .slide05 .indslideinner{background: url(../images/index/indbg_memorial.jpg?a) no-repeat center; background-size: cover;}
#fullpage .slide06 .indslideinner{background: url(../images/index/indbg_ossuary.jpg?a) no-repeat center; background-size: cover;}
#fullpage .indmid { margin-bottom: 80px; letter-spacing: 0.2em; line-height: 1.4;}
.btn{ width: 150px; height: 50px; border: 1px solid #fff;font-family: 'EB Garamond', serif;}
.btn:hover { background: #fff; color: #000;}
@media screen and (max-width:750px){
    .indslideinner{ min-height: 400px;}
    #fullpage .indmid { margin-bottom: 40px; letter-spacing: 0.1em; }
}

#fullpage .slide07 .inner1000{ padding: 190px 0 140px;}
.pagemid{ padding-bottom: 90px; margin-bottom: 50px; letter-spacing: 0.2em;}
.pagemid:after { bottom: 0; left: 50%; width: 1px; height: 50px; background: #000;  }
.indmapwrap{ margin-bottom: 30px; width: 100%;}
.indmaptxt{}
.indmaptxt p{}
@media screen and (max-width:1000px){
#mainslide .swiper-slide03{ background: url(../images/index/indbg01-03sp.jpg?ab) no-repeat center; background-size: auto 100%;}
}
@media screen and (max-width:750px){
    #fullpage .slide07 .inner1000{ padding: 90px 0 70px;}
    .pagemid{ padding-bottom: 45px; margin-bottom: 25px; letter-spacing: 0.1em;}
    .pagemid:after {height: 25px;  }
    .indmaptxt{ display: block; text-align: center;}
    .indmaptxt p{}
    #mainslide .swiper-slide02{background-position: 20% 50%;}
}



/* kasou
==========================================================*/

.mainwrap { height: 100vh; max-height: 750px; min-height: 450px; }
.page-about .mainwrap { background: url(../images/index/indbg_about.jpg?a) no-repeat center; background-size: cover;}
.page-keidai .mainwrap { background: url(../images/index/indbg_keidai.jpg?a) no-repeat center; background-size: cover;}
.page-event .mainwrap { background: url(../images/index/indbg_event.jpg?a) no-repeat center; background-size: cover;}
.page-memorial .mainwrap { background: url(../images/index/indbg_memorial.jpg?a) no-repeat center; background-size: cover;}
.page-ossuary .mainwrap { background: url(../images/index/indbg_ossuary.jpg?a) no-repeat center; background-size: cover;}
.page-access .mainwrap { background: url(../images/index/indbg01-01.jpg?ab) no-repeat center; background-size: cover;}
.mainttl { letter-spacing: 0.2em;}
@media screen and (max-width:750px){
    .mainwrap { height: 50vh; max-height: inherit; min-height: 300px; }
    .mainttl { font-size: calc(32em / 15); letter-spacing: 0.1em;}
}
    
.pagesectionwrap {}
.pagesectionwrap section { padding: 140px 0;}
.pagesectionwrap section:nth-child(2n) { background: #EBEBEB; }
.page-nomain .pagedescwrap{ padding-top: 0;}
.pagedescmid{ margin-bottom: 20px; letter-spacing: 0.2em; line-height: 1.4;}
.pagedescimg { margin-top: 80px; }
.pagecontwrap{}
.midwrap{ margin-bottom: 50px;}
.mid{ padding-bottom: 60px; letter-spacing: 0.2em; }
.mid:after { width: 1px; height: 40px; left: 50%; bottom: 0; background: #000; }
.pagelrwrap{ margin-bottom: 50px;}
.pagewideimg{ margin-bottom: 40px;}
.page-l{ width: 50%; }
.page-r{width: calc(50% - 50px);}
.pagelrwrap .fs28 { margin-bottom: 25px; letter-spacing: 0.2em; line-height: 1;}
.pagecontwrap p { margin-bottom: 20px;}
@media screen and (max-width:900px){
    .pagesectionwrap section { padding: 100px 0;}
    .page-r{width: calc(50% - 30px);}
}    
@media screen and (max-width:750px){
    .pagesectionwrap section { padding: 50px 0;}
    .pagedescmid{ margin-bottom: 15px; letter-spacing: 0.1em; font-size: calc(30em / 15);}
    .pagedescimg { margin-top: 30px; width: calc(100% +  40px); margin-left: -20px;}
    .midwrap{ margin-bottom: 40px;}
    .mid{ padding-bottom: 40px; letter-spacing: 0.1em; font-size: calc(32em / 15); line-height: 1.4; }
    .mid:after { height: 30px;}
    .pagelrwrap{ margin-bottom: 30px;}
    .pagewideimg{ margin-bottom: 20px; width: calc(100% +  40px); margin-left: -20px;}
    .page-r{width: calc(50% - 20px);}
    .pagelrwrap .fs28 { margin-bottom: 15px; letter-spacing: 0.1em; font-size: calc(25em / 15);}
    .pagecontwrap p { margin-bottom: 15px;}
}
@media screen and (max-width:600px){
    .pagelrwrap{ flex-direction: column;}
    .page-l{ margin-bottom: 10px; width: 100%; }
    .page-r{width: 100%;}
}


.about_history dl {padding: 0.8em 0;border-bottom: 1px solid #ccc;}
.about_history dt {width: 13em;}
@media screen and (min-width: 500px) {
.about_history dt {clear: left;float: left;}
}




  .custom-swiper {width: 100%; max-width: 100%; position: relative; overflow: hidden; }
  .custom-swiper .swiper-wrapper {display: flex;  transition-timing-function: ease;  }
  .custom-swiper .swiper-slide { flex-shrink: 0; width: 100%;  }
  .custom-swiper img {width: 100%; height: auto; display: block;}
  .custom-swiper .swiper-pagination {position: static; margin-top: 10px;  text-align: center;  }
  .custom-swiper .swiper-pagination-bullet {width: 10px;  height: 10px; background-color: #999; opacity: 1;
    border-radius: 50%; margin: 0 4px; transition: background-color 0.3s;  }
  .custom-swiper .swiper-pagination-bullet-active { background-color: #333;}

@media screen and (max-width:600px){
  .custom-swiper .swiper-pagination-bullet{width: 8px;  height: 8px;}
    .custom-swiper .swiper-pagination { margin-top: 6px;margin-bottom: 10px; }
}


/* event
==========================================================*/

@media screen and (min-width: 751px){
    .eventtab { border-left: 1px solid #999; border-top: 1px solid #999; width: 100%; }
    .eventtab th,
    .eventtab td{ padding: 20px; border-bottom: 1px solid #999; border-right:  1px solid #999; }
    .eventtab th { width: 60px; padding: 20px 10px; text-align: center;}
    .eventtab td:last-child { width: 70%;}
}
.eventtab a { text-decoration: underline;}
.eventtab a:hover { text-decoration: none;}
@media screen and (max-width: 750px){
    .eventtab { padding-top: 20px; border-top: 1px solid #999; border-bottom: 1px solid #999; display: block;}
    .eventtab tr { display: block; position: relative;}
    .eventtab th { top: 0; left: 0; position: absolute; display: block;}
    .eventtab td { margin-left: 50px; display: block;}
    .eventtab td:last-child { padding-bottom: 20px; margin-bottom: 20px; border-bottom: 1px dotted #999;}
    .eventtab tr:last-child td:last-child { border: none; margin-bottom: 0; }
}



/* blog
==========================================================*/

.nomainwrap { padding: 180px 0 100px;}
.bloglrwrap{}
.blog-l{ width: 115px;}
.blog-lmid{ padding-bottom: 10px; margin-bottom: 30px; border-bottom: 1px solid #000;}
.blog-lul{ margin-bottom: 80px;}
.blog-lul li{position: relative; padding-left: 20px; margin-bottom: 30px; line-height: 1; }
.blog-lul li:after {content: ""; position: absolute; width: 10px; height: 1px; left: 0; top: 50%; background: #000; }
.blog-lul li a{}

.blog-r{ max-width: 740px; width: calc(100% - 115px - 40px);}
.blogpostul{}
.blogpostul li{ padding-bottom: 80px; margin-bottom: 100px;}
.blogpostul li:after { width: 70px; height: 1px; left: calc(50% - 35px); bottom: 0; background: #000;}
.blogpostul li:last-child:after { display: none;}
.blogpostdc{}
.blogpostdc div{ margin-right: 10px;}
.blogpostttl{ margin-bottom: 40px;}
.blogposttxt{}
.blogposttxt p{ margin-bottom: 30px;}
@media screen and (max-width:750px){
    .nomainwrap { padding: 50px 0;}
    .bloglrwrap{ flex-direction: column-reverse; padding-bottom: 40px;}
    .blog-l{ width: 100%;}
    .blog-lmid{ padding-bottom: 10px; margin-bottom: 20px;}
    .blog-lul{ margin-bottom: 40px;}
    .blog-lul li{ padding-left: 20px; margin-bottom: 20px; }
    .blog-r{ max-width: inherit; width: 100%;}
    .blogpostul{}
    .blogpostul li{ padding-bottom: 30px; margin-bottom: 50px;}
    .blogpostul li:last-child { margin-bottom: 0;}
    .blogpostdc div{ margin-right: 10px;}
    .blogpostttl{ margin-bottom: 20px;}
}



/* contact
==========================================================*/

.contactwrap { padding-bottom: 100px;}
.contactform { }
.contactul { display: flex; justify-content: space-between; flex-wrap: wrap; }
.contactul > li { margin-bottom: 40px; }
.contactul > li.w1 { width: 100%; }
.contactul > li.w2 { width: calc(50% - 5px); }
.contactmid { margin-bottom: 10px; display: inline-block; position: relative;}
.contactmid.hissu:after { content: "※"; color: #C1272D; position: absolute; top: 0; right: -1.5em;  }
.contactul > li > input { height: 50px; padding: 0 15px; font-size: 0.8em; box-sizing: border-box; background: #fff; border: none; width: 100%; }
.contactform ::placeholder {color: #999; }
.contactform textarea { width: 100%; height: 400px; padding: 15px; line-height: 2; box-sizing: border-box; border: none; background: #fff; }
.error_box { padding: 30px; margin-bottom: 30px; line-height: 2; display: none; color: #f00; border: 1px solid #f00;}
.submitwrap { text-align: center;}
input[type="submit"] { -webkit-appearance: none; border-radius: 0; }
.submitbtn { width: 200px; height: 50px; line-height: 50px; cursor: pointer; display: inline-block; border: none; text-align: center; background: #000; color: #fff; font-weight: bold;} 
.submitbtn:hover { opacity: -webkit-opacity:.6;opacity:.6;}

.thankswrap { padding-bottom: 100px;}
.thankswrap h2 { margin-bottom: 30px;}
.thankswrap p { margin-bottom: 15px;}
@media screen and (max-width: 750px){
    .contactwrap { padding-bottom: 50px;}
    .contactform textarea { width: 100%; height: 250px; }
    .thankswrap { padding-bottom: 50px;}
    .thankswrap h2 { margin-bottom: 20px;}
    .thankswrap p br { display: none;} 
}
    










