@charset "utf-8";
/* =======================================

	Structure CSS

========================================== */

body.open {
	position: fixed;
}

.contents {
	max-width: 100%;
	width: calc(100% - 40px);
}

/* =======================================

	Text Decorations CSS

========================================== */

.title07 {
	font-size: 122%;
	margin-bottom: 30px;
}

.title07 span {
	display: inline;
}

/* =======================================

	Header CSS

========================================== */

.home .site-header .site-header__inner,
.promise .site-header .site-header__inner {
	position: static;
}

.site-header .site-header__inner .hnavi__wrap {
	max-width: 100%;
	padding-right: 0;
	position: static;
	width: 100%;
}

.site-header__logo {
	padding: 10px 13px;
}

.site-header__logo a {
	height: 35px;
	width: 224px;
}

/* =======================================

	Globalnavi CSS

========================================== */

.pc_menu {
	display: none;
}
.gnavi__wrap .gnavi__btn {
	border-left: 1px solid #E0E0E0;
	cursor: pointer;
	display: block;
	float: right;
	height: 60px;
	position: relative;
	text-align: center;
	width: 60px;
}

.gnavi__wrap .gnavi__btn p {
	color: #5F567E;
	font-family: 'Helvetica Neue' , '游ゴシック Medium' , 'Yu Gothic Medium' , '游ゴシック体' , YuGothic , 'ヒラギノ角ゴ Pro W3' , 'Hiragino Kaku Gothic Pro' , 'Meiryo UI' , 'メイリオ' , Meiryo , 'ＭＳ Ｐゴシック' , 'MS PGothic' , arial, sans-serif;
	font-size: 50%;
	left: 15px;
	top: 35px;
	position: absolute;
}

.site-header .gnavi__btn .gnavi__btn-line span {
	background: #5F567E;
	border-radius: 2px;
	display: block;
	height: 3px;
	left: 17px;
	position: absolute;
	-webkit-transition: 0.5s ease-in-out;
	-moz-transition: 0.5s ease-in-out;
	transition: 0.5s ease-in-out;
	width: 26px;
}

.site-header .gnavi__btn .gnavi__btn-line span.gnavi__btn-line--top {
	top: 14px;
}

.site-header .gnavi__btn .gnavi__btn-line span.gnavi__btn-line--middle {
	top: 22px;
}

.site-header .gnavi__btn .gnavi__btn-line span.gnavi__btn-line--bottom {
	top: 30px;
}

body.open .site-header .gnavi__btn .gnavi__btn-line span.gnavi__btn-line--top {
	-moz-transform: translate(0, 8px) rotate(45deg);
	-webkit-transform: translate(0, 8px) rotate(45deg);
	transform: translate(0, 8px) rotate(45deg);
}

body.open .site-header .gnavi__btn .gnavi__btn-line span.gnavi__btn-line--bottom {
	-moz-transform: translate(0, -8px) rotate(-45deg);
	-webkit-transform: translate(0, -8px) rotate(-45deg);
	transform: translate(0, -8px) rotate(-45deg);
}

body.open .site-header .gnavi__btn .gnavi__btn-line span.gnavi__btn-line--middle {
	display: none;
}

.gnavi__wrap .gnavi__menu01 {
	margin: 0 auto;
	max-height: 0;
	overflow: hidden;
	width: 100%;
}

body.open .gnavi__wrap .gnavi__menu01 {
	background-color: #fff;
	border-top: 1px solid #5F567E;
	height: 100%;
	left: 0;
	max-height: 2000px;
	opacity: 1;
	position: fixed;
	top: 60px;
	transition: all 1s ease-in-out;
	z-index: 9999;
}

.gnavi__wrap .gnavi__menu01 nav {
	height: 100%;
	overflow-y: auto;
}

.gnavi__wrap .gnavi__menu01 ul {
	height: 1500px;
	display: block;
	overflow-y: auto;
	padding: 20px 50px;
}

.gnavi__wrap .gnavi__menu01 ul li {
	border-bottom: 1px solid #DDD;
	width: 100%;
}

