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

/*===============================================================
	
	HAVEFUN 共通部上書き
	
===============================================================*/
/* メインビジュアル */
.mainvisual:before {
	/*background-image: linear-gradient(to right, #F1E5F1 0%, #F1E5F1 100%);*/
	bottom: -15px;
}

.mainvisual .logo {
	max-width: 480px;
}

.mainvisual .kv {
	position: relative;
	background-image: linear-gradient(to right, #fcfbfa 0%, #f4f2ee 100%);
	overflow: hidden;
	display: flex;
	align-content: center;
	justify-content: center;
	align-items: center;
	flex-direction: row;
	flex-wrap: nowrap;
	background: url(../images/logo_mv.jpg) repeat center center;
	overflow: hidden;
	background-size: cover;
	height: 100%;
}



.mainvisual .kv .chara01 {
	width: 380px;
	left: 20px;
	position: absolute;
	z-index: 12;
}

.mainvisual .kv .chara02 {
	width: 380px;
	right: 30px;
	bottom: 7px;
	position: absolute;
	z-index: 13;
}

.section_lead .title {
	font-size: 20px;
	line-height: 1.8;
}

@media (max-width: 1500px) {
	.mainvisual .kv .chara01 {
		width: 300px;
		left: -30px;
	}

	.mainvisual .kv .chara02 {
		width: 300px;
		right: -20px;
		bottom: 40px;
	}

}

@media (max-width: 1220px) {

	.mainvisual {
		height: 400px;
	}


	.mainvisual .kv .chara01 {
		width: 210px;
		left: -35px;
		bottom: 45px;
	}

	.mainvisual .kv .chara02 {
		width: 210px;
		right: -35px;
	}


}


@media (max-width: 1023px) {

	.mainvisual {
		height: 330px;
	}

	.mainvisual .logo {
		width: 300px;
	}


	.mainvisual .kv .house {
		width: 200px;

	}

	.mainvisual .kv .chara01 {
		width: 220px;
		left: -60px;
		bottom: -1%;
	}

	.mainvisual .kv .chara02 {
		width: 220px;
		right: -70px;
		bottom: 5%;
	}
}

@media (max-width: 767px) {

	.mainvisual {
		height: auto;
	}

	.mainvisual .logo {
		width: 50vw;
	}

	.mainvisual .kv .house {
		width: 32vw;
	}


	.mainvisual .kv .chara01 {
		width: 60vw;
		left: -9%;
		bottom: -50%;
	}

	.mainvisual .kv .chara02 {
		width: 60vw;
		right: -12%;
		bottom: -52%;
	}


	.section_lead .title {
		font-size: 4vw;
	}
}

/*====================================================================

	content_title

====================================================================*/
.content_title {
	position: relative;
	display: block;
	text-align: center;
}

.content_title .content_title_inner {
	position: relative;
	display: inline-block;
}

.headline_pop {
	position: relative;
	display: inline-block;
	text-align: center;
}

.headline_pop .title {
	display: inline-block;
	color: #fff;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.5;
	font-weight: normal;
	text-align: center;
	word-break: keep-all;
	background: #f39800;
	padding: 4px 10px;
	margin: 0 auto 30px;
	position: relative;
}

.headline_pop .title:after {
	content: "";
	position: absolute;
	bottom: -6px;
	left: 50%;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 6px 5px 0 5px;
	border-color: #f39800 transparent transparent transparent;
	transform: translateX(-50%);
}

.content_title .head {
	position: relative;
	display: inline-block;
	font-size: 28px;
	font-size: 2.8rem;
	line-height: 1;
	font-weight: 600;
	text-align: center;
	color: #3FA153;
}

.content_title .head.white {
	color: #fff;
}

.content_title .icon_num {
	position: absolute;
	top: 50%;
	right: 100%;
	width: 90px;
	margin-right: 2em;
	transform: translateY(-50%);
}

.content_title .icon_illust {
	position: absolute;
	top: 50%;
	left: 100%;
	width: 300px;
	margin-left: 2em;
	transform: translateY(-50%);
}

.content_title p {
	line-height: 1.6;
	text-align: center;
	margin-top: 50px;
}

.content_title p.white {
	color: #fff;
}

@media screen and (max-width: 1023px) {
	.content_title .icon_num {
		width: 80px;
		margin-right: 1em;
	}

	.content_title .icon_illust {
		width: 250px;
		margin-left: 0;
	}
}

@media only screen and (max-width: 767px) {
	.content_title .icon_num {
		width: 12vw;
		margin-right: .5em;
	}

	.headline_pop .title {
		position: relative;
		top: 0;
		font-size: 2.67vw;
		padding: 1vw 2.5vw;
		margin: 0 0 4vw;
	}

	.content_title .head {
		font-size: 4.80vw;
		margin-top: 0;
	}

	.content_title .icon_illust {
		width: 12vw;
		margin-left: .5em;
	}

	.content_title p {
		margin-top: 4vw;
	}
}

/*====================================================================

	section_qa

====================================================================*/
.section_qa {
	padding-bottom: 70px;
}

/* qa */
.qa {
	display: flex;
	justify-content: space-between;
	margin-top: 60px;
}

.qa .item {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 22%;
}

.qa .item.item_02 {
	width: 24.8%;
}


.qa .item .txt {
	text-align: center;
	margin-bottom: 10px
}

.qa .item .txt .head {
	display: inline-block;
	color: #fff;
	font-size: 20px;
	font-size: 2.0rem;
	line-height: 1.6;
	font-weight: normal;
	background: #f39800;
	border-radius: 5px;
	padding: 5px 20px;
}

.qa .item .txt p {
	font-size: 20px;
	font-size: 2.0rem;
	line-height: 1.2;
	margin-top: 30px;
}

.qa .item .txt p span {
	font-size: 12px;
	font-size: 1.2rem;
	font-weight: normal;
}

.qa .item .img {
	width: 100%;
	margin-top: auto;
}

.qa .item.item_02 .img {
	padding-right: 10px;
}

.content_detail .qa_footer {
	margin-top: 50px;
}

.content_detail .qa_footer p {
	line-height: 1.6;
	text-align: center;
}

@media screen and (max-width: 1023px) {
	.qa .item .txt p {
		font-size: 1.8vw;
	}

	.content_detail .qa_footer p {
		text-align: left;
	}
}

@media only screen and (max-width: 767px) {
	.section_qa {
		padding-bottom: 8vw;
	}

	.qa {
		flex-wrap: wrap;
		margin-top: 0;
	}

	.qa .item {
		width: 48%;
		margin-top: 6vw;
	}

	.qa .item.item_02 {
		width: 52%;
	}

	.qa .item.item_02 .img {
		padding-right: 0;
		margin-top: 0;
	}


	.qa .item .txt {
		text-align: center;
		margin-top: 0;
	}

	.qa .item .txt .head {
		font-size: 4vw;
		padding: 1vw 2vw;
	}

	.qa .item .txt p {
		font-size: 3.47vw;
		margin-top: 4vw;
	}

	.qa .item .txt p span {
		font-size: 2.67vw;
	}

	.qa .item .img {
		margin-top: 2vw;
	}

	.content_detail .qa_footer {
		margin-top: 4vw;
	}

	.content_detail .qa_footer p {
		font-size: 3.47vw;
	}
}

/*====================================================================

	section_aruaru

====================================================================*/
.section_aruaru {
	/* background: linear-gradient(to right, #b4eeff, #9fd9f6); */
	background: #c2debd;
	padding-top: 70px;
	padding-bottom: 70px;
}

.section_aruaru .aruaru {
	position: relative;
	padding-bottom: 20px;
}

.section_aruaru .aruaru .flex_container {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap !important;
	justify-content: flex-start;
}

.section_aruaru .aruaru .item {
	position: relative;
	padding: 40px;
	margin-top: 70px;
	color: #fff;
	z-index: 1;
}

.section_aruaru .aruaru .item_4_1 {
	width: 23.5981308411%;
	/* margin-right: 1.8691588785%; */
	margin-left: 35px;
}

.section_aruaru .aruaru .item:nth-child(1)::before {
	background: url(../images/pop_01.svg) no-repeat, center / contain;
	margin-left: 20px;
	transform: scale(1.6);
}

.section_aruaru .aruaru .item:nth-child(2)::before {
	background: url(../images/pop_02.svg) no-repeat, center / contain;
	transform: scale(1.4);
}

.section_aruaru .aruaru .item:nth-child(3)::before {
	background: url(../images/pop_03.svg) no-repeat, center / contain;
	transform: scale(1.4);
}

.section_aruaru .aruaru .item:nth-child(4)::before {
	background: url(../images/pop_04.svg) no-repeat, center / contain;
	transform: scale(1.3);
}

.section_aruaru .aruaru .item::before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: -1;
	margin: auto;
	width: 100%;
}





