:root {
	--oa-liteorange: #e9a269;
	--oa-bg-liteorange: #fcc79d;
	--oa-liteyellow: rgb(225, 215, 79);
	--oa-bg-liteyellow: #f7e478;
	--oa-pink: #ea8a8f;
	--oa-bg-pink: #f6a3a7;
	--oa-litegreen: #69ce96;
	--oa-bg-litegreen: #afe0c5;
	--oa-litepurple: #93a5d8;
	--oa-bg-litepurple: #b8c2e0;
	--oa-bg-liteblue: #abd1f5;
	--oa-bg-liteliteblue: #c2e7f3;
	--oa-litegrey: #bcbcbc;
	--oa-bg-litegrey: #dbdada;
	--oa-bg-liteorange-op7: #fcc79d80;
	--oa-bg-liteyellow-op7: #f7e47880;
	--oa-bg-pink-op7: #f6a3a780;
	--oa-bg-litepurple-op7: #b8c2e080;
	--oa-bg-litegreen-op7: #afe0c580;
	--oa-bg-liteblue-op7: #abd1f580;
	--oa-bg-liteliteblue-op7: #b4e0ee80;
	--oa-bg-litegrey-op7: #dbdada80;
}
.cast {
	padding-top: 5rem;
}
.cast-caption {
	/* color: var(--oa-grey); */
	font-size: 0.9rem;
	margin: 0 auto;
	text-align: center;
	margin-top: -1rem;
	font-weight: 900;
	padding: 0.25rem;
	background-color: var(--oa-liteblue);
	border-radius: 3rem;
	display: inline-block;
	position: absolute;
	left: calc(50% - 64px);
	z-index: 7;
	width: 128px;
	height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
	animation: bounce 0.39s ease-out infinite alternate,
	fadeinout 4.8s 1s linear forwards 1;
	/* border: 2px solid var(--oa-white); */
	line-height: 1.4;
	letter-spacing: -0.25px;
	color: var(--oa-white);
	opacity: 0;
	white-space: nowrap;
}
.cast-caption::after {
	width: 6px;
	height: 6px;
	position: absolute;
	border-bottom: 6px solid var(--oa-liteblue);
	border-right: 6px solid transparent;
	border-left: 6px solid transparent;
	right: calc(50% - 6px);
	bottom: 0;
	content: "";
	transition-duration: 0.33s;
	transition-property: transform;
	transform-origin: center bottom;
	transform: scaleY(-1);
	z-index: 0;
}
@keyframes bounce {
	0% {
		transform: translateY(0);
	}
	100% {
		transform: translateY(-3px);
	}
}
@keyframes fadeinout {
	0% {
		opacity: 0;
	}
	5% {
		opacity: 1;
	}
	98% {
		opacity: 1;
	}
	100% {
		opacity: 0;
	}
}
#app-cast {
	--corner-padding: 4px;
	--corner-width: 12px;
	margin-top: 2rem;
	padding: 0 4rem;
}

.cast-box {
	padding: 0 2rem 2rem;
	display: flex;
	flex-direction: column;
}
.cast-box-outer:last-child .cast-box {
	min-height: unset;
}
.cast-box::before,
.cast-box::after,
.cast-box-outer::before,
.cast-box-outer::after {
	position: absolute;
	border-style: solid;
	border-color: transparent;
	content: "";
	opacity: 0.5;
}

