@charset "utf-8";

/* ==========================================
module [add]
========================================== */

/* mod-fee-example
------------------------------------------------------------------- */
.mod-fee-example {
	width: 100%;
}
.mod-fee-example-label {
	margin: 0;
	margin-bottom: 8px;
	padding-left: 40px;
	font-size: 16px;
	color: #333;
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 32px;
	background-image: url(../img/icon_bed.svg);
}
.mod-fee-example-item {
	display: flex;
	align-items: center;
	padding: 22px 0 23px;
	border-top: 1px solid #d9d9d9;
}
.mod-fee-example-item:last-child {
	border-bottom: 1px solid #d9d9d9;
}
.mod-fee-example-item-txt {
	display: flex;
	align-items: center;
}
.mod-fee-example-item-title {
	/* width: 165px; */
	font-size: 14px;
	color: #333;
	padding-right: 12px;
	line-height: 1.5;
}
.mod-fee-example-item-unit {
	flex-shrink: 0;
	font-size: 16px;
	font-weight: 500;
	color: #1995B5;
	white-space: nowrap;
}
.mod-fee-example-item-value {
	flex-shrink: 0;
	color: #1995B5;
	font-size: 24px;
	font-weight: 500;
	line-height: 1;
	margin-left: 4px;
	display: flex;
	align-items: center;
}
.mod-fee-example-item-value .num {
	margin: -5px 3px 0 0;
	font-size: 40px;
	font-weight: 500;
}
.mod-fee-example-item .mod-reserve-btn {
	flex-shrink: 0;
	margin-left: auto;
}

@media screen and (min-width : 641px) {}
@media screen and (max-width : 640px) {
	.mod-fee-example-label {
		padding-left: 32px;
		font-size: 13px;
		background-size: 24px;
	}
	.mod-fee-example-item-txt {
		flex-wrap: wrap;
		padding-right: 12px;
	}
	.mod-fee-example-item-title {
		padding: 0;
		margin-bottom: 14px;
		width: 100%;
		font-size: 12px;
	}
	.mod-fee-example-item-unit {
		font-size: 12px;
	}
	.mod-fee-example-item-value {
		font-size: 20px;
	}
	.mod-fee-example-item-value .num {
		font-size: 32px;
		margin: -10px 0 0;
	}
	.post-content .in-house-info .mod-reserve-btn {
		width: auto;
	}
	.post-content .in-house-info .mod-reserve-btn > a {
		width: 145px;
	}
}

/* .mod-reserve-btn
------------------------------------------------------------------- */
.mod-reserve-btn {
	width: 242px;
	margin: 0;
}
.mod-reserve-btn > a {
	display: block;
	text-align: center;
	padding: 11px 0 13px;
	background-color: #1995B5;
	color: #fff;
	border-radius: 4px;
	font-size: 16px;
}
.mod-reserve-btn > a > span {
	padding: 0;
}

@media screen and (min-width : 641px) {
	.mod-reserve-btn > a:hover {
		text-decoration: none;
		opacity: 0.7;
	}
}
@media screen and (max-width : 640px) {}

/* .mod-link-btn
------------------------------------------------------------------- */
.mod-link-btn {
	margin: 0;
	margin-bottom: 15px;
	max-width: 100%;
	text-align: center;
}
.mod-link-btn > a {
	width: 340px;
	max-width: 100%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 13px 50px 14px;
	color: #fff;
	font-size: 15px;
	background-color: #333;
	background-repeat: no-repeat;
	background-position: right 22px center;
	background-size: 8px;
	background-image: url(../img/icon_btn_arrow_w.png);
	box-sizing: border-box;
}
.mod-link-btn > a > span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 0;
}
.mod-link-btn[class*="icon-"] > a > span:before {
	content: '';
	display: inline-flex;
	height: 1em;
	margin-top: 0.1em;
	background-repeat: no-repeat;
	background-position: left center;
	background-size: contain;
	background-image: url(../img/xxx.png);
}
.mod-link-btn.icon-link > a > span:before {
	width: 11px;
	background-image: url(../img/icon_link_w.svg);
}
.mod-link-btn.icon-flag > a > span:before {
	width: 13px;
	background-image: url(../img/icon_flag_w.svg);
}

@media screen and (min-width : 641px) {
	.mod-link-btn > a:hover {
		text-decoration: none;
		opacity: 0.7;
	}
}
@media screen and (max-width : 640px) {}

