@charset "UTF-8";
@import url(all.css);
/* ###################### */
/* ######## 変数 ######## */
/* ###################### */
/* カラー */
/* パターン */
/* 書式 */
/* ###################### */
/* ######## 関数 ######## */
/* ###################### */
/*===============================================
  切り替え用
===============================================*/
.pc-none {
  display: none !important;
}

a[href^="tel:"] {
  pointer-events: none;
}

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

/*===============================================
  header
===============================================*/
#header .header__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 100px;
  padding: 0 30px;
}
#header .header__right {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
#header .header__right > * {
  margin-right: 20px;
}
#header .header__right > *:last-child {
  margin-right: 0;
}
#header .header__btn {
  width: 220px;
  height: 60px;
}
#header .header__btn a {
  font-size: 1.5rem;
}

/*===============================================
  footer
===============================================*/
/*コピーライト
-----------------------------*/
.footer__copyright {
  padding: 6px 0 5px;
}
.footer__copyright p {
  font-size: 1.2rem;
}

/*===============================================
  visual
===============================================*/
.visual {
  height: clamp(540px, 41.6666666667vw, 800px);
}

/*メインビジュアル
-----------------------------*/
.visual__main::before {
  height: clamp(435px, 33.8541666667vw, 650px);
}
.visual__main .visual__main-inner {
  width: clamp(720px, 56.25vw, 1080px);
  padding-top: 35px;
}
.visual__main .visual__main-inner::before {
  height: calc(100% - 35px);
}
.visual__main .visual__main-catch {
  font-size: clamp(2.8rem, 2.0833333333vw, 4rem);
}
.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: clamp(1.4rem, 1.0416666667vw, 2rem);
  margin-bottom: 0.5em;
}
.visual__main .visual__main-txt::before {
  height: calc(100% - 1px);
}
.visual__main .visual__main-btn .com__btn {
  width: clamp(340px, 26.0416666667vw, 500px);
  height: clamp(60px, 4.1666666667vw, 80px);
}
.visual__main .visual__main-btn .com__btn a {
  font-size: clamp(16px, 1.25vw, 24px);
}

/*サブビジュアル
-----------------------------*/
.visual__sub .visual__sub-catch {
  width: clamp(720px, 56.25vw, 1080px);
  height: clamp(80px, 6.25vw, 120px);
  font-size: clamp(2.8rem, 2.0833333333vw, 4rem);
}

/*===============================================
  main#container
===============================================*/
#container {
  font-size: 1.8rem;
  line-height: 2;
  letter-spacing: 0.01em;
}

/*===============================================
  main共通
===============================================*/
.inner {
  width: 1080px;
}

/*電話番号
-----------------------------*/
.com__tel .com__tel-num {
  font-size: 3.6rem;
}
.com__tel .com__tel-num::before {
  font-size: 1.5rem;
}
.com__tel .com__tel-time {
  font-size: 1.2rem;
  line-height: 1.5;
  margin-top: 6px;
}

/*ボタン
-----------------------------*/
/*テーブル
-----------------------------*/
.com__table {
  font-size: 1.6rem;
  line-height: 1.5;
}
.com__table tr th {
  width: 240px;
  padding: 35px 0;
}
.com__table tr td {
  padding: 35px 0;
}
.com__table tr:first-child th,
.com__table tr:first-child td {
  padding-top: 0;
}

/*フォーム部品
-----------------------------*/
.com__form {
  font-size: 1.6rem;
  line-height: 1.5;
}
.com__form tr th {
  width: 360px;
  padding: 19px 20px;
}
.com__form tr th span {
  display: inline-block;
  width: 3.25em;
}
.com__form tr td {
  padding: 13px 20px;
}
.com__form tr td label {
  line-height: 2.25;
}
.com__form select,
.com__form textarea,
.com__form input[type=tel],
.com__form input[type=text]:not([name=your-age]),
.com__form input[type=email] {
  width: 100%;
  font-size: 1.6rem;
  line-height: 1.5;
  padding: 5px;
}
.com__form input[name=your-age] {
  width: 6em;
  font-size: 1.6rem;
  line-height: 1.5;
  padding: 5px;
}
.com__form textarea {
  width: 100%;
}
.com__form button,
.com__form input[type=submit] {
  width: 486px;
  height: 76px;
  font-size: 2rem;
}
.com__form .com__form-text {
  padding: 80px 0 30px;
}
.com__form .com__form-text p:first-child {
  margin-top: -0.25em;
}
.com__form .com__form-text p:last-child {
  margin-bottom: -0.25em;
}

