@charset "UTF-8";
html, body {
  height: 100%;
}

.body-fixed {
  overflow: hidden;
}

.wrapper {
  position: relative;
  margin: auto;
  min-height: 100vh;
  overflow-x: hidden;
}

@media (min-width: 768px) {
  .wrapper { width: 1200px !important; }
}

@media (max-width: 767.98px) {
  .wrapper { width: 100% !important; }
}

.wrapper .container {
  max-width: 100% !important;
}

section {
  position: relative;
}

header {
  position: relative;
  z-index: 1;
}

header .sidenav-brand {
  position: relative;
  margin: 0;
  margin-bottom: 1rem;
  width: 80%;
  padding-top: 46.92%;
  background-color: transparent;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url("../images/base/site-logo.png");
}

@media (max-width: 767.98px) {
  header .sidenav-brand {
    width: 100%;
    padding-top: 25%;
  }
}

header .main-visual {
  position: relative;
  background-color: transparent;
  background-image: url("../images/base/mv-bg.png");
  background-repeat: no-repeat;
}
@media (min-width: 768px) {
  header .main-visual {
    padding-top: 660px;
    background-position: left 60px top 90px;
  }
  header .main-visual .img-visual {
    position: absolute;
    right: -350px;
    top: 60px;
    width: 865px;
    height: auto;
  }
}
@media (max-width: 767.98px) {
  header .main-visual {
    padding-top: 15%;
    background-position: center top 15%;
    background-size: 85%;
  }
  header .main-visual .img-visual {
    position: static;
    max-width: 100%;
  }
}

footer {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  text-align: center;
}

footer small {
  font-family: "Helvetica", "Yu Gothic", "Hiragino Sans", sans-serif;
  line-height: 60px;
}

/* SP Menu */
.navbar-burger {
  z-index: 1001;
  cursor: pointer;
}

@media (min-width: 768px) {
  .navbar-burger {
    display: none;
  }
}

@media (max-width: 767.98px) {
  .navbar-burger {
    position: absolute;
    top: 15px;
    right: 15px;
  }
  .navbar-burger::after {
    display: block;
    width: 40px;
    height: 20px;
    content: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 40 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='%23898989' stroke-width='2' stroke-miterlimit='10' fill='none' d='M3 2h34 m-34 8h34 m-34 8h34'/%3E%3C/svg%3E");
  }
  .navbar-burger.is-active::after {
    content: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 40 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='%233a3a3a' stroke-width='1' stroke-miterlimit='10' fill='none' d='M3 1l34 18 M3 19l34 -18'/%3E%3C/svg%3E");
  }
}

.sidenav {
  z-index: 1;
}

/* SP Menu */
@media (min-width: 768px) {
  .sidenav {
    display: block;
    position: absolute;
    top: 60px;
    left: 0;
    width: 16.666666%;
    padding-left: 45px;
    padding-right: 15px;
  }
}
@media (max-width: 767.98px) {
  .sidenav {
    display: none;
  }
}

.sidenav ul {
  padding-left: 0;
  list-style: none;
}

.sidenav ul.menu li {
  display: block;
  position: relative;
  font-size: 14px;
  line-height: 36px;
}
@media (max-width: 767.98px) {
  .sidenav ul.menu li {
    line-height: 32px;
  }
}

.sidenav ul.menu li a {
  color: rgba(0, 0, 0, 0.9);
  z-index: 1001;
}

.sidenav ul.menu li a:hover, .sidenav ul.menu li a:focus {
  color: black;
}

.sidenav ul.menu li ul.include {
  display: none;
  position: absolute;
  padding-left: 60px;
  left: 120px;
  top: 6px;
}

.sidenav ul.menu li ul.include::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 10px;
  border-top: 2px solid rgba(0, 0, 0, 0.4);
  width: 50px;
}

.sidenav ul.menu li ul.include li {
  white-space: nowrap;
  line-height: 24px;
}

.sidenav ul.menu li ul.include li:not(:first-child)::before {
  content: "";
  display: block;
  position: absolute;
  left: -35px;
  top: -14px;
  border-bottom: 2px solid rgba(0, 0, 0, 0.4);
  border-left: 2px solid rgba(0, 0, 0, 0.4);
  width: 25px;
  height: 25px;
}

.sidenav ul.menu li ul.include li a {
  color: rgba(0, 0, 0, 0.4);
}

.sidenav ul.menu li ul.include li a:hover, .sidenav ul.menu li ul.include li a:focus {
  color: rgba(0, 0, 0, 0.8);
}

@media (min-width: 768px) {
  .sidenav ul.menu li:hover ul.include, .sidenav ul.menu li:focus ul.include {
    display: block;
  }
  .sidenav ul.sns li + li {
    margin-top: 1rem;
  }
}

