@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; }


@media screen and (min-width: 751px) {
  .show-750 {
    display: none;
  }
  .hide-750 {
    display: block;
  }
}
@media screen and (max-width: 750px) {
  .show-750 {
    display: block;
  }
  .hide-750 {
    display: none;
  }
}


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

header {}
.headlogo{ top: 30px; left: 20px; width: 80px; z-index: 2; position: absolute; }
.page-ind .headlogo { position: fixed; }
.fp-viewing-0-0 .headlogo{ opacity: 0;}
.fp-viewing-5-0 .headlogo,
.page-nomain .headlogo{ background: url(../images/common/logo-b.png?251218a) no-repeat center; background-size: cover;}
.fp-viewing-5-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: 28px;}
.gnavul li{}
.gnavul li a { height: 90px; padding: 0 18px; display: flex; align-items: center;}
.fp-viewing-5-0 .gnavul li a,
.page-nomain .gnavul li a{ color: #000;}
/* .headbtn{}
.headbtn a{ width: 200px; height: 80px; background: #000; line-height: 1.2; flex-flow: column;}
.headbtn span{font-size: 1.3em; display: flex; align-items: center; column-gap: 5px; margin-block-start: 5px;}
.headbtn span::before{content: ""; display: block; width: 14px; height: 14px; background-image: url(/assets/images/common/tell.svg);} */
.navInner { display: none;}
@media screen and (max-width:1000px){
    .headlogo{ top: 20px; 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: 120px; top: 70px; left: 120px; 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: 50px; justify-content: flex-end;}
.footbtnul li{ margin-left: 40px;}
.footbtnul li a { width: 270px; height: 100px; 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: 10px;}
.footcopy{ text-align: right;}

.footnap{letter-spacing: .15em; line-height: 1.6; text-align: right; margin-block-end: 40px;}
.footnap span{display: block; font-size: 1.4em; margin-block-end: 5px;}
@media screen and (max-width:1200px){
    .footlogo{ width: 100px; top: 70px; left: 70px; }
}
@media screen and (max-width:1000px){
    footer{ padding-right: 50px;}
    .footlogo{ left: 20px; }
    .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 { margin-bottom: 30px; margin-left: -30px; justify-content: center;}
    .foot-rnav li { margin-bottom: 10px;}
    .footbtnul { margin-left: -10px; margin-bottom: 30px; justify-content: center;}
    .footbtnul li{ margin-left: 10px; margin-bottom: 10px;}
    .footbtnul li a { width: 180px; height: 70px;}
    .footcopy{ text-align: center;} 
    .footnap{text-align: center;margin-block-end: 30px;}
}



/* 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-5-0 #fp-nav ul li a span,
.fp-viewing-5-0 .fp-slidesNav ul li a span,
.fp-viewing-5-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-5-0 #fp-nav.right { display: none;}
}

.indmainlogo{ width: 170px; left: 50%; top: 50%; transform: translate(-50%,-50%); z-index: 2; }
#mainslide{width: 100%; height: 100%;} 
#mainslide .swiper-wrapper{}
#mainslide .swiper-slide::before{content: ""; display: block; position: absolute; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,.15);}
#mainslide .swiper-slide01{ background: url(../images/index/indbg01-01.jpg?25) no-repeat center; background-size: cover;}
#mainslide .swiper-slide02{ background: url(../images/index/indbg01-02.jpg?25) no-repeat center; background-size: cover;}
#mainslide .swiper-slide03{ background: url(../images/index/indbg01-03.jpg?25) 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;}
}
    
.indslideinner{ flex-direction: column; width: 100%; height: 100%; min-height: 600px;}
.indslideinner h2,.indslideinner a{position: relative; z-index: 1;}
#fullpage .slide .indslideinner::after{content: ""; display: block; width: 100%; height: 100%; position: absolute; left: 0; top: 0; background-color: rgba(0,0,0,.2);}
#fullpage .slide02 .indslideinner{background: url(../images/index/indbg02.jpg?25) no-repeat center; background-size: cover;}
#fullpage .slide03 .indslideinner{background: url(../images/index/indbg03.jpg?25) no-repeat center; background-size: cover;}
#fullpage .slide04 .indslideinner{background: url(../images/index/indbg04.jpg?25a) no-repeat center; background-size: cover;}
#fullpage .slide05 .indslideinner{background: url(../images/index/indbg05.jpg?25) no-repeat center; background-size: cover;}
#fullpage .indmid { margin-bottom: 80px; letter-spacing: 0.2em; }
.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 .slide06 .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%; height: 450px;}
.indmapwrap iframe { width: 100%; height: 100%;}
.indmaptxt{}
.indmaptxt p{}
@media screen and (max-width:750px){
    #fullpage .slide06 .inner1000{ padding: 90px 0 70px;}
    .pagemid{ padding-bottom: 45px; margin-bottom: 25px; letter-spacing: 0.1em;}
    .pagemid:after {height: 25px;  }
    .indmapwrap{ margin-bottom: 30px; width: 100%; height: 250px;}
    .indmaptxt{ display: flex; flex-flow: column; row-gap: 10px; text-align: center;}
    .indmaptxt p{}
}



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

.mainwrap { height: 100vh; max-height: 750px; min-height: 450px; position: relative;}
.mainwrap::before{content: ""; display: block; width: 100%; height: 100%; position: absolute; left: 0; top: 0; background-color: rgba(0,0,0,.2);}
.page-about .mainwrap { background: url(../images/index/indbg02.jpg) no-repeat center; background-size: cover;}
.page-memorial .mainwrap { background: url(../images/index/indbg03.jpg?1012) no-repeat center; background-size: cover;}
.page-bill .mainwrap { background: url(../images/index/indbg04.jpg?25a) no-repeat center; background-size: cover;}
.page-event .mainwrap { background: url(../images/index/indbg05.jpg?1012) no-repeat center; background-size: cover;}
.mainttl { letter-spacing: 0.2em; position: relative; z-index: 1;}
.nomainwrap .midwrap .pagemid{white-space: nowrap;}
@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{padding-block-start: 100px;}
.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;}
.disp-b{display: block;}
@media screen and (max-width:900px){
    .pagesectionwrap section { padding: 100px 0;}
    .page-r{width: calc(50% - 30px);}
}    
@media screen and (max-width:750px){
    .page-nomain{padding-block-start: 75px;}
    .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%;}
}




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

@media screen and (min-width: 751px){
    .eventtab { width: 100%; max-width: 800px; margin: 0 auto;}
    .eventtab th,
    .eventtab td{ padding: 20px 0; border-bottom: 1px solid #999;}
    .eventtab th { width: 180px; padding: 20px 10px; font-weight: bold;}
    .eventtab td:nth-of-type(1){width: 180px;}
    .eventtab td:nth-of-type(2){width: calc(100% - 360px);}
}
.eventtab a { text-decoration: underline;}
.eventtab a:hover { text-decoration: none;}
@media screen and (max-width: 750px){
    .eventtab { width: 100%; }
    .eventtab th,
    .eventtab td{ padding: 20px 0; border-bottom: 1px solid #999;}
    .eventtab th { width: 100px; padding: 20px 10px 20px 0; font-weight: bold;}
    .eventtab td:nth-of-type(1){width: 110px;}
    .eventtab td:nth-of-type(2){width: calc(100% - 210px);}
}




/* history
==========================================================*/

@media screen and (min-width: 751px){
    .historytab { width: 100%; }
    .historytab th,
    .historytab td{ padding: 20px 0; border-bottom: 1px solid #999;}
    .historytab th { width: 35%; padding-inline-end: 40px; font-weight: 600;}
    .historytab td{ width: 65%;}
}
.historytab a { text-decoration: underline;}
.historytab a:hover { text-decoration: none;}
@media screen and (max-width: 750px){
    .historytab { width: 100%; }
    .historytab th,
    .historytab td{ padding: 20px 0; border-bottom: 1px solid #999;}
    .historytab th { padding-inline-end: 20px; width: 35%; font-weight: 600;}
    .historytab td{ width: 65%;}
}



.flex-img{display: flex; justify-content: space-between; margin-block-start: 10px;}
.flex-img img{width: calc(50% - 5px);}

@media screen and (max-width: 750px){
    .flex-img{margin-block-start: 5px;}
    .flex-img img{width: calc(50% - calc(5px / 2));}
}