/* mod-in-house
------------------------------------------------------------------- */
.mod-in-house {
	margin: 63px 0 60px;
}
.mod-in-house .ih-title {
	margin: 0 0 24px!important;
	font-size: 20px!important;
	font-weight: bold!important;
	padding: 0;
	background-color: transparent;
	display: flex;
	justify-content: center;
}
.mod-in-house .ih-title.main {
	font-size: 24px!important;
}
.mod-in-house .ih-title:before {
	content: '';
	width: 32px;
	height: 32px;
	margin-right: 8px;
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 32px;
	background-image: url(../img/icon_flag.svg);
}
.mod-in-house .ih-title.main:before {
	background-position: left 3px;
}
.mod-in-house .ih-gallery {
	display: flex;
	flex-wrap: wrap;
	gap: 15px 24px;
	border: 0;
}
.mod-in-house .ih-gallery-item {
	padding: 0;
	width: calc((100% - 24px) / 2);
	border: 0;
}
.mod-in-house .ih-gallery-item > a {}
.mod-in-house .ih-gallery-item-img {
	position: relative;
	padding-top: 85.71428571428571%;
}
.mod-in-house .ih-gallery-item-img > img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 4px;
	object-fit: cover;
}
.mod-in-house .ih-gallery-item p,
.articleInfo .mod-in-house .ih-gallery-item p {
	margin: 0;
	margin-top: 4px;
	padding: 7px 20px 7px 0;
	font-size: 15px;
	font-weight: bold;
	color: #333;
	background-repeat: no-repeat;
	background-position: right top 17px;
	background-size: 6px;
	background-image: url(../img/icon_ih-gallery_arrow.svg);
}
.mod-in-house .mod-link-btn {
	margin-top: 24px;
}
.mod-in-house .mod-link-btn > a {
	width: 348px;
}

@media screen and (min-width : 641px) {
	.mod-in-house .ih-gallery-item > a:hover p {
		color: #666;
	}
}
@media screen and (max-width : 640px) {
	.mod-in-house {
		margin: 28px 0;
	}
	.mod-in-house .ih-title {
		margin-bottom: 20px!important;
		font-size: 16px!important;
	}
	.mod-in-house .ih-title.main {
		font-size: 16px!important;
	}
	.mod-in-house .ih-title:before {
		width: 24px;
		height: 24px;
		background-size: 24px;
		margin-right: 6px;
	}
	.mod-in-house .ih-title.main:before {
		background-position: left center;
	}
	.mod-in-house .ih-gallery {
		gap: 16px;
	}
	.mod-in-house .ih-gallery-item {
		width: calc((100% - 16px) / 2);
	}
	.mod-in-house .ih-gallery-item p,
	.articleInfo .mod-in-house .ih-gallery-item p {
		font-size: 14px;
	}
}

/* mod-img-gallery
------------------------------------------------------------------- */
.mod-img-gallery {
	width: 100%;
	position: relative;
}
.mod-img-gallery .mod-img-gallery-slide {
	position: relative;
	list-style-type: none;
	margin: 0;
	padding: 0;
	border: 0;
	background: none;
}
.mod-img-gallery .mod-img-gallery-slide li {
	margin: 0;
	padding: 0;
	border: 0;
	background: none;
}
.mod-img-gallery .mod-img-gallery-slide img {
	max-width: 100%;
	height: auto;
    display: block;
}
.mod-img-gallery .mod-img-gallery-slide:not(.slick-initialized) {
	opacity: 0;
}
.mod-img-gallery .mod-img-gallery-slide .slick-prev,
.mod-img-gallery .mod-img-gallery-slide .slick-next {
	width: 36px;
	height: 48px;
	z-index: 1;
}
.mod-img-gallery .mod-img-gallery-slide .slick-prev:before,
.mod-img-gallery .mod-img-gallery-slide .slick-next:before {
	display: inline-block;
	width: 36px;
	height: 48px;
	font-size: 48px;
	line-height: 48px;
	color: #fff;
}
.mod-img-gallery .mod-img-gallery-slide .slick-prev {
	left: 24px;
}
.mod-img-gallery .mod-img-gallery-slide .slick-next {
	right: 24px;
}
.mod-img-gallery .mod-img-gallery-slide .slick-slide {
	position: relative;
}
.mod-img-gallery .mod-img-gallery-slide .slick-dots {
	position: absolute;
	margin: 0;
	padding: 10px 0;
	z-index: 10;
	border: 0;
}
.mod-img-gallery .mod-img-gallery-slide .slick-dots li {
	margin: 0;
	padding: 0;
	border: 0;
	width: 42px;
	height: 42px;
}
.mod-img-gallery .mod-img-gallery-slide .slick-dots li button {
	width: 42px;
	height: 42px;
	padding: 15px;
}
.mod-img-gallery .mod-img-gallery-slide .slick-dots li button:before {
	width: 42px;
	height: 42px;
	font-size: 12px;
	line-height: 42px;
	opacity: 1;
	color: #fff;
}
.mod-img-gallery .mod-img-gallery-slide .slick-dots li.slick-active button:before {
	color: #333;
}
.mod-img-gallery .mod-img-gallery-slide.caption li p.caption {
    padding: 10px 0;
    font-size: 14px;
    line-height: 1.6;
}