/*テキスト
-----------------------------*/
.com__text .mb {
  margin-bottom: 2em;
}

/*===============================================
  タイトル
===============================================*/
/*大タイトル
-----------------------------*/
.com__title01 {
  font-size: 4rem;
  line-height: 1.7;
  margin-bottom: 20px;
}
.com__title01.mid {
  font-size: 3.2rem;
  line-height: calc(1em + 10px);
}
.com__title01.mid .b {
  font-size: 4rem;
}

/*中タイトル
-----------------------------*/
.com__title02 {
  font-size: 2rem;
  line-height: 1.5;
  margin-bottom: 20px;
}

/*===============================================
  温かな気持ちで、大切な人と向き合う場所
===============================================*/
.about {
  padding: 80px 0;
}
.about::after {
  min-width: 1560px;
  height: 100%;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 0;
  z-index: 0;
}
.about .inner {
  padding-left: 350px;
}
.about .about__title {
  align-items: flex-start;
  text-align: left;
  margin-bottom: 30px;
}

/*===============================================
  こんなお悩みありませんか？
===============================================*/
.trouble {
  padding: 100px 0 50px;
}
.trouble::after {
  height: 70px;
}
.trouble .trouble__list {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-top: -15px;
}
.trouble .trouble__list::after {
  width: 308px;
  height: 227px;
  margin-right: 127px;
}
.trouble .trouble__list-item {
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0.01em;
  width: calc(50% - 10px);
  padding: 22px 30px;
  margin-top: 15px;
}

/*===============================================
  ご相談時にすべての費用をお伝えいたします。
===============================================*/
.message {
  padding: 120px 0;
}
.message .inner {
  min-height: 570px;
  padding-right: 475px;
}
.message .message__title {
  font-size: 3.2rem;
  line-height: calc(1em + 10px);
  align-items: flex-start;
  text-align: left;
}
.message .message__title::after {
  width: 50px;
  margin-top: 20px;
}
.message .message__text {
  font-size: 1.6rem;
}
.message .message__image {
  position: absolute;
  top: 0;
  right: 0;
}

/*===============================================
  納骨堂　葬儀　法要に関するすべてのご相談を承ります。
===============================================*/
.consult {
  padding: 60px 0;
}
.consult .consult__inner {
  padding: 30px 0;
}
.consult .consult__inner::before {
  border-radius: 8px;
}
.consult .consult__title {
  font-size: 2.4rem;
  line-height: 1.5;
}
.consult .consult__list {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  margin-top: -20px;
}
.consult .consult__item {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  padding: 30px 0;
  margin: 20px 20px 0;
}
.consult .consult__item-ttl {
  font-size: 2.4rem;
  line-height: 1.5;
  padding: 7px 20px;
  margin-bottom: 20px;
}
.consult .consult__item-txt {
  text-align: center;
  font-size: 1.6rem;
  line-height: 1.6875;
}
.consult .consult__text {
  text-align: center;
  line-height: 1.72223;
  padding-top: 15px;
}
.consult .consult__text::after {
  height: 12px;
  margin-top: 10px;
}
.consult .consult__btn {
  width: 500px;
  height: 60px;
  margin: 10px auto 0;
}
.consult .consult__btn a {
  font-size: 1.8rem;
}