.gnavi__wrap .gnavi__menu01 ul li a {
	padding: 20px 28px 20px 10px;
}

.gnavi__wrap .gnavi__menu01 ul.sec {
	height: auto;
	margin-top: 0;
	padding: 0 0 0 15px;
}

.gnavi__wrap .gnavi__menu01 ul.sec li {
	font-size: 100%;
}

.gnavi__wrap .gnavi__menu01 ul.sec li:last-child {
	border-bottom: 0;
}



/* =======================================

	お急ぎの方はこちら

========================================== */

.hnavi__tel--btn {
	overflow: hidden;
	padding: 8px 0 9px;
	position: static;
	text-align: center;
	width: 100%;
}

.hnavi__tel--title {
	border-bottom: none;
	border-left: 1px solid rgba(255,255,255,.15);
	float: right;
	font-size: 116%;
	margin-bottom: 0;
	padding: 5px 17px 5px 38px;
	text-align: left;
	width: calc(50% - 56px);
}

.hnavi__tel--title:before {
	left: 15px;
	margin-top: -2.2px;
}

.hnavi__tel--note {
	float: left;
	font-size: 77%;
	font-weight: bold;
	padding: 10px 15px;
	text-align: right;
	width: calc(50% - 30px);
}

.site-header.open .hnavi__tel--content {
	margin: 0 0 40px;
	border-top: 1px solid #FFF;
}

.hnavi__tel--content .tel--content_header {
	font-size: 116%;
}

.hnavi__tel--content .tel--content_header .tel_close {
	display: none;
}

.tel--box__wrap {
	display: block;
	margin: 30px auto 0;
	max-width: 100%;
}

.tel--box__wrap .tel--box {
	width: 100%;
}

.tel--box__header .title06 {
	padding-right: 25px;
}

.tel--box__wrap .box__gray ul li {
	padding-left: 13px;
	width: calc(50% - 13px);
}

.tel--box__wrap .box__gray ul li:before {
	height: 6px;
	margin-top: -3px;
	width: 6px;
}

.tel--box__wrap .tel--box2 .box__gray ul li {
	width: calc(50% - 13px);
}

/* =======================================

	ホーム

========================================== */

.home .contents {
	max-width: 100%;
	width: 100%;
}

body.open .home-slide {
	width: 0;
}

.home-slide .swiper-container-horizontal > .swiper-pagination-bullets {
  bottom: 20px;
}

.swiper-slide01:before {
	-webkit-background-size: 333px 163px;
	background-size: 333px 163px;
	height: 163px;
	top: 90px;
	width: 333px;
}

.swiper-slide02:before {
	-webkit-background-size: 412px 123px;
	background-size: 412px 123px;
	height: 123px;
	margin-right: -79px;
	top: 90px;
	width: 412px;
}

.swiper-slide03:before {
	-webkit-background-size: 342px 123px;
	background-size: 342px 123px;
	height: 123px;
	top: 90px;
	width: 342px;
}

.swiper-slide04:before {
	-webkit-background-size: 333px 123px;
	background-size: 333px 123px;
	height: 123px;
	top: 90px;
	width: 333px;
}

.home-news .box__wrap,
.home-plan,
.home-jisen a,
.home-estimates a,
.home-access,
.home-tel .box__wrap,
.home-consultation .box__wrap,
.home-service .box__wrap,
.home-faq .box__wrap,
.home-guide .box__wrap {
	padding: 0 20px;
	max-width: 100%;
}

.home-plan{
	padding: 80px 20px 100px;
}

.home-plan .box__wrap .text .title {
	font-size: 200%;
}

.home-plan .box-other .box__img-right {
	display: block;
}

.home-plan .box-other .box__img-right .text {
	width: calc(100% - 130px)
}

.home-plan .box-other .box__img-right .img {
	display: -webkit-box;
	display: flex;
	width: 100%;
}

.home-plan .box-other .box__img-right .img p {
	width: 50%;
}

.home-jisen .hometitle03,
.home-estimates .hometitle03 {
	margin: 0 0 30px;
}

