@charset "utf-8";

@property --clip {
	syntax: "*";
	initial-value: 0%;
	inherits: true
}

/* __________ パララックス 設定 __________ */
.parallax {
	position: relative;
	width: 100%;
	overflow: hidden;
	aspect-ratio: var(--parallax-fr);
}
.parallax-item {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	aspect-ratio: var(--parallax-img);
}
.parallax-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.is-parallax .parallax-img {
	will-change: transform;
}


/* _____ ヘッダー コンテンツ _____ */
.header-wrapper {
	display: none;
}
@media (min-width: 960px) {
	.header-wrapper {
		display: grid;
		grid-template-columns: 615rem 1fr;
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		pointer-events: none;
		z-index: var(--z-header);
	}
	.header-left {
		position: relative;
		width: 100%;
		height: 100%;
		transform: scale(1);
		transform-origin: 0 0;
		transition: transform var(--duration-1000) var(--ease-out-expo);
	}
	/* logo */
	.header-wrapper .logo-shadow {
		inline-size: 615rem;
		aspect-ratio: 615 / 463;
	}
	.header-wrapper .logo {
		position: absolute;
		top: 32rem;
		left: 64rem;
		inline-size: 480rem;
	}
	.header-wrapper .logo:lang(ja) {
		aspect-ratio: 480 / 312;
	}
	.header-wrapper .logo:lang(en) {
		aspect-ratio: 480 / 237;
	}
	.header-wrapper .onair {
		position: absolute;
		opacity: 1;
		visibility: visible;
		transition: var(--duration-1000) var(--ease-out-expo);
	}
	.header-wrapper .onair:lang(ja) {
		top: 354rem;
		left: 74rem;
		inline-size: 455rem;
		aspect-ratio: 704 / 124;
	}
	.header-wrapper .onair:lang(en) {
		top: 294rem;
		left: 62rem;
		inline-size: 480rem;
		aspect-ratio: 680 / 111;
	}
	.is-frame .header-left {
		transform: scale(0.36);
	}
	.is-frame .header-wrapper .onair {
		opacity: 0;
		visibility: hidden;
	}

	/* ナビゲーション */
	.header-nav {
		display: grid;
		align-items: center;
		justify-content: end;
		grid-template-columns: max-content max-content;
		column-gap: calc(48rem - 12rem);
		block-size: 100rem;
		padding-inline-end: 32rem;
		opacity: 1;
		visibility: visible;
		transition: var(--duration-1000) var(--ease-out-expo);
	}
	.header-nav-list {
		display: flex;
	}
	.header-nav-link {
		display: grid;
		align-items: center;
		justify-items: center;
		block-size: 40rem;
		inline-size: fit-content;
		padding-inline: 12rem;
		color: var(--color-white);
		font-size: 20rem;
	}
	.header-nav-link:lang(ja) {
		font-weight: 800;
	}
	.header-nav-link:lang(en) {
		font-weight: 900;
	}
	.header-nav-link:hover,
	.header-nav-link.menu-focus {
		color: var(--color-red);
	}

	.header-lang-list {
		display: flex;
	}
	.is-frame .header-nav {
		opacity: 0;
		visibility: hidden;
	}
}


