﻿@charset "utf-8";
/* CSS Document */


/*トップコンテンツ*/
.page-top{
	margin-top: 100px;
	width: 100%;
	height: 500px;
	position: relative;
}
.page-top-inner{
	width: 100%;
	height: 100%;
	background-position: center center;
	background-size: cover;
	border-bottom-left-radius: 300px;
	position: relative;
}
body.room .page-top-inner{
	background-image: url("../img/room-top.jpg");
}
body.food .page-top-inner{
	background-image: url("../img/food/dinner-item.jpg");
}
body.access .page-top-inner{
	background-image: url("../img/access-top.jpg");
}
body.howto .page-top-inner{
	background-image: url("../img/howto-top.jpg");
}
.page-top-inner::before{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	width: 100%;
	height: 100%;
	background: #005851;
	background: linear-gradient(0deg,rgba(0, 88, 81, 0.4) 0%, rgba(0, 88, 81, 0) 30%);
}
.page-top-title{
	position: absolute;
	bottom: 0;
	left: 50%;
	z-index: 2;
	transform: translateX(-50%);
	color: #ffffff;
	text-align: center;
}
.page-top-title p{
	font-size: 1.1rem;
    letter-spacing: 0.025em;
}
.page-top-title h1{
	margin-top: 25px;
	font-size: 7rem;
	line-height: 0.6em;
    letter-spacing: 0.025em;
}
.page-top-deco{
	position: absolute;
	bottom: 0;
	right: -20px;
	z-index: 3;
	max-width: 350px;
	transform: translateY(50%);
}


/*メインコンテンツ*/
.site-about{
	padding: 150px 0 120px;
	text-align: center;
}
.site-about h2{
	font-size: 2.2rem;
	font-weight: 300;
	letter-spacing: 0.025em;
}
.site-about p{
	margin-top: 30px;
	font-size: 1rem;
	font-weight: 300;
	line-height: 2em;
	letter-spacing: 0.025em;
}
.contents-info{
	width: 85%;
	margin: 0 auto;
	color: #005851;
	background-color: #ffffff;
	-webkit-border-radius: 50px;
	border-radius: 50px;
	position: relative;
}

/*ROOM*/
body.room .contents-info{
	margin-top: 100px;
}
body.room .contents-info + .contents-info{
	margin-top: 250px;
}
.room-info{
	padding: 200px 0 0;
}
.room-info-item{
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 485px;
}
.room-info-sentence{
	text-align: center;
}
.room-info-sentence h2{
	font-size: 3rem;
    font-weight: 500;
    letter-spacing: 0.025em;
}
.room-info-sentence p{
	margin-top: 10px;
    font-size: 1rem;
    font-weight: 300;
    line-height: 2em;
    letter-spacing: 0.025em;
}
.tent-info{
	width: 90%;
	margin: 70px auto 0;
}
.tent-img-wrap{
	width: 100%;
	height: 500px;
	position: relative;
}
.room-name{
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	color: #ffffff;
	width: 100%;
	text-align: center;
	font-size: 4.4rem;
	line-height: 0.7em;
	letter-spacing: 0.025em;
}
.tent-img{
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: calc(100% + (100vw * .135));
	height: 450px;
	-webkit-border-radius: 20px;
	border-radius: 20px;
	overflow: hidden;
}
.tent-img li{
	width: 100%;
	height: 100%;
	background-position: center center;
	background-size: cover;
}
.tent-subimg{
	position: absolute;
	bottom: 0;
	left: 50%;
	z-index: 2;
	transform: translateX(-50%);
	width: 75%;
}
.tent-subimg li{
	width: 100%;
	height: 100px;
	margin: 0 10px;
	background-position: center center;
	background-size: cover;
	-webkit-border-radius: 10px;
	border-radius: 10px;
	overflow: hidden;
	cursor: pointer;
}
.tent-info-sentence{
	margin-top: 30px;
}
.tent-info-sentence h3{
    font-size: 3rem;
    font-weight: 500;
    letter-spacing: 0.025em;
}
.tent-info-sentence p{
    margin-top: 10px;
    font-size: 1rem;
    font-weight: 300;
    line-height: 2em;
    letter-spacing: 0.025em;
	color: #000000;
}
.tent-info-sentence p span{
	color: #005851;
	text-decoration: underline;
}
a.room-reserve{
	margin-top: 40px;
    display: block;
    width: 100%;
    height: 60px;
    text-align: center;
    font-size: 1.1rem;
    font-weight: 300;
    letter-spacing: 0.13em;
    line-height: 54px;
    border: 3px solid #005851;
    color: #005851;
    background-color: #ffffff;
    transition: .5s ease;
}
a.room-reserve:hover{
	color: #ffffff;
    background-color: #005851;
}
.room-sub-info{
	margin-top: 100px;
	padding: 70px 0;
	background-color: #ebf2f1;
	-webkit-border-radius: 0 0 50px 50px;
	border-radius: 0 0 50px 50px;
}
.room-sub-info-table{
	width: 90%;
	max-width: 1100px;
	margin: 0 auto;
}
.room-sub-info-table h3{
	text-align: center;
	font-size: 1.3rem;
	letter-spacing: 0.025em;
}
.room-sub-info-table table{
	margin-top: 15px;
	width: 100%;
	border-collapse: collapse;
	border-top: 5px solid #005851;
}
.room-sub-info-table table th,
.room-sub-info-table table td{
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0.025em;
	padding: 2em;
	border-bottom: 1px solid #005851;
}
.room-sub-info-table table th{
	border-right: 1px solid #005851;
}


