@charset "UTF-8";
@import url(all.css);
/* ###################### */
/* ######## 変数 ######## */
/* ###################### */
/* カラー */
/* パターン */
/* 書式 */
/* ###################### */
/* ######## 関数 ######## */
/* ###################### */
/*===============================================
  切り替え用
===============================================*/
body {
  font-size: 16px;
}

.sp-none {
  display: none !important;
}

.com__form table,
.com__form table tbody,
.com__form table th,
.com__form table tr,
.com__form table td {
  display: block !important;
  width: 100% !important;
}

/*===============================================
  wrapper
===============================================*/
#wrapper {
  min-width: 320px;
}

/*===============================================
  header
===============================================*/
#header .header__inner {
  padding: 15px 5%;
}
#header .header__logo img {
  height: 40px;
}
#header .header__right {
  display: flex;
  justify-content: space-around;
  align-items: center;
  width: 100%;
  background: #fff;
  padding: 10px 5px;
  position: fixed !important;
  left: 0;
  bottom: 0;
  z-index: 101;
}
#header .header__right > * {
  width: 100%;
}
#header .header__tel {
  display: none;
}
#header .header__btn {
  width: 48%;
  height: 50px;
}
#header .header__btn a {
  font-size: 1.4rem;
}

/*===============================================
  footer
===============================================*/
#footer {
  padding-bottom: 70px;
}

/*コピーライト
-----------------------------*/
.footer__copyright p {
  font-size: clamp(1rem, 3vw, 1.2rem);
  padding: 0.5em;
}

/*===============================================
  visual
===============================================*/
.visual {
  height: 100vw;
}

/*メインビジュアル
-----------------------------*/
.visual__main::before {
  width: 150vw;
  height: 50vw;
}
.visual__main .visual__main-inner {
  width: 90%;
  padding-top: 6.25vw;
}
.visual__main .visual__main-inner::before {
  height: calc(100% - 6.25vw);
}
.visual__main .visual__main-catch {
  font-size: 5vw;
  margin-bottom: 0.5em;
}
.visual__main .visual__main-catch > span {
  margin-bottom: 0.5em;
}
.visual__main .visual__main-catch > span.sub {
  min-width: 14em;
}
.visual__main .visual__main-txt {
  width: 8.5em;
  font-size: 3.75vw;
  margin-bottom: 0.5em;
}
.visual__main .visual__main-txt::before {
  height: calc(100% - 1px);
}
.visual__main .visual__main-btn .com__btn {
  width: 56.25vw;
  height: 15.625vw;
}
.visual__main .visual__main-btn .com__btn a {
  font-size: 4.375vw;
}

/*サブビジュアル
-----------------------------*/
.visual__sub .visual__sub-catch {
  width: 90%;
  font-size: 5vw;
  padding: 6.25vw 0;
}

/*===============================================
  main#container
===============================================*/
#container {
  font-size: clamp(1.3rem, 4vw, 1.6rem);
  line-height: 2;
  letter-spacing: 0.05em;
}

/*===============================================
  main共通
===============================================*/
.inner {
  width: 90%;
}

/*ボタン
-----------------------------*/
/*テーブル
-----------------------------*/
.com__table tr th {
  width: 9em;
  padding: 1em 0;
}
.com__table tr td {
  padding: 1em 0;
}

/*フォーム部品
-----------------------------*/
.com__form tr {
  margin-bottom: 2em;
}
.com__form tr:last-of-type {
  margin-bottom: 0;
}
.com__form tr th {
  margin-bottom: 0.6em;
}
.com__form tr th span {
  display: inline-block;
  font-size: 0.8em;
  line-height: 2;
  padding: 0 0.75em;
}
.com__form select,
.com__form textarea,
.com__form input[type=tel],
.com__form input[type=text],
.com__form input[type=email],
.com__form input[type=url] {
  width: 100%;
  font-size: 1em;
  line-height: 1.6;
  padding: 5px;
}
.com__form textarea {
  width: 100%;
}
.com__form button,
.com__form input[type=submit] {
  width: min(360px, 75vw);
  max-width: 100%;
  height: clamp(60px, 18.75vw, 75px);
  font-size: 1.25em;
  letter-spacing: 0.05em;
  margin: clamp(32px, 10vw, 40px) auto 0;
}
.com__form .com__form-text {
  padding: 60px 0 20px;
}
.com__form .com__form-text p:first-child {
  margin-top: -0.3em;
}
.com__form .com__form-text p:last-child {
  margin-bottom: -0.3em;
}

