/* ▼▼CSS module-Document▼▼ */
/*福祉葬について吹き出し会話*/
.talk {
margin-bottom: 40px;
}

.talk figure img {
width: 100%;
height: 100%;
border: 2px solid #c5c5c5;
border-radius: 50%;
margin: 0;
}

/* 画像の下のテキスト */
.talk-imgname {
padding: 5px 0 0;
font-size: 10px;
text-align: center;
}

p.talk-text {
margin: 0 0 8px;
}

p.talk-text:last-child {
margin-bottom: 0px;
}

/* 回り込み解除 */
.talk:after,.talk:before {
clear: both;
content: "";
display: block;
}

/* ----- 左の場合 ----- */

/* 左画像 */
.talk-Limg {
margin-left: 4px;
margin-top: -1px;
float: left;
width: 60px;
height: 60px;
}

/* 左からの吹き出しテキスト */
.talk-Ltxt {
color: #444;
position: relative;
margin-left: 100px;
padding: 1.2em;
border: 3px solid #9ad19e;
background-color: #fff;
border-radius: 5px;
}

/* 左の三角形を作る */
.talk-Ltxt:before {
position: absolute;
content: '';
border: 10px solid transparent;
border-right: 10px solid #9ad19e;
top: 15px;
left: -20px;
}

.talk-Ltxt:after {
position: absolute;
content: '';
border: 10px solid transparent;
border-right: 10px solid #fff;
top: 15px;
left: -16px;
}
/* ----- 右の場合 ----- */

/* 右画像 */
.talk-Rimg {
margin-right: 4px;
margin-top: -1px;
float: right;
width: 60px;
height: 60px;
}

/* 右からの吹き出しテキスト */
.talk-Rtxt {
position: relative;
margin-right: 100px;
padding: 1.2em;
border: 3px solid #5554a0;
background-color: #e3e3f3;
border-radius: 5px;
}

/* 右の三角形を作る */
.talk-Rtxt:before {
position: absolute;
content: '';
border: 10px solid transparent;
border-left: 10px solid #5554a0;
top: 15px;
right: -23px;
}

.talk-Rtxt:after {
position: absolute;
content: '';
border: 10px solid transparent;
border-left: 10px solid #e3e3f3;
top: 15px;
right: -19px;
}

/*斎場詳細ナビ*/
#contentsLinks{
position:fixed;
z-index:1;
right:0;
bottom:170px;
}

#contentsLinks li{
margin:20px 0;
}

#contentsLinks a{
display:block;
width:80px;
background:#5554a0;
color:#ffffff;
border-top-left-radius:10px;
border-bottom-left-radius:10px;
padding:10px;
font-size:12px;
}

@media screen and (max-width:1150px) {

	#contentsLinks{
	display:none;
	}
}


/*ページトップボタン*/
#contentsLinks_top{
position:fixed;
z-index:1;
right:0;
bottom:120px;
}

#contentsLinks_top li{
margin:20px 0;
}

#contentsLinks_top a{
display:block;
width:12px;
background:#5554a0;
color:#ffffff;
border-top-left-radius:10px;
border-bottom-left-radius:10px;
padding:10px;
font-size:12px;
}
/* FAQ */
.qa-list a{
	color:#666666;
	text-decoration:none;
	display:block;
}

.faqtel{
	font-weight:bold;
	font-size:24px;
	color:#f1f1f1;
}

.qa-list{
	width:90%;
	border:1px solid #cccccc;
	padding:3%;
	margin:0px auto;
	border-radius:7px;
	background-color:#faf7f2;
}


.qa-list dl {
    position: relative;
    margin: 30px 0 0;
    cursor: pointer;
    border: 1px solid #DDD;
    border-radius:5px;
}

