@charset "UTF-8";

/* object fit */
.obf { -o-object-fit: cover; object-fit: cover; -o-object-position: center; object-position: center; font-family: 'object-fit: cover; object-position: center;'; height: 100%; width: 100%; }
}

/* slider */
.slide ul{ display: none; }
.slide ul.slick-initialized { display: block; }

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

#toppages #mainBlock { order: -1;}

#ind_mainImage { background: url(../images/index/ind_mainbg.jpg) 0 0 repeat-x; background-size: contain; height: 596px; margin: 0 0 30px; }
  #ind_main { width: 100%; max-width: 910px; height: 90vh; max-height: 550px;}
  #ind_main li { height: 550px;}

.ind_bnr_online { margin-bottom: 60px; overflow: }

ul.ind_list li { width: 48%; max-width: 284px; margin-bottom: 30px;}
  ul.ind_list li .ind_h2ttl { line-height: 1; font-size: 2rem; color: #222; padding: 10px 5px 10px 12px; background: #f2f2f2; border-left: solid 5px #D16678; letter-spacing: 0.1rem;}
  ul.ind_list li .ind_contents_img { margin: 10px 0 10px;}
  ul.ind_list li .ind_detail { margin: 10px 0 0;}
  ul.ind_list li .ind_detail a { padding: 10px 0;}
@media screen and (-ms-high-contrast: active), screen and (-ms-high-contrast: none) {
  ul.ind_list li .ind_h2ttl { padding: 15px 5px 8px 12px;}
}

#ind_news {}
	#ind_news .ind_news_ttl { margin-bottom: 20px; border-bottom: 2px solid #905FB7; position: relative; padding-bottom: 4px;}
	#ind_news .ind_news_ttl:after { content: ""; width: 100%; height: 1px; background: #905FB7; position: absolute; bottom: -5px; left: 0;}
	#ind_news ul li { padding-bottom: 8px; border-bottom: dotted 1px #ccc; font-size: 1.4rem; line-height:1.5; margin-bottom: 10px;}
	#ind_news li span { font-weight: bold; display: block; margin-bottom: 3px; letter-spacing: .05em; font-family: "Lato", "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Helvetica, Arial, sans-serif;}
  #ind_news li a { display: block;}

@media screen and (max-width: 910px) {
  #ind_mainImage { background: none; height: auto; margin-bottom: 60px;}
}



/* 下層共通
==========================================================*/

.kasou_main_img { margin-bottom: 30px; width: 100%; height: 350px;}

.kasou_flex_img2 { margin-top: 30px;}
.kasou_flex_img2 li { width: 48.5%;}


/* 寺院紹介
==========================================================*/

#About_enkaku dl.About_template_dl { margin-top: -10px; margin-bottom: 40px;}
  #About_enkaku dt { width: 140px; padding: 13px 5px; box-sizing: border-box; border-bottom: 1px dotted #c8c8c8;}
  #About_enkaku dd { padding: 13px 5px; box-sizing: border-box; width: -webkit-calc(100% - 140px); width: -moz-calc(100% - 140px); width: calc(100% - 140px); border-bottom: 1px dotted #c8c8c8;}

#About_aisatsu {}
  #About_aisatsu .aisatsu_box .aisatsu_img { width: 50%;}
  #About_aisatsu .aisatsu_box .aisatsu_txt { width: 47%; font-size: 1.5rem;}
  #About_aisatsu .aisatsu_box .aisatsu_txt p.aisatsu_name { font-size: 1.7rem; line-height: 1.4; margin-bottom: 30px;}
  #About_aisatsu .aisatsu_box .aisatsu_txt p.aisatsu_name span { font-size: 1.5rem;}
  #About_aisatsu .aisatsu_box .aisatsu_txt dt { color: #a986ad;}
  #About_aisatsu .aisatsu_box .aisatsu_txt dd { border-bottom: 1px dotted #c8c8c8; margin-bottom: 10px; padding-bottom: 10px; line-height: 1.4;}
  #About_aisatsu .aisatsu_board { margin: 30px auto 0; padding: 5% 5% 6%; box-sizing: border-box; border: 1px solid #ede4ee; background: rgba(236, 229, 238, 0.2); border-radius: 5px;}
  #About_aisatsu .aisatsu_board .aisatsu_three { font-size: 2rem; margin: 20px 0; padding-left: 10px; line-height: 2.2;}

#About_soutou dl.About_template_dl { }
  #About_soutou dt { width: 90px; padding: 20px 5px; box-sizing: border-box; border-bottom: 1px dotted #c8c8c8; }
  #About_soutou dd { padding: 20px 5px; box-sizing: border-box; width: -webkit-calc(100% - 90px); width: -moz-calc(100% - 90px); width: calc(100% - 90px); border-bottom: 1px dotted #c8c8c8;}

@media screen and (max-width: 600px) {
  #About_enkaku dt { width: 100px; padding: 13px 0; }
    #About_enkaku dd { width: -webkit-calc(100% - 100px); width: -moz-calc(100% - 100px); width: calc(100% - 100px);}
    #About_enkaku ul.flex { display: block;}
    #About_enkaku ul.flex li { width: 100%; margin-top: 20px;}

  #About_aisatsu .aisatsu_box { display: block;}
    #About_aisatsu .aisatsu_box .aisatsu_img { width: 100%; margin-bottom: 15px;}
    #About_aisatsu .aisatsu_box .aisatsu_txt { width: 100%;}
    #About_aisatsu .aisatsu_board .aisatsu_three { font-size: 1.7rem;}

  #About_soutou dt { width: 60px;}
    #About_soutou dd { width: -webkit-calc(100% - 60px); width: -moz-calc(100% - 60px); width: calc(100% - 60px);}

}

/* 永代供養
==========================================================*/

#Eitai_kannon .kannon_flex_img { width: 50%; order: 1; margin-top: 5px;}
  #Eitai_kannon .kannon_flex_txt { width: 45%;}

#Eitai_plan .plan_box { margin: 30px 0 35px; border: 1px solid #9d77bb; box-sizing: border-box; padding: 30px; background: rgba(219, 202, 224, 0.2);}
  #Eitai_plan .plan_box ul { padding-left: 10px; margin-top: 10px;}
  #Eitai_plan .plan_box ul span { font-size: 1rem; color: #9d77bb; position: relative; bottom: 2px;}
  #Eitai_plan .plan_box p { margin-top: 15px;}

@media screen and (max-width: 600px) {
#Eitai_plan .plan_box { padding: 20px; }

}
@media screen and (max-width: 500px) {
#Eitai_kannon .flex { display: block;}
  #Eitai_kannon .kannon_flex_img { width: 100%; margin-bottom: 20px;}
  #Eitai_kannon .kannon_flex_txt { width: 100%;}

#Eitai_plan .plan_box ul { padding-left: 0; }
}
/* 行事案内
==========================================================*/

.event_time { color: #5c3a77; margin-bottom: 10px;}


/* アクセス
==========================================================*/

.googleMap { width: 100%; margin: 25px 0 0;}
  .googleMap iframe { width: 100%;}

@media screen and (max-width: 600px) {
  .googleMap iframe { height: 50vh;}
}

/* オンライン法要
==========================================================*/

#OnlinePage #mainBlock { max-width: 100%; width: 100%; margin-left: 0; color: #222;}
  #OnlinePage #mainBlock .kasou_main_img { height: auto; margin-bottom: 60px;}
  #OnlinePage .online_lead { text-align: center; font-size: 1.9rem; margin-bottom: 60px;}
  #OnlinePage .arrow { margin: 40px 0;}
  #OnlinePage .online_photos li { width: 47%;}
  #OnlinePage .online_photos li p { font-size: 2.4rem; background: rgba(233, 196, 223, 0.5); padding: 20px 0;}
  #OnlinePage .online_photos li:nth-child(2) p { background: rgba(202, 184, 224, 0.5);}

#Online_flow { margin-top: 120px; }
#Online_flow .Online_flow_h2ttl { margin-bottom: 45px;}

#Online_flow ul li { border-bottom: 2px solid #9d77bb;}
  #Online_flow .triangle { margin-bottom: 50px; position: relative;}
  #Online_flow .triangle:before {position: absolute; top: 100%; left: 50%; border: solid transparent; content: " "; border-top-color: #9d77bb; border-width: 16px; margin-left: -16px;}
  .Online_flow_num { width: 150px; height: 150px; background: #9d77bb; align-items: center;}
  	.Online_flow_num .icon { width: 100px; margin: 0 auto; }
  .Online_flow_cnt { width: -webkit-calc(100% - 150px); width: -moz-calc(100% - 150px); width: calc(100% - 150px); background-color: #f5f5f5; align-items: center;}
  	.Online_flow_cnt .Online_flow_cntInner { padding: 0 40px; box-sizing: border-box;}
  	.Online_flow_cnt .Online_flow_cntInner p span { color: #de3a3a;}
  	.Online_flow_cnt h3 { font-size: 2.4rem;; color: #8a67a6;}
  	.Online_flow_cnt p {  padding-top: 10px;}

.Online_flow_contact { margin-top: 50px;}

@media screen and (max-width: 768px) {
    #OnlinePage .online_photos li { width: 48%;}
    #OnlinePage .online_photos li p { font-size: 2rem;}

    #Online_flow .Online_flow_h2ttl { width: 70%; margin: 0 auto 7%; max-width: 300px;}
    .Online_flow_num { padding: 20px; width: auto; height: auto;}
    .Online_flow_num .icon { width: 70px;}
    .Online_flow_cnt { width: 100%;}
    .Online_flow_cnt .Online_flow_cntInner { padding: 20px 25px;}
    .Online_flow_cnt h3 { font-size: 1.8rem;}
    #Online_flow .triangle { margin-bottom: 40px;}
}
@media screen and (max-width: 600px) {
    #OnlinePage #mainBlock .kasou_main_img { margin-bottom: 10%;}
    #OnlinePage .online_lead { text-align: left; font-size: 1.6rem; margin-bottom: 10%;}
    #OnlinePage .online_lead p.mt30 { margin-top: 5% !important;}
      #OnlinePage .arrow { margin: 30px auto 20px; width: 25px;}
    #OnlinePage .online_photos li p { font-size: 1.7rem;}
    #Online_flow { margin-top: 20%; }
}
@media screen and (max-width: 480px) {
    #OnlinePage .online_photos ul { display: block;}
    #OnlinePage .online_photos li { width: 100%; margin: 20px auto 0; max-width: 340px;}
    #OnlinePage .online_photos li p { font-size: 2rem;}

    .Online_flow_num { padding: 20px 10px;}
    .Online_flow_num .icon { width: 50px;}
    .Online_flow_cnt .Online_flow_cntInner { padding: 20px 15px; letter-spacing: normal;}
    .Online_flow_cnt h3 { font-size: 1.7rem; font-weight: bold;}
    .Online_flow_cnt p { font-size: 1.4rem; letter-spacing: normal;}
    .Online_flow_contact { margin-top: 30px; }
}


/* 寺報 かける
==========================================================*/

#Kakeru ul li { margin-bottom: 20px;}
  #Kakeru ul li a { display: block; width: 100%; padding: 20px 30px 20px 50px; box-sizing: border-box; background: #f2f2f2; border-radius: 3px;border-bottom: 1px solid #9d77bb; position: relative;}
  #Kakeru ul li p span { display: inline-block; margin-left: 1rem;}

  #Kakeru ul li a::before,
  #Kakeru ul li a::after { position: absolute; top: 0; bottom: 0; left: 20px; margin: auto; content: ""; vertical-align: middle; }
  #Kakeru ul li a::before { width: 16px; height: 16px; -webkit-border-radius: 50%; border-radius: 50%; background: #9d77bb; }
  #Kakeru ul li a::after { left:26px; box-sizing: border-box; width: 5px; height: 5px; border: 4px solid transparent; border-left: 6px solid #fff; }

@media screen and (max-width: 500px) {
#Kakeru ul li a { padding: 15px 15px 15px 35px; line-height: 30px;}
  #Kakeru ul li a::after { left:16px; }
  #Kakeru ul li a::before { left: 10px;}

}


/* お問い合わせ
==========================================================*/

#Contact_tel ul li { font-size: 2.4rem;}

.contact_lead { margin-bottom: 30px;}
.hissu { background: #de3a3a; color: #fff; padding: 4px 10px; box-sizing: border-box; display: inline-block; margin-left: 1em; font-size: 1.3rem;}

/* bodyを引き継がせる（SP:16p以上必須） */
input, textarea, select {
font: 16px/1.75 "Lato", "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Helvetica, Arial, sans-serif; letter-spacing: .05rem; color: #555;}

table.inqtable { width: 100%; letter-spacing: 0;}
  table.inqtable th { padding: 0 0 8px; display: block; width: 100%; vertical-align: middle; line-height: 1.4; font-weight: bold;}
  table.inqtable td { padding: 0 0 30px; display: block; width: 100%; box-sizing: border-box;}
  table.inqtable td .half { max-width: 300px;}
  table.inqtable td input, table.inqtable td textarea { border: none; -webkit-appearance: none; border-radius: 2px; padding: 10px 15px; width: 100%; background: rgba(238, 238, 238, 0.6); box-sizing: border-box;}

  /* focus時 */
  input, textarea { outline: none; -webkit-transition: all .3s; transition: all .3s; }
  input:focus, textarea:focus { box-shadow: 0 0 4px #ccc; }

  :placeholder-shown { color: #CCCCCC; font-weight: normal;}
  ::-webkit-input-placeholder { color: #c6c6c6; font-weight: normal;}
  :-moz-placeholder { color: #CCCCCC; font-weight: normal;}
  ::-moz-placeholder { color: #CCCCCC; font-weight: normal;}
  :-ms-input-placeholder { color: #CCCCCC; font-weight: normal;}
  ::-ms-input-placeholder { color: #CCCCCC; font-weight: normal;}

  /* ie用 */
  @media all and (-ms-high-contrast: none){ .selectyaji { display: none; } }
  input::-ms-clear, input::-ms-reveal { visibility: hidden; } /* 右に出てくるアイコン削除 */
  @media screen and (-ms-high-contrast: active), screen and (-ms-high-contrast: none) {
    table.inqtable td input, table.inqtable td textarea { padding: 8px 12px 15px;}
  }

  /* スマホオート入力の背景色削除 */
  input:-webkit-autofill { -webkit-box-shadow: 0 0 0px 1000px #fff inset; box-shadow: 0 0 0px 1000px #fff inset;}

  /* radioボタン */
  input[type=radio], input[type=checkbox] { display: none;}
   .radio, .checkbox { padding: 5px 30px 5px 35px; display: inline-block; box-sizing: border-box; position: relative; vertical-align: middle; cursor: pointer; font-size: 1.6rem; letter-spacing: .15rem;}
   .radio:before, .checkbox:before { position: absolute; top: 50%; left: 0; display: block; margin-top: -12px; width: 20px; height: 20px; border-radius: 50%; content: ''; background: #fff; border: 1px solid #CBCBCB; }
   .radio:after, .checkbox:after { -webkit-transition: all .2s linear; transition: all .2s linear; position: absolute; top: 50%; left: 6px; display: block; margin-top: -6px; width: 10px; height: 10px; border-radius: 50%; background-color: #9d77bb; content: ''; opacity: 0; z-index: 2; }
  /* input[type=radio]:checked + .radio:before  { box-shadow: 0 0 3px #ccc; } */
  input[type=radio]:checked + .radio:after,
  input[type=checkbox]:checked + .checkbox:after  { opacity: 1; }

  /* エラーボックス */
  .error_box { width: 100%; text-align: left; background: #FFF; border:1px solid #de3a3a; color:#de3a3a; display: none; margin: 30px auto 40px; padding: 20px 30px; box-sizing: border-box; }

  /* 送信ボタン */
  .submitwrap input[type=submit], .submitwrap input[type=button]
  { -webkit-appearance: none; font-size: 2.4rem; max-width: 400px; width: 100%; height: 70px; margin: 40px auto 0; cursor: pointer; color: #fff; background: #9d77bb; -webkit-transition:all .3s; transition:all .3s; border: none; box-sizing: border-box;
  border-radius: 3px; display: block; line-height: 70px; text-align: center; letter-spacing: .3rem; box-shadow: none;}
@media screen and (-ms-high-contrast: active), screen and (-ms-high-contrast: none) {
  .submitwrap input[type=submit], .submitwrap input[type=button] { padding-top: 4px;}
}
@media screen and (min-width: 769px) {
  .submitwrap input[type=submit]:hover, .submitwrap input[type=button]:hover { -webkit-opacity: 0.8; opacity: 0.8; cursor: pointer;}
}

  /* OK・errorページ */
  .contact_result { text-align: center; margin-top: 40px;}
    .contact_result .result_h2ttl { font-size: 2.8rem; margin-bottom: 30px;}
    .contact_result .result_txt p { margin-bottom: 40px; line-height: 2;}
    .contact_result .result_txt p.result_bikou { margin-bottom: 0; font-size: 1.2rem; color: #888;}

:disabled,
:disabled:hover { cursor: default; opacity: 0.4 !important;}
.g-recaptchaInner{ display: flex; justify-content: center; padding-top: 20px; }


@media screen and (max-width: 500px) {
  #Contact_tel ul li { font-size: 1.8rem; }
  table.inqtable th span.fn08 { display: block; margin-top: 5px;}
}

/*  */