@media (max-width: 767.98px) {
  .sidenav ul.sns li {
    display: inline-block;
  }
  .sidenav ul.sns li + li {
    margin-left: .125rem;
  }
}

.sidenav ul.sns li a {
  position: relative;
  margin: 0;
  padding-top: 24px;
  background-color: transparent;
  background-position: left top;
  background-repeat: no-repeat;
  background-size: contain;
  color: rgba(0, 0, 0, 0.9);
}

@media (min-width: 768px) {
  .sidenav ul.sns li a.youtube {
    padding-top: 24px;
    width: 112.5px;
    background-image: url("../images/base/link-youtube.png");
  }
}

@media (max-width: 767.98px) {
  .sidenav ul.sns li a.youtube {
    padding-top: 32px;
    width: 40px;
    background-image: url("../images/base/link-youtube_sp.png");
  }
}

.sidenav ul.sns li a.facebook, .sidenav ul.sns li a.instagram, .sidenav ul.sns li a.twitter, .sidenav ul.sns li a.line {
  padding-top: 32px;
  width: 40px;
}

.sidenav ul.sns li a.facebook {
  background-image: url("../images/base/link-facebook.png");
}

.sidenav ul.sns li a.instagram {
  background-image: url("../images/base/link-instagram.png");
}

.sidenav ul.sns li a.twitter {
  background-image: url("../images/base/link-twitter.png");
}

.sidenav ul.sns li a.line {
  background-image: url("../images/base/link-line.png");
}

.sidenav ul.sns li a:hover, .sidenav ul.sns li a:focus {
  color: black;
}

@media (max-width: 767.98px) {
  body.is-fixed {
    overflow: hidden;
  }
  #navbarGlobal.is-active {
    display: block;
    position: fixed;
    top: 30px;
    left: 25%;
    width: 50%;
    height: 100%;
    z-index: 1000;
    opacity: 1;
    text-align: center;
  }
  #navbarGlobal.is-active::after {
    background-color: #f5eee1;
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    content: "";
    z-index: -1;
  }
}
body {
  font-family: "Helvetica", "Yu Gothic", "Hiragino Sans", sans-serif;
}
* {
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
}

h3, h4, .h3, .h4 {
  font-family: "Helvetica", "Yu Gothic", "Hiragino Sans", sans-serif;
  font-size: 1rem;
  font-weight: 600;
}

h5, h6 {
  font-weight: 600;
}

.list-styled {
  padding: 0;
  list-style: none;
}

.list-styled > li {
  margin-left: 1.2rem;
}

.list-styled > li::before {
  content: "・\00A0";
  margin-left: -1.2rem;
}

.list-styled.type-diamond > li {
  margin-bottom: 0.3rem;
}

.list-styled.type-diamond > li::before {
  content: "◆\00A0";
}

.list-styled.type-rice > li::before {
  content: "※\00A0";
}

.list-styled.type-square > li {
  margin-bottom: 0.3rem;
}

.list-styled.type-square > li::before {
  content: "■\00A0";
}

.list-styled.small {
  font-size: 0.75rem;
}

a.backtotop {
  position: relative;
  float: right;
  font-family: "Helvetica", "Yu Gothic", "Hiragino Sans", sans-serif;
  font-size: 80%;
  color: #898989;
  z-index: 1000;
}

a.backtotop:hover, a.backtotop:focus {
  color: #575757;
}

a.backtotop::after {
  clear: both;
}

a.underline {
  position: relative;
  display: inline-block;
  text-decoration: none;
}

a.underline::after {
  position: absolute;
  bottom: 5px;
  left: 0;
  content: '';
  width: 100%;
  height: 2px;
  background-color: #3a3a3a;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
  -webkit-transition: -webkit-transform .3s;
  transition: -webkit-transform .3s;
  transition: transform .3s;
  transition: transform .3s, -webkit-transform .3s;
}

a.underline:hover::after {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}

.brackets-indent {
  text-indent: -0.5rem;
}

.sanserif {
  font-family: "Helvetica", "Yu Gothic", "Hiragino Sans", sans-serif;
}

.tel, .fax, .mail, .freedial {
  color: #3a3a3a;
}

.tel:hover, .tel:focus, .fax:hover, .fax:focus, .mail:hover, .mail:focus, .freedial:hover, .freedial:focus {
  color: #3a3a3a;
}

.sanserif.tel, .sanserif.fax, .sanserif.mail, .sanserif.freedial {
  font-size: 30px;
  font-weight: bolder;
}

@media (max-width: 767.98px) {
  .sanserif.tel, .sanserif.fax, .sanserif.mail, .sanserif.freedial {
    font-size: 24px;
  }
}

