/* ---------------------------------------------------
	header
---------------------------------------------------- */
.header {
	position: relative;
}

.header__kv {
	width: 100%;
	overflow: hidden;
}

/* ---------------------------------------------------
	gnav
---------------------------------------------------- */
.gnav {
	background: rgba(var(--wht), 0.8);
	width: 100%;
	line-height: 1;
	font-family: var(--jost);
	font-size: 2rem;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 999;
}

.gnav__list {
	/* ,lang表示の時に解除 */
	/* margin-right: 14.4rem; */
	height: 7.3rem;
	display: flex;
	align-items: center;
}

.gnav__item {
	margin-right: 2rem;
}

.gnav__item a {
	color: rgb(var(--blk));
	text-decoration: none;
	display: flex;
	justify-content: center;
	align-items: center;
}

@media screen and (max-width: 768px) {
	.gnav {
		background-color: rgb(var(--gnav));
		padding-top: 7.2rem;
		max-width: 28rem;
		width: 100%;
		height: 100%;
		overflow: auto;
		display: block;
		right: 0;
		left: auto;
		transform: translateX(100%);
		transition: transform 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	}

	.gnav__list {
		margin: 0;
		height: auto;
		font-size: 1.8rem;
		display: block;
		position: static;
	}

	.gnav__item {
		margin: 0 0 3rem;
		padding-left: 4rem;
	}

	.gnav__item a {
		color: rgb(var(--wht));
		font-size: 2.4rem;
		justify-content: flex-start;
	}

	.overlay.is-gnav-overlay {
		background: rgba(var(--blk), 0.75);
		width: 100vw;
		height: 100vh;
		opacity: 0;
		visibility: hidden;
		position: fixed;
		top: 0;
		left: 0;
		z-index: 998;
	}

	body.is-open {
		overflow: hidden;
	}

	.is-open .gnav--sp-toggle {
		transform: translateX(0);
	}

	.is-open .overlay.is-gnav-overlay {
		opacity: 1;
		visibility: visible;
		cursor: pointer;
	}
}

/* ---------------------------------------------------
	lang:
---------------------------------------------------- */
.lang {
	background-image: url(../img/icon-lang.svg);
	background-position: center left;
	background-repeat: no-repeat;
	background-size: 2rem auto;
	padding-left: 3rem;
	height: 7.3rem;
	font-family: var(--jost);
	font-size: 2rem;
	display: flex;
	position: fixed;
	top: 0;
	right: 3.2rem;
	z-index: 1000;
	transition: all 0.5s ease 0s;
}

.lang__item {
	display: flex;
	align-items: center;
}

.lang__item:first-of-type:after {
	margin: 0 0.5rem;
	content: "/";
}

a.lang__item--link {
	color: rgb(var(--gra));
	text-decoration: none;
}

@media screen and (max-width: 768px) {
	.lang {
		height: 5.5rem;
		font-size: 1.4rem;
		position: fixed;
		top: 0;
		right: 8.7rem;
	}

	.is-open .lang {
		background-image: url(../img/icon-lang-wht.svg);
		color: rgb(var(--wht));
	}
}

/* ---------------------------------------------------
	toggle
---------------------------------------------------- */
.toggle {
	display: none;
}

@media screen and (max-width: 768px) {
	.toggle {
		width: 4.25rem;
		height: 1.6rem;
		display: block;
		position: fixed;
		top: 2rem;
		right: 2rem;
		z-index: 1000;
	}

	.toggle::before {
		background-color: rgba(var(--wht), 0.8);
		width: 100vw;
		height: 5.5rem;
		position: absolute;
		top: -2rem;
		right: -2rem;
		z-index: 1;
		transition: all 0.5s ease 0s;
		content: "";
	}

	.toggle__line {
		background: rgb(var(--blk));
		width: 100%;
		height: 1px;
		display: block;
		position: absolute;
		left: 50%;
		z-index: 2;
		transition: all 0.6s;
		transform: translateX(-50%);
		transform-origin: center;
	}

	.toggle__line:nth-child(1) {
		top: 0;
	}

	.toggle__line:nth-child(2) {
		bottom: 0;
	}

	.is-open .toggle__line {
		transform-origin: 0 0;
	}

	.is-open .toggle::before {
		display: none;
	}

	.is-open .toggle__line {
		background-color: rgb(var(--wht));
	}

	.is-open .toggle__line:nth-child(1) {
		top: 50%;
		transform: rotate(20deg) translate(-50%, -50%);
	}

	.is-open .toggle__line:nth-child(2) {
		top: 50%;
		bottom: auto;
		transform: rotate(-20deg) translate(-50%, -50%);
	}
}

