@charset "UTF-8";

/* ------------------------------------------------
                    index
--------------------------------------------------- */

/*---------- MV ----------*/
.sec-mv {
	width: 100%;
	position: relative;
}
.sec-mv::after {
	content: '';
	width: 100%;
	height: 10vw;
	background: url("../img/bg_mv_top.png") 0 0 no-repeat;
	background-size: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

.mv-deco-01 {
	width: 12%;
	max-width: 144px;
	position: absolute;
	top: 40px;
	right: 45px;
	z-index: 3;
}
.mv-deco-02 {
	width: 10%;
	max-width: 108px;
	position: absolute;
	bottom: 45px;
	left: 70px;
	z-index: 3;
}

@media (max-width: 768px) {
	.mv-deco-01 {
		width: 18%;
		max-width: 144px;
		position: absolute;
		top: 2.5vw;
		right: 4%;
	}
	.mv-deco-02 {
		width: 18%;
		max-width: 108px;
		position: absolute;
		bottom: 4vw;
		left: 3%;
	}
}


/*---------- About ----------*/
.sec-about {
	width: 100%;
	padding-bottom: 150px;
	position: relative;
	text-align: center;
}
@media (max-width: 768px) {
	.sec-about {
		padding-bottom: 18vw;
	}
}


/*---------- Dining ----------*/
.sec-dining {
	width: 100%;
	padding-bottom: 150px;
	position: relative;
	text-align: center;
}
@media (max-width: 768px) {
	.sec-dining {
		padding-bottom: 18vw;
	}
    
}


/*---------- Room ----------*/
.sec-room {
	width: 100%;
	padding-bottom: 150px;
	position: relative;
	text-align: center;
}

.sec-room .sec-txt.is-en {
	max-width: 650px;
	margin: 0 auto;
}
@media (max-width: 768px) {
	.sec-room {
		padding-bottom: 18vw;
	}
    
}


/*---------- Reservasion ----------*/
.sec-reservasion {
	width: 100%;
	padding-bottom: 150px;
	position: relative;
	text-align: center;
}

.reservasion-txt {
	margin-bottom: 55px;
	line-height: 2.2;
}
.sec-reservasion .btn-modal-open {
	margin-bottom: 90px;
}

.reservasion-deco {
	width: 36px;
	position: absolute;
	bottom: 200px;
	left: 26%;
}

/* modal */
.terms-modal-wrap {
	width: 100%;
	padding: 50px;
	border: 1px solid #c8c8c8;
	text-align: center;
    font-size: 1.4rem;
}
.terms-ttl {
	margin-bottom: 30px;
	text-align: center;
}
.terms-txt {
	text-align: left;
}

.cancel-table {
	width: 100%;
	margin: 20px auto;
	border-collapse: collapse;
}
.cancel-table th,
.cancel-table td {
	width: 50%;
	padding: 5px;
	border: 1px solid #c8c8c8;
}
.cancel-table th {
	background: #efefef;
}

.txt-modal-close {
	margin-top: 50px;
	display: inline-block;
	cursor: pointer;
}

@media (max-width: 768px) {
	.sec-reservasion {
		padding-bottom: 20vw;
	}

	.reservasion-txt {
		margin-bottom: 8vw;
		font-size: 3.8vw;
		line-height: 2.0;
	}
	.sec-reservasion .btn-modal-open {
		margin-bottom: 10vw;
	}

	.reservasion-deco {
		width: 9vw;
		position: absolute;
		bottom: 84vw;
		left: 13%;
	}

	/* modal */
	.modaal-content-container {
		padding: 3vw;
	}
	.terms-modal-wrap {
		width: 100%;
		padding: 5vw;
		font-size: 3.2vw;
	}
	.terms-ttl {
		margin-bottom: 3vw;
	}

	.cancel-table {
		width: 100%;
		margin: 4vw auto;
	}
	.cancel-table th,
	.cancel-table td {
		width: 50%;
		padding: 1vw;
	}

	.txt-modal-close {
		margin-top: 10vw;
	}
    
}


/*---------- Access ----------*/
.sec-access {
	width: 100%;
	padding-bottom: 150px;
	position: relative;
	text-align: center;
}

.access-map-wrap {
	width: 100%;
	height: 40vw;
	position: relative;
}
.access-map-wrap iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

.access-txt {
	margin-bottom: 75px;
}

.access-box {
	width: 100%;
	max-width: 600px;
	margin: 0 auto;
	padding: 25px 40px;
	border: 1px solid #bbbbbb;
	text-align: left;
}
.access-box + .access-box {
	margin-top: 50px;
}

.access-box-ttl {
	margin-bottom: 10px;
	line-height: 1;
	font-weight: 300;
}
.access-box-txt + .access-box-ttl {
	margin-top: 25px;
}
.access-box-txt {
	font-weight: 300;
	line-height: 1.7;
}
@media (max-width: 768px) {
	.sec-access {
		padding-bottom: 12vw;
	}

	.access-map-wrap {
		width: 100%;
		height: 86vw;
	}

	.access-txt {
		margin-bottom: 10vw;
	}

	.access-box {
		width: 100%;
		max-width: 600px;
		margin: 0 auto;
		padding: 6vw 5vw;
	}
	.access-box + .access-box {
		margin-top: 8vw;
	}

	.access-box-ttl {
		margin-bottom: 2vw;
	}
	.access-box-txt + .access-box-ttl {
		margin-top: 6vw;
	}
    
}


/*---------- Order ----------*/
.sec-order {
	width: 100%;
	padding: 100px 0 150px;
	background: url("../img/bg_gray_02.png") repeat;
	background-size: 285px;
	position: relative;
	text-align: center;
}
.sec-order img {
	max-width: 750px;
	margin: 0 auto;
}
.order-txt {
	margin-bottom: 75px;
	line-height: 2.2;
}

.order-deco {
	width: 36px;
	position: absolute;
	bottom: 170px;
	right: 26%;
}

@media (max-width: 768px) {
	.sec-order {
		width: 100%;
		padding: 12vw 0 18vw;
	}
	.order-txt {
		margin-bottom: 12vw;
		text-align: left;
		line-height: 2.2;
	}
	.order-txt.is-en {
		text-align: center;
	}

	.order-deco {
		width: 9vw;
		position: absolute;
		bottom: auto;
		top: 78vw;
		right: 10%;
	}
    
}