*{
	padding: 0;
	margin: 0;
	border: 0;
	box-sizing: border-box;
	font-size: 100%;
	list-style: none;
	font-weight: normal;
}
html{
	font-size: 62.5%;
	-webkit-font-smoothing: antialiased;
}
body{
	font-size: 2rem;
	font-family: "游明朝","Yu Mincho",YuMincho,"Hiragino Mincho Pro",serif;
	line-height: 2;
	line-break: strict;
	overflow-wrap: break-word;
	word-wrap: break-word;
}
amp-img{width:100%;height:auto;}
a{text-decoration:none;}



header{
	padding-top: 30px;
	position: relative;
}
header p{
	position: absolute;
	z-index: 10;
	width: 70%;
	left: 50%;
	transform: translateX(-50%);
	bottom: 10%;
}



main{
	padding-bottom: 120px;
}
main > *{
	width: 100%;
	max-width: 1200px;
	margin: auto;
}



.menu{
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin: 40px auto;
}
.menu button{
	display: block;
	width: 25%;
	background: transparent;
	margin: 0 1%;
	transition: 0.3s;
}
.menu button:hover{
	cursor: pointer;
	opacity: 0.8;
}



.hdr{
	font-size: 240%;
	letter-spacing: 0.2em;
	text-align: center;
	color: #878788;
	margin-top: 50px;
}



#concept{
	max-width: 100%;
	text-align: center;
}
#concept > section{
	background: url(./images/bg.jpg) no-repeat center;
	background-size: cover;
	padding: 60px 4%;
}
#concept h3{
	font-size:120%;
	color: #888;
}
#concept h4{
	margin-bottom: 40px;
	font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans",Meiryo,sans-serif;
	font-size: 120%;
	letter-spacing: 0.2em;
	color: #888;
}
#concept section section{
	width: 100%;
	max-width: 700px;
	padding: 30px 30px 60px;
	margin: 30px auto 0;
	background: rgb(255,255,255);
	background: linear-gradient(0deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.8) 30%);
}
#concept section section p:last-child{
	margin-top: 40px;
}



#anshin{
	max-width: 100%;
}
#anshin div{
	max-width: 100%;
	background: url(./images/anshin-bg.jpg) no-repeat top center;
	background-size: 100% auto;
}
#anshin ul{
	display: flex;
	justify-content: center;
}
#anshin li{
	display: flex;
	width: 27%;
	margin: 19% 1.5% 0;
}
#anshin section{
	max-width: 1200px;
	margin: 40px auto 0;
	display: flex;
	justify-content: space-between;
}
#anshin section > *{
	width: 47%;
}



#gallery ul{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
#gallery li{
	width: calc((100% - 20px)/2);
	margin-bottom: 20px;
}
#gallery li:nth-child(1),
#gallery li:nth-child(2),
#gallery li:nth-child(3),
#gallery li:nth-child(8){
	width: 100%;
}


#gallery.second{
	margin-top: 80px;
}

#gallery.second li{
	width: calc((100% - 20px)/2);
	margin-bottom: 20px;
}

#gallery.second li:nth-child(1),
#gallery.second li:nth-child(6)
{
	width: 100%;
}

.btn{
	max-width: 750px;
	box-shadow: 5px 5px 20px rgba(0,0,0,0.1);
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 20px 50px;
	margin-top: 50px;
}
.btn h2{
	width: 20%;
}
.btn section{
	width: 75%;
	text-align: center;
}
.btn h3{
	font-size: 150%;
	letter-spacing: 0.2em;
}
.btn div{
	display: flex;
	justify-content: space-between;
}
.btn a{
	display: flex;
	align-items: center;
	justify-content: center;
	background: #eee;
	width: 32%;
	height: 120px;
	color: #fff;
	transition: 0.3s;
}
.btn a:nth-child(1){background:#642c2f;}
.btn a:nth-child(2){background:#4f564f;}
.btn a:nth-child(3){background:#1e264b;}
.btn a:hover{opacity:0.8;}



#setsubi div{
	display: flex;
	align-items: center;
	margin-top: 30px;
}
#setsubi figure{
	width: 45%;
}
#setsubi section{
	width: 55%;
	padding: 0 8%;
}
#setsubi h3{
	font-size: 160%;
	text-align: center;
	letter-spacing: 0.2em;
	margin-bottom: 40px;
	color: #888888;
}



