@import url("https://use.typekit.net/blp5tma.css");
/* ------------------------------------------------- Default and Common --------------------------------------------------- */
html,
body {
	width: 100%;
	min-height: 100%;
}

html {
	font-size: 62.5%;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
}

body {
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	font-size: 1rem;
	line-height: 1.5;
	color: #000;
	text-align: center;
	-webkit-text-size-adjust: 100%;
	background-color: #FFF;
	position: fixed;
	left: 0;
	top: 0;
	overflow-x: hidden;
}

body.loaded {
	position: static;
}

a {
	color: inherit;
	text-decoration: none;
	cursor: pointer !important;
	transition: opacity 0.25s ease 0s;
}

a:hover,
a:active,
a.active {
	opacity: 0.55;
}

img {
	width: 100%;
	height: auto;
	vertical-align: bottom;
}

section,
p,
div,
ul,
li,
dl,
dt,
dd,
a,
span,
footer {
	padding: 0;
	margin: 0;
	box-sizing: border-box;
	list-style: none;
}

/* --------------------------------------------------------- loading --------------------------------------------------------- */
#loader {
	width: 100%;
	height: 100vh;
	background-color: #FFF;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	position: fixed;
	left: 0;
	bottom: 0;
	z-index: 9999;
	transition: opacity 1.1s cubic-bezier(0.19, 1, 0.22, 1) 0s;
}

#loader .logo {
	width: 216px;
}

#loader .logo img {
	width: 100%;
	height: auto;
	display: block;
}

#loader .bar {
	width: 100%;
	height: 8px;
	background-color: rgba(0, 0, 0, 0.14);
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: 5;
}

#loader .bar span {
	width: 0%;
	height: 100%;
	background-color: #C5FF05;
	display: block;
}

#loader.complete {
	opacity: 0;
}

/* --------------------------------------------------------- page --------------------------------------------------------- */
#container {
	width: 100%;
	min-height: 100vh;
	background-color: #FFF;
	position: relative;
	opacity: 0;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: row;
	justify-content: flex-start;
	align-items: flex-start;
	transition: opacity 1.15s cubic-bezier(0.19, 1, 0.22, 1) 0.28s;
}

body.show_contents #container {
	opacity: 1;
}

.main_visual {
	width: 50%;
	aspect-ratio: 640/1103;
	position: sticky;
	top: var(--sticky-offset, -1px);
	left: 0;
	background-color: #FFF;
	z-index: 1;
}

.main_visual .inner {
	width: 100%;
	height: 100%;
	margin: 0;
	position: relative;
	text-align: left;
	overflow: hidden;
}

.main_visual_bg {
	width: 78.125%;
	height: 98.1876699909%;
	background-color: #C5FF05;
	position: absolute;
	left: 18.75%;
	top: 1.8123300091%;
}

.main_title {
	width: 58.125%;
	aspect-ratio: 372/293;
	position: absolute;
	left: 3.125%;
	top: 7.7969174977%;
	z-index: 3;
}

.main_title img {
	width: 100%;
	height: auto;
	display: block;
}

.main_model {
	width: 43.75%;
	height: 38.0779691741%;
	position: absolute;
	left: 53.125%;
	top: 0;
	z-index: 2;
	overflow: hidden;
}

.main_model img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.main_photo_grid {
	width: 97.03125%;
	display: flex;
	flex-wrap: wrap;
	flex-direction: row;
	justify-content: flex-start;
	align-items: flex-start;
	column-gap: 3.125%;
	row-gap: 20px;
	position: absolute;
	left: 0;
	top: 39.8912058024%;
	z-index: 2;
}

.main_photo_grid ul {
	width: 31.1863123994%;
	aspect-ratio: 193.667/290.358;
	position: relative;
	overflow: hidden;
	background-color: #C5FF05;
}

.main_photo_grid li {
	width: 100%;
	height: 100%;
}

.main_photo_grid img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.main_photo_grid .slick-list,
.main_photo_grid .slick-track,
.main_photo_grid .slick-slide,
.main_photo_grid .slick-slide > div {
	height: 100%;
}

.sub_title {
	width: 32.96875%;
	aspect-ratio: 211/28;
	position: absolute;
	left: 32.1875%;
	top: 96.1015412511%;
	z-index: 3;
}

.sub_title img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}

.main_contents {
	width: 50%;
	min-height: 2504px;
	background-color: #FFF;
	position: relative;
	z-index: 2;
	text-align: left;
}

.lead {
	width: 100%;
	padding-top: 90px;
	color: #000;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0;
	font-style: normal;
	text-align: center;
}

.lead p:not(:last-child) {
	margin-bottom: 20px;
}