@media screen and (min-width : 641px) {}
@media screen and (max-width : 640px) {
	.mod-img-gallery .mod-img-gallery-slide .slick-prev,
	.mod-img-gallery .mod-img-gallery-slide .slick-next {
		width: 40px;
		height: 40px;
	}
	.mod-img-gallery .mod-img-gallery-slide .slick-prev:before,
	.mod-img-gallery .mod-img-gallery-slide .slick-next:before {
		width: 40px;
		height: 40px;
		font-size: 30px;
		line-height: 40px;
	}
	.mod-img-gallery .mod-img-gallery-slide .slick-prev {
		left: 0;
	}
	.mod-img-gallery .mod-img-gallery-slide .slick-next {
		right: 0;
	}
	.mod-img-gallery .mod-img-gallery-slide .slick-dots {
		bottom: 0;
	}
	.mod-img-gallery .mod-img-gallery-slide .slick-dots li {
		width: 28px;
		height: 28px;
	}
	.mod-img-gallery .mod-img-gallery-slide .slick-dots li button {
		width: 28px;
		height: 28px;
		padding: 10px;
	}
	.mod-img-gallery .mod-img-gallery-slide .slick-dots li button:before {
		width: 28px;
		height: 28px;
		line-height: 28px;
		font-size: 8px;
	}
}

/* mod-speech-bubble
------------------------------------------------------------------- */
.mod-speech-bubble {
	margin: 32px 0;
	padding: 0;
	max-width: 100%;
	border: 0;
	display: flex;
	flex-direction: column;
	gap: 24px;
}
.mod-speech-bubble .sb_item {
	margin: 0;
	padding: 0;
	display: flex;
	gap: 12px;
	border: 0;
}
.mod-speech-bubble .sb_item_img {
	min-width: 64px;
	flex-shrink: 0;
	text-align: center;
}
.mod-speech-bubble .sb_item_img img {
	width: 64px;
	height: 64px;
	object-fit: cover;
	border-radius: 50%;
}
.mod-speech-bubble .sb_item_name {
	display: block;
	font-size: 13px;
	font-weight: 400;
	margin-top: 8px;
}
.mod-speech-bubble .sb_item_txt {
	flex-grow: 0;
	flex-shrink: 1;
	width: 480px;
	padding: 16px;
	border: 2px solid #EDEDED;
	border-radius: 0 16px 16px 16px;
}
.mod-speech-bubble.full .sb_item_txt {
	width: 100%;
}
.mod-speech-bubble .sb_item_desc {
	font-size: 13px;
	letter-spacing: 0.04em;
	line-height: 1.75;
	margin: 0;
	color: #333;
}

/* type_b */
.mod-speech-bubble .sb_item.type_b {
	justify-content: flex-end;
}
.mod-speech-bubble .sb_item.type_b .sb_item_img {
	order: 2;
}
.mod-speech-bubble .sb_item.type_b .sb_item_txt {
	order: 1;
	background-color: #f7f7f7;
	border-color: #f7f7f7;
	border-radius: 16px 0 16px 16px;
}

@media screen and (min-width : 641px) {}
@media screen and (max-width : 640px) {}


/* ==========================================
common [add]
========================================== */

/* .tagUl2
------------------------------------------------------------------- */
.post-content .detail-inner-tag {}
.post-content .detail-inner-tag .tagUl2 {
	list-style-type: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	border: 0;
}
.post-content .detail-inner-tag .tagUl2 > li {
	margin: 0;
	padding: 0;
	border: 0;
}
.post-content .detail-inner-tag .tagUl2 > li > a {
	display: block;
	padding: 5px 10px 6px;
	font-weight: normal;
	font-size: 13px;
	line-height: 1;
	border: 1px solid #6D6D68;
	border-radius: 16px;
	text-decoration: none;
}

@media screen and (min-width : 641px) {
	.post-content .detail-inner-tag .tagUl2 > li > a:hover {
		color: #666;
		border-color: #666;
	}
}
@media screen and (max-width : 640px) {}