.section_aruaru .aruaru .item p {
	font-size: 14px;
	font-weight: 600;
	line-height: 1.6;
	text-align: left;
	color: #fff;
}

@media (max-width: 1220px) {

	.section_aruaru .aruaru .item {
		padding: 20px;
	}

	.section_aruaru .aruaru {
		margin-left: 0;
	}

	.section_aruaru .aruaru .item_4_1 {
		margin-right: 0;
	}

	.section_aruaru .aruaru .item:nth-child(1)::before {
		margin-left: 70px;
		transform: scale(2);
	}

	.section_aruaru .aruaru .item:nth-child(2)::before {
		margin-left: 42px;
		transform: scale(1.8);
	}

	.section_aruaru .aruaru .item:nth-child(3)::before {
		margin-left: 30px;
		transform: scale(1.7);
	}

	.section_aruaru .aruaru .item:nth-child(4)::before {
		margin-left: 20px;
		transform: scale(1.5);
	}

	.section_aruaru .aruaru .item p {
		font-size: 1.3vw
	}
}

@media (max-width: 1023px) {

	.section_aruaru .aruaru .item {
		padding: 15px;
	}

	.section_aruaru .aruaru .item:nth-child(1)::before {
		transform: scale(2);
		margin-left: 20px;
	}

	.section_aruaru .aruaru .item:nth-child(2)::before {
		transform: scale(1.7);
		margin-left: 15px;
	}

	.section_aruaru .aruaru .item:nth-child(3)::before {
		transform: scale(1.7);
		margin-left: 20px;
	}

	.section_aruaru .aruaru .item:nth-child(4)::before {
		transform: scale(1.6);
		margin-top: 10px;
		margin-left: 10px;
	}








}