.item_section {
	width: min(100%, 640px);
	margin: 150px auto 0;
}

.main_item {
	width: 100%;
	padding: 0 96px;
}

.main_item_inner {
	width: 100%;
	max-width: 448px;
	margin: 0 auto;
	position: relative;
}

.main_item_photo {
	width: 100%;
	aspect-ratio: 448/672;
	overflow: hidden;
	position: relative;
}

.main_item_photo > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.heading {
	position: absolute;
	left: -30px;
	top: 30px;
	z-index: 2;
}

.heading p {
	width: max-content;
	margin-bottom: 10px;
	padding: 2px 4px;
	background-color: #C5FF05;
	color: #000;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0;
	font-style: normal;
	white-space: nowrap;
	clip-path: inset(0 100% 0 0);
	will-change: clip-path;
}

.heading p:last-child {
	margin-bottom: 0;
}

.heading.is-visible p {
	animation: headingMaskIn 0.72s cubic-bezier(0.19, 1, 0.22, 1) both;
}

.heading.is-visible p:nth-child(2) {
	animation-delay: 0.12s;
}

@keyframes headingMaskIn {
	0% {
		clip-path: inset(0 100% 0 0);
	}
	100% {
		clip-path: inset(0 0 0 0);
	}
}

.credit_tee {
	position: absolute;
	left: 19px;
	top: 605px;
	z-index: 2;
	color: #C5FF05;
	font-family: "bebas-neue-pro", sans-serif;
	font-size: 2rem;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: 0.03em;
	font-style: normal;
}

.credit_tee .credit_tee_price {
	display: flex;
	flex-wrap: nowrap;
	flex-direction: row;
	justify-content: flex-start;
	align-items: center;
	gap: 8px;
}

.credit_tee .credit_tee_price > div {
	flex: 0 0 auto;
	line-height: 1;
}

.credit_tee .items__a {
	padding: 2px 20px;
	background-color: #C5FF05;
	color: #000;
	font-size: 1.8rem;
	display: inline-block;
}

.credit_tee .item-d-none .items__a {
	display: none;
}

.circle_icon {
	width: 116px;
	aspect-ratio: 116/115;
	position: absolute;
	right: -33px;
	top: -46px;
	z-index: 2;
}

.circle_icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
	transform-origin: center center;
	animation: circleIconRotate 28s linear infinite;
}

@keyframes circleIconRotate {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(360deg);
	}
}

.item_text {
	width: calc(100% - 20px);
	margin: 30px auto 0;
	color: #000;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	font-size: 1.2rem;
	font-weight: 500;
	line-height: 1.8;
	letter-spacing: 0;
	font-style: normal;
}

.item_text p:not(:last-child) {
	margin-bottom: 12px;
}

.styles {
	width: 100%;
	margin-top: 60px;
	padding: 0 60px 0;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: column;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 20px;
}

.style {
	width: 520px;
	height: 1020px;
	position: relative;
}

.style_bg {
	width: 500px;
	height: 100%;
	background-color: #C5FF05;
	position: absolute;
	left: 20px;
	top: 0;
}

.style_photo_main {
	width: 500px;
	height: 750px;
	position: absolute;
	left: 0;
	top: 20px;
	overflow: hidden;
}

.style_photo_main .slick-list,
.style_photo_main .slick-track,
.style_photo_main .slick-slide,
.style_photo_main .slick-slide > div {
	height: 100%;
}

.style_photo_main img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.thumbnail {
	width: 500px;
	height: 250px;
	position: absolute;
	left: 0;
	top: 770px;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: row;
	justify-content: flex-start;
	align-items: stretch;
}

.thumbnail li {
	width: 33.333%;
	height: 100%;
	overflow: hidden;
	cursor: pointer;
	position: relative;
	transition: opacity 0.25s ease 0s;
}

.thumbnail li:hover {
	opacity: 0.75;
}

.thumbnail li.is-current::after {
	content: "";
	width: 100%;
	height: 100%;
	border: 2px solid #C5FF05;
	box-sizing: border-box;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 2;
	pointer-events: none;
}

.thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.credits {
	width: 234px;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: column;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 10px;
}

.credit {
	width: 100%;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: row;
	justify-content: flex-start;
	align-items: center;
	gap: 10px;
}

.credit p {
	color: #333333;
	font-family: "bebas-neue-pro", sans-serif;
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 0.89;
	letter-spacing: 0.03em;
	font-style: normal;
	white-space: nowrap;
}

.credit > div {
	flex: 0 0 auto;
	line-height: 1;
}

.credit .items__a {
	min-width: 74px;
	height: 22px;
	padding: 0 18px;
	background-color: #C5FF05;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	color: #333333;
	font-family: "bebas-neue-pro", sans-serif;
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 0.89;
	letter-spacing: 0.03em;
	font-style: normal;
}

