/* ==================================
=  basic settings
================================== */
/* ==================================
= header 
================================== */
.l-header {
	-webkit-box-align: center;
	-ms-flex-align: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	align-items: center;
	padding: 1.55rem 1rem 1.55rem 1.5rem;
	background-color: #000;
	color: #fff;
	-webkit-transition: background-color 0.3s ease-in-out, color 0.3s ease-in-out;
	transition: background-color 0.3s ease-in-out, color 0.3s ease-in-out;
}
.l-header a {
	color: #fff;
	-webkit-transition: color 0.3s ease-in-out;
	transition: color 0.3s ease-in-out;
}
.l-header a:hover {
	color: rgba(255, 255, 255, 0.8);
}
.l-header.is-sticky {
	z-index: 10;
	position: -webkit-sticky;
	position: sticky;
	top: 0;
	left: 0;
	width: 100%;
}
.l-header.is-scrolled {
	background-color: #fff;
	color: #1a1a1a;
}
.l-header.is-scrolled a {
	color: #1a1a1a;
}
.l-header.is-scrolled a:hover {
	color: rgba(26, 26, 26, 0.8);
}
.l-header.is-scrolled .logo-white {
	opacity: 0;
}
.l-header.is-scrolled .l-menu-btn span {
	background-color: #1a1a1a;
}
.l-header-logo {
	width: 13.8rem;
}
.l-header-logo a {
	display: block;
	position: relative;
}
.l-header-logo .logo-white {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 1;
	-webkit-transition: opacity 0.3s ease-in-out;
	transition: opacity 0.3s ease-in-out;
}
.l-header-caption {
	margin-left: 1.6rem;
	font-size: 1.4rem;
	line-height: 1.375;
}
.l-header-menu {
	-webkit-box-flex: 1;
	-ms-flex: 1;
	flex: 1;
	min-width: 100px;
	padding: 0 0 0 0.6rem;
}
.l-header-menu-sp {
	margin-left: auto;
}
.l-header-menu-sp button {
	display: block;
	position: relative;
	padding: 0;
	background-color: transparent;
}
.l-header-menu-sp .l-menu-btn span {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	display: inline-block;
	position: absolute;
	left: 0;
	width: 6.5104166667vw;
	height: 0.1rem;
	background-color: #fff;
	-webkit-transition: all 0.2s ease;
	transition: all 0.2s ease;
}
.l-header-menu-sp .l-menu-btn span:nth-of-type(1) {
	top: 0;
}
.l-header-menu-sp .l-menu-btn span:nth-of-type(2) {
	top: 2.6041666667vw;
}
.l-header-menu-sp .l-menu-btn span:nth-of-type(3) {
	top: 5.2083333333vw;
}
.l-header-menu-sp .l-menu-btn.is-open span:nth-of-type(1) {
	-webkit-transform: translateY(2.6041666667vw) rotate(-45deg);
	transform: translateY(2.6041666667vw) rotate(-45deg);
}
.l-header-menu-sp .l-menu-btn.is-open span:nth-child(2) {
	opacity: 0;
}
.l-header-menu-sp .l-menu-btn.is-open span:nth-of-type(3) {
	-webkit-transform: translateY(-2.6041666667vw) rotate(45deg);
	transform: translateY(-2.6041666667vw) rotate(45deg);
}

/*----------  gnav  ----------*/
.gnav {
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	justify-content: flex-end;
	padding: 2rem;
}
.gnav li {
	font-weight: bold;
}
.gnav li:not(:first-child) {
	margin: 0 0 0 2rem;
	font-size: 1.6rem;
}
.gnav li a.c-button {
	padding: 2rem 1.9rem;
	color: #fff;
	-webkit-transition: opacity 0.3s ease-in-out;
	transition: opacity 0.3s ease-in-out;
}

/* ==================================
= content 
================================== */
body {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-direction: column;
	flex-direction: column;
	min-height: 100vh;
}

