/**
 *
 * page-home.scss
 *
 */
/* ------------------------------------------------------------
 home-kv
------------------------------------------------------------ */
.home-kv {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	height: var(--wh);
	/* ---------- is-load ---------- */
	/* ---------- is-open ---------- */
	/* ---------- is-transition ---------- */
}

@media screen and (min-width: 561px) {
	.home-kv {
		min-height: 76.8rem;
	}
}

@media screen and (min-width: 1024px) {
	.home-kv {
		padding: 8.2rem 0 7.6rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-kv {
		padding: 9.5rem 0 9.5rem;
	}
}

@media screen and (max-width: 560px) {
	.home-kv {
		min-height: 42rem;
	}
}

.home-kv.is-load .home-kv__frame {
	width: var(--main-width);
	height: 100%;
	transition: var(--transition-loading-logo);
	transition-property: width,height;
}

.home-kv.is-load .home-kv__main {
	opacity: 1;
	visibility: visible;
	transition: var(--transition-loading-shown);
	transition-delay: 1700ms;
	transition-property: opacity,visibility;
}

body.is-loaded .home-kv .home-kv__frame {
	transition: none;
}

body.is-loaded .home-kv .home-kv__main {
	transition: var(--transition-nav-item);
	transition-delay: 1100ms;
	transition-property: opacity,visibility;
}

.home-kv.is-open .home-kv__bg {
	pointer-events: auto;
}

.home-kv.is-open .home-kv__inner,
.home-kv.is-open .home-kv__frame {
	border-radius: 0px;
}

@media screen and (min-width: 1024px) {
	.home-kv.is-open .home-kv__inner,
	.home-kv.is-open .home-kv__frame {
		width: var(--contents);
	}
}

.home-kv.is-open .home-kv__main {
	opacity: 0;
	visibility: hidden;
	transition-delay: 0ms !important;
}

.home-kv.is-open .home-kv__nav {
	opacity: 1;
	visibility: visible;
	transition-delay: 1000ms;
}

.home-kv.is-transition .home-kv__inner,
.home-kv.is-transition .home-kv__frame {
	transition: var(--transition-nav) !important;
	transition-property: width,border-radius !important;
}

.home-kv__main {
	opacity: 0;
	visibility: hidden;
}

.home-kv__nav {
	transition: var(--transition-nav-item);
	transition-property: opacity,visibility;
}

/* ----------------------------------------
 home-kv__bg
---------------------------------------- */
.home-kv__bg {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
	pointer-events: none;
}

/* ----------------------------------------
 home-kv__inner
---------------------------------------- */
.home-kv__inner {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--main-width);
	height: 100%;
	--radius: calc( var(--main-width) * var(--radius-ratio) );
}

@media screen and (min-width: 1024px) {
	.home-kv__inner {
		--inner-width: 810;
		--inner-height: 840;
		--radius-ratio: calc( 403 / 810 );
		aspect-ratio: 810 / 840;
		max-height: 84rem;
	}
}

@media screen and (min-width: 1441px) {
	.home-kv__inner {
		max-height: 100.8rem;
	}
}