.qa-list dl:first-child {
  margin-top: 0;
}
.qa-list dl::after {
    position: absolute;
    top: 27px;
    right: 26px;
    display: block;
    width: 7px;
    height: 7px;
    margin: auto;
    content: '';
    transform: rotate(135deg);
    border-top: 2px solid #000;
    border-right: 2px solid #000;
}
.qa-list .open::after {
    transform: rotate(-45deg);
}
.qa-list dl dt {
    position: relative;
    margin: 0;
    padding: 20px 40px 20px 60px;
    font-weight: normal;
    background: #DDD;
}
.qa-list dl dt::before {
    font-size: 24px;
    line-height: 1;
    position: absolute;
    top: 20px;
    left: 20px;
    display: block;
    content: 'Q.';
    color: #9e1919;
}
.qa-list dl dd::before {
    font-size: 22px;
    line-height: 1;
    position: absolute;
    left: 20px;
    display: block;
    content: 'A.';
    font-weight: normal;
    color: #ffffff;
}
.qa-list dl dd {
    position: relative;
    margin: 0;
    padding: 20px 20px 20px 60px;
    background-color: #3285bf;
    color: #ffffff;
    /*border-radius:5px;*/
}
.qa-list dl dd p {
    margin: 30px 0 0;
}
.qa-list dl dd p:first-child{
    margin-top: 0;
}

@media screen and (max-width: 767px) {
 .qa-list dl {
    margin: 10px 0 0;
}
.qa-list dl:after {
    top: 20px;
    right: 20px;
    width: 7px;
    height: 7px;
}
.qa-list dl dt {
    padding: 16px 40px 16px 50px;
    font-size: 14px;
}
.qa-list dl dt::before {
    font-size: 14px;
    top: 20px;
    left: 20px;
}
.qa-list dl dd::before {
    font-size: 14px;
    left: 20px;
    margin-top: 5px;
}
.qa-list dl dd {
    margin: 0;
    padding: 16px 16px 16px 50px;
    font-size: 14px;
}
.qa-list dl dd p {
    margin: 30px 0 0;
}
.qa-list dl dd p:first-child{
    margin-top: 0;
}
}


/*--コンセプトカラー#006cb8_#0599d9_#52c3f1※左ほど濃い--*/
/*  並び替えコンテンツ------------------------------------------------------------------------------------------------------------------------------------------*/
.contentsblock{
max-width:80%;
margin:20px auto;
}

.contentsblock ul{
display:flex;
flex-wrap: wrap;
}

.contentsblock_between ul{
justify-content:space-between;
}

.contentsblock li{
background-color:#fff;
width:21%;
list-style:none;
padding:10px;
margin:10px;
}

.contentsblock li p{
line-height:1.5;
padding:10px 0;
}


.itaku_contentsblock{
max-width:80%;
margin:20px auto;
}

.itaku_contentsblock ul{
width:100%;
}

.itaku_contentsblock li{
background-color:#fff;
width:90%;
list-style:none;
margin:6px auto;
padding:20px;
line-height:1.3;
color:#333333;
}

.itaku_title{
font-size:20px;
line-height:1.8;
font-weight:bold;
color:#006cb8;
}

.item-content h4{
font-size:24px;
border-left:5px solid #296e99;
padding:10px;
width:80%;
margin:0 auto;
}