/* _____ キービジュアル _____ */
.hero-area {
	--clip: 100%;
	--clip-deg: 168rem;
	position: absolute;
	width: 100%;
	aspect-ratio: var(--hero-as);
	overflow: hidden;
	clip-path: polygon(0 0, 100% 0%, 100% var(--clip), 0% calc(var(--clip) + var(--clip-deg)));
}
.kv-wrapper {
	position: fixed;
	width: 100%;
	height: 100%;
	z-index: var(--z-bottom-level);
}
.kv-container {
	position: relative;
}
.kv-wrapper .logo {
	position: absolute;
	top: 64rem;
	left: 0;
	right: 0;
	margin-inline: auto;
	inline-size: 560rem;
	aspect-ratio: 660 / 446;
}
.kv-wrapper .onair {
	position: absolute;
	left: 0;
	right: 0;
	margin-inline: auto;
}
.kv-wrapper .onair:lang(ja) {
	bottom: 64rem;
	inline-size: 704rem;
	aspect-ratio: 704 / 124;
}
.kv-wrapper .onair:lang(en) {
	bottom: 16rem;
	inline-size: 680rem;
	aspect-ratio: 680 / 111;
}
.kv-wrapper .catch {
	position: absolute;
}
.kv-wrapper .catch:lang(ja) {
	top: 160rem;
	right: 16rem;
	inline-size: 176rem;
	aspect-ratio: 176 / 946;
}
.kv-wrapper .catch:lang(en) {
	bottom: 112rem;
	right: 0;
	left: 0;
	margin-inline: auto;
	inline-size: 896rem;
	aspect-ratio: 960 / 160;
}
.kv-border {
	width: 100%;
	height: var(--clip-deg);
}
@media (min-width: 960px) {
	.hero-area {
		--clip-deg: 336rem;
	}
	.kv-wrapper .logo,
	.kv-wrapper .onair {
		display: none;
	}
	.kv-wrapper .catch:lang(ja) {
		top: 180rem;
		right: 32rem;
	}
	.kv-wrapper .catch:lang(en) {
    bottom: 96rem;
    inline-size: 960rem;
	}
}


/* _____ キービジュアルとメインコンテンツの境界線 _____ */
.kv-area {
	width: 100%;
	aspect-ratio: var(--kv-as);
}
.blank-space {
	pointer-events: none;
}
.border {
	position: relative;
	width: 100%;
	height: 40rem;
	margin-block: -1px;
	transform: skewY(-10deg);
	transform-origin: top right;
	z-index: var(--z-lower-level);
}
.border-1 {
	-webkit-backdrop-filter: blur(.5px) grayscale(0.2);
	backdrop-filter: blur(.5px) grayscale(0.2);
}
.border-2 {
	-webkit-backdrop-filter: blur(1px) grayscale(0.4);
	backdrop-filter: blur(1px) grayscale(0.4);
}
.border-3 {
	-webkit-backdrop-filter: blur(1.5px) grayscale(0.6);
	backdrop-filter: blur(1.5px) grayscale(0.6);
}
.border-4 {
	-webkit-backdrop-filter: blur(2px) grayscale(0.8);
	backdrop-filter: blur(2px) grayscale(0.8);
}
.border-5 {
	-webkit-backdrop-filter: blur(2.5px) grayscale(1);
	backdrop-filter: blur(2.5px) grayscale(1);
}
@media (min-width: 960px) {
	.border {
		height: 80rem;
	}
}