.note {
  font-family: "Helvetica", "Yu Gothic", "Hiragino Sans", sans-serif;
  color: #717171;
}

.unit {
  font-family: "Helvetica", "Yu Gothic", "Hiragino Sans", sans-serif;
  font-weight: bold;
}

.freedial {
  line-height: 1.125;
}
.freedial::before {
  content: url("../images/base/icon-freedial.svg");
  display: inline-block;
  width: 60px;
  vertical-align: top;
}
@media (max-width: 767.98px) {
  .freedial::before {
    width: 45px;
  }
}

.line-icon, .line-qr {
  display: inline-block;
  width: 100px;
  height: 0;
  padding-top: 100px;
  overflow: hidden;
  background-color: transparent;
  background-position: left top;
  background-repeat: no-repeat;
  background-size: contain;
}

@media (max-width: 767.98px) {
  .line-icon, .line-qr {
    width: 60px;
    padding-top: 60px;
  }
}

.line-icon {
  background-image: url("../images/base/lineicon.png");
}

.line-qr {
  background-image: url("../images/base/lineQR.gif");
}

label,
input,
button,
select,
optgroup,
textarea,
.btn {
  font-family: "Helvetica", "Yu Gothic", "Hiragino Sans", sans-serif;
}

label,
select,
.btn {
  font-weight: bold !important;
}

input[type="radio"], input[type="checkbox"] {
  position: relative !important;
  top: -2px !important;
}

hr.dotted {
  border-top: 1px dotted rgba(0, 0, 0, 0.3);
}

@media (max-width: 767.98px) {
  body {
    font-size: 0.825rem;
  }
}

.wrapper {
  background-image: url("../images/base/bg-all.jpg");
  background-color: #eee6d5;
  background-position: top center;
  background-repeat: repeat-y;
  background-size: 1200px auto;
}

.center-band {
  position: relative;
  padding-left: 3rem;
  padding-right: 3rem;
  padding-bottom: 0;
  background-color: rgba(255, 255, 255, 0.75);
  z-index: 0;
}

main .center-band {
  padding-bottom: 90px;
}

.contents {
  position: relative;
  padding-top: 110px;
}

.contents::before {
  position: absolute;
  top: 90px;
  left: -75px;
  display: block;
  width: 52px;
}

.contents.narrow {
  padding-top: 35px;
}

.contents.narrow::before {
  top: 15px;
}

@media (max-width: 767.98px) {
  .contents {
    padding-top: 45px;
  }
  .contents::before {
    position: absolute;
    top: 40px;
    left: 0;
    display: block;
    width: 26px;
  }
  .contents.narrow {
    padding-top: 20px;
  }
  .contents.narrow::before {
    top: 15px;
  }
  .contents h3 {
    margin-left: 30px;
  }
}

@media (min-width: 768px) {
  .center-band {
    padding-left: 3rem;
    padding-right: 3rem;
  }
}
@media (max-width: 767.98px) {
  .center-band {
    margin-left: 15px;
    margin-right: 15px;
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

.img-txt {
  display: block;
  height: 0;
  overflow: hidden;
  padding: 0;
}

@media (min-width: 768px) {
  .news {
    margin-top: 120px;
  }
  .news dl dd:nth-of-type(1) {
    padding-right: 150px;
  }
  .news dl dd:nth-of-type(2) {
    padding-right: 100px;
  }
}

.news dl dd a:hover, .news dl dd a:focus {
  text-decoration: underline;
}
/*
.img-diamond {
  position: absolute;
  right: -180px;
  top: 50px;
  width: 240px;
  height: auto;
}
*/
.img-diamond {
  position: absolute;
  width: 240px;
  height: auto;
}

.row .neg-2 {
  margin: -0.5rem;
}

.narrow dd {
  margin-bottom: .3rem;
}

.no-wrap > span {
  display: inline-block;
}

.mt-n6 {
  margin-top: -5rem;
}

table.sanserif th, table.sanserif td {
  font-family: "Helvetica", "Yu Gothic", "Hiragino Sans", sans-serif;
}

@media (max-width: 767.98px) {
  figure {
    margin-bottom: 0;
  }
  figure .figure-caption {
    font-size: 0.6rem;
  }
}

.form-control[required], .form-control.inline {
  display: inline-block;
}

.form-control[required] {
  width: calc(100% + -5rem);
  margin-right: .5rem;
}

.form-control[required].non-calc {
  width: 100%;
}

.form-control.inline {
  width: calc(100% + -3rem);
  margin-right: .5rem;
}

.form-control[required].inline {
  width: calc(100% + -8rem);
  margin-right: .5rem;
}

.form-control[required].inline.non-calc {
  width: calc(100% + -3rem);
}

.btn-color, .btn-light.white {
  border: none;
  color: rgba(255, 255, 255, 0.8);
}

.btn-color:hover, .btn-color:focus, .btn-light.white:hover, .btn-light.white:focus {
  color: #fff;
}

@media (max-width: 767.98px) {
  .form-row .form-row {
    margin-bottom: -10px;
  }
  .form-row .form-row [class*="col"] {
    margin-bottom: 10px;
  }
  [class*="col-form-label"] {
    margin-bottom: 0.125rem;
  }
}

#index .contents::before {
  content: url("../images/home/icon-section_index.svg");
}

#index .contents .btn-color {
  background-color: #244a8f;
}