.arrow_down{
	display:block;
	width:10px;
	height:10px;
	border-right:1px solid #666666;
	border-bottom:1px solid #666666;
	text-align:center;
	-webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

@media screen and (max-width:1279px) { 
	.contentsblock{
	max-width:82%;
	margin:20px auto;
	}
	
	.item-content h4{
	font-size:24px;
	border-left:5px solid #296e99;
	padding:10px;
	width:90%;
	margin:0 auto;
	}
	.contentsblock_between ul{
	justify-content:start;
	}
}

@media screen and (max-width:1127px) { 
	.contentsblock{
	max-width:88%;
	margin:20px auto;
	}
	
	.contentsblock li{
	background-color:#fff;
	width:200px;
	list-style:none;
	padding:10px;
	margin:10px;
	}
	
}

@media screen and (max-width:799px) { 
	.contentsblock{
	max-width:84%;
	margin:20px auto;
	}
	
	.contentsblock li{
	background-color:#fff;
	width:280px;
	list-style:none;
	padding:10px;
	margin:10px;
	}
	
	.item-content h4{
	font-size:24px;
	border-left:5px solid #296e99;
	padding:10px;
	width:80%;
	margin:0 auto;
	}
	
	.mobile_none{
	display:none;
	}
}

@media screen and (max-width:779px) { 
	.contentsblock{
	max-width:70%;
	margin:20px auto;
	}
	
	.contentsblock li{
	background-color:#fff;
	width:100%;
	list-style:none;
	padding:10px;
	margin:10px;
	}
	
	.item-content h4{
	font-size:20px;
	border-left:5px solid #296e99;
	padding:10px;
	width:82%;
	margin:0 auto;
	}
	
}

@media only screen and (max-width: 768px) {
	.contentsblock{
	max-width:90%;
	}
}



/*TOPスライダーあさひ葬祭
----------------------------------------------------------------------*/
		.slide-arrow{
			position:absolute;
			top:50%;
			transform: translateY(-50%);
			-webkit-transform: translateY(-50%);
			-ms-transform: translateY(-50%);
			z-index:100;
			cursor:pointer;
		}
		.slide-arrow::before{
			display:block;
			color:#fff;
			font-size:30px;
			font-weight:900;
			font-family:"Font Awesome 5 Free";
		}
		.prev-arrow{ left:10px;}
		.next-arrow{ right:10px; }
		.next-arrow::before{
			content:"\f054";
		}
		.prev-arrow::before{
			content:"\f053";
		}
		.slide-arrow:hover::before{
			color:#11cfff;
		}
		.slick-dots{
			position:absolute;
			bottom:0;
			z-index:100;
		}
		.slick-dots li button:before{
			color:#fff;
			opacity:1;
		}
		.slick-dots li.slick-active button:before{ color:#11cfff; opacity:1; }
		
		
		.slider img{
		width:100%;
		}





/*　ハンバーガーボタン ------------------------------------------------------------------------------------------------------------------------------------------*/
.hamburger {
  display : block;
  position: fixed;
  z-index : 5;
  right : 23px;
  top   : 60px;
  width : 42px;
  height: 42px;
  cursor: pointer;
  text-align: center;
}

@media screen and (min-width:370px) { 
	.hamburger {
	  top   : 54px;
	}
}


.hamburger span {
  display : block;
  position: absolute;
  width   : 30px;
  height  : 2px ;
  left    : 6px;
  background : #555;
  -webkit-transition: 0.5s all;
  -moz-transition   : 0.5s all;
  transition        : 0.5s all;
}
.hamburger span:nth-child(1) {
  top: 10px;
}
.hamburger span:nth-child(2) {
  top: 20px;
}
.hamburger span:nth-child(3) {
  top: 30px;
}

/* ナビ開いてる時のボタン */

.hamburger.active span:nth-child(1) {
  top : 18px;
  left: 7px;
  width: 24px;
  -webkit-transform: rotate(-45deg);
  -moz-transform   : rotate(-45deg);
  transform        : rotate(-45deg);
  background : #fff;
}
.hamburger.active span:nth-child(2) {
  left: 60%;
  opacity: 0;
  -webkit-animation: active-btn17-bar02 .8s forwards;
  animation: active-hamburger-bar02 .8s forwards;
  background : #fff;
}
@-webkit-keyframes active-hamburger-bar02 {
  100% {
    height: 0;
  }
}
@keyframes active-hamburger-bar02 {
  100% {
    height: 0;
  }
}
.hamburger.active span:nth-child(3) {
  top: 18px;
  left:8px;
  width: 24px;
  -webkit-transform: rotate(45deg);
  -moz-transform   : rotate(45deg);
  transform        : rotate(45deg);
  background : #fff;
}


.hamburger::after {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  content: '';
  width: 52px;
  height: 52px;
  margin: -29px 0 0 -30px;
  border-radius: 50%;
  border: 2px solid rgba(0, 0, 0, 0);
  transition: all .75s;
}
.hamburger.active::after {
  border: 2px solid #555;
}

#menu_flex{
	display:flex;
	flex-wrap:nowrap;
	padding:0;
	width:88%;
	margin:20px auto;
}

#scroll{/*スマホ時にメニューをスクロール*/
	max-height: 100vh;
	margin:20px auto;
	overflow-y: scroll;
	-webkit-overflow-scrolling: touch;
	padding-bottom:50px;
}


nav.globalMenuSp {
  position: fixed;
  z-index : 4;
  top  : 0;
  left : 0;
  color: #fff;
  background: #000000;
  opacity:0.75;
  text-align: left;
  transform: translateY(-100%);
  transition: all 0.6s;
  width: 100%;
  padding:25px 10px;
}

/*
nav.globalMenuSp h2{
	text-align:center;
}*/