/* 文字スクロール */
.border-wrapper {
	position: relative;
	display: grid;
	width: 100%;
	height: calc(360rem - 18px);
	align-items: center;
	transform: skewY(-10deg);
	transform-origin: top right;
	overflow: hidden;
	z-index: var(--z-middle-level);
}
.border-txt-contents {
	display: flex;
	column-gap: 16rem;
	white-space: nowrap;
	will-change: transform;
}
.border-txt {
	display: inline-block;
	padding-block-end: 8rem;
	color: var(--color-white-alpha20);
	font-family: var(--font-oswald);
	font-size: 32rem;
	font-weight: 700;
	letter-spacing: .05em;
	filter: drop-shadow(0 0 8px #fbc95680) blur(0.5px);
}
@media (min-width: 960px) {
	.border-wrapper {
		height: calc(720rem - 18px);
	}
	.border-txt-contents {
		column-gap: 24rem;
	}
	.border-txt {
		padding-block-end: 16rem;
		font-size: 64rem;
	}
}


/* _____ ニュース _____ */
.news-article {
	display: block;
	background-color: var(--color-denki-black);
}
.news-article ~ .news-article {
	margin-block-start: 16rem;
}
.news-head {
	display: grid;
	align-items: center;
	grid-template-columns: max-content minmax(0, 1fr) max-content;
	column-gap: 16rem;
}
.news-date {
	padding: 24rem 16rem;
	color: var(--color-red);
	font-family: var(--font-oswald);
	font-size: 48rem;
	font-weight: 700;
}
.news-date-yyyy {
	display: flex;
	justify-content: space-between;
	margin-block-start: var(--leading-trim);
	margin-block-end: -.25em;
	padding-inline: .25em;
	font-size: 20rem;
}
.news-date-md {
	margin-block: var(--leading-trim);
}
.news-title {
	padding-block: 16rem;
	color: var(--color-white);
	font-size: 24rem;
	font-weight: 500;
}
.news-arrow {
	--_svg-size: 24rem;
	width: 100%;
	height: 100%;
	min-block-size: 120rem;
	max-inline-size: 80rem;
	color: var(--color-denki-black);
	background-color: var(--color-red);
}
.news-more {
	display: grid;
	align-items: center;
	grid-template-columns: 1fr auto 1fr;
	inline-size: 320rem;
	padding: 16rem;
	margin-inline: auto;
	margin-block-start: 48rem;
	color: var(--color-red);
	font-size: 20rem;
	font-weight: 500;
	border: 2px currentColor solid;
}
.news-more:before {
	content: "";
}
.news-more-arrow {
	--_svg-size: 16rem;
	margin-inline: auto 0;
}
@media (any-hover: hover) {
	.news-article:hover .news-title {
		color: var(--color-red);
	}
	/* .news-article:hover .news-arrow {
		color: var(--color-white);
	} */
	.news-more:hover {
		color: var(--color-white);
		background-color: var(--color-red);
		border-color: var(--color-red);
	}
}
@media (min-width: 960px) {
	.news-arrow {
		--_svg-size: 32rem;
		max-inline-size: 120rem;
	}
}


/* _____ イントロダクション _____ */
.intro-contents {
	position: relative;
	z-index: var(--z-foreground);
}
.intro-separate {
	--parallax-fr: 1920 / 450;
	--parallax-img: 1920 / 540;
	position: relative;
	width: 100vw;
	margin-left: calc((50vw - 50%) * -1);
	margin-block: 96rem;
	pointer-events: none;
}
.intro-bg {
	--parallax-fr: 1920 / 800;
	--parallax-img: 1920 / 1288;
	position: relative;
	width: 100vw;
	margin-left: calc((50vw - 50%) * -1);
	pointer-events: none;
}
.intro01 {
	display: inline grid;
	row-gap: 32rem;
}
.intro02 {
	display: inline grid;
	row-gap: 16rem;
	margin-block-start: 96rem;
}
.intro03 {
	display: inline grid;
	row-gap: 48rem;
	margin-block-start: 96rem;
}
.intro04 {
	display: inline grid;
	row-gap: 32rem;
	margin-block-start: 96rem;
}
.intro04 .text-line:last-of-type {
	margin-block-start: 8rem;
}
.is-mobile .text-line[data-type="desktop"] {
	display: none;
}
.is-desktop .text-line[data-type="mobile"] {
	display: none;
}
.intro05 {
	display: inline grid;
	row-gap: 24rem;
}
.intro06 {
	display: inline grid;
	row-gap: 24rem;
	margin-block-start: 64rem;
	margin-block-end: 112rem;
}
.font-LB {
	font-size: 46rem;
}
.font-LB:lang(ja) {
	font-weight: 800;
}
.font-LB:lang(en) {
	font-weight: 900;
}
.font-MR {
	font-size: 30rem;
	font-weight: 400;
}
.font-MM {
	font-size: 30rem;
	font-weight: 500;
}
.text-line {
	display: block;
	margin-block: var(--leading-trim);
	line-height: 1.8;
}
.text-yellow {
	color: var(--color-yellow);
}
.marker-red {
	color: var(--color-denki-black);
	--color-marker: var(--color-red);
}
.marker-yellow {
	color: var(--color-denki-black);
	--color-marker: var(--color-yellow);
}
.marker-black {
	color: var(--color-white);
	--color-marker: var(--color-denki-black);
}
.text-marker {
	padding-inline: .25em;
	background: linear-gradient(transparent 10%, var(--color-marker) 10%, var(--color-marker) 98%, transparent 98%);
	filter: drop-shadow(1px 1px 0px var(--color-denki-black)) drop-shadow(0px -1px 0px var(--color-denki-black)) drop-shadow(-1px 0px 0px var(--color-denki-black));
}
.text-excl {
	margin-inline-start: -.25em;
}
.text-square-s {
	margin-inline: .15em .1em;
}
.text-square-e {
	margin-inline: .1em .15em;
}
.text-angle-s {
	margin-inline: .25em .1em;
}
.text-angle-e {
	margin-inline: .1em .25em;
}
.text-dash {
	display: inline grid;
	position: relative;
	width: 2em;
	height: .75em;
	margin-inline: .2em;
}
.text-dash:after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 100%;
	height: .08em;
	margin: auto;
	background-color: currentColor;
}
@media (min-width: 960px) {
	.intro-separate {
		margin-block: 160rem;
	}
	.intro02 {
		margin-block-start: 112rem;
	}
	.intro06 {
		margin-block-start: 48rem;
		margin-block-end: 160rem;
	}
	.font-LB {
		font-size: 48rem;
	}
	.font-MR {
		font-size: 28rem;
	}
	.font-MM {
		font-size: 28rem;
	}
}