#index .contents .img-diamond {
  right: calc(-16.66666% - 180px);
  top: -90px;
}

@media (max-width: 767.98px) {
  #index .contents .img-diamond {
    position: static;
    float: right;
    width: 30%;
    margin-left: 15px;
  }
}

#under.message .contents::before {
  content: url("../images/under/icon-section_message.svg");
}

#under.message .contents .img-diamond {
  right: -180px;
  bottom: -300px;
}

@media (max-width: 767.98px) {
  #under.message .contents .img-diamond {
    position: static;
    max-width: 100%;
    margin-bottom: 15px;
  }
}

#under.message .btn-color {
  background-color: #7e318e;
}

#under.message #monthly > .row, #under.message #monthly > .row [class*="col"] {
  position: static;
}

#under.message #monthly article {
  border: 1px dashed #b5b5b5;
  padding: 1rem;
}

#under.message #monthly article h1 {
  font-size: 1.25rem;
  text-indent: -0.5rem;
}

#under.message #monthly article p {
  margin: 0;
  text-indent: 1rem;
}

#under.message #backnumber nav a:hover, #under.message #backnumber nav a:focus {
  text-decoration: underline;
}

#under.memorial .contents::before {
  content: url("../images/under/icon-section_memorial.svg");
}

#under.memorial .btn-color {
  background-color: #244a8f;
}

#under.cemetery .contents::before {
  content: url("../images/under/icon-section_cemetery.svg");
}

#under.cemetery .btn-color {
  background-color: #006934;
}

#under.cemetery .img-diamond {
  right: -160px;
  top: 0;
}

@media (max-width: 767.98px) {
  #under.cemetery .img-diamond {
    display: none;
  }
}

#under.eternity .contents::before {
  content: url("../images/under/icon-section_eternity.svg");
}

#under.eternity .btn-color {
  background-color: #7f8cae;
}

#under.eternity dl.faq dt::before {
  content: "Q:\00A0";
}

#under.eternity dl.faq dd::before {
  content: "A:\00A0";
}

#under.access .contents::before {
  content: url("../images/under/icon-section_access.svg");
}

#under.access .contents address ul.contact li > span {
  padding-right: 1.0rem;
}

#under.access .contents address h6 {
  font-weight: 700;
}

#under.contact .contents::before {
  content: url("../images/under/icon-section_contact.svg");
}

#under.contact .btn-color {
  background-color: #006934;
}

#under.mizukokuyo .contents:first-child {
  margin-top: 150px;
}

@media (max-width: 767.98px) {
  #under.mizukokuyo .contents:first-child {
    margin-top: 30px;
  }
}

#under.mizukokuyo .contents::before {
  content: url("../images/under/icon-section_mizukokuyo.svg");
}

#under.mizukokuyo .btn-color {
  background-color: #ee8196;
}

#under.mizukokuyo .caution {
  color: #a71d2a;
}

#under #bookinfo h5, #under #goodsinfo h5 {
  font-size: 1rem;
}

#under #bookinfo h6.line, #under #goodsinfo h6.line {
  text-align: center;
  overflow-x: hidden;
}

#under #bookinfo h6.line span, #under #goodsinfo h6.line span {
  position: relative;
  display: inline-block;
  padding: 0 0.5em;
}

#under #bookinfo h6.line span::before, #under #bookinfo h6.line span::after, #under #goodsinfo h6.line span::before, #under #goodsinfo h6.line span::after {
  position: absolute;
  top: 50%;
  content: '';
  width: 100%;
  height: 1px;
  background-color: #000;
}

#under #bookinfo h6.line span::before, #under #goodsinfo h6.line span::before {
  left: 100%;
}

#under #bookinfo h6.line span::after, #under #goodsinfo h6.line span::after {
  right: 100%;
}

#under.cemetery address, #under.memorial address, #under.contact address {
  padding-left: 1rem;
  margin-bottom: 0.3rem;
}