/*FOOD*/
body.food .contents-info{
	padding: 100px 0 80px;
}
body.food p.chaya-copy + .contents-info{
	margin-top: 20px;
	padding: 500px 40px 80px;
}
.food-info{
}
.food-info-sentence{
	text-align: center;
}
.food-info-sentence h2{
	font-size: 3rem;
    font-weight: 500;
    letter-spacing: 0.025em;
}
.food-info-sentence p{
	margin-top: 10px;
    font-size: 1rem;
    font-weight: 300;
    line-height: 2em;
    letter-spacing: 0.025em;
}
.food-item{
	width: 90%;
    max-width: 1100px;
    margin: 300px auto 0;
    display: flex;
    flex-wrap: wrap;
    position: relative;
    z-index: 2;
}
.food-item.num2{
	flex-flow: row-reverse;
} 
.food-item-info h3{
	font-size: 3rem;
    font-weight: 500;
    letter-spacing: 0.025em;
}
.food-item-info p{
	margin-top: 10px;
    font-size: 1.2rem;
    font-weight: 300;
    line-height: 2.5em;
    letter-spacing: 0.025em;
    color: #000000;
}
.food-item-img{
    position: absolute;
    top: 50%;
    right: -200px;
    transform: translateY(-50%);
    width: 500px;
}
.num2 .food-item-img{
	position: absolute;
    top: 50%;
	right: initial;
    left: -200px;
    transform: translateY(-50%);
    width: 500px;
}
.food-subitem{
	width: 90%;
    max-width: 1100px;
    margin: 300px auto 0;
    display: flex;
    flex-wrap: wrap;
	justify-content: space-between;
    position: relative;
    z-index: 2;
}
.food-subitem-img{
	width: calc(100% - 600px);
	background-position: center center;
	background-size: cover;
	background-image: url("../img/food/dinner-item.jpg");
	-webkit-border-radius: 20px;
	border-radius: 20px;
}
.food-subitem-img.num2{
	background-image: url("../img/food/breakfast-item.jpg");
	background-position: center left 30%;
}
.food-subitem-info{
	width: 550px;
}
.food-subitem-info h4{
	width: 100%;
	line-height: 60px;
	text-align: center;
	background-color: #ebf2f1;
	font-size: 1.3rem;
	letter-spacing: 0.025em;
}
.food-subitem-info p{
	margin-top: 25px;
    font-size: 1.1rem;
    font-weight: 300;
    line-height: 2.2em;
    letter-spacing: 0.025em;
    color: #000000;
}
p.chaya-copy{
	text-align: center;
	margin-top: 150px;
	font-size: 3rem;
	letter-spacing: 0.025em;
}
.chaya-img{
	position: absolute;
	top: 0;
	left: 50%;
	z-index: 1;
	transform: translateX(-50%);
	width: calc(100% + (100vw * .135));
    height: 450px;
	background-image: url("../img/food/chaya.jpg");
	background-position: center center;
	background-size: cover;
	-webkit-border-radius: 50px;
	border-radius: 50px;
}
.chaya-title{
	text-align: center;
}
.chaya-title h3{
	font-size: 3rem;
    font-weight: 500;
    letter-spacing: 0.025em;
}
.chaya-title p{
	margin-top: 10px;
    font-size: 1rem;
    font-weight: 300;
    line-height: 2em;
    letter-spacing: 0.025em;
    color: #000000;
}
.chaya-subimg{
	margin-top: 50px;
	width: 100%;
	height: 400px;
	position: relative;
}
.chaya-subimg li{
	position: absolute;
	background-position: center center;
	background-size: cover;
	-webkit-border-radius: 20px;
	border-radius: 20px;
}
.chaya-subimg li:nth-of-type(1){
	top: 0;
	left: 0;
	width: 35%;
	height: 80%;
	z-index: 0;
	background-image: url("../img/food/chaya-item1.jpg");
}
.chaya-subimg li:nth-of-type(2){
	bottom: 0;
	left: 25%;
	width: 30%;
	height: 70%;
	z-index: 1;
	background-image: url("../img/food/chaya-item2.jpg");
}
.chaya-subimg li:nth-of-type(3){
	top: 0;
	right: 17%;
	width: 25%;
	height: 50%;
	z-index: 3;
	background-image: url("../img/food/chaya-item3.jpg");
}
.chaya-subimg li:nth-of-type(4){
	bottom: 0;
	right: 0;
	width: 30%;
	height: 80%;
	z-index: 2;
	background-image: url("../img/food/chaya-item4.jpg");
}