.cast-box,
.cast-box-outer {
	position: relative;
}
.cast-box::before {
	border-width: var(--corner-width) 0 0 var(--corner-width);
	left: var(--corner-padding);
	bottom: var(--corner-padding);
	border-left-color: var(--oa-white);
}
.cast-box-outer::before {
	border-width: var(--corner-width) var(--corner-width) 0 0;
	border-top-color: var(--oa-white);
	left: var(--corner-padding);
	top: var(--corner-padding);
}
.cast-box-outer::after {
	border-width: 0 0 var(--corner-width) var(--corner-width);
	border-bottom-color: var(--oa-white);
	right: var(--corner-padding);
	bottom: var(--corner-padding);
}
.cast-box::after {
	border-width: 0 var(--corner-width) var(--corner-width) 0;
	border-right-color: white;
	right: var(--corner-padding);
	top: var(--corner-padding);
}
.cast-box-outer {
	margin-top: 0.5rem;
}
.cast-box-outer-0 {
	background-color: var(--oa-bg-liteorange);
}
.cast-box-outer-1 {
	background-color: var(--oa-bg-liteyellow);
}
.cast-box-outer-2 {
	background-color: var(--oa-bg-pink);
}
.cast-box-outer-3 {
	background-color: var(--oa-bg-liteblue);
}
.cast-box-outer-4 {
	background-color: var(--oa-bg-litegreen);
}
.cast-box-outer-5 {
	background-color: var(--oa-bg-liteliteblue);
}
.cast-box-outer-6 {
	background-color: var(--oa-bg-litegrey);
}
.viewer-bg-0 {
	background-color: var(--oa-bg-liteorange-op7);
}
.viewer-bg-1 {
	background-color: var(--oa-bg-liteyellow-op7);
}
.viewer-bg-2 {
	background-color: var(--oa-bg-pink-op7);
}
.viewer-bg-3 {
	background-color: var(--oa-bg-liteblue-op7);
}
.viewer-bg-4 {
	background-color: var(--oa-bg-litegreen-op7);
}
.viewer-bg-5 {
	background-color: var(--oa-bg-liteliteblue-op7);
}
.viewer-bg-6 {
	background-color: var(--oa-bg-litegrey-op7);
}
.viewer-color-0 {
	color: var(--oa-bg-liteorange);
}
.viewer-color-1 {
	color: var(--oa-bg-liteyellow);
}
.viewer-color-2 {
	color: var(--oa-bg-pink);
}
.viewer-color-3 {
	color: var(--oa-bg-liteblue);
}
.viewer-color-4 {
	color: var(--oa-bg-litegreen);
}
.viewer-color-5 {
	color: var(--oa-bg-liteliteblue);
}
.viewer-color-6 {
	color: var(--oa-bg-litegrey);
}
.drop-box {
	width: calc(83% + 4rem);
	margin: 1rem auto;
}
.teacher-box {
	width: calc(20% + 4rem);
	margin: 1rem auto;
}
.teacher-box .visual-box {
	--mr: 0;
	--w: calc(100% - var(--mr));
	width: var(--w);
	flex: 0 1 var(--w);
	margin-right: var(--mr);
}
.cast-unit-logo {
	width: 40%;
	text-align: center;
	margin: 0 auto;
	animation: glow 1.2s ease-in alternate infinite;
}
@keyframes glow {
	0% {
		filter: brightness(1);
	}
	50% {
		filter: brightness(1);
	}
	100% {
		filter: brightness(1.2);
	}
}
.cast-unit-logo-image {
	width: 100%;
}
.cast-unit-text {
	font-size: calc(2.8 * var(--rem-vw));
	color: var(--oa-white);
	flex: 1 1 30%;
	align-self: center;
	font-weight: 600;
	white-space: nowrap;
	margin-bottom: 1rem;
}
.maisy {
	transform: translateY(-0.5rem);
}
.hotblood {
	transform: translateY(-0.5rem);
}
.eme {
	transform: translateY(-0.5rem);
}
.cast-unit-text.teacher {
	margin-top: 1.8rem;
}
.teacher {
	font-size: calc(2.1 * var(--rem-vw));
	margin-top: 0.3rem;
	justify-content: center;
}
#cast {
	margin-top: 2rem;
}
.cast-member-box {
	font-size: calc(1 * var(--rem-vw));
	color: var(--oa-grey);
	flex: 1 0 103%;
	display: flex;
	justify-content: center;
	white-space: nowrap;
	font-weight: 400;
	width: 103%;
	align-items: flex-start;
}
.cast-member {
	display: flex;
	justify-content: flex-end;
	align-items: center;
}

