@charset "utf-8";
/* Copyright 2023 FSFIELD All Rights Reserved. */

/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

PC、タブレット、スマートフォン共通

_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

/* ------------------------------------------------------------

施工事例

------------------------------------------------------------ */

/* 一覧
---------------------------------------------- */
.gallery_inner{
	max-width: 1200px;
	margin: 0 auto;
}

.gallery_inner .nav_cat{margin-bottom: 60px;}

.gallery_inner .nav_cat ul{display: flex;}

.gallery_inner .nav_cat ul li{
	width: calc((100% - 120px)/4);
	margin-right: 40px;
}

.gallery_inner .nav_cat ul li:nth-of-type(4n){margin-right: 0;}

.gallery_inner .nav_cat ul li a{
	display: block;
	border: 1px solid #AEB7AE;
	color: #333;
	line-height: 1;
	padding: 16px 0;
	border-radius: 25px;
	text-align: center;
	font-size: 1.6rem;
	letter-spacing: 0;
	transition: background .3s, border.3s;
}

.gallery_inner .nav_cat ul li.active a,
.gallery_inner .nav_cat ul li a:hover{
	border-color: #88CEC9;
	background: #88CEC9;
}

.gallery_list{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-bottom: -60px;
}

.gallery_list .item{
	width: calc(50% - 30px);
	margin-bottom: 60px;
}

.gallery_list .item a{display: block;}

.gallery_list .item a .image{
	position: relative;
	overflow: hidden;
	padding-top: 61.754%;
}

.gallery_list .item a .image img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	position: absolute;
	top: 0;
	left: 0;
	transition: transform .3s;
}

.gallery_list .item a:hover .image img{transform: scale(1.05);}

.gallery_list .item a .image .noimage{
	background: #EDEFED;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	padding: 15px;
}

.gallery_list .item a .image .noimage img{
	max-width: 300px;
	height: auto;
	position: unset;
}

.gallery_list .item a .ttl{
	text-align: center;
	margin-top: 35px;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: 1.4;
	color: #333;
}

.gallery_list .item .tags{
	background: #EDEFED;
	padding: 0 12px 0 0;
	margin-top: 30px;
}

.gallery_list .item .tags p{display: inline-block;}

.gallery_list .item .tags p a{
	display: inline-block;
	padding: 12px 8px;
	color: #AC7F71;
	font-size: 1.6rem;
	letter-spacing: 0.1em;
}

/* 詳細
---------------------------------------------- */
.article_single .ttl{text-align: center;}

.article_single .tags{
	margin-top: 55px;
	background: #EDEFED;
	padding: 0 5px;
}

.article_single .tags{
	padding: 0;
}

.article_single .tags p{display: inline-block;}

.article_single .tags p a{
	color: #AC7F71;
	display: inline-block;
	padding: 9px 6px;
	font-size: 1.4rem;
	letter-spacing: 0.1em;
}

/* ラインナップ
---------------------------------------------- */
.lineup{
	display: flex;
	background: #FFF;
	padding-bottom: 100px;
}

.lineup .inner{
	position: relative;
	width: 33.333%;
	padding-top: 33.333%;
}

.lineup .inner a{
	display: block;
	text-align: center;
	height: 100%;
}

.lineup .inner a .image{
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	object-fit: cover;
	overflow: hidden;
}

.lineup .inner a .image img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.005);
	transition: transform .3s;
}

.lineup .inner a:hover .image img{transform: scale(1.05);}

.lineup .inner a .image img.sp{display: none;}

.lineup .inner a p{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate3d(-50%, -50%, 0);
	color: #FFF;
	font-weight: 700;
	letter-spacing: 0.2em;
	line-height: 1.6;
}

.lineup .inner a p span{
    font-size: 2.8rem;
    font-weight: 700;
	letter-spacing: 0.2em;
	display: block;
}



.tagtitle {
	background: #AEB7AE;
	color: #fff;
	padding:10px 20px;
	font-size: 19px;
}

.buttoms{
	display: flex;
	margin-top: 55px;
	justify-content: center;
}