/* _____ スタッフ ／ キャスト 共通 _____ */
.credits-bg {
	position: absolute;
	top: 128rem;
	left: 0;
	width: 60vw;
	height: 80vh;
	margin-left: 40%;
	overflow: hidden;
	pointer-events: none;
	z-index: var(--z-background);
}
.credits-bg-img {
	width: 100%;
	height: 120%;
	object-fit: cover;
	object-position: bottom;
}
.is-parallax .credits-bg-img {
	will-change: transform;
}
.credits-contents {
	position: relative;
	display: grid;
	grid-template-columns: minmax(300rem, max-content) 1fr;
	column-gap: 48rem;
	row-gap: 64rem;
	z-index: var(--z-foreground);
}
.staff-container .credits-contents {
	padding-block-start: calc(16vh - 128rem);
}
.cast-container {
	padding-block-end: calc(50vh - 128rem);
}
.credits-item {
	display: grid;
	grid-template-columns: subgrid;
	align-items: center;
	grid-column: 1 / -1;
}
.credits-role {
	display: flex;
	flex-direction: column;
	color: var(--color-red);
	font-size: 28rem;
	font-weight: 500;
}
.credits-name {
	display: flex;
	flex-direction: column;
	color: var(--color-white);
	font-size: 40rem;
	font-weight: 500;
}
.credits-name span:not(.icon-comment) {
	text-shadow: 0px 0px 5px var(--color-black-alpha60);
}
.credits-indent {
	text-indent: -0.45em;
}
.credits-sub {
	font-size: 24rem;
	margin-block-start: 14rem;
}
.comment-btn {
	display: grid;
	grid-template-columns: max-content minmax(0, 1fr);
	align-items: center;
	column-gap: 16rem;
	width: fit-content;
}
.icon-comment {
	--_svg-size: 56rem;
	--_svg-aspect: 34 / 25;
	color: var(--color-white);
	transform: scale(1);
	transform-origin: bottom left;
	transition: transform var(--duration-500) var(--ease-out-expo);
}
.path-comment-balloon {
	fill: var(--color-red);
}
@media (any-hover: hover) {
	.comment-btn:hover .icon-comment {
		transform: scale(1.2);
	}
}
@media (min-width: 960px) {
	.credits-contents {
		grid-template-columns: minmax(320rem, max-content) 1fr;
		column-gap: 64rem;
		row-gap: 80rem;
	}
	.staff-container .credits-contents {
		padding-block-start: calc(50vh - 128rem);
	}
	.cast-container {
		padding-block-end: calc(50vh - 128rem);
	}
	.credits-sub {
		margin-block-start: 0;
	}
}