.home-access {
	padding: 60px 20px 100px;
}

.home-access .home-box__header {
	padding-left: 0;
	position: static;
	text-align: center;
	width: 100%;
}

.home-access .hometitle02 {
	text-align: center;
}

.home-access .box__img-left {
	display: block;
}

.home-access .text {
	margin-top: 0;
	width: 100%;
}

.home-access .img {
	margin: 0 auto 40px;
	text-align: center;
	width: 50%;
}

.home-tel .box3 {
	width: 48%;
}

.home-consultation .box4,
.home-service .box3 {
	margin-bottom: 20px;
	width: 48%;
}

.home-consultation .box4 a,
.home-service .box3 a {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: flex;
}

.home-img__btn img {
	height: 80px;
	width: 105px;
}

.home-img__btn p {
	background-color: transparent;
	position: static;
}

.home-service .home-img__btn {
	background-color: rgba(240,237,248,.8);
}

.home-service .home-img__btn p {
	position: static;
}

.box3.home-text__btn {
	width: 48%;
}


/* =======================================

	下層ページ共通

========================================== */

.page-header {
	margin: 40px 0 30px;
}

/* =======================================

	虹のホールのお約束

========================================== */

.promise .contents {
	max-width: 100%;
	width: 100%;
}

.promise .page-header .maintext {
	top: 60px;
}

.box__promise-wrap {
	margin-top: -200px;
}

.box__promise {
	max-width: 100%;
}

.box__promise .text {
	padding: 36px 30px 40px 30px;
}

.box__promise01 {
	padding-top: 100px;
}

.box__promise01 .text {
	width: calc(53% - 60px);
}

.box__promise02 {
	padding-bottom: 120px;
	margin-bottom: 0;
}

.box__promise02 .text {
	width: calc(62% - 60px);
}

.box__promise03 {
	padding-top: 70px;
}

.box__promise03 .text {
	width: calc(62% - 60px);
}

.box__promise03 .img {
	margin-top: 0;
}

.box__promise04 {
	padding-top: 50px;
}

.box__promise04 .text {
	width: calc(53% - 60px);
}

.box__promise05 {
	padding-top: 35px;
}

.box__promise05 .text {
	padding-right: 30px;
	width: calc(53% - 60px);
}

.box__promise05 .text p {
	margin-right: 0;
}

.box__promise06 {
	padding-top: 30px;
}

.box__promise06 .text {
	width: calc(62% - 60px);
}

.promise .box__bnr {
	display: block;
	margin-bottom: 80px;
	max-width: 530px;
}

.promise .box__bnr a {
	margin-bottom: 20px;
	width: calc(100% - 170px);
}

.promise .box__bnr a dl {
	padding: 29px;
}

.promise .box__bnr a dt {
	font-size: 144%;
}

.promise .box__bnr a dd {
	font-size: 100%;
}



.gift .page-header .maintext {
	margin-top:0;
	top: 25px;
}

.box__gift-wrap {
	margin: 0 auto;
	max-width: 100%;
	width: calc(100% - 40px);
}

.gift-point .box__wrap {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.gift-point .gift-point02 {
	margin: 48px 0 0 -60px;
}

/* =======================================

	施設一覧・アクセス

========================================== */

.access .contents {
	max-width: 100%;
	width: calc(100% - 40px);
}

.access .box__wrap {
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.access .box3 {
	margin: 0 0 40px;
	width: calc(48% - 2px);
}

.access .box__header,
.access .img,
.access .text {
	padding: 0 30px;
}

/* =======================================

	葬儀

========================================== */

.sogi .contents {
	max-width: 100%;
	width: calc(100% - 40px);
}

/* 事前相談のご案内 */
/* 供物・供花のご案内 */

.jizen .home-tel .box__wrap .tel--num,
.offerings .home-tel .box__wrap .tel--num {
	background: url(../img/common/tel_l_purple.svg) no-repeat 5px center;
	-webkit-background-size: 17.74px 25.97px;
	background-size: 17.74px 25.97px;
	font-size: 183%;
	padding-left: 25px;
}