.l-content-wrap {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-direction: column;
	flex-direction: column;
	width: 100%;
	min-height: 100vh;
	margin: 0 auto;
}
.l-primary {
	-webkit-box-flex: 1;
	-ms-flex: 1;
	flex: 1;
}
.l-main-column {
	-webkit-box-flex: 1;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex: 1 0 auto;
	flex: 1 0 auto;
	min-height: 1px;
}

/* ==================================
= footer 
================================== */
.l-footer {
	margin-top: auto;
	letter-spacing: 0em;
	text-align: center;
}
.l-footer .footer-content {
	padding: 0.4rem 2rem;
	background-color: #f1f1f1;
	font-size: 1.4rem;
}
.l-footer .footer-copyright {
	padding: 0.4rem 2rem;
	background-color: #1a1a1a;
	color: #fff;
}
@media screen and (max-width: 1360px) {
	.gnav li:not(:first-child) {
		margin: 0 0 0 1rem;
		font-size: 1.5rem;
	}
}
@media screen and (max-width: 767px) {
	.l-header {
		min-height: 13.0208333333vw;
		padding: 2.4vw 3.4666666667vw 2.1333333333vw 2.6666666667vw;
		-webkit-box-shadow: 0.2604166667vw 0.2604166667vw 0.2604166667vw rgba(0, 0, 0, 0.1490196078);
		box-shadow: 0.2604166667vw 0.2604166667vw 0.2604166667vw rgba(0, 0, 0, 0.1490196078);
	}
	.l-header-logo {
		width: 22.9333333333vw;
	}
	.l-header-caption {
		width: auto;
		margin-left: 2.4vw;
		font-size: 2.6041666667vw;
	}
	.l-header-menu {
		display: none;
		z-index: 10;
		position: fixed;
		top: 13.0208333333vw;
		left: 0;
		width: 100%;
		height: auto;
		max-height: calc(100% - 13.0208333333vw);
		padding: 13.8020833333vw 10.4166666667vw;
		overflow-x: hidden;
		overflow-y: scroll;
		background-color: rgba(255, 255, 255, 0.95);
	}
	.l-header-menu.is-open {
		display: block;
	}
	.l-header-menu-sp button {
		width: 6.5104166667vw;
		height: 5.2083333333vw;
	}
	.l-header-menu-sp .l-menu-btn.is-open span {
		width: 6.5104166667vw;
	}
	.gnav {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-webkit-box-align: center;
		-ms-flex-align: center;
		-ms-flex-direction: column;
		flex-direction: column;
		align-items: center;
	}
	.gnav li {
		font-weight: normal;
		font-size: 3.6458333333vw;
		letter-spacing: 0.06em;
	}
	.gnav li:not(:first-child) {
		margin: 6.25vw 0 0 0;
	}
	.gnav li:last-child {
		margin: 8.0729166667vw 0 0 0;
	}
	.gnav li a {
		color: #1a1a1a;
	}
	.gnav li a.c-button {
		-webkit-box-align: center;
		-ms-flex-align: center;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		align-items: center;
		padding: 1.5625vw 4.1666666667vw;
		font-size: 3.6458333333vw;
	}
	.l-primary {
		min-width: 100px;
	}
	.l-content {
		padding: 0 5.2083333333vw;
	}
	.l-footer .footer-content {
		font-size: 3.6458333333vw;
	}
}
@media screen and (min-width: 768px) {
	.l-header {
		min-width: 1280px;
	}
	.l-header-menu-sp {
		display: none;
	}
	.l-primary {
		min-width: 1280px;
	}
	.l-content {
		width: 1280px;
		margin-right: auto;
		margin-left: auto;
		padding: 0 40px;
	}
	.l-footer {
		min-width: 1280px;
	}
}
@media screen and (min-width: 1440px) {
	.l-header-caption {
		margin-left: 2.8rem;
		font-size: 1.6rem;
	}
	.gnav li:not(:first-child) {
		margin: 0 0 0 2.8rem;
	}
}