nav.globalMenuSp ul li {
  list-style-type: none;
  margin-right:15px;
  margin-top:15px;
}
/*
nav.globalMenuSp ul li:last-child {
  padding-bottom: 0;
  margin-right:0px;
}*/
nav.globalMenuSp ul li a:hover{
  color:#cccccc;
}

nav.globalMenuSp ul li a {
  display: block;
  color: #fff;
  padding:1em;
  text-decoration :none;
  border:1px solid #ffffff;
  text-align:center;
}



nav.globalMenuSp dl {
  margin: 0 auto;
  padding: 0;
  width: 30%;
}

nav.globalMenuSp dl dt {
  font-weight:bold;
  font-size:120%;
  padding:20px 10px 5px 0;
}

nav.globalMenuSp dl dd {
  list-style-type: none;
  padding:0 0 0 10px;
  margin:12px 0 12px 15px;
  border-left:1px solid #fff;
  line-height:2.2;
  /*font-size:80%;*/
}
nav.globalMenuSp dl dd:last-child {
  padding-bottom: 0;
}
nav.globalMenuSp dl dd a:hover{
  color:#cccccc;
}

nav.globalMenuSp dl dd a {
  display: block;
  color: #fff;
  /*padding: 0.5em 0;*/
  text-decoration :none;
}


#under_menu{
	overflow:hidden;
	/*display:flex;
	flex-wrap:wrap;*/
	width:80%;
	margin:50px auto;
	padding: 0px 0 85px 0;
}

#under_menu li{
	float:left;
	font-size:90%;
	/*width:20%;*/
}

#under_menu a:hover{
	background-color:#ffffff;
	color:#333333;
}


/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
  transform: translateY(0%);
}

.active{
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

/*スマホタブレット用メニューレイアウト*/
@media screen and (max-width:930px) { 
#menu_flex{
	display:block;
	padding:0;
	width:80%;
	margin:20px auto;
}

nav.globalMenuSp dl {
  margin: 20px 0 0 0;
  width:100%;
}

nav.globalMenuSp dl dd {
  list-style-type: none;
  padding:0 0 5px 5px;
  margin:12px 0 12px 15px;
  border-left:none;
  border-bottom:1px solid #fff;
  line-height:1.8;
  width:90%;
}



}



/*　スクロールで表示するフッター ------------------------------------------------------------------------------------------------------------------------------------------*/
#slide {
	font-size: 85%;
	position: fixed;
	width: 150px;
	height: 28px;
	bottom: 2px;
	right: 0;
	color: #ffffff;
	background: #333333;
	z-index:9;
	/*
	border-left: solid 1px #999;
	border-top: solid 1px #999;*/
	border-bottom:6px solid #f57c0a;
	-webkit-border-top-left-radius: 0px;
	-moz-border-radius-topleft: 0px;
	-webkit-box-shadow: 0px 0px 10px 0px rgba(0,0,0,1);
	-moz-box-shadow: 0px 0px 10px 0px rgba(0,0,0,1);
	box-shadow: 0px 0px 10px 0px rgba(0,0,0,1);
}
#slide-in {
	padding: 5px 10px;
}
#slide p {
	margin: 3px 0 0px 0;
	padding:0;
	font-size:90%;
	text-align:left;
	font-size:16px;
	font-weight:bold;
}
#slide a {
	text-decoration: none;
	cursor: pointer;
	display:block;
	padding:0 0 0 0px;
	color: #ffffff;
	position:relative;
	border-bottom:1px solid #ffffff;
}
#slide h3 {
	font-size:14px;
	margin:8px 0 7px 0;
}
#slide li {
	font-size:10px;
	margin:3px 0 0px 0;
}
#slide #open-btn {
	position: absolute;
	right: 10px;
	top: 10px;
	width: 20px;
	height: 20px;
	cursor: pointer;
	background: url(../images/close-btn.gif);
}

@media screen and (min-width:799px) { 
	#slide {
		display:none;
	}
}

/*  ふわっと出るアニメ------------------------------------------------------------------------------------------------------------------------------------------*/

/*アニメーション要素のスタイル*/
.animation{
	opacity : 0;
	visibility: hidden;
	transition: 1s;
	transform: translateY(30px);
}
/*アニメーション要素までスクロールした時のスタイル*/

/*=======================================
slickスライダー
=======================================*/