/* _____ キャラクター _____ */
.container.character-container {
	padding-inline: 0;
}
/* _____ キャラクター 背景ライン _____ */
.chara-contents {
	position: relative;
	width: 100%;
	height: 100%;
}
.chara-contents ~ .chara-contents {
	margin-block-start: 128rem;
}
.chara-bg {
	display: none;
}
@media (min-width: 960px) {
	.chara-contents ~ .chara-contents {
		margin-block-start: 240rem;
	}
	.chara-bg {
		display: grid;
		align-content: center;
		grid-template-columns: 1fr;
		grid-template-rows: repeat(3, 400rem);
		position: absolute;
		width: 100%;
		height: 100%;
		pointer-events: none;
		transform: skewY(-10deg);
	}
	.line-top {
		grid-column: 1 / -1;
		grid-row: 1 / 3;
		z-index: var(--z-bottom-level);
		transform: translate3d(-100%, 0, 0);
		transition: var(--duration-500) var(--ease-out-expo);
		transition-delay: var(--duration-1000);
	}
	.line-center {
		grid-column: 1 / -1;
		grid-row: 2 / 3;
		z-index: var(--z-lower-level);
		transform: scaleX(0) translate3d(0, 0, 0);
		transition: var(--duration-500) var(--ease-out-expo);
		transition-delay: var(--duration-500);
	}
	.line-bottom {
		grid-column: 1 / -1;
		grid-row: 2 / 4;
		z-index: var(--z-bottom-level);
		transform: translate3d(100%, 0, 0);
		transition: var(--duration-500) var(--ease-out-expo);
		transition-delay: var(--duration-1000);
	}
	.is-active.chara-contents .line-center {
		transform: scaleX(1.0) translate3d(0, 0, 0);
	}
	.is-active.chara-contents .line-top {
		transform: translate3d(0, 0, 0);
	}
	.is-active.chara-contents .line-bottom {
		transform: translate3d(0, 0, 0);
	}
	.chara-kihachi .line-top {
		background-image: linear-gradient(90deg, rgba(var(--color-rgb-kihachi), 1) 0%, rgba(var(--color-rgb-kihachi), .6) 75%, rgba(var(--color-rgb-kihachi), .05) 100%);
	}
	.chara-kihachi .line-center {
		background-color: var(--color-kihachi);
	}
	.chara-kihachi .line-bottom {
		background-image: linear-gradient(270deg, rgba(var(--color-rgb-kihachi), 1) 0%, rgba(var(--color-rgb-kihachi), .6) 75%, rgba(var(--color-rgb-kihachi), .05) 100%);
	}
	.chara-inako .line-top {
		background-image: linear-gradient(90deg, rgba(var(--color-rgb-inako), 1) 0%, rgba(var(--color-rgb-inako), .6) 75%, rgba(var(--color-rgb-inako), .05) 100%);
	}
	.chara-inako .line-center {
		background-color: var(--color-inako);
	}
	.chara-inako .line-bottom {
		background-image: linear-gradient(270deg, rgba(var(--color-rgb-inako), 1) 0%, rgba(var(--color-rgb-inako), .6) 75%, rgba(var(--color-rgb-inako), .05) 100%);
	}
}