/*テキスト
-----------------------------*/
.com__text .mb {
  margin-bottom: 1em;
}
.com__text br {
  display: none;
}

/*===============================================
  タイトル
===============================================*/
/*大タイトル
-----------------------------*/
.com__title01 {
  font-size: clamp(2.4rem, 7.5vw, 3rem);
  line-height: 1.5;
  margin-bottom: 1em;
}
.com__title01.mid {
  font-size: clamp(2rem, 6vw, 2.4rem);
  line-height: 1.5;
}
.com__title01.mid .b {
  font-size: 1.25em;
}

/*中タイトル
-----------------------------*/
.com__title02 {
  font-size: clamp(1.6rem, 5vw, 2rem);
  line-height: 1.5;
  margin-bottom: 1em;
}

/*===============================================
  温かな気持ちで、大切な人と向き合う場所
===============================================*/
.about::after {
  display: block;
  height: 37.5vw;
  background-size: cover;
}
.about .inner {
  padding: clamp(56px, 16vw, 64px) 0;
}

/*===============================================
  こんなお悩みありませんか？
===============================================*/
.trouble {
  padding: clamp(56px, 16vw, 64px) 0 clamp(20px, 6.25vw, 25px);
}
.trouble::after {
  height: clamp(32px, 10vw, 40px);
}
.trouble .trouble__list::after {
  width: 100%;
  height: 120px;
}
.trouble .trouble__list-item {
  padding: 1.5em 1.25em;
  margin-bottom: 1em;
}
.trouble .trouble__list-item br {
  display: none;
}

/*===============================================
  ご相談時にすべての費用をお伝えいたします。
===============================================*/
.message {
  padding: clamp(80px, 25vw, 100px) 0 clamp(32px, 10vw, 40px);
}
.message .message__title br {
  display: none;
}
.message .message__title .br {
  display: block;
  margin-right: -0.5em;
}
.message .message__title::after {
  width: 1.5em;
  margin-top: 0.75em;
}
.message .message__image {
  width: 68.75vw;
  margin-top: clamp(32px, 10vw, 40px);
  margin-right: -5vw;
  margin-left: auto;
}
.message .message__image img {
  width: 100%;
}

/*===============================================
  納骨堂　葬儀　法要に関するすべてのご相談を承ります。
===============================================*/
.consult {
  padding: clamp(32px, 10vw, 40px) 0;
}
.consult .consult__inner {
  padding: clamp(32px, 10vw, 40px) 0;
}
.consult .consult__inner::before {
  width: 100vw;
}
.consult .consult__title {
  font-size: clamp(1.6rem, 5vw, 2rem);
  line-height: 1.5;
  margin-bottom: 1.5em;
}
.consult .consult__title .br {
  display: inline-block;
}
.consult .consult__item {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding: 1.5em 1em;
  margin-bottom: 1em;
}
.consult .consult__item:last-of-type {
  margin-bottom: 0;
}
.consult .consult__item-ttl {
  font-size: 1.25em;
  line-height: 2;
  padding: 0 1.5em;
  margin-bottom: 0.5em;
}
.consult .consult__item-txt {
  text-align: center;
}
.consult .consult__text {
  text-align: center;
  padding-top: 2em;
}
.consult .consult__text .br {
  display: inline-block;
}
.consult .consult__text::after {
  height: 12px;
  margin-top: 1em;
}
.consult .consult__btn {
  width: 100%;
  height: 60px;
  margin: 1em auto 0;
}
.consult .consult__btn a {
  font-size: 1.25em;
}