/* ----------------------------------------------------
	sec
---------------------------------------------------- */
.sec {
	padding: 10rem 0;
}

.sec__title {
	margin-bottom: 5rem;
	line-height: 1;
	font-family: var(--cormorant);
	font-size: 5.5rem;
	font-weight: 600;
	text-align: center;
}

.sec .category {
	padding: 0 1rem;
	height: 2rem;
	line-height: 1;
	color: rgb(var(--wht));
	font-family: var(--jost);
	font-size: 1.4rem;
	border-radius: 2rem;
	display: inline-flex;
	align-items: center;
}

.sec .category.dia {
	background-color: rgb(var(--dia));
}

.sec .category.sky {
	background-color: rgb(var(--sky));
}

@media screen and (max-width: 768px) {
	.sec {
		padding: 6rem 0;
	}

	.sec__title {
		margin-bottom: 2rem;
		font-size: 4rem;
	}
}

/* ----------------------------------------------------
	bg-color
---------------------------------------------------- */
.bg-color {
	background: linear-gradient(90deg, #49AFDB 0%, #4831A1 100%);
	color: rgb(var(--wht));
}

/* ----------------------------------------------------
	concept
---------------------------------------------------- */
.concept__lead {
	margin-bottom: 6rem;
	line-height: 2.1;
	font-size: 1.8rem;
	text-align: center;
}

.concept__lead .text:not(:last-of-type) {
	margin-bottom: 2rem;
}

.concept__list {
	margin: 0 auto;
	width: 100rem;
}

.concept__item:not(:last-of-type) {
	margin-bottom: 4rem;
}

.concept__detail {
	text-align: center;
}

.concept__detail--title {
	line-height: normal;
	font-family: var(--cormorant);
	font-size: 2.8rem;
	font-weight: 600;
}

.concept__detail--content {
	font-size: 1.8rem;
	font-weight: 500;
}

.concept__detail--content:not(:last-of-type) {
	margin-bottom: 1rem;
}

@media screen and (max-width: 768px) {
	.concept__lead {
		line-height: 2.25;
		font-size: 1.6rem;
	}

	.concept__list {
		width: 33rem;
	}

	.concept__item:not(:last-of-type) {
		margin-bottom: 2rem;
	}

	.concept__detail--title {
		font-size: 2rem;
	}
}

/* ----------------------------------------------------
	nav
---------------------------------------------------- */
.nav {
	margin-bottom: 12rem;
	overflow: hidden;
}

.nav__slider {
	padding: 0 21.962vw;
	width: 100%;
	overflow: visible;
}

.nav__slide {
	padding: 0 2.928vw;
	width: 28.038vw !important;
}

.nav__slide a {
	text-decoration: none;
}

.nav__image figcaption {
	font-size: 2.4rem;
	font-weight: 500;
}

@media screen and (max-width: 768px) {
	.nav {
		margin-bottom: 10rem;
	}

	.nav__slider {
		padding: 0;
		overflow: hidden;
	}

	.nav__slide {
		padding: 0 4rem;
		width: 100% !important;
	}
}

/* ----------------------------------------------------
	rental
---------------------------------------------------- */
.rental__content {
	margin: 0 auto;
	width: 100rem;
}

.rental__lead {
	margin-bottom: 5rem;
	text-align: center;
}

.rental__lead .text {
	font-size: 1.5rem;
}

.rental__lead .note {
	margin-top: 0.5rem;
}

.rental__list {
	display: flex;
	flex-wrap: wrap;
}

.rental__list--item {
	margin-bottom: 5rem;
	width: calc((100% - 7.5rem) / 2);
	line-height: normal;
}

.rental__list--item:nth-child(odd) {
	margin-right: 7.5rem;
}

.rental__image {
	margin-bottom: 1.5rem;
}

.rental__title {
	font-size: 2.4rem;
	font-weight: 500;
}

.rental__price {
	font-size: 2rem;
}

@media screen and (max-width: 768px) {
	.rental__content {
		width: 33rem;
	}

	.rental__list {
		display: block;
	}

	.rental__list--item {
		margin-bottom: 3rem;
		width: 100%;
	}

	.rental__list--item:nth-child(odd) {
		margin-right: 0;
	}

	.rental__image {
		margin-bottom: 1rem;
	}

	.rental__detail {
		display: flex;
		align-items: center;
	}

	.rental__title {
		font-size: 2rem;
	}

	.rental__price {
		margin-left: 0.5rem;
		font-size: 2rem;
	}
}

/* ----------------------------------------------------
	notice
---------------------------------------------------- */
.notice .link-button {
	width: 28rem;
}

.notice.under .link-button {
	height: 7.5rem;
	line-height: 1.5;
	text-align: center;
}

/* ----------------------------------------------------
	page-note
---------------------------------------------------- */
.page-note {
	margin: 0 auto 10rem;
	width: 100rem;
}

@media screen and (max-width: 768px) {
	.page-note {
		width: 33rem;
	}
}

/* ----------------------------------------------------
	footer
---------------------------------------------------- */
.footer {
	background-color: rgb(var(--footer));
	padding-top: 5rem;
	color: rgb(var(--wht));
}

/* 
	footer__head
------------------------------ */
.footer__head {
	margin: 0 auto;
	padding-bottom: 5rem;
	width: 100rem;
	display: flex;
	justify-content: space-between;
}

.footer__head--logo {
	width: 28.7rem;
}

.footer__sns {
	display: flex;
	align-items: center;
}

.footer__sns--title {
	margin-right: 1rem;
	font-size: 2.4rem;
}

.footer__sns--content {
	display: flex;
}

.footer__sns--icon {
	margin-left: 4rem;
}

@media screen and (max-width: 768px) {
	.footer__head {
		padding: 0 2.6rem 3rem;
		width: 100%;
		display: block;
	}

	.footer__head--logo {
		margin-bottom: 3.2rem;
		width: 19.4rem;
	}

	.footer__sns--title {
		margin-right: 0;
		font-size: 1.6rem;
	}

	.footer__sns--icon {
		margin-left: 3rem;
	}
}

/* 
	footer__body
------------------------------ */
.footer__body {
	margin: 0 auto;
	padding: 5rem 0;
	width: 100rem;
	display: flex;
	position: relative;
}

.footer__body::before,
.footer__body::after {
	background-color: rgb(var(--wht));
	width: 100vw;
	height: 1px;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	content: "";
}

.footer__body::before {
	top: 0;
}

.footer__body::after {
	bottom: 0;
}

.footer__body a {
	display: inline-flex;
	align-items: center;
}

.footer__body a:not(.telephone)::before {
	content: "＞";
}

.footer__body--content {
	font-size: 1.6rem;
	white-space: nowrap;
}

.footer__body--content:not(:last-of-type) {
	margin-right: 11.5rem;
}

.footer__body--title {
	margin-bottom: 1rem;
	line-height: normal;
	font-size: 2rem;
	font-weight: 500;
}

.footer__address {
	margin-bottom: 1rem;
}

.footer__pool {
	width: 26rem;
	display: flex;
	flex-wrap: wrap;
}

.footer__pool--item:nth-child(odd) {
	width: 15rem;
}

.footer__pool--item:not(:nth-child(even)) {
	margin-right: 4rem;
}

@media screen and (max-width: 768px) {
	.footer__body {
		padding: 4rem 2.6rem;
		width: 100%;
		display: block;
	}

	.footer__body--content:not(:last-of-type) {
		margin-right: 0;
		margin-bottom: 3rem;
	}

	.footer__address {
		margin-bottom: 1rem;
	}

	.footer__pool {
		width: 100%;
	}
}

/* 
	copy
------------------------------ */
.footer .copy {
	padding: 2rem 0;
	line-height: normal;
	font-size: 1.1rem;
	text-align: center;
}

@media screen and (max-width: 768px) {
	.footer .copy {
		font-size: 1rem;
		letter-spacing: -0.005rem;
	}
}