/* .post-area
------------------------------------------------------------------- */
.post-content .detail-inner-area {
	float: left;
	width: 50%;
}
.post-content .detail-inner-area .post-area {
	margin-top: 8px;
	padding-top: 10px;
	display: inline-flex;
	align-items: flex-start;
	padding-left: 30px;
	background-repeat: no-repeat;
	background-position: left top 12px;
	background-size: 23px 23px;
	background-image: url(../menu_icon11.png);
}
.post-content .detail-inner-area .post-area > a {
	font-weight: normal;
	text-decoration:underline;
}

@media screen and (min-width : 641px) {}
@media screen and (max-width : 640px) {
	.post-content .detail-inner-area .post-area {
		padding-left: 18px;
		background-position: left top 15px;
		background-size: 14px 14px;
	}
	.post-content .detail-inner-area .post-area > a {
		font-size:13px;
	}
	.post-content .detail-inner-area {
		float: none;
		width: 100%;
	}
}

/* in-house-info
------------------------------------------------------------------- */
.post-content .in-house-info {
	margin: 54px 0 80px;
}
.post-content .in-house-info .ihi-title {
	display: inline-block;
	margin: 0;
	margin-bottom: 26px;
	padding: 0;
	padding-bottom: 1px;
	font-size: 20px;
	border: 0;
	border-bottom: 2px solid;
	background-color: transparent;
}
.post-content .in-house-info .ihi-title:before {
	display: none;
}
.post-content .in-house-info .mod-reserve-btn {
	flex-grow: 0;
	flex-shrink: 0;
	margin-left: auto;
}
.post-content .in-house-info .mod-in-house {
	margin-top: 30px;
}

@media screen and (min-width : 641px) {}
@media screen and (max-width : 640px) {
	.post-content .in-house-info {
		margin: ;
	}
	.post-content .in-house-info .mod-in-house {
		margin-top: 32px;
	}
}

/* .staffList
------------------------------------------------------------------- */
.staffList {
	display: flex;
	flex-direction: column;
	gap: 16px;
	width: 100%;
	list-style-type: none;
	margin: 40px 0;
	padding: 0;
	border: 0;
	background: none;
	border-top:none;
}
.staffList .sl_item {
	margin: 0;
	padding: 24px;
	display: flex;
	gap: 24px;
	border: 2px solid #EDEDED;
	border-radius: 8px;
	background: none;
}
.staffList .sl_item_txt {
	order: 2;
	margin: auto 0;
}
.staffList .sl_item_div {
	display: block;
	font-size: 13px;
	color: #333;
}
.staffList .sl_item_name {
	margin: 4px 0 0;
	font-size: 20px;
	font-weight: bold;
	color: #333;
	border-bottom: none;
}
.staffList .sl_item_desc {
	margin: 15px 0 0;
	font-size: 14px;
	line-height: 1.5;
}
.staffList .sl_item_img {
	order: 1;
	flex-shrink: 0;
	width: 96px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 13px;
}
.staffList .sl_item_img img {
	width: 96px;
	height: 96px;
	object-fit: cover;
	border-radius: 50%;
}
.staffList .sl_item_position {
	display: inline-block;
	padding: 4px 8px;
	font-size: 13px;
	font-weight: bold;
	line-height: 1.2;
	color: #333;
	background-color: #F7F7F7;
	border-radius: 32px;
}

/* type_editor */
.staffList .sl_item.type_editor {
	border-color: #F7F7F7;
	background-color: #F7F7F7;
}
.staffList .sl_item.type_editor .sl_item_position {
	background-color: #fff;
}

@media screen and (min-width : 641px) {}
@media screen and (max-width : 640px) {
	.staffList {
		margin: 32px 0;
		gap: 12px;
	}
	.staffList .sl_item {
		gap: 14px;
		padding: 18px 14px;
	}
	.staffList .sl_item_div {
		font-size: 10px;
	}
	.staffList .sl_item_name {
		margin-top: 6px;
		font-size: 16px;
	}
	.staffList .sl_item_desc {
		margin-top: 16px;
		font-size: 11px;
	}
}

.authorbox.no-bottom {
    border-bottom: 0px;
}
.authorbox.no-bottom  .staffList{
	margin-top:16px;
	margin-bottom:32px;
	border-top:0;
}
@media screen and (max-width : 640px) {
	.post-footer .staffList {
		width: calc(100% - 28px);
		padding: 0 14px;
	}
}