/*===============================================
  納骨堂 葬儀 法要の相談窓口が選ばれる理由
===============================================*/
.reason {
  padding: clamp(56px, 16vw, 64px) 0;
}
.reason .reason__title .br {
  display: inline-block;
}
.reason .reason__list {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-top: clamp(-40px, -10vw, -32px);
}
.reason .reason__item {
  width: 48%;
  margin-top: clamp(32px, 10vw, 40px);
  margin-right: 4%;
}
.reason .reason__item:nth-of-type(2n), .reason .reason__item:last-of-type {
  margin-right: 0;
}
.reason .reason__item-image {
  margin-bottom: 0.5em;
}
.reason .reason__item-image img {
  width: 100%;
}
.reason .reason__item-txt::before {
  padding-right: 1em;
}
.reason .reason__item-txt::after {
  top: 1em;
}
.reason .reason__item-txt p {
  font-size: 1.2em;
  line-height: 1.5;
}

/*===============================================
  その他セクション
===============================================*/
.other {
  padding: clamp(56px, 16vw, 64px) 0;
}
.other .other__box {
  margin-bottom: clamp(32px, 10vw, 40px);
}
.other .other__box:nth-of-type(2) .other__box-inner::before {
  bottom: -2.5%;
}
.other .other__box-inner {
  padding: 2em 1em;
}
.other .other__box-inner::before {
  width: 40%;
  padding-top: 30%;
  left: 2%;
  bottom: -1%;
  z-index: 1;
}
.other .other__box-title br {
  display: none;
}
.other .other__box-title .br {
  display: block;
}
.other .other__box-title .br .br {
  display: inline-block;
}
.other .other__box-title::after {
  width: 1.5em;
  margin-top: 0.75em;
}
/*===============================================
  利用者様からの貴重なご意見をご紹介
===============================================*/
.review {
  padding: clamp(56px, 16vw, 64px) 0;
}
.review .review__title .br {
  display: inline-block;
}
.review .review__item {
  margin-bottom: clamp(32px, 10vw, 40px);
}
.review .review__item-icon {
  width: 80px;
  margin: 0 auto 20px;
}
.review .review__item-title {
  align-items: center;
}
.review .review__item-text {
  line-height: 1.5;
}

/*===============================================
  美しい納骨堂で心安らぐひとときを
===============================================*/
.lead {
  padding: clamp(32px, 10vw, 40px) 0 clamp(80px, 25vw, 100px);
}
.lead .lead__inner {
  padding: clamp(32px, 10vw, 40px) 1.5em;
}
.lead .lead__inner::after {
  width: calc(100% + 10em);
  height: 9em;
  bottom: clamp(-100px, -25vw, -80px);
}
.lead .lead__title .br {
  display: inline-block;
}

/*===============================================
  公式LINEはこちら
===============================================*/
.sns {
  padding: clamp(32px, 10vw, 40px) 0;
}
.sns .sns__btn {
  width: 90%;
  height: clamp(60px, 18.75vw, 75px);
}
.sns .sns__btn a {
  font-size: 1.25em;
}

/*===============================================
  お問い合わせフォーム
===============================================*/
.contact {
  padding: clamp(56px, 16vw, 64px) 0;
}

/*===============================================
  寺院概要
===============================================*/
.info {
  padding: clamp(56px, 16vw, 64px) 0;
}
.info .info__map {
  height: 320px;
  margin-top: 40px;
}

/*===============================================
  404エラー
===============================================*/
.error {
  padding: 64px 0;
}
.error .error__title .br {
  display: block;
  margin-right: -0.5em;
}
.error .error__text {
  text-align: center;
}
.error .error__text .br {
  display: inline-block;
}