/*===============================================
  納骨堂 葬儀 法要の相談窓口が選ばれる理由
===============================================*/
.reason {
  padding: 100px 0 80px;
}
.reason .reason__title {
  line-height: 1.7;
  margin-bottom: 50px;
}
.reason .reason__list {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
}
.reason .reason__item {
  width: 250px;
  height: 300px;
  margin-right: 26px;
}
.reason .reason__item:nth-of-type(4n), .reason .reason__item:last-of-type {
  margin-right: 0;
}
.reason .reason__item-image {
  margin-bottom: 10px;
}
.reason .reason__item-txt::before {
  padding-right: 1em;
}
.reason .reason__item-txt::after {
  top: 1em;
}
.reason .reason__item-txt p {
  font-size: 2rem;
  line-height: 1.3;
}

/*===============================================
  その他セクション
===============================================*/
.other {
  padding: 80px 0;
}
.other .other__box {
  display: flex;
  justify-content: center;
  flex-direction: column;
  min-height: 600px;
  padding-top: 4px;
  margin-bottom: 26px;
  position: relative;
  z-index: 0;
}
.other .other__box:nth-of-type(2n + 1) {
  align-items: flex-end;
}
.other .other__box:nth-of-type(2n + 1) .other__box-inner::before {
  top: -94px;
  right: -42px;
}
.other .other__box:nth-of-type(2n + 1) .other__box-image {
  right: calc(50% + 110px);
}
.other .other__box:nth-of-type(2n) {
  align-items: flex-start;
}
.other .other__box:nth-of-type(2n) .other__box-inner::before {
  top: -63px;
  right: -32px;
}
.other .other__box:nth-of-type(2n) .other__box-image {
  left: calc(50% + 110px);
}
.other .other__box-inner {
  width: 742px;
  min-height: 470px;
  padding: 40px 50px;
  position: relative;
  z-index: 0;
}
.other .other__box-inner::before {
  width: 250px;
  height: 186px;
}
.other .other__box-title {
  align-items: flex-start;
  text-align: left;
}
.other .other__box-title::after {
  width: 50px;
  margin-top: 20px;
}
.other .other__box-text {
  font-size: 1.6rem;
}
.other .other__box-image {
  width: calc(50vw - 110px);
  max-width: 850px;
  min-width: 530px;
  height: 600px;
  position: absolute;
  top: 0;
  z-index: -2;
}
.other .other__box-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/*===============================================
  利用者様からの貴重なご意見をご紹介
===============================================*/
.review {
  padding: 100px 0;
}
.review .review__title {
  margin-bottom: 50px;
}
.review .review__list {
  width: 900px;
  margin: 0 auto;
}
.review .review__item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 40px;
}
.review .review__item-icon {
  width: 150px;
}
.review .review__item-inner {
  width: calc(100% - 180px);
}
.review .review__item-text {
  font-size: 1.6rem;
  line-height: 1.5;
}

/*===============================================
  美しい納骨堂で心安らぐひとときを
===============================================*/
.lead {
  padding: 50px 0;
}
.lead .lead__inner {
  padding: 50px 60px 40px;
}
.lead .lead__inner::after {
  width: calc(100% + 320px);
  height: 467px;
  bottom: -50px;
}
.lead .lead__title {
  align-items: flex-start;
  text-align: left;
  line-height: 1.3;
  margin-bottom: 30px;
}
.lead .lead__text {
  font-size: 1.6rem;
}

/*===============================================
  公式LINEはこちら
===============================================*/
.sns {
  padding: 36px 0 44px;
}
.sns .sns__btn {
  width: 500px;
  height: 80px;
}
.sns .sns__btn a {
  font-size: 2.4rem;
}

/*===============================================
  お問い合わせフォーム
===============================================*/
.contact {
  padding: 80px 0;
}
.contact .contact__title {
  line-height: 1.5;
  margin-bottom: 40px;
}

/*===============================================
  寺院概要
===============================================*/
.info {
  padding: 80px 0;
}
.info .inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}
.info .info__title {
  font-size: 3.2rem;
  line-height: 1;
}
.info .info__table {
  width: 725px;
}
.info .info__map {
  width: 960px;
  height: 350px;
  margin: 80px auto 0;
}

/*===============================================
  404エラー
===============================================*/
.error {
  padding: 100px 0;
}
.error .error__text {
  text-align: center;
}