/* _____ キャラクター メイン _____ */
.chara-body {
	position: relative;
	padding-block: 80rem;
	padding-inline: 26rem;
	color: var(--color-denki-black);
}
.chara-kihachi .chara-body {
	background-color: var(--color-kihachi);
}
.chara-inako .chara-body {
	background-color: var(--color-inako);
}
.chara-figure {
	display: grid;
	justify-content: center;
	justify-items: center;
	width: 100%;
	aspect-ratio: 864 / 1126;
	pointer-events: none;
	overflow: hidden;
}
.chara-figure-name {
	--_svg-size: 878rem;
	--_svg-aspect: 864 / 882;
	grid-area: full;
	z-index: var(--z-bottom-level);
}
.chara-figure-img {
	grid-area: full;
	inline-size: 480rem;
	z-index: var(--z-middle-level);
}
.chara-kihachi .chara-figure-img {
	filter: drop-shadow(10rem 0px 0px var(--color-kihachi));
}
.chara-inako .chara-figure-img {
	filter: drop-shadow(10rem 0px 0px var(--color-inako));
}
.chara-caption {
	display: grid;
	align-items: center;
	grid-template-columns: 400rem minmax(0, 1fr);
	column-gap: 16rem;
	padding-inline: 32rem;
	margin-block-start: 40rem;
}
.chara-furigana {
	font-size: 28rem;
	letter-spacing: .05em;
}
.chara-furigana:lang(ja) {
	font-weight: 800;
}
.chara-furigana:lang(en) {
	font-weight: 900;
}
.chara-name {
	position: relative;
	margin-block: var(--leading-trim);
	color: var(--color-white);
	font-size: 64rem;
	letter-spacing: .075em;
}
.chara-name:lang(ja) {
	font-weight: 800;
}
.chara-name:lang(en) {
	font-weight: 900;
}
.chara-name::before {
	content: attr(data-name);
	position: absolute;
	inset: 0;
	color: var(--color-denki-black);
	-webkit-text-stroke: 2rem var(--color-denki-black);
	z-index: var(--z-background);
}
.chara-name::first-letter {
	color: var(--color-denki-black);
}
.chara-name-upper {
	position: relative;
	z-index: var(--z-foreground);
}
.chara-va {
	display: flex;
	align-items: baseline;
	column-gap: 16rem;
	width: fit-content;
	padding-inline: 8rem;
	margin-block: 24rem 36rem;
	font-size: 28rem;
	font-weight: 700;
	background-color: var(--color-white);
	border: 2rem solid var(--color-denki-black);
}
.chara-kihachi .chara-va {
	color: var(--color-kihachi);
}
.chara-inako .chara-va {
	color: var(--color-inako);
}
.chara-va-name {
	color: var(--color-denki-black);
	font-size: 40rem;
	letter-spacing: .04em;
}
.chara-kihachi .chara-liner:lang(ja) {
	--_svg-size: 283rem;
	--_svg-aspect: 208 / 40;
}
.chara-kihachi .chara-liner:lang(en) {
	--_svg-size: 329rem;
	--_svg-aspect: 242 / 40;
}
.chara-inako .chara-liner:lang(ja) {
	--_svg-size: 272rem;
	--_svg-aspect: 224 / 40;
}
.chara-inako .chara-liner:lang(en) {
	--_svg-size: 363rem;
	--_svg-aspect: 267 / 40;
}
.chara-bio {
	margin-block-start: 24rem;
	color: var(--color-white);
	font-size: 28rem;
	font-weight: 700;
	line-height: 1.8;
	letter-spacing: .04em;
}
@media (min-width: 960px) {
	.chara-body {
		max-inline-size: 864rem;
		padding-block: 80rem;
		padding-inline: 0;
		margin-inline: auto;
	}
	.chara-figure-name {
		--_svg-size: 866rem;
	}
	.chara-figure-img {
		inline-size: 436rem;
	}
	.chara-caption {
		grid-template-columns: 432rem minmax(0, 1fr);
	}
	.chara-furigana {
		font-size: 14rem;
	}
	.chara-name:lang(ja) {
		font-size: 64rem;
	}
	.chara-name:lang(en) {
		font-size: 54rem;
	}
	.chara-va {
		font-size: 16rem;
	}
	.chara-va:lang(ja) {
		margin-block: 16rem 32rem;
	}
	.chara-va:lang(en) {
		margin-block: 24rem 32rem;
	}
	.chara-va-name {
		font-size: 24rem;
	}
	.chara-kihachi .chara-liner:lang(ja) {
		--_svg-size: 208rem;
	}
	.chara-kihachi .chara-liner:lang(en) {
		--_svg-size: 242rem;
	}
	.chara-inako .chara-liner:lang(ja) {
		--_svg-size: 224rem;
	}
	.chara-inako .chara-liner:lang(en) {
		--_svg-size: 267rem;
	}
	.chara-bio {
		margin-block-start: 16rem;
		font-size: 16rem;
	}
}
/* _____ キャラクター スライドショー 初期設定 _____ */
.slider-contents {
	position: relative;
	width: 100%;
	height: 100%;
	user-select: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	touch-action: none;
}
.slider-item {
	position: absolute;
	width: 100%;
	height: 100%;
	opacity: 0;
	visibility: hidden;
	transition: 500ms ease;
}
.is-active.slider-item {
	opacity: 1;
	visibility: visible;
}
/* _____ キャラクター スライドショー _____ */
.chara-face-list {
	aspect-ratio: 1;
}
.chara-face-btn-list {
	display: grid;
	justify-content: center;
	grid-template-columns: repeat(6, max-content);
	column-gap: 28rem;
	margin-block-start: 40rem;
}
.chara-face-btn {
	inline-size: 32rem;
	aspect-ratio: 1;
	background-color: var(--color-white);
	border-radius: 9999px;
}
.chara-face-btn:hover,
.is-active.chara-face-btn {
	background-color: var(--color-denki-black);
}
@media (min-width: 960px) {
	.chara-face-btn-list {
		column-gap: 16rem;
		margin-block-start: 24rem;
	}
	.chara-face-btn {
		inline-size: 24rem;
	}
}