/* hotel-info
------------------------------------------------------------------- */
.post-footer .hotel-info-wrap {
	padding-bottom:10px;
}
.post-footer .hotel-info {
	padding: 30px 24px 40px;
	display: flex;
	flex-direction: column;
	align-items: center;
	border: 3px solid #e3e3e3;
	border-radius: 16px;
	font-family: "SourceHanSans-Medium",'Noto Sans JP', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
	box-sizing: border-box;
	margin-bottom:30px;
}
.post-footer .hotel-info .mod-link-btn {
	margin: 32px 0 0;
}
.post-footer .hotel-info .mod-link-btn > a {
	width: 348px;
}
.post-footer .hotel-info-title {
	display: inline-block;
	margin: 0;
	margin-bottom: -5px;
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	border-bottom: 2px solid;
}
.post-footer .hotel-info-title a:hover{
	text-decoration:none;
}

.post-footer .hotel-info-address {
	margin: 0;
	margin-top: 25px;
	font-size: 14px;
	color: #333;
	display: flex;
}
.post-footer .hotel-info-address:before {
	content: '';
	width: 10px;
	height: 14px;
	margin-top: 5px;
	margin-right: 7px;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	background-image: url(../img/icon_map.svg);
}
.post-footer .hotel-info-desc {
	margin: 0;
	margin-top: 25px;
	font-size: 16px;
	line-height: 1.5;
	color: #333;
}
.post-footer .mod-img-gallery {
	margin: 36px 0 40px;
}
.post-footer .hotel-info-access {
	align-self: flex-start;
	display: flex;
	align-items: flex-start;
}
.post-footer .hotel-info-access .label {
	flex-shrink: 0;
	width: 64px;
	height: 23px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #333;
	font-size: 12px;
	font-weight: bold;
	line-height: 1;
	background-color: #e5e5e5;
	border-radius: 32px;
	margin-right: 8px;
}
.post-footer .hotel-info-access .val {
	line-height: 1.4;
}
.post-footer .mod-fee-example {
	align-self: flex-start;
	margin-top: 22px;
}
.post-footer .mod-fee-example .mod-reserve-btn {
	width: 195px;
}

@media screen and (min-width : 641px) {}
@media screen and (max-width : 640px) {
	.post-footer .hotel-info-wrap {
		border-bottom:1px solid #B9B9B9;
	}
	.post-footer .hotel-info {
		padding: 22px 14px 30px;
		width: calc(100% - 28px);
		margin-left: auto;
		margin-right: auto;
		border-width: 2px;
		border-radius: 8px;
	}
	.post-footer .hotel-info-title {
		font-size: 20px;
	}
	.post-footer .hotel-info-address {
		margin-top: 21px;
		font-size: 12px;
	}
	.post-footer .hotel-info-address:before {
		margin-right: 5px;
	}
	.post-footer .hotel-info-desc {
		margin-top: 21px;
		font-size: 14px;
	}
	.post-footer .mod-img-gallery {
		margin: 36px 0;
	}
	.post-footer .hotel-info-access .label {
		font-size: 9px;
		width: 52px;
		height: 20px;
	}
	.post-footer .hotel-info-access .val {
		font-size: 12px;
	}
	.post-footer .mod-fee-example {
		margin-top: 18px;
	}
	.post-footer .mod-fee-example .mod-reserve-btn {
		width: 117px;
	}
	.post-footer .hotel-info .mod-link-btn {
		margin-top: 28px;
	}
}


/* ==========================================
common [change]
========================================== */

/* .post-header
------------------------------------------------------------------- */
h1.pTitle {}

@media screen and (min-width : 641px) {}
@media screen and (max-width : 640px) {
	h1.pTitle {
		margin-bottom: 20px;
	}
}

/* dl#facilityinfo
------------------------------------------------------------------- */
dl#facilityinfo dt {
	text-align: center;
	margin-bottom: 18px;
}
dl#facilityinfo dt > span {
	display: inline-block;
	padding-bottom: 1px;
	font-weight: bold;
	border-bottom: 2px solid;
}

/* #author-box .mod-link-btn
------------------------------------------------------------------- */
#author-box .mod-link-btn {
	margin: 24px 0 0;
}

/* #author-faq
------------------------------------------------------------------- */
#author-faq {
	width: calc(100% + 30px);
	max-width: calc(100% + 30px);
	margin: 60px 0 20px -15px;
	padding: 40px 15px;
	border-top: 1px solid #B9B9B9;
	border-bottom: 1px solid #B9B9B9;
	box-sizing: border-box;
}

@media screen and (min-width : 641px) {}
@media screen and (max-width : 640px) {
	#author-faq {
		margin-bottom: 0;
		padding: 40px 15px 0px 15px;
	}
}