.credit .item-d-none .items__a {
	display: none;
}

.staff {
	width: 100%;
	margin-top: 100px;
	background-color: #C5FF05;
	position: relative;
}

.staff_inner {
	width: 360px;
	margin: 0 auto;
	padding: 60px 0;
	display: flex;
	flex-wrap: wrap;
	flex-direction: row;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 40px;
}

.staff_item {
	width: 160px;
	min-height: 233px;
	position: relative;
	text-align: left;
}

.staff_photo {
	width: 156px;
	aspect-ratio: 1/1;
	background-color: #000;
	box-shadow: 4px 4px 0 #000;
	overflow: hidden;
	position: relative;
}

.staff_photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.staff_name {
	margin-top: 20px;
	color: #000;
	font-family: "bebas-neue-pro", sans-serif;
	font-size: 2.6rem;
	font-weight: 600;
	line-height: 1;
	letter-spacing: 0.03em;
	font-style: normal;
}

.staff_position {
	margin-top: 8px;
	color: #000;
	font-family: "bebas-neue-pro", sans-serif;
	font-size: 2rem;
	font-weight: 600;
	line-height: 1;
	letter-spacing: 0.03em;
	font-style: normal;
}

.staff_instagram {
	margin-top: 14px;
}

.staff_instagram a {
	color: #000;
	font-family: "bebas-neue-pro", sans-serif;
	font-size: 1.6rem;
	font-weight: 600;
	line-height: 1;
	letter-spacing: 0.03em;
	font-style: normal;
	text-decoration: underline;
	text-underline-offset: 2px;
}

footer {
	width: 100%;
	margin-top: 0;
	position: relative;
	text-align: center;
}

footer .infoot {
	width: 100%;
	padding: 80px 20px 60px;
}

footer .logo {
	width: 216px;
	margin: 0 auto 50px;
}

footer .logo img {
	width: 100%;
	height: auto;
	display: block;
}

footer ul {
	display: flex;
	flex-wrap: nowrap;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	gap: 20px;
	margin-bottom: 50px;
}

footer li a,
footer p {
	color: #000;
	font-family: "bebas-neue-pro", sans-serif;
	font-size: 1.2rem;
	font-weight: 400;
	line-height: 1;
	letter-spacing: 0.03em;
	font-style: normal;
}

footer li a {
	text-decoration: underline;
	text-underline-offset: 2px;
}

@media screen and (max-width: 768px) {
	#container {
		display: block;
	}

	.main_visual,
	.main_contents {
		width: 100%;
	}

	.main_visual {
		height: auto;
		position: relative;
		top: auto;
		left: auto;
		z-index: auto;
	}

	.main_visual .inner {
		width: 100%;
		height: auto;
		min-height: 0;
		aspect-ratio: 640/1103;
	}

	.main_visual_bg {
		width: 81.25%;
	}

	.main_photo_grid {
		width: 100%;
		column-gap: 3.125%;
		row-gap: 3.125vw;
	}

	.main_contents {
		min-height: 0;
	}

	.item_section {
		margin-top: 120px;
	}

	.item_section.item01 {
		margin-top: 100px;
	}

	.lead {
		padding-top: 60px;
	}

	.main_item {
		padding-right: 40px;
		padding-left: 40px;
	}

	.heading p {
		margin-bottom: 6px;
		font-size: 1.6rem;
	}

	.credit_tee {
		top: 86.3095238095%;
		left: 4.2410714286%;
	}

	.circle_icon {
		width: 100px;
		right: -28px;
		top: -35px;
	}

	.styles {
		margin-top: 60px;
		padding-right: 20px;
		padding-left: 20px;
	}

	.style {
		width: 100%;
		height: auto;
		aspect-ratio: 520/1020;
	}

	.style_bg {
		width: 96.1538461538%;
		height: 100%;
		left: 3.8461538462%;
	}

	.style_photo_main {
		width: 96.1538461538%;
		height: 73.5294117647%;
		top: 1.9607843137%;
	}

	.thumbnail {
		width: 96.1538461538%;
		height: 24.5098039216%;
		top: 75.4901960784%;
	}

	.staff_inner {
		width: 80%;
		gap: 30px;
	}

	.staff_item {
		width: calc((100% - 30px) / 2);
	}

	.staff_photo {
		width: calc(100% - 4px);
	}

	.staff_name {
		margin-top: 15px;
		font-size: 2.4rem;
	}

	.staff_position {
		margin-top: 5px;
		font-size: 1.8rem;
	}

	.staff_instagram {
		margin-top: 12px;
	}
}