.buttoms .btn_reservation a{
	display: flex;
    align-items: center;
    background: #EBDE67 url(../img/ico_arrow02.png) no-repeat right 25px center;
    background-size: 10px;
    color: #333;
    border-radius: 50px;
    width: 500px;
    height: 70px;
    padding: 0 45px;
    transition: background .3s;
    margin: 0 10px;
}

.buttoms .btn_catalog a{
	display: flex;
	align-items: center;
	background: #EBDE67 url("../img/ico_arrow02.png") no-repeat right 25px center;
	background-size: 10px;
	color: #333;
	border-radius: 50px;
	width: 500px;
    height: 70px;
	padding: 0 45px;
	transition: background .3s;
	margin: 0 10px;
}

.buttoms .btn_reservation a:hover,.buttoms .btn_catalog a:hover{
	background-color: #88CEC9;
}

.buttoms .btn_reservation a img{
	width: 24px;
	height: auto;
	display: inline-block;
	margin-right: 14px;
}

.buttoms .btn_catalog a img{
	width: 24px;
	height: auto;
	display: inline-block;
	margin-right: 14px;
}

@media only screen and (max-width:1024px){ /* 表示領域が1024px以下の場合に適用するスタイル */

	/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	タブレット

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

	/* ------------------------------------------------------------

	施工事例

	------------------------------------------------------------ */
	
	/* 一覧
	---------------------------------------------- */
	.gallery_inner .nav_cat ul li{
		width: calc((100% - 60px)/4);
		margin-right: 20px;
	}
	
	.gallery_inner .nav_cat ul li a{font-size: 1.5rem;}
	
	.gallery_list{margin-bottom: -40px;}
	
	.gallery_list .item{
		width: calc(50% - 15px);
		margin-bottom: 40px;
	}
	
	/* 詳細
	---------------------------------------------- */
	
	
}/*--@media--*/


@media only screen and (max-width:767px){ /* 表示領域が767px以下の場合に適用するスタイル */
	/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	スマートフォン（iPhone,Android)

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

	/* ------------------------------------------------------------

	施工事例

	------------------------------------------------------------ */
	
	/* 一覧
	---------------------------------------------- */
	.gallery_inner .nav_cat{margin-bottom: 35px;}

	.gallery_inner .nav_cat ul{
		justify-content: space-between;
		flex-wrap: wrap;
	}

	.gallery_inner .nav_cat ul li{
		width: calc(50% - 7.5px);
		margin: 0 0 15px;
	}

	.gallery_inner .nav_cat ul li a{
		padding: 12px 0;
		border-radius: 20px;
		font-size: 1.3rem;
	}
	
	.gallery_list{margin-bottom: -30px;}

	.gallery_list .item{
		width: calc(50% - 7.5px);
		margin-bottom: 30px;
	}

	.gallery_list .item a .ttl{
		margin-top: 10px;
		font-size: 1.1rem;
	}

	.gallery_list .item .tags{
		background: #EDEFED;
		padding: 0 4px;
		margin-top: 12px;
	}

	.gallery_list .item .tags p a{
		padding: 4px;
		font-size: 1rem;
	}
	
	.gallery_list .item .tags {
		margin-top: 0;
		padding: 0;
	}

	.tagtitle {
		padding: 5px 0px;
    	width: 100%;
    	text-align: center;
    	font-size: 8px;
	}

	.buttoms{
		flex-flow: column;
	}

	.buttoms .btn_catalog a,.buttoms .btn_reservation a{
		width: 350px;
		margin: 10px auto;
	}

	/* 詳細
	---------------------------------------------- */
	.article_single .ttl{text-align: left;}
	
	.article_single .tags{margin-top: 35px;}

	.article_single .tags p a{
		font-size: 1.1rem;
		letter-spacing: 0;
	}
	
	/* ラインナップ
	---------------------------------------------- */
	.lineup{
		display: block;
		padding-bottom: 50px;
	}

	.lineup .inner{
		position: relative;
		width: 100%;
		padding-top: 37.333%;
	}

	.lineup .inner a .image img.pc{display: none;}
	.lineup .inner a .image img.sp{display: block;}

	.lineup .inner a p{font-size: 1.1rem;}

	.lineup .inner a p span{font-size: 1.8rem;}

}/*--@media--*/

