@charset "utf-8";

#fv{ background: url(../images/special-viewing/fv_bg.jpg) center/cover no-repeat; }
.cta{ padding-bottom: 85px; }


/* --------------------------------------------------------------------------- lead */
#lead{ background: url(../images/special-viewing/bg_11.png) center top/ 100% no-repeat; }
#news{ padding: 0; }
#news .main-title{ margin-bottom: 45px; font-size: 36px; }


/* --------------------------------------------------------------------------- special-viewing */
#special-viewing { padding: 95px 0 123px; }
#special-viewing .main-title { margin-bottom: 56px; font-size: 42px; font-family: "Zen Old Mincho", serif; font-weight: 400; font-style: normal;}
#special-viewing .viewing-inner{max-width: 1600px; height: auto; margin: 0 auto;}
#special-viewing .viewing-inner {}

.worship-block { display: flex; align-items: flex-start; justify-content: space-between; gap: 106px; align-items: center; position: relative; z-index: 1;}
.worship-block__image { width: 50%; max-width: 760px; }
.worship-block__image img { width: 100%; height: auto; }
.worship-block__main-image { margin: 0; }

.worship-block__body { width: 534px; margin: 0px auto 0 0; }
.worship-block__title { margin-bottom: 10px; font-family: "Zen Old Mincho", serif; font-weight:500; font-style: normal;font-size: 34px; line-height: 150%; }
.worship-block__text { line-height: 207%; font-size: 16px;}
.worship-block__text + .worship-block__text { margin-top: 35px; }

