@charset "UTF-8";
/* CSS Document */

/* ----------------------------------------------------------------------- 
  text
----------------------------------------------------------------------- */
/* align
--------------------------------------------------*/
.tL {
	text-align: left !important;
}
.tC {
	text-align: center !important;
}
.tR {
	text-align: right !important;
}
.vT {
	vertical-align: top !important;
}

/* font-weight
--------------------------------------------------*/
.bold {
	font-weight: bold;
}

/* title
--------------------------------------------------*/
#ttlArea {
	padding: 55px 0 85px;
	margin-bottom: 55px;
	background-repeat: no-repeat;
	background-position: top center;
	background-size: cover;
}
#ttlArea .titleIn {
	display: table;
	width: 1300px;
	margin: auto;
}
#ttlArea .titleIn > * {
	display: table-cell;
	vertical-align: middle;
}
#ttlArea .ttlLogo {
	width: 184px;
}
#ttlArea .ttlLogo a {
	display: block;
	background: url(../img/common/cmn_logo02.jpg) no-repeat top left;
	background-size: 100%;
}
#ttlArea .ttlLogo a:hover img {
	opacity: 0;
}
#ttlArea .ttlStyle01 {
	color: #fff;
	font-size: 70px;
	line-height: 1.2;
	padding-left: 45px;
}
#ttlArea .ttlStyle01 span {
	display: block;
	font-size: 40px;
}
.ttlStyle02 {
	text-align: center;
	font-size: 36px;
	line-height: 1.6;
	margin-bottom: 30px;
}
.ttlStyle02 small {
	display: block;
	font-size: 15px;
	letter-spacing: 0.4em;
}
.ttlStyle02 span {
	display: block;
	font-size: 54px;
	margin-top: 7px;
}
.ttlStyle03 {
	font-size: 40px;
	margin-bottom: 10px;
}
.ttlStyle03 + .ttlBottom {
	margin-bottom: 23px;
}
.ttlStyle04 {
	font-size: 40px;
	line-height: 1.1;
	padding-bottom: 13px;
	margin-bottom: 40px;
	border-bottom: solid 3px #7a3f35;
}

@media screen and (max-width:768px) {
	#ttlArea {
		padding: 30px 0;
		margin-bottom: 40px;
	}
	#ttlArea .titleIn {
		width: 92%;
	}
	#ttlArea .ttlLogo {
		width: 27%;
	}
	#ttlArea .ttlLogo a {
		max-width: 150px;
	}
	#ttlArea .ttlStyle01 {
		width: 73%;
		font-size: 24px;
		padding-left: 5%;
	}
	#ttlArea .ttlStyle01 span {
		font-size: 18px;
		margin-bottom: 5px;
	}
	.ttlStyle02 {
		font-size: 24px;
		margin-bottom: 20px;
	}
	.ttlStyle02 small {
		font-size: 10px;
		margin-bottom: 5px;
	}
	.ttlStyle02 span {
		font-size: 36px;
		margin-top: 0;
	}
	.ttlStyle03 {
		font-size: 20px;
		margin-bottom: 5px;
	}
	.ttlStyle03 + .ttlBottom {
		margin-bottom: 20px;
	}
	.ttlStyle04 {
		font-size: 20px;
		margin-bottom: 20px;
		border-bottom-width: 1px;
	}
}

/* English */
.en .ttlStyle02 {
	font-size: 29px;
}

@media screen and (max-width:768px) {
	.en .ttlStyle02 {
		font-size: 24px;
	}
}

/* ----------------------------------------------------------------------- 
  other
----------------------------------------------------------------------- */
.fL {
	float: left;
}
.fR {
	float: right;
}
.cB {
	clear: both;
}
.spOnly {
	display: none;
}

@media screen and (max-width:768px) {
	.pcOnly {
		display: none !important;
	}
	.spOnly {
		display: block;
	}
}

/* box
--------------------------------------------------*/
.boxStyle01:after,
.boxStyle02:after {
	content: "";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}
.boxStyle01 .text {
	width: 730px;
	float: left;
}
.boxStyle01 .image {
	float: right;
}
.boxStyle02 .image {
	width: 454px;
	float: left;
}
.boxStyle02 .text {
	width: 450px;
	float: right;
}
.boxStyle02 .text .boxTitle {
	font-size: 40px;
	line-height: 1.1;
	margin: -0.2em 0 23px;
}

@media screen and (max-width:768px) {
	.boxStyle01 .text {
		width: auto;
		float: none;
	}
	.boxStyle01 .image {
		text-align: center;
		float: none;
		margin-top: 20px;
	}
	.boxStyle02 .image {
		width: auto !important;
		float: none;
		text-align: center;
	}
	.boxStyle02 .text {
		width: auto !important;
		float: none;
		margin-top: 20px;
	}
	.boxStyle02 .text .boxTitle {
		font-size: 20px;
		margin: 0 0 10px;
	}
}

/* English */
.en .boxStyle02 .text .boxTitle {
	font-size: 36px;
}

@media screen and (max-width:768px) {
	.en .boxStyle02 .text .boxTitle {
		font-size: 20px;
	}
}