@media (max-width: 800px) {
	.section_aruaru {
		padding-top: 8vw;
		padding-bottom: 8vw;
	}

	.section_aruaru .content_title .icon_illust {
		width: 20vw;
	}

	.section_aruaru .aruaru {
		flex-wrap: wrap;
		margin-top: 15vw;
	}

	.section_aruaru .aruaru .flex_container {
		display: flex;
		flex-direction: row;
		flex-wrap: wrap !important;
		justify-content: space-between;
		gap: 2vw 6vw;
	}

	.section_aruaru .aruaru .item {
		width: 46%;
		padding: 4vw;
		margin-top: 0vw;
		margin-left: 0;
	}


	.section_aruaru .aruaru .item p {
		font-size: 3vw;
		margin-left: 0;
		margin-top: 0;
	}

	.section_aruaru .aruaru .item .txt_rg {
		margin-left: 2vw;
	}

	.section_aruaru .aruaru .item:nth-child(1)::before {
		transform: scale(1.7);
		margin-left: 2vw;
		padding: 4vw;
	}

	.section_aruaru .aruaru .item:nth-child(2)::before {
		transform: scale(1.7);
		margin-left: 3vw;
		margin-top: 2vw;
	}

	.section_aruaru .aruaru .item:nth-child(3)::before {
		transform: scale(1.6);
		margin-left: 0;
		margin-top: 3vw;
	}

	.section_aruaru .aruaru .item:nth-child(4)::before {
		transform: scale(1.5);
		margin-top: 4vw;
		margin-left: 2vw;
	}






}


