@charset "utf-8";
/*==================================================
	くつろぐ
==================================================*/
#relax .bg {
	margin-bottom: 120px;
}
#relax .bg:before {
	background: url("../img/bg-wave04.jpg") no-repeat bottom 60px left /100% auto, url("../img/bg-wave.jpg") no-repeat top left /100% auto, linear-gradient(to top, transparent 60px, rgba(13, 183, 214, 0.1) 60px);
}
#relax .box {
	margin-bottom: 60px;
	position: relative;
}
#relax .box.rev .img img {
	border-radius: 30px 0 0 0;
}
#relax .box .info {
	width: 700px;
	margin-left: auto;
	position: relative;
}
#relax .box .info::before {
	content: "";
	position: absolute;
	right: -205px;
	bottom: -30px;
	display: inline-block;
	width: 276px;
	height: 289px;
	background: url("../img/bg-maru04.png") no-repeat center /100% auto;
	z-index: -1;
}
#relax .box.rev .info::before {
	right: auto;
	left: -200px;
	bottom: -175px;
	width: 382px;
	height: 474px;
	background: url("../img/bg-maru05.png") no-repeat center /100% auto;
}
#relax .box.rev .info {
	margin-left: 0;
	margin-right: auto;
}
#relax .box .info .waku {
	padding: 50px;
	box-sizing: border-box;
	background: #fff;
	border-radius: 30px;
	letter-spacing : 2.8px;
}
#relax .box .info .waku.bg_gray {
	background: #FAFAF8;
}
#relax .box .info .waku .txt {
	margin-bottom: 0;
}
#relax .box .info .waku table {
	width: 100%;
	letter-spacing: 2.8px;
	margin-top: 50px;
}
#relax .box .info .waku table tr {
	border-top: 1px solid #E6E6DC;
}
#relax .box .info .waku table tr:last-of-type {
	border-bottom: 1px solid #E6E6DC;
}
#relax .box .info .waku table tr th, #relax .box .info .waku table tr td {
	padding: 15px 20px;
	box-sizing: border-box;
}
#relax .box .info .waku table tr th {
	width: 120px;
	color: #0DB7D6;
}
#relax .box .info .waku table tr td {
	width: calc(100% - 120px);
}
#relax .imgs {
	display: grid;
	justify-content: space-between;
	grid-template-columns: repeat(4, 250px);
	gap: 40px 0;
}
#relax .imgs img {
	border-radius: 30px 0;
	width: 100%;
}
@media print, screen and (min-width: 769px){ /* PCのみ */
	#relax .box .img {
		position: absolute;
		left: calc(50% - 50vw);
		width: calc( (100vw - 1100px) / 2 + (1100px - 750px) );
	}
	#relax .box.rev .img {
		left: auto;
		right: calc(50% - 50vw);
	}
	@media only screen and (max-width: 1150px) {
		#relax .box .img {
			left: -30px;
			width: 400px;
		}
		#relax .box.rev .img {
			left: auto;
			right: -30px;
		}
	}
	#relax .box .img img {
		width: 100%;
		max-height: 370px;
		object-fit: cover;
		border-radius: 0 30px 0 0;
	}
}
@media print, screen and (min-width: 641px){ /* PC・タブレット */
}
@media only screen and (max-width: 768px) and (min-width: 641px){ /* タブレットのみ */
}
@media only screen and (max-width: 768px) {  /* タブレット以下 */
	#relax .bg {
		margin-bottom: 50px;
	}
	#relax .box {
		margin-bottom: 30px;
	}
	#relax .box .img {
		text-align: center;
		margin-bottom: 30px;
	}
	#relax .box .img img {
		width: 300px;
		border-radius: 20px;
	}
	#relax .box.rev .img img {
		border-radius: 20px;
	}
	#relax .box .info {
		width: 100%;
	}
	#relax .box .info::before {
		right: -75px;
		bottom: -20px;
		width: 100px;
		height: 120px;
	}
	#relax .box.rev .info::before {
		right: auto;
		left: -150px;
		bottom: -125px;
		width: 190px;
		height: 230px;
		background: url(../img/bg-maru05.png) no-repeat center / 100% auto;
	}
	#relax .box .info h3.sub {
		text-align: center;
	}
	#relax .box .info .waku {
		padding: 20px;
	}
	#relax .box .info .waku table {
		margin-top: 20px;
	}
	#relax .box .info .waku table tr th, #relax .box .info .waku table tr td {
		padding: 15px;
	}
	#relax .imgs {
		grid-template-columns: repeat(4, 23%);
		gap: 30px 0;
	}
}
@media only screen and (max-width: 640px){ /* スマホ */
	#relax .box .info .waku table tr th, #relax .box .info .waku table tr td {
		padding: 10px;
	}
	#relax .box .info .waku table tr th {
		width: 100px;
	}
	#relax .box .info .waku table tr td {
		width: calc(100% - 100px);
	}
	#relax .imgs {
		grid-template-columns: repeat(2, 48%);
		gap: 15px 0;
	}
}