.cosmo {
	font-size: 0.7em;
	margin-right: -0.5em;
	margin-left: -0.5em;
}
.cast-caption-box {
	text-align: center;
	margin-top: 0.5rem;
}
.cast-actor-text {
	font-size: calc(1.1 * var(--rem-vw));
	text-align: center;
}
.member {
	display: flex;
}
.staff {
	margin-top: 8rem;
}
.staff-title {
	padding-bottom: 3rem;
}
.staff-text {
	font-size: 0.9rem;
	color: var(--oa-grey);
	line-height: 1.7;
	padding: 0 1rem;
	font-weight: 400;
}

.visual-box {
	--mr: 3%;
	--w: calc(20% - var(--mr));
	width: var(--w);
	flex: 0 1 var(--w);
	margin-right: var(--mr);
}
.visual-image {
	width: 100%;
	height: calc(400 / 16 * var(--rem-vw));
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	position: relative;
	aspect-ratio: 145.68 / 400;
}
.teacher-box .visual-image {
	min-width: 13.76vw;
}
.viewer {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	/* background: #ffffffcc; */
	transition-duration: 0.33s;
	transition-property: opacity color;
	z-index: 8;
	flex-direction: column;
}
.viewer-unit {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	/* background: #ffffffcc; */
	transition-duration: 0.33s;
	transition-property: opacity color;
	z-index: 8;
	flex-direction: column;
}
.viewer-image-box {
	display: flex;
	flex-direction: column;
	position: absolute;
	height: 100%;
	justify-content: center;
	align-items: center;
}