/* _____ ムービー _____ */
.movie-container {
	padding-inline: 0;
}
.movie-contents {
	display: grid;
	position: relative;
	inline-size: 880rem;
	margin-inline: auto;
	aspect-ratio: 880 / 528;
}
.movie-item {
	display: grid;
	align-items: center;
	justify-items: center;
	position: relative;
	inline-size: 760rem;
	margin-inline: auto;
	aspect-ratio: 880 / 495;
	overflow: hidden;
}
.thumbnail-image {
	grid-area: full;
}
.movie-play-icon {
	--_svg-size: 760rem;
	grid-area: full;
	position: absolute;
}
.path-play-movie-outer,
.path-play-movie-inner {
	transform: rotate(0deg) translate3d(0, 0, 0);
	transform-origin: center;
	animation: play-rotate-animation 7968ms steps(12) 83ms infinite;
}
@keyframes play-rotate-animation {
	0% {
		transform: rotate(0deg) translate3d(0, 0 , 0);
	}
	100% {
		transform: rotate(-90deg) translate3d(0, 0 , 0);
	}
}
.path-play-movie-outer {
	fill: var(--color-yellow);
	opacity: .25;
	mix-blend-mode: plus-lighter;
}
.path-play-movie-inner {
	fill: var(--color-white);
}
.path-play-outer,
.path-play-inner,
.path-play-arrow {
	fill: var(--color-white);
	transform: scale(1);
	transform-origin: center;
	transition: var(--duration-500) var(--ease-out-back);
}
.path-play-outer {
	fill: var(--color-white);
}
.path-play-inner {
	fill: var(--color-denki-black);
}
.path-play-arrow {
	fill: var(--color-yellow);
}
@media (any-hover: hover) {
	.movie-item:hover .path-play-outer {
		transform: scale(1.36);
	}
	.movie-item:hover .path-play-inner {
		transform: scale(1.1);
	}
	.movie-item:hover .path-play-arrow {
		transform: scale(1.1);
	}
}
.movie-inari {
	position: absolute;
	left: -20rem;
	bottom: 0;
	width: 190rem;
	pointer-events: none;
}
@media (min-width: 960px) {
	.movie-container {
		padding-inline: 64rem;
	}
	.movie-contents {
		inline-size: 1104rem;
		aspect-ratio: 1104 / 576;
	}
	.movie-item {
		inline-size: 880rem;
	}
	.movie-play-icon {
		--_svg-size: 880rem;
	}
	.movie-inari {
		left: 0;
		width: 208rem;
	}
}