.full div {
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  height: 80vh;
  /*height: auto;*/
  margin: 0;
  position:relative;
}
@media screen and (max-width:1360px) { 
	.full div {
	  height: 68vh;
	}
}
@media screen and (max-width:930px) { 
	.full div {
	  height: 40vh;
	}
}

@media screen and (max-width:500px) { 
	.full div {
	  height: 32vh;
	}
}


.full div.img01 {
  background-image: url(../images/top01.jpg);
}
.full div.img01-2 {
  background-image: url(../images/top01-2.jpg);
}
.full div.img01-3 {
  background-image: url(../images/top01-3.jpg);
}
.full div.img02 {
  background-image: url(../images/top02.jpg);
}
.full div.img02-2 {
  background-image: url(../images/top02-2.jpg);
}
.full div.img03 {
  background-image: url(../images/top03.jpg);
}
.full div.img03-2 {
  background-image: url(../images/top03-2.jpg);
}
.full div.img03-3 {
  background-image: url(../images/top03-3.jpg);
}
.full div.img04 {
  background-image: url(../images/top04.jpg);
}
.full div.img04-2 {
  background-image: url(../images/top04-2.jpg);
}
.full div.img04-3 {
  background-image: url(../images/top04-3.jpg);
}
.full div.img05 {
  background-image: url(../images/top05.jpg);
}
.full div.img05-2 {
  background-image: url(../images/top05-2.jpg);
}
.full div.img05-3 {
  background-image: url(../images/top05-3.jpg);
}

.full .slick-dots {
  bottom: 3%;
  z-index: +1;
}

/*キャッチコピーの調整20220322BAK
.full h2 {
  color:#ffffff;
  text-align:center;
  font-size:28px;
  line-height:1.8;
  letter-spacing:0.1em;
  padding:0 20px;
  margin-top:300px;
  text-shadow: 2px 5px 15px #000;
}*/


/*キャッチコピーの調整
.maincopy{
}
*/
.maincopy h2{
  display: flex;
  color:#ffffff;
  font-size:18px;
  font-weight:normal;
  line-height:1.6;
  letter-spacing:0.1em;
  text-align:left;
  /*justify-content: center;*/
  align-items: center;
  width:100%;
  height: 140vh;
  padding:0 60px;
  box-sizing: border-box;
  text-shadow: 1px 1px 2px #000;
}

/*小さめのPC画面用*/
@media screen and (max-width:1360px) { 
	.maincopy h2{
	  display: flex;
	  color:#ffffff;
	  font-size:16px;
	  font-weight:normal;
	  line-height:1.6;
	  letter-spacing:0.1em;
	  text-align:left;
	  justify-content: center;
	  align-items: center;
	  width:100%;
	  height: 100vh;
	  padding:0 40px;
	  box-sizing: border-box;
	  text-shadow: 2px 2px 3px #000;
	}
}
/*スマホタブレット用レイアウト*/
@media screen and (max-width:930px) { 
	.maincopy h2{
	  display: flex;
	  color:#ffffff;
	  font-size:4vw;
	  font-weight:normal;
	  line-height:1.6;
	  letter-spacing:0.1em;
	  text-align:left;
	  justify-content: center;
	  align-items: center;
	  width:100%;
	  /*height: 40vh;*/
	  padding:0 20px;
	  box-sizing: border-box;
	  text-shadow: 2px 2px 3px #000;
	}
}

/*スマホ用レイアウト*/
@media screen and (max-width:500px) { 
	.maincopy h2{
	  display: flex;
	  color:#ffffff;
	  font-size:4vw;
	  font-weight:normal;
	  line-height:1.6;
	  letter-spacing:0.1em;
	  text-align:left;
	  justify-content: center;
	  align-items: center;
	  width:100%;
	  /*height: 32vh;*/
	  padding:0 20px;
	  box-sizing: border-box;
	  text-shadow: 2px 2px 2px #000;
	}
}

/*タブレット・スマホ表示用*/
.full div {
  content: "";
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

/*スマホ用レイアウト*/
@media screen and (max-width:428px) { /*iPhone系縦画面すべて適用*/
	.sp_ios_block{
	display:block;
	}
}

/*スマホ用レイアウト*/
@media screen and (min-width:429px) { /*iPhone系縦画面すべて適用*/
	.sp_none{
	display:none;
	}
}