/*アクセス*/
body.access .contents-info{
	padding: 0 0 140px;
	overflow: hidden;
}
.access-map{
	width: 100%;
}
.access-map iframe{
	width: 100%;
	height: 500px;
}
.access-info{
	width: 90%;
	max-width: 1100px;
	margin: 120px auto 0;
}
.access-info h3{
	text-align: center;
	font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: 0.025em;
	padding-bottom: 20px;
	border-bottom: 5px solid #005851;
}
.access-info > p{
	text-align: center;
	margin-top: 20px;
    font-size: 1rem;
    font-weight: 300;
    line-height: 2em;
    letter-spacing: 0.025em;
    color: #000000;
}
.access-info-illust{
	margin-top: 50px;
}
.access-info-chaya{
	margin-top: 50px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.access-info-chaya-img{
	width: calc(50% - 30px);
	background-image: url("../img/food/chaya.jpg");
	background-position: center center;
	background-size: cover;
}
.access-info-chaya-sentence{
	width: 50%;
	padding: 90px 0 60px;
}
.access-info-chaya-sentence h4{
	font-size: 3rem;
    font-weight: 500;
    letter-spacing: 0.025em;
}
.access-info-chaya-sentence p{
	margin-top: 10px;
    font-size: 1rem;
    font-weight: 300;
    line-height: 2em;
    letter-spacing: 0.025em;
}
.access-info-chaya-sentence span{
	display: block;
	font-size: 0.9em;
	text-indent: -1em;
	padding-left: 1em;
}



/*調整用*/
@media screen and (max-width:1100px) {
	/*トップコンテンツ*/
	.page-top-deco{
		display: none;
	}
}

/*スマートフォン*/
@media screen and (max-width:780px) {
	/*トップコンテンツ*/
	.page-top{
		margin-top: 60px;
		height: 250px;
	}
	.page-top-inner{
		border-bottom-left-radius: 80px;
	}
	.page-top-title{
		width: 100%;
	}
	.page-top-title p{
		font-size: 0.8rem;
	}
	.page-top-title h1{
		margin-top: 10px;
		font-size: 3.8rem;
	}
	
	/*メインコンテンツ*/
	.site-about{
		padding: 70px 0 60px;
	}
	.site-about h2{
		font-size: 1.3rem;
	}
	.site-about p{
		margin-top: 15px;
		font-size: 0.8rem;
	}
	.contents-info{
		width: 95%;
		-webkit-border-radius: 20px;
		border-radius: 20px;
	}
	
	/*room*/
	body.room .contents-info{
		margin-top: 50px;
	}
	body.room .contents-info + .contents-info{
		margin-top: 110px;
	}
	.room-info{
		padding: 90px 0 0;
	}
	.room-info-item{
		width: 220px;
	}
	.room-info-sentence h2{
		font-size: 1.3rem;
	}
	.room-info-sentence p{
		font-size: 0.8rem;
	}
	.tent-info{
		margin-top: 40px;
	}
	.tent-img-wrap{
		height: 250px;
	}
	.room-name{
		font-size: 1.5rem;
	}
	.tent-img{
		height: 220px;
		-webkit-border-radius: 10px;
		border-radius: 10px;
	}
	.tent-subimg{
		width: 90%;
	}
	.tent-subimg li{
		height: 60px;
		margin: 0 2.5px;
		-webkit-border-radius: 5px;
		border-radius: 5px;
	}
	.tent-info-sentence{
		margin-top: 20px;
	}
	.tent-info-sentence h3{
		font-size: 2rem;
	}
	.tent-info-sentence p{
		font-size: 0.8rem;
	}
	.tent-info-sentence p br{
		display: none;
	}
	a.room-reserve{
		margin-top: 20px;
	}
	.room-sub-info{
		margin-top: 60px;
		padding: 40px 0;
		-webkit-border-radius: 0 0 20px 20px;
		border-radius: 0 0 20px 20px;
	}
	.room-sub-info-table h3{
		font-size: 1rem;
	}
	.room-sub-info-table table th,
	.room-sub-info-table table td{
		display: block;
		width: 100%;
		font-size: 0.8rem;
		padding: 1em;
		text-align: center;
	}
	.room-sub-info-table table th{
		border-right: none;
		border-bottom: 1px dashed #005851;
	}
	
	/*FOOD*/
	body.food .contents-info{
		padding: 50px 0 40px;
	}
	body.food p.chaya-copy + .contents-info{
		padding: 200px 20px 20px;
	}
	.food-info-sentence h2{
		font-size: 1.3rem;
	}
	.food-info-sentence p{
		font-size: 0.8rem;
	}
	.food-item{
		margin-top: 60px;
	}
	.food-item.num2{
		flex-flow: wrap;
	}
	.food-item-info{
		order: 1;
        margin-top: 25px;
        text-align: center;
        width: 100%;
	}
	.food-item-img,
	.num2 .food-item-img{
		order: 0;
        position: relative;
        width: 75%;
		margin: 0 auto;
        right: initial;
        left: initial;
        transform: none;
	}
	.food-item-info h3{
		font-size: 2rem;
	}
	.food-item-info p{
		font-size: 0.8rem;
	}
	.food-subitem{
		margin-top: 40px;
	}
	.food-subitem-info h4{
		font-size: 1rem;
		line-height: 40px;
	}
	.food-subitem-info p{
		font-size: 0.8rem;
	}
	p.chaya-copy{
		margin-top: 80px;
		font-size: 1rem;
	}
	.chaya-img{
		height: 180px;
		-webkit-border-radius: 20px;
		border-radius: 20px;
	}
	.chaya-title h3{
		font-size: 2rem;
	}
	.chaya-title p{
		font-size: 0.8rem;
	}
	.chaya-subimg{
		margin-top: 30px;
		height: 150px;
	}
	.chaya-subimg li{
		-webkit-border-radius: 5px;
		border-radius: 5px;
	}
	
	/*アクセス*/
	body.access .contents-info{
		padding: 0 0 50px;
	}
	.access-map iframe{
		height: 220px;
	}
	.access-info{
		margin-top: 60px;
	}
	.access-info h3{
		font-size: 1.1rem;
		border-width: 3px;
	}
	.access-info-illust{
		margin-top: 30px;
	}
	.access-info > p{
		text-align: justify;
		font-size: 0.8rem;
	}
	.access-info-chaya{
		margin-top: 30px;
	}
	.access-info-chaya-img{
		width: 100%;
		height: 180px;
	}
	.access-info-chaya-sentence{
		margin-top: 20px;
		width: 100%;
		padding: 0px;
	}
	.access-info-chaya-sentence h4{
		font-size: 2rem;
	}
	.access-info-chaya-sentence p{
		font-size: 0.8rem;
	}
}