.viewer-image {
	width: auto;
	height: calc(100% - 8rem);
	cursor: default;
	position: relative;
}
.unit .viewer-image {
	height: calc(100% - 8rem);
	transform: translateY(-40px);
}
.viewer-image-box-now {
	z-index: 8;
}
.viewer-image-box-next {
	z-index: 7;
}
.x-stroke {
	fill:none;stroke:#ff0000;stroke-miterlimit:10;
}
.x-stroke-1 {
	stroke:var(--oa-bg-liteorange);
}
.x-stroke-2 {
	stroke:var(--oa-bg-liteyellow);
}
.x-stroke-3 {
	stroke:var(--oa-bg-pink);
}
.x-stroke-4 {
	stroke:var(--oa-bg-liteblue);
}
.x-stroke-5 {
	stroke:var(--oa-bg-litegreen);
}
.x-stroke-5 {
	stroke:var(--oa-bg-liteliteblue);
}
.viewer-button {
	font-weight: 600;
	position: absolute;
	appearance: none;
	-webkit-appearance: none;
	transition-duration: 0.33s;
	transition-property: opacity;
	border: 0;
	z-index: 2;
	background-color: transparent;
	padding: 0.3rem;
}
.button-disabled {
	opacity: 0.3;
}
.viewer-button:hover {
	cursor: pointer;
}
.viewer-close-button-box, .viewer-close-button-image-box {
	position: absolute;
	right: 0;
}
.viewer-image-box.unit .viewer-caption {
	z-index: 1;
}
.viewer-close-button {
	border: 0;
	appearance: none;
	background-color: transparent;
	padding: 0;
	margin: 0;
	width: 40px;
	height: 40px;
	display: block;
	z-index: 21;
}
.viewer-close-button:hover {
	cursor: pointer;
	color: var(--oa-white);
}
.viewer-close-button-image {
	width: 100%;
	height: 100%;
}
.viewer-next-button {
	right: calc(50vw - 35.4vh - 1rem);
	z-index: 9;
	right: 0;
}
.viewer-prev-button {
	left: calc(50vw - 35.4vh - 1rem);
	transform: rotate(-180deg);
	transform-origin: center;
	z-index: 9;
	left: 0;
}
.viewer-button-image {
	width: 32px;
	height: 32px;
}
.viewer-caption {
	font-size: 1rem;
	font-weight: 500;
	position: relative;
	z-index: -1;
	width: 100%;
	height: 40px;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	white-space: nowrap;
	color: var(--oa-grey);
}
.viewer-unit-text,
.viewer-caption-text {
	padding: 0.2rem;
	padding-left: 0.5rem;
	display: flex;
	align-items: center;
}
.viewer-unit-text {
	font-size: 1.5rem;
	transform: translateY(3px);
	font-weight: 600;
	color: var(--oa-white);
	cursor: default;
}
.viewer-caption-character {
	text-align: right;
}
.viewer-caption-dots {
	width: 30px;
	text-align: center;
	transform: translateY(-0.24rem);
	color: var(--oa-white);
	margin-left: 0.3rem;
	margin-right: 0.3rem;
}
.viewer-caption-actor {
	/* font-size: 1.15em; */
	text-align: left;
}
.viewer-caption-next {
	z-index: -2;
}
.fade-enter-active,
.fade-leave-active {
	transition: opacity 1s;
}
.fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ {
	opacity: 0;
}
.fade-next-enter-active,
.fade-next-leave-active {
	transition: opacity 0.6s, filter 0.6s;
}
.fade-next-enter, .fade-next-leave-to /* .fade-next-leave-active below version 2.1.8 */ {
	opacity: 0;
	filter: blur(3px);
}
@media screen and (min-width: 1024px) {
	.visual-image {
		height: 400px;
	}
	.teacher-box .visual-image {
		min-width: 141px;
	}
	.cast-unit-text {
		font-size: 2.3rem;
	}
	.eme {
		font-size: 2.1rem;
	}
	.viewer-unit-text.eme {
		font-size: 1.4rem;
		transform: translateY(2px);
	}
	.teacher {
		font-size: 2.1rem;
	}
	.cast-member-box {
		font-size: 1rem;
	}
	.cast-actor-text {
		font-size: 1.1rem;
	}
}
@media screen and (max-width: 768px) {
	#app-cast {
		--corner-padding: 4px;
		--corner-width: 10px;
		padding: 0 1rem;
		margin-top: 2rem;
	}
	.cast-caption {
		font-size: 0.8rem;
		width: 110px;
		height: 50px;
		left: calc(50% - 55px);
		margin-top: -2.5rem;
	}
	.drop-box {
		width: calc(80% + 1.5rem);
	}
	.teacher-box {
		width: calc(20% + 1.5rem);
	}
	.cast-box {
		padding: 0 0.75rem 1rem;
	}
	.cast-unit-text {
		font-size: 1.7rem;
		margin-bottom: 0.5rem;
	}
	.cast-unit-text.teacher {
		margin-top: 1rem;
	}
	.teacher {
		font-size: 1.2rem;
	}
	.eme {
		font-size: 1.3rem;
	}
	.cast-character-text {
		font-size: 0.7rem;
	}
	.cast-character-text,
	.cast-actor-text {
		width: 120%;
		margin-left: -10%;
		overflow: visible;
	}
	.cast-actor-text {
		font-size: 0.8rem;
	}
	.staff {
		margin-top: 4rem;
	}
	.staff-title {
		padding-bottom: 2rem;
	}
	.staff-text {
		font-size: 0.8rem;
		line-height: 1.6;
	}
	.cast-unit-logo {
		width: 50%;
	}
	.viewer {
		z-index: 7;
	}
	.viewer-image-box {
		width: calc(100%);
	}
	.viewer-image {
		width: 100%;
		height: auto;
	}
	.unit .viewer-image {
		height: auto;
		transform: translateY(-40px);
	}
	.viewer-button {
		height: 2.6rem;
	}
	.viewer-next-button {
		right: 0.2rem;
	}
	.viewer-prev-button {
		left: 0.2rem;
		transform-origin: center center;
	}
}