/*====================================================================

	section_room

====================================================================*/
.section_room {
	padding-top: 70px;
	padding-bottom: 70px;
}

.section_room .content_title .icon_illust {
	width: 110px;
}

.section_room .content_detail {
	display: flex;
	justify-content: space-between;
}

.section_room .item {
	box-sizing: border-box;
	width: 48.305084745762712%;
	background: #f39800;
	margin-top: 60px;
	padding: 30px;
	color: #fff;
}

.section_room .item:last-child {
	background: #3fa155;
	color: #fff;
}

.section_room .item .head {
	/*	color: #f39800;*/
	font-size: 26px;
	font-size: 2.6rem;
	line-height: 1.6;
	text-align: center;
	color: #fff;
	font-weight: bold;
}

.section_room .item .lead {
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.6;
	font-weight: bold;
	margin-top: 30px;
}

.section_room .item .txt {
	margin-top: 30px;
}

.section_room .item .txt .sub {
	color: #fff;
	font-size: 18px;
	font-size: 1.8rem;
	margin-top: 10px;
	font-weight: bold;
}


.section_room .item .txt li {
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.5;
	margin-left: .5em;
	text-indent: -.5em;
	margin-top: 15px;
}

.section_room .item .txt li:before {
	content: "・";
}

.section_room .item .txt ul+.sub {
	margin-top: 30px;
}

.section_room .item .detail {
	color: #f39800;
	/*	background: #fff;*/
	padding: 20px 0;
	margin-top: 30px;
	color: #fff;
}

.section_room .item .detail .title {
	font-size: 18px;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1;
	text-align: center;
	padding: 5px 0;
	background: #fff;
	border-radius: 10px;
}

.section_room .item.alone .detail .title {
	color: #f39800;
}

.section_room .item.dormitory .detail .title {
	color: #3fa155;
}

.section_room .item .detail .type {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-top: 20px;
}

.section_room .item .detail .type .img {
	width: 48%;
}

.section_room .item .detail .type dl {
	width: 48%;
	display: flex;
	flex-wrap: wrap;
}

.section_room .item .detail .type dt {
	width: 6em;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.6;
	font-weight: bold;
	margin-top: 10px;
}

.section_room .item .detail .type dd {
	width: calc(100% - 6em);
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.6;
	margin-top: 10px;
}

.section_room .item .detail .type dt:nth-child(-n+2),
.section_room .item .detail .type dd:nth-child(-n+2) {
	margin-top: 0;
}

.section_room .item .detail+p {
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.6;
	margin-top: 20px;
}

@media screen and (max-width: 1023px) {
	.section_room .item .detail .type {
		display: block;
	}

	.section_room .item .detail .type .img {
		width: 100%;
	}

	.section_room .item .detail .type dl {
		width: 100%;
		margin-top: 20px;
	}
}