/* button
--------------------------------------------------*/
[class^="btnStyle"],
.btnPageTop {
	display: block;
	line-height: 1.0;
}
[class^="btnStyle"]:hover,
.btnPageTop:hover {
	text-decoration: none;
}
.btnPageTop {
	width: 175px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	text-align: center;
	color: #7a3f35 !important;
	font-size: 18px;
	padding: 11px 0 7px;
	margin: 40px 0 0 auto;
	border: solid 2px #7a3f35;
	background: #fff;
}
.btnPageTop:hover {
	background: #cab2ae;
}
.btnStyle01 {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	text-align: center;
	color: #7a3f35 !important;
	font-size: 26px;
	padding: 25px 0 21px;
	border: solid 1px #7a3f35;
	background: #eeebe6;
}
.btnStyle01:hover {
	background: #cab2ae;
}
.btnStyle02 {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	text-align: center;
	color: #fff;
	font-size: 26px;
	padding: 26px 0 22px;
	background: #7a3f35;
}
.btnStyle02:hover {
	color: #fff;
	background: #cab2ae;
}
.btnStyle03 {
	text-align: center;
	color: #7a3f35 !important;
	font-size: 28px;
	padding: 14px 0 20px;
	background: #e1dcd1;
}
.btnStyle03:hover {
	background: #cab2ae;
}
.btnStyle04 {
	text-align: center;
	color: #7a3f35 !important;
	font-size: 22px;
	padding: 8px 0 12px;
	background: #e1dcd1;
}
.btnStyle04:hover {
	background: #cab2ae;
}
.btnStyle05 {
	width: 290px;
	text-align: center;
	color: #7a3f35 !important;
	font-size: 25px;
	padding: 8px 0 14px;
	margin: auto;
	background: #e1dcd1;
}
.btnStyle05:hover {
	background: #cab2ae;
}
.btnStyle06 {
	width: 206px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	color: #7a3f35 !important;
	padding: 8px 15px 7px;
	border: solid 3px #7a3f35;
	background: #e1dcd1;
}
.btnStyle06:hover {
	background: #cab2ae;
}

@media screen and (max-width:768px) {
	.btnPageTop {
		width: 125px;
		font-size: 12px;
		padding: 8px 0 6px;
		border-width: 1px;
	}
	.btnStyle01 {
		font-size: 16px;
		padding: 17px 0 15px;
	}
	.btnStyle02 {
		font-size: 16px;
		padding: 17px 0 15px;
	}
	.btnStyle03 {
		font-size: 18px;
		padding: 16px 0 14px;
	}
	.btnStyle04 {
		font-size: 18px;
		padding: 16px 0 14px;
	}
	.btnStyle05 {
		max-width: 70%;
		font-size: 18px;
		padding: 16px 0 14px;
	}
	.btnStyle06 {
		width: 150px;
		font-size: 12px;
		padding: 8px 10px 6px;
		margin: auto;
		border-width: 1px;
	}
}

/* English */
.en .btnStyle03 {
	padding: 20px 0 14px;
}
.en .btnStyle04 {
	padding: 12px 0 8px;
}
.en .btnStyle05 {
	padding: 12px 0 10px;
}

@media screen and (max-width:768px) {
	.en .btnStyle03 ,
	.en .btnStyle04 ,
	.en .btnStyle05 {
		padding: 16px 0 14px;
	}
}

/* image list
--------------------------------------------------*/
.imageList01 li {
	width: 458px;
	float: left;
}
.imageList01 li:nth-child(even) {
	float: right;
}
.imageList01 li p {
	margin-top: 20px;
}
.imageList02 li {
	width: 162px;
	text-align: center;
	float: left;
}
.imageList02 li + li {
	margin-left: 42px;
}
.imageList02 li p {
	font-size: 23px;
	margin-top: 7px;
}

@media screen and (max-width:768px) {
	.imageList01 li:nth-child(1n+0) {
		width: auto;
		text-align: center;
		float: none;
	}
	.imageList01 li:nth-child(n+2) {
		margin-top: 25px;
	}
	.imageList01 li p {
		margin-top: 5px;
	}
	.imageList02 li {
		width: 32%;
		margin-right: 2%;
	}
	.imageList02 li:nth-child(3n) {
		margin-right: 0;
	}
	.imageList02 li:nth-child(n+4) {
		margin-top: 4%;
	}
	.imageList02 li + li {
		margin-left: 0;
	}
	.imageList02 li p {
		font-size: 13px;
		margin-top: 5px;
	}
}

/* English */
.en .imageList02 li p {
	font-size: 19px;
	line-height: 1.0;
}
@media screen and (max-width:768px) {
	.en .imageList02 li p {
		font-size: 13px;
	}
}

/* hotel information
--------------------------------------------------*/
.hotelInfo > * + * {
	margin-top: 25px;
}
.hotelInfo .hotelDetail {
	font-size: 16px;
	padding: 20px 33px 25px;
	background: #e1dcd1;
}
.hotelInfo .hotelDetail .hotelName {
	font-size: 24px;
	line-height: 1.0;
	margin-bottom: 10px;
}
.hotelInfo .hotelDetail .hotelName span {
	font-size: 33px;
	display: inline-block;
	vertical-align: text-top;
	margin: -0.1em 0 0 0.5em;
}
.hotelInfo .hotelDetail a:hover {
	color: inherit;
	text-decoration: underline;
}
.hotelInfo .listInfoBtn li {
	width: 474px;
	float: left;
}
.hotelInfo .listInfoBtn li:nth-child(even) {
	float: right;
}

@media screen and (max-width:768px) {
	.hotelInfo > * + * {
		margin-top: 20px;
	}
	.hotelInfo .hotelDetail {
		font-size: 14px;
		padding: 20px 7%;
	}
	.hotelInfo .hotelDetail .hotelName {
		font-size: 16px;
		margin-bottom: 15px;
	}
	.hotelInfo .hotelDetail .hotelName span {
		font-size: 24px;
		margin-top: -0.17em;
	}
	.hotelInfo .listInfoBtn li:nth-child(1n+0) {
		width: 49%;
	}
}