.worship-block__info { margin-top: 30px; padding-top: 25px; border-top: 1px solid #707070; }
.worship-block__info-title { margin-bottom: 10px; font-family: "Zen Old Mincho", serif; font-weight:600; font-style: normal; font-size: 39px; line-height: 150%; }
.worship-block__info-title.small{ font-size: 30px; }

.worship-block__info-text { line-height: 200%; font-size: 16px; }
.worship-block__info-text.small{ white-space: nowrap; }
.worship-block__info-text span { color: #f00; }

.worship-block__list { margin-top: 30px; padding-top: 28px; border-top: 1px solid #D1D1D1; }
.worship-block__row { display: grid; grid-template-columns: 75px 1fr; column-gap: 35px; padding-bottom: 10px; }
.worship-block__row dt,
.worship-block__row dd{ line-height: 150%; }

.worship-block__row + .worship-block__row {	margin-top: 8px; }
.worship-block--reverse{ flex-direction: row-reverse; }

#special-viewing .content_list{padding: 161px 0 0;}
#special-viewing .content_list .box{position: relative;}
#special-viewing .content_list .box:not(:first-child){margin: 151px 0 0;}
#special-viewing .content_list .box .title_box{text-align: center; position: relative; z-index: 2;}
#special-viewing .content_list .box .title_box h3{font-size: 36px; display: inline-block; position: relative; font-family: "Zen Old Mincho", serif; font-weight: 400; font-style: normal; padding: 0 98px; line-height: 119.5%; letter-spacing: 0.3em;}
#special-viewing .content_list .box .title_box h3:before{content: ""; display: block; width: 67px; height: 1px; background:#707070; position: absolute; left: 0px; top: 50%; transform: translateY(-50%); }
#special-viewing .content_list .box .title_box h3:after{content: ""; display: block; width: 67px; height: 1px; background:#707070; position: absolute; right: 0px; top: 50%; transform: translateY(-50%); }

#special-viewing .content_list .box_1 .title_box h3,
#special-viewing .content_list .box_2 .title_box h3{letter-spacing: 0;}

#special-viewing .content_list .box .main_img{padding: 44px 0 0; position: relative; z-index: 2;}
#special-viewing .content_list .box .main_img .flex{display: flex; align-items: center; margin: 22px 0 0;}
#special-viewing .content_list .box .main_img .flex h4{font-size: 33px; line-height: 122.2%; font-family: "Zen Old Mincho", serif; font-weight: 500; font-style: normal; margin: 0 23px 0 0;}
#special-viewing .content_list .box .main_img .flex p{font-size: 16px; line-height: 188%; width: calc(100% - 396px);}

#special-viewing .content_list .box .flex{display: flex; justify-content: space-between;  margin: 38px 0 0; position: relative; z-index: 2;}
#special-viewing .content_list .box .flex.bg_box{background: url(../images/special-viewing/bg_9.jpg) no-repeat center center; background-size: cover; padding: 52px 53px;align-items: center;}
#special-viewing .content_list .box.box_2 .flex{ flex-direction: row-reverse;}
#special-viewing .content_list .box .flex.bg_box .text_box{width: 463px;}
#special-viewing .content_list .box .flex .text_box h4{font-size: 19px; font-family: "Zen Old Mincho", serif; font-weight: 400; font-style: normal; line-height: 121%; padding: 0 0 10px;}
#special-viewing .content_list .box .flex .text_box h4 span{font-size: 33px; font-family: "Zen Old Mincho", serif; font-weight: 400; font-style: normal; line-height: 121.2%; display: inline-block;}
#special-viewing .content_list .box .flex .text_box p{line-height: 219%; font-size: 16px; padding: 10px 0 0;}
#special-viewing .content_list .box .flex .mini{background: url(../images/special-viewing/bg_9.jpg) no-repeat center center; background-size: cover; width: 347px; padding: 31px 26px 43px; }
#special-viewing .content_list .box .flex .mini .text_box h4{text-align: center; font-size: 15px; padding: 27px 0 0; letter-spacing: -0.05em;}
#special-viewing .content_list .box .flex .mini .text_box h4 span{ display: inline-block; padding: 0 0 5px;}
#special-viewing .content_list .box .flex .mini .text_box p{line-height: 194%; padding: 15px 0 0;}
#special-viewing .content_list .box_4 .flex.bg_box{margin: 58px 0 0;}

#special-viewing .content_list .box_1:before{content: ""; display: block; position: absolute; right: 0px; top: -129px; background: url(../images/special-viewing/bg_1.jpg) no-repeat center center; background-size: 100%; width: 528px; height: 358px; }
#special-viewing .content_list .box_2:before{content: ""; display: block; position: absolute; left: 0px; top: -203px; background: url(../images/special-viewing/bg_2.jpg) no-repeat center center; background-size: 100%; width: 777px; height: 358px; }
#special-viewing .content_list .box_3:before{content: ""; display: block; position: absolute; right: 0px; top: -227px; background: url(../images/special-viewing/bg_3.jpg) no-repeat center center; background-size: 100%; width: 678px; height: 371px; }
#special-viewing .content_list .box_4:before{content: ""; display: block; position: absolute; left: 0px; top: -242px; background: url(../images/special-viewing/bg_4.jpg) no-repeat center center; background-size: 100%; width: 618px; height: 358px; }

/* --------------------------------------------------------------------------- fee */
#fee { padding: 80px 0 110px; background: #ECDCBB; position: relative;}
#fee:before{content: ""; display: block; width: 438px; height: 368px; background:url(../images/special-viewing/bg_5.jpg) no-repeat center center; background-size: 100%; top: 0px; left: 0px; position: absolute;}
#fee:after{content: ""; display: block; width: 430px; height: 333px; background:url(../images/special-viewing/bg_6.jpg) no-repeat center center; background-size: 100%; position: absolute; bottom: 0px; right: 0px;}
#fee .main-title { margin-bottom: 50px; font-size: 42px; }
#fee .white_bg{background: #fff; padding: 83px 60px 93px; position: relative; z-index: 2;}
#fee .white_bg .table_box{border: 2px solid #707070;}
#fee .white_bg .img_box{text-align: center; padding: 36px 0 0;}
.fee-table { width: 100%; border-collapse: collapse; table-layout: fixed; }
.fee-table th,
.fee-table td {vertical-align: middle; font-size: 26px; line-height: 100%; }
.fee-table tr:not(:last-child) th,
.fee-table tr:not(:last-child) td{border-bottom: 2px solid #959595;}
.fee-table thead th { padding: 11px 20px; color: #fff; background: #404040; border-bottom: none; }
.fee-table thead th:not(:last-child){border-right: 2px solid #F3EEE7;}
.fee-table thead th:first-child { width: 46.6%; }
.fee-table thead th span{font-size: 20px;}
.fee-table tbody th { padding: 17px 20px 15px; background: #F3EEE8; font-size: 26px; line-height: 138.5%; text-align: center; }
.fee-table tbody th span{ font-size: 14px; }
.fee-table tbody td { padding: 17px 20px 15px; font-size: 26px; line-height: 138.5%; text-align: center; }
.fee-table thead th:last-child{border-right: 2px solid #404040;}
.fee-table tbody td:last-child{border-right: none;}
.fee-table tbody td,
.fee-table tbody th:not(:last-child){border-right: 2px solid #959595;}
.fee-note { margin-top: 15px; text-align: left; line-height: 150%; font-size: 15px; }

.fee-item-list { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; }
.fee-item { width: calc((100% - 20px) / 2); text-align: center; }
.fee-item__image { display: flex; align-items: flex-end; justify-content: center; height: 330px; margin: 0 0 28px; }
.fee-item__image img { width: auto; height: auto; }
.fee-item__title { margin-bottom: 10px; font-family: "Zen Old Mincho", serif; font-weight:600; font-style: normal; font-size: 29px; line-height: 150%; }
.fee-item__text {  line-height: 150%; }


/* --------------------------------------------------------------------------- application */
#application { padding: 60px 0 70px; background: url(../images/special-viewing/bg_10.jpg) center/cover no-repeat; }
#application h2 { margin-bottom: 65px; text-align: center; font-family: "Zen Old Mincho", serif; font-weight:600; font-style: normal;font-size: 36px; }

.application__list { display: flex; align-items: stretch; justify-content: space-between; gap: 30px; }
.application__item { width: calc((100% - 30px) / 2); padding: 40px 35px 35px; background: #fff; }
.application__title { margin-bottom: 20px; text-align: center; font-family: "Zen Old Mincho", serif; font-weight:600; font-style: normal;font-size: 32px; line-height: 150%; }
.application__text { line-height: 200%; font-size: 16px; }
.application__text.center{ text-align: center; }
.application__text small{ display: inline-block; font-size: 14px; padding-top: 15px; }

.application__arrow { position: absolute; right: 20px; top: 50%; width: 30px; height: 7px; border-bottom: 1px solid #fff; border-right: 1px solid #fff; transform: translate(0,-50%) skew(45deg); transition: all 0.2s; }

.application__link{ margin-top: 25px; }
.application__link a{ position: relative; display: flex; align-items: center; justify-content: center; flex-wrap: wrap; margin: 0 auto; }
.application__link a:hover { opacity: 0.6; }

.application__button a{ width: 325px; background: #C35129; color: #fff; padding: 24px 20px; }
.application__tel a{ flex-direction: column; font-family: "Zen Old Mincho", serif; font-weight: 600; font-style: normal;}
.application__tel-main { display: flex; align-items: center; justify-content: center; gap: 8px; font-size: 50px; line-height: 130%; font-family: "Zen Old Mincho", serif; font-weight: 600; font-style: normal; }
.application__tel-main img { width: 32px; height: auto; }
.application__tel-time { font-size: 14px; line-height: 130%; }


/* --------------------------------------------------------------------------- worship-guide */
#worship-guide { padding: 163px 0 0; }
#worship-guide .main-title { margin-bottom: 80px; font-size: 40px; }

.guide-item{ position: relative; }
.guide-item:before,
.guide-item:after{ z-index: -1; content: ""; position: absolute; width: 80%; height: 387px; right: 0; top: -40px; }
.guide-item:before{ background: #F5F2EC; }
.guide-item:after{ background: url(../images/special-viewing/bg_7.jpg) right top/566px no-repeat; }

.guide-item--reverse:before,
.guide-item--reverse:after{ left: 0; right: initial; }
.guide-item--reverse:after{ background: url(../images/special-viewing/bg_8.jpg) left top/566px no-repeat; }
.guide-item--reverse .worship-inner{ flex-direction: row-reverse; }

.guide-item + .guide-item{ margin-top: 120px; }
.worship-inner { position: relative; display: flex; justify-content: space-between; align-items: flex-start; width: 1100px; margin: 0 auto; }
.guide-item__image { width: 50%; background: #e8e8e8; }
.guide-item__image img { width: 100%; height: auto; }

.guide-item__body { width: 44%; }
.guide-item__head{ display: flex; align-items: center; gap: 25px; padding-bottom: 20px; }
.guide-item__number { font-family: "times-new-roman", sans-serif; font-weight: 400; font-style: italic; font-size: 94px; line-height: 1; }
.guide-item__title { position: relative; font-family: "Zen Old Mincho", serif; font-weight:600; font-style: normal; font-size: 36px; line-height: 150%; }
.guide-item__text,
.guide-item__text small{ font-size: 16px; line-height: 220%; }

.guide-item:nth-child(1) .guide-item__body{}
.guide-item:nth-child(2) .guide-item__body{padding: 29px 0 0;}
.guide-item:nth-child(3) .guide-item__body{padding: 35px 0 0;}
.guide-item:nth-child(4) .guide-item__body{padding: 29px 0 0;}
.guide-item:nth-child(5) .guide-item__body{padding: 35px 0 0;}
.guide-item:nth-child(6) .guide-item__body{padding: 44px 0 0;}



/* ------------------------------------------------------------ #main_hall ------------------------------------------------------------ */
#main_hall{padding: 113px 0 111px;}
#main_hall .img_box{ width: 901px; margin: 0 auto;}


/* ------------------------------------------------------------ mobile ------------------------------------------------------------ */
@media only screen and (max-width: 768px) {
	
	#bread{ margin-bottom: 0; }
	.cta { padding-bottom: 50px; }

	#fv{ }
/* --------------------------------------------------------------------------- lead */
	#lead { background: none; }
	#news .s-inner { width: 100%; }
	#news .main-title { margin-bottom: 20px; font-size: 25px; }

	.news__box{ padding: 40px 5% 55px; }

/* --------------------------------------------------------------------------- special-viewing */
	#special-viewing { padding: 50px 0 70px; background: url(../images/common/bg_02.png) center top/100% no-repeat; }
	#special-viewing .main-title { margin-bottom: 30px; font-size: 25px; }

	.worship-block { display: flex; flex-direction: column; gap: 37px; }
	.worship-block__image { order: -1; width: 100%; }
	.worship-block__body { width: 90%; margin: 0 auto; }
	.worship-block__title { margin-bottom: 12px; font-size: 26px; }
	.worship-block__info-title.small{ font-size: 27px; }
	.worship-block__text{ font-size: 16px; }
	.worship-block__text + .worship-block__text { margin-top: 20px; }
	.worship-block__info { margin-top: 25px; padding-top: 20px; }
	.worship-block__info-title { margin-bottom: 8px; font-size: 24px; }
	.worship-block__info-text{ line-height: 180%; }

	.worship-block__main-image{ width: 95vw; }

/* --------------------------------------------------------------------------- content_list */
	/* 外枠の幅・中央寄せは .s-inner のSP(common.css:90%)を流用。ここではPC固定幅の横並びを縦積みに */
	#special-viewing .content_list { padding: 60px 0 0; }
	#special-viewing .content_list .box:not(:first-child){ margin: 70px 0 0; }

	#special-viewing .content_list .box .title_box h3{ font-size: 30px; padding: 0 40px; }
	#special-viewing .content_list .box .title_box h3:before,
	#special-viewing .content_list .box .title_box h3:after{ width: 28px; }

	#special-viewing .content_list .box .main_img{ padding: 22px 0 0; }
	#special-viewing .content_list .box .main_img .flex{ display: block; margin: 15px 0 0; }
	#special-viewing .content_list .box .main_img .flex h4{ margin: 0 0 10px; font-size: 24px; text-align: center; }

	/* .flex / .bg_box / .mini をまとめて縦積み・全幅化 */
	#special-viewing .content_list .box .flex{ display: block; margin: 20px 0 0; }
	#special-viewing .content_list .box .flex.bg_box{ padding: 25px 5%; }
	#special-viewing .content_list .box .flex .img_box{ text-align: center; }
	#special-viewing .content_list .box .flex .img_box img{ width: 100%; height: auto; }
	#special-viewing .content_list .box .flex .text_box{ width: 100%; margin-top: 20px; }
	#special-viewing .content_list .box .flex.bg_box .text_box{ width: 100%; }
	#special-viewing .content_list .box .flex .text_box h4{ text-align: center; font-size: 13px; }
	#special-viewing .content_list .box .flex .text_box h4 span{ font-size: 24px; }
	#special-viewing .content_list .box .flex.bg_box .text_box h4 span{ font-size: 24px; }

	#special-viewing .content_list .box_3 .flex .mini{ width: 100%; padding: 25px 5%; }
	#special-viewing .content_list .box_3 .flex .mini + .mini{ margin-top: 20px; }
	#special-viewing .content_list .box_3 .flex .mini .text_box{ margin-top: 0; }
	#special-viewing .content_list .box .flex .mini .text_box h4{ padding: 18px 0 0; font-size: 13px; }

	/* 本文テキストは共通指定にまとめる（miniの行間のみ個別調整） */
	#special-viewing .content_list .box .main_img .flex p,
	#special-viewing .content_list .box .flex .text_box p{ width: 100%; padding: 10px 0 0; font-size: 14px; line-height: 190%; }
	#special-viewing .content_list .box .flex .mini .text_box p{ padding: 15px 0 0; line-height: 180%; }

	/* 装飾背景はSP用に縮小（個別指定／幅は%・高さはpadding%で縦横比を保持） */
	#special-viewing .content_list .box_1:before{ width: 48%; height: 0; padding-top: 32.5%; top: -45px; }
	#special-viewing .content_list .box_2:before{ width: 60%; height: 0; padding-top: 27.6%; top: -40px; }
	#special-viewing .content_list .box_3:before{ width: 55%; height: 0; padding-top: 30%; top: -45px; }
	#special-viewing .content_list .box_4:before{ width: 52%; height: 0; padding-top: 30%; top: -45px; }
	#special-viewing .content_list .box_4 .flex.bg_box{margin: 32px 0 0;}

/* --------------------------------------------------------------------------- fee */
	#fee{ padding: 60px 0; }
	#fee:before{ width: 65%; height: 0; padding: 55% 0 0; }
	#fee .white_bg{ padding: 35px 5% 40px; }
	#fee .white_bg .img_box{ padding: 25px 0 0; }
	#fee .white_bg .img_box img{ width: 100%; height: auto; }
	#fee .main-title { margin-bottom: 25px; font-size: 25px; }
	.fee-table-wrap { margin-bottom: 35px; }

	.fee-table thead th { padding: 10px 5px; font-size: 16px; }
	.fee-table thead th span{ font-size: 11px; }
	.fee-table thead th:first-child{ width: 36%; }
	.fee-table thead th:not(:first-child){ width: 25%; }
	
	.fee-table tbody th { padding: 6px 5px; font-size: 12px; }
	.fee-table tbody th span{ font-size: 0.7em; }
	.fee-table tbody td { padding: 14px 8px; font-size: 16px; }
	.fee-note { margin-top: 10px; font-size: 12px; text-align: left; }

	.fee-item-list {}
	.fee-item:first-of-type { flex: 1; }
	.fee-item:last-of-type { width: 35%; }
	
	.fee-item:first-of-type .fee-item__image img{ width: 230px; height: 130px; object-fit: cover; }
	.fee-item:last-of-type .fee-item__image img{ width: 250px; height: 140px; object-fit: cover; }
	
	.fee-item__image { height: 130px; margin: 0 0 16px; }
	.fee-item__title { margin-bottom: 8px; font-size: 16px; }
	.fee-item__text{ font-size: 12px; }

/* --------------------------------------------------------------------------- application */
	#application { padding: 40px 0 45px; background: url(../images/special-viewing/bg_10-sp.jpg) center/cover no-repeat; }
	#application h2 { margin-bottom: 9px; line-height: 150%; font-size: 26px; }

	.application__list { display: block; }
	.application__item { width: 100%; padding: 25px 7% 30px; }
	.application__item + .application__item { margin-top: 20px; }
	.application__title { margin-bottom: 7px; font-size: 24px; }
	.application__text{ font-size: 14px; line-height: 170%; }
	.application__text small{ padding-top: 7px; font-size: 12px; }

	.application__link { margin-top: 25px; }
	.application__link a { height: auto; padding: 14px 20px; font-size: 18px; }
	.application__button a { width: 100%; padding: 20px 20px; font-size: 15px; }
	
	.application__tel{ margin-top: 13px; }
	.application__tel a { width: 100%; padding: 0; }
	.application__tel-main img {width: 28px;}
	.application__tel-main { font-size: 36px;gap: 4px; }
	.application__tel-time{ font-size: 12px; }


/* --------------------------------------------------------------------------- worship-guide */
	#worship-guide { padding: 60px 0 0; }
	#worship-guide .main-title { margin-bottom: 40px; font-size: 25px; }

	.guide-item { flex-direction: column; padding: 0 0 20px; }
	.guide-item + .guide-item { margin-top: 70px; }
	
	.guide-item::before,
	.guide-item::after {width: 100%; height: 100%; top: 8%; }

	.guide-item--reverse .worship-inner{ flex-direction: column; }
	.guide-item::after { background: url(../images/special-viewing/bg_7.jpg) right top/100% no-repeat; }
	.guide-item--reverse::after{ background: url(../images/special-viewing/bg_8.jpg) right top /100% no-repeat; }
		
	.guide-item__head{ justify-content: center; padding-bottom: 15px; gap: 13px; }
	.guide-item__image { width: 100%; }
	.guide-item__body { width: 100%; padding: 18px 0 0; }
	.guide-item__number { font-size: 64px; }
	.guide-item__title { font-size: 26px; }
	.guide-item__text { font-size: 16px; line-height: 170%; }
	.guide-item__text small{ font-size: 14px; }

	.worship-inner{ width: 90%; flex-direction: column; }

	.worship-block__list{ padding: 0; }
	.worship-block__row{ column-gap: 0; grid-template-columns: 80px 1fr; padding-bottom: 0; }
	.worship-block__row dt,
	.worship-block__row dd{ padding: 10px 0; font-size: 15px; border-bottom: 1px solid #D1D1D1; }
	.worship-block__row + .worship-block__row{ margin: 0; }
	

	.guide-item:nth-child(2) .guide-item__body,
	.guide-item:nth-child(3) .guide-item__body,
	.guide-item:nth-child(4) .guide-item__body,
	.guide-item:nth-child(5) .guide-item__body,
	.guide-item:nth-child(6) .guide-item__body{padding: 20px 0 0;}
	/* --------------------------------------------------------------------------- main_hall */
	#main_hall{ padding: 100px 0 60px; }
	#main_hall .img_box{ width: 100%; }
	#main_hall .img_box img{ width: 100%; height: auto; }
}