@media only screen and (max-width: 767px) {
	.section_room {
		padding-top: 8vw;
		padding-bottom: 8vw;
	}

	.section_room .content_title .icon_illust {
		width: 15vw;
	}

	.section_room .content_detail {
		display: block;
	}

	.section_room .item {
		width: 100%;
		margin-top: 6vw;
		padding: 4vw;
	}

	.section_room .item .head {
		font-size: 4.27vw;
	}

	.section_room .item .lead {
		font-size: 3.47vw;
		margin-top: 4vw;
	}

	.section_room .item .txt {
		margin-top: 4vw;
	}

	.section_room .item .txt .sub {
		font-size: 3.47vw;
		margin-top: 4vw;
	}

	.section_room .item .txt ul {
		margin-top: 4vw;
	}

	.section_room .item .txt li {
		font-size: 3.47vw;
		padding-left: 0;
		margin-top: 0;
	}

	.section_room .item .txt .sub {
		font-size: 4.27vw;
	}

	.section_room .item .txt ul+.sub {
		margin-top: 4vw;
	}

	.section_room .item .detail {
		padding: 4vw;
		margin-top: 4vw;
	}

	.section_room .item .detail .title {
		font-size: 4.27vw;
	}

	.section_room .item .detail .type {
		margin-top: 4vw;
	}

	.section_room .item .detail .type .img {}

	.section_room .item .detail .type dl {
		margin-top: 4vw;
	}

	.section_room .item .detail .type dt {
		font-size: 3.47vw;
		width: 20vw;
		margin-top: 2vw;
	}

	.section_room .item .detail .type dd {
		width: calc(100% - 20vw);
		font-size: 3.47vw;
		margin-top: 2vw;
	}

	.section_room .item .detail .type dd:first-child,
	.section_room .item .detail .type dt:first-child {
		margin-top: 0;
	}

	.section_room .item .detail+p {
		font-size: 3.47vw;
		margin-top: 4vw;
	}
}


/*====================================================================

	section_spot

====================================================================*/
.section_spot {
	/* background: linear-gradient(to right, #ffec8a, #FFD775); */
	background: #f0e6af;
	padding-top: 70px;
	padding-bottom: 70px;
}

.section_spot .content_title .icon_illust {
	width: 102px;
}

.spot {
	display: flex;
	justify-content: space-between;
}

.spot .item {
	position: relative;
	box-sizing: border-box;
	width: 48.305084745762712%;
	background-color: #fff;
	padding: 50px 30px 30px;
	margin-top: 60px;
}

.spot .item .head {
	position: absolute;
	top: 0;
	left: 50%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	width: 80px;
	height: 80px;
	color: #fff;
	font-size: 20px;
	font-size: 2.0rem;
	text-align: center;
	background: url("../images/bg_park_num.svg") no-repeat center / contain;
	transform: translate(-50%, -50%);
	z-index: 10;
}

.spot .item.food .head {
	background: url("../images/bg_food_num.svg") no-repeat center / contain;
}

.spot .item .box {
	box-sizing: border-box;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.spot .item .box .txt {
	width: 65%;
}

.spot .item .box .txt .sub {
	color: #0097d2;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.6;
}

.spot .item .box .txt p {
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.6;
}

.spot .item .box .txt .sub+p {
	margin-top: 10px;
}

.spot .item .box .img {
	width: 30%;
}

@media screen and (max-width: 1023px) {
	.spot .item .box {
		flex-direction: column;
	}

	.spot .item .box .txt {
		width: 100%;
		margin-bottom: 20px;
	}

	.spot .item .box .img {
		width: 100%;
		margin-top: auto;
		/* 下付けがなぜか効かない */
	}
}

@media only screen and (max-width: 767px) {
	.section_spot .content_title .icon_illust {
		width: 12vw;
	}

	.spot {
		display: block;
	}

	.spot .item {
		width: 100%;
		padding: 8vw 4vw 4vw;
		margin-top: 8vw;
	}

	.spot .item .head {
		width: 12vw;
		height: 12vw;
		font-size: 3.0vw;
	}

	.spot .item .box {}

	.spot .item .box .txt {
		margin-bottom: 0;
	}

	.spot .item .box .txt .sub {
		font-size: 3.47vw;
	}

	.spot .item .box .txt .sub+p {
		margin-top: 2vw;
	}

	.spot .item .box .txt p {
		font-size: 3.47vw;
	}

	.spot .item .box .img {
		margin-top: 4vw;
	}
}