@media screen and (min-width: 1921px) {
	.home-kv__inner {
		max-height: 117.6rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__inner {
		--inner-width: 304;
		--radius-ratio: calc( 152 / 304 );
		aspect-ratio: 304 / 476;
	}
}

@media screen and (max-width: 1023px) and (min-width: 561px) {
	.home-kv__inner {
		max-height: 76.16rem;
	}
}

@media screen and (max-width: 560px) {
	.home-kv__inner {
		max-height: 47.6rem;
	}
}

/* ------------------------------
 home-kv__main
------------------------------ */
.home-kv__frame {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	pointer-events: none;
	border-radius: var(--radius) var(--radius) 0 0;
	border: var(--solid);
	background-color: var(--color-bg);
}

@media screen and (min-width: 1024px) {
	.home-kv__frame {
		width: 16rem;
		height: 21.8rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__frame {
		width: 5.3rem;
		height: 7.2rem;
	}
}

/* ------------------------------
 home-kv__main
------------------------------ */
.home-kv__main {
	position: relative;
	z-index: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	aspect-ratio: inherit;
	border: var(--solid);
	border-color: var(--pallet-transp);
}

.home-kv__en,
.home-kv__button__txt {
	--font-size-ratio: calc( var(--font-size) / var(--inner-width) );
	font-size: calc( var(--main-width) * var(--font-size-ratio));
}

/* ---------- home-kv__cath ---------- */
@media screen and (min-width: 1024px) {
	.home-kv__cath {
		width: calc( ( 324 / var(--inner-width) ) * 100%);
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__cath {
		width: calc( ( 147 / var(--inner-width) ) * 100%);
	}
}

.home-kv__cath img {
	width: 100%;
}

/* ---------- home-kv__en ---------- */
.home-kv__en {
	position: absolute;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	font-family: var(--font-serif);
	padding-top: 0.1px;
	padding-bottom: 0.1px;
	white-space: nowrap;
}

.home-kv__en::before, .home-kv__en::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	font-size: inherit;
}

.home-kv__en::before {
	margin-right: var(--font-serif-top);
}

.home-kv__en::after {
	margin-left: var(--font-serif-bottom);
}

@media screen and (min-width: 1024px) {
	.home-kv__en {
		--font-size: 32;
		bottom: calc( ( 85 / var(--inner-height) ) * 100%);
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__en {
		--font-size: 16;
		top: 50%;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
	}
}

@media screen and (min-width: 1024px) {
	.home-kv__en.-left {
		left: calc( ( 18 / var(--inner-width) ) * 100%);
		-webkit-transform: scale(-1, -1);
		transform: scale(-1, -1);
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__en.-left {
		left: calc( ( 5 / var(--inner-width) ) * 100%);
		-webkit-transform: translateY(-50%) scale(-1, -1);
		transform: translateY(-50%) scale(-1, -1);
	}
}

@media screen and (min-width: 1024px) {
	.home-kv__en.-right {
		right: calc( ( 18 / var(--inner-width) ) * 100%);
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__en.-right {
		right: calc( ( 5 / var(--inner-width) ) * 100%);
	}
}

/* ---------- home-kv__button ---------- */
.home-kv__button {
	position: absolute;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	transition: none;
}

@media screen and (min-width: 1024px) {
	.home-kv__button {
		min-width: calc( ( 194 / var(--inner-width) ) * 100%);
		bottom: calc( ( 24 / var(--inner-height) ) * 100%);
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__button {
		min-width: calc( ( 194 / var(--inner-width) ) * 100%);
		bottom: calc( ( 22 / var(--inner-height) ) * 100%);
	}
}

.home-kv__button__txt {
	display: block;
	font-weight: 600;
}

@media screen and (min-width: 1024px) {
	.home-kv__button__txt {
		--font-size: 19;
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__button__txt {
		--font-size: 12;
	}
}

@media screen and (min-width: 1024px) {
	.home-kv__button__back {
		margin-top: -1.5rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__button__back {
		margin-top: -1.4rem;
	}
}

/* ------------------------------
 home-kv__nav
------------------------------ */
.home-kv__nav {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	width: 100%;
	height: 100%;
	opacity: 0;
	visibility: hidden;
	border: var(--solid);
	border-color: var(--pallet-transp);
}

@media screen and (min-width: 1024px) {
	.home-kv__nav {
		--inner-width: 1240;
		--inner-height: 840;
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__nav {
		--inner-width: 304;
		--inner-height: 474;
	}
}

.home-kv__nav__inner {
	display: flex;
	flex-direction: row-reverse;
	align-items: center;
	width: 100%;
	height: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	-ms-scroll-chaining: none;
	overscroll-behavior: none;
}

@media screen and (min-width: 1024px) {
	.home-kv__nav__inner {
		padding: 0 calc( ( 70 / var(--inner-width) ) * 100%);
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__nav__inner {
		padding: 0 calc( ( 28 / var(--inner-width) ) * 100%);
	}
}

.home-kv__nav__title {
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	font-family: var(--font-serif);
	padding-top: 0.1px;
	padding-bottom: 0.1px;
}

.home-kv__nav__title::before, .home-kv__nav__title::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	font-size: inherit;
}

.home-kv__nav__title::before {
	margin-right: var(--font-serif-top);
}

.home-kv__nav__title::after {
	margin-left: var(--font-serif-bottom);
}

@media screen and (min-width: 1024px) {
	.home-kv__nav__title {
		font-size: var(--font-size53);
		margin-left: 12.8rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__nav__title {
		font-size: var(--font-size30);
		margin-left: 7.2rem;
	}
}

.home-kv__nav__list {
	flex: 1;
	display: flex;
	flex-direction: row-reverse;
}

@media screen and (min-width: 1024px) {
	.home-kv__nav__list {
		height: calc( ( 450 / var(--inner-height) ) * 100%);
		gap: 6rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__nav__list {
		height: calc( ( 258 / var(--inner-height) ) * 100%);
		gap: 3.5rem;
	}
}

.home-kv__nav__list a {
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: upright;
	font-weight: 600;
	letter-spacing: calc( 200 / 1000 * 1em);
	transition-property: opacity;
}

@media (hover: hover) {
	.home-kv__nav__list a:hover {
		opacity: var(--hover-opacity);
	}
}

@media screen and (min-width: 1024px) {
	.home-kv__nav__list a {
		font-size: var(--font-size28);
	}
}

@media screen and (max-width: 1023px) {
	.home-kv__nav__list a {
		font-size: var(--font-size16);
	}
}

/* ------------------------------------------------------------
 home-about
------------------------------------------------------------ */
@media screen and (min-width: 1024px) {
	.home-about {
		--inner-padding-top: 21.3rem;
		--inner-padding-bottom: 21.3rem;
		--title-top: 19.3rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-about {
		--inner-padding-top: 12.7rem;
		--inner-padding-bottom: 5.5rem;
		--title-top: 4rem;
	}
}

@media screen and (min-width: 1024px) {
	.home-about__txt {
		width: calc( ( 590 / var(--inner-width) ) * 100%);
	}
}

/* ------------------------------------------------------------
 home-cast
------------------------------------------------------------ */
@media screen and (min-width: 1024px) {
	.home-cast {
		--title-top: 12.9rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-cast {
		--title-top: 5.2rem;
	}
}

@media screen and (min-width: 1024px) {
	.home-cast .c-illust.-type2 {
		width: 25rem;
		top: 16rem;
		right: calc( ( 346 / var(--inner-width) ) * 100%);
	}
}

@media screen and (max-width: 1023px) {
	.home-cast .c-illust.-type2 {
		width: 13.5rem;
		top: -2.3rem;
		right: calc( ( 68 / var(--inner-width) ) * 100%);
	}
}

@media screen and (min-width: 1024px) {
	.home-cast .c-illust.-type3 {
		width: 21.2rem;
		bottom: -7.4rem;
		right: calc( ( 364 / var(--inner-width) ) * 100%);
	}
}

@media screen and (max-width: 1023px) {
	.home-cast .c-illust.-type3 {
		width: 12.8rem;
		bottom: -11.4rem;
		right: calc( ( 74 / var(--inner-width) ) * 100%);
	}
}

/* ----------------------------------------
 home-cast__section
---------------------------------------- */
.home-cast__section {
	padding-left: var(--grid);
}

@media screen and (min-width: 1024px) {
	.home-cast__section {
		width: calc( ( 844 / var(--inner-width) ) * 100%);
		max-width: 143.4rem;
		padding-top: 22rem;
		padding-bottom: 22rem;
		padding-right: calc( ( 127 / var(--inner-width) ) * 100%);
	}
}

@media screen and (max-width: 1023px) {
	.home-cast__section {
		width: 100%;
		padding-top: 5rem;
		padding-bottom: 5rem;
	}
}

.home-cast__section + .home-cast__section {
	border-top: var(--solid);
}

/* ---------- home-cast__name ---------- */
.home-cast__name {
	font-weight: 600;
	letter-spacing: calc( 100 / 1000 * 1em);
}

@media screen and (min-width: 1024px) {
	.home-cast__name {
		margin-top: 12.3rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-cast__name {
		margin-top: 8rem;
	}
}

.home-cast__name__job {
	font-size: var(--font-size13);
}

.home-cast__name__main {
	display: flex;
	align-items: center;
	margin-top: 1.8rem;
}

.home-cast__name__ja {
	font-size: var(--font-size25);
}

.home-cast__name__nickname {
	font-size: var(--font-size15);
}

.home-cast__name__kana {
	font-size: var(--font-size13);
	margin-top: 1.5rem;
}

/* ---------- home-cast__txt ---------- */
@media screen and (min-width: 1024px) {
	.home-cast__txt {
		margin-top: 6.2rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-cast__txt {
		margin-top: 4.5rem;
	}
}

.home-cast__txt + .home-cast__txt {
	margin-top: 1em;
}

/* ---------- home-cast__list ---------- */
@media screen and (min-width: 1024px) {
	.home-cast__list {
		margin-top: 5.6rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-cast__list {
		margin-top: 5.2rem;
	}
}

/* ---------- home-cast__txt2 ---------- */
@media screen and (min-width: 1024px) {
	.home-cast__txt2 {
		margin-top: 9rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-cast__txt2 {
		margin-top: 5.2rem;
	}
}

/* ------------------------------------------------------------
 home-works
------------------------------------------------------------ */
.home-works {
	overflow: hidden;
}

@media screen and (min-width: 1024px) {
	.home-works {
		--inner-padding-top: 21.5rem;
		--inner-padding-bottom: 12.5rem;
		--title-top: 21.5rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-works {
		--inner-padding-top: 5.2rem;
		--inner-padding-bottom: 4.5rem;
		--title-top: 4rem;
	}
}

/* ---------- home-works__header ---------- */
.home-works__header {
	position: relative;
	z-index: 10;
}

/* ---------- home-works__title2 ---------- */
@media screen and (min-width: 1024px) {
	.home-works__title2 {
		display: none;
	}
}

/* ---------- home-works__list ---------- */
.home-works__list {
	position: relative;
	z-index: 0;
}

@media screen and (max-width: 1023px) {
	.home-works__list {
		margin-top: 8rem;
	}
}

@media screen and (min-width: 1024px) {
	.home-works__list article {
		width: 86.4rem;
	}
}

@media screen and (max-width: 1023px) and (min-width: 561px) {
	.home-works__list article {
		width: 40rem;
	}
}

@media screen and (max-width: 560px) {
	.home-works__list article {
		width: 23.8rem;
	}
}

@media screen and (min-width: 1024px) {
	.home-works__list article:not(:last-of-type) {
		margin-right: 12.2rem;
	}
}

@media screen and (max-width: 1023px) {
	.home-works__list article:not(:last-of-type) {
		margin-right: 1.8rem;
	}
}
/*# sourceMappingURL=sourcemaps/page-home.css.map */