#saiji h3{
	margin-bottom: 30px;
}
#saiji section section{
	display: flex;
	align-items: center;
	padding-right: 18%;
	margin-bottom: 60px;
}
#saiji h4{
	white-space: nowrap;
	font-size: 160%;
	line-height: 1.4;
	padding: 0 1em;
	letter-spacing: 0.2em;
	color: #888888;
}
#saiji p{
	line-height: 1.6;
}



#access ul{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#access li{
	width: calc((100% - 80px)/3);
	margin-top: 40px;
}
#access p{
	font-size: 60%;
	padding: 20px;
}


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

body{font-size:1.6rem;}



header{
	padding-top: 20px;
}
header p{
	width: 80%;
	bottom: 5%;
}



main{
	padding-bottom: 40px;
}



.menu{
	justify-content: space-between;
	margin: 30px auto;
	padding: 0 4%;
}
.menu button{
	width: 32.5%;
	margin: 0;
}



.hdr{
	font-size: 150%;
	margin-top: 30px;
}



#concept > section{
	padding: 30px 4%;
}
#concept h3{
	font-size: 100%;
}
#concept h4{
	margin-bottom: 20px;
	font-size: 110%;
}
#concept section section{
	padding: 40px 10px;
	margin: 20px auto 0;
}
#concept section section p:last-child{
	margin-top: 20px;
}



#anshin ul{
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0 4%;
	padding-top: 19%;
}
#anshin li{
	width: 48%;
	margin: 0;
	border-radius: 50%;
	box-shadow: 0 0 20px rgba(0,0,0,0.1);
}
#anshin li:last-child{
	margin-left: 26%;
}
#anshin section{
	margin: 30px 0 0;
	display: block;
}
#anshin section > *{
	width: 100%;
}
#anshin h3{
	margin-bottom: 20px;
	padding-left: 4%;
}
#anshin p{
	width: 92%;
	margin: auto;
}



#gallery li{
	width: calc((100% - 2px)/2);
	margin-bottom: 2px;
}

#gallery.second li{
	width: calc((100% - 2px)/2);
	margin-bottom: 2px;
}

.btn{
	width: 92%;
	padding: 10px;
	margin-top: 40px;
}
.btn section{
	width: 78%;
}
.btn h3{
	font-size: 90%;
}
.btn a{
	width: 33%;
	height: auto;
	font-size: 80%;
	padding: 15px 0;
}



#setsubi div{
	display: block;
	margin: 0;
	margin-bottom: 40px;
}
#setsubi figure{
	width: 100%;
}
#setsubi section{
	width: 92%;
	padding: 2em;
	margin: -30% auto 0;
	background: rgba(255,255,255,0.9);
	position: relative;
	z-index: 5;
	box-shadow: 0 0 20px rgba(0,0,0,0.1);
}
#setsubi h3{
	font-size: 140%;
	margin-bottom: 10px;
}



#saiji h3{
	margin-bottom: 30px;
	width: 98%;
}
#saiji section section{
	display: block;
	padding: 0 4%;
	margin-bottom: 40px;
}
#saiji h4{
	padding: 0;
	margin-bottom: 20px;
	font-size: 150%;
	letter-spacing: 0.2em;
}
#saiji p{
	padding-left: 4%;
}



#access ul{
	margin-top: 30px;
}
#access li{
	width: calc((100% - 8px)/3);
	margin-top: 4px;
}
#access p{
	padding: 20px 4% 0;
}




}/* SP */


@media only screen and (min-width: 768px){
.sp{display:none;}
}
@media only screen and (max-width: 767px){
.pc{display:none;}
}