@charset "utf-8";

/* ---------------------------------------------------------- */
/* 登場人物 */
/* ---------------------------------------------------------- */
#character {
	padding: 80px 0;
	}

/* list */
#character .list {
	max-width: 900px;
	margin: 0 auto -50px auto;
	}

#character .list ul {
	width: calc(100% + 80px);
	margin: 0 0 0 -40px;
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	}

#character .list ul li {
	width: 33.33333%;
	text-align: center;
	margin: 0 0 50px 0;
	padding: 0 40px;
	}

#character .list ul li a {
	margin: 0 0 5px 0;
	display: block;
	}

#character .list ul li a:hover {
	transform: scale(1.02,1.02);
	}

#character .list ul li a img {
	width: 100%;
	border-radius: 50%;
	background: #fff;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	transition: all 0.3s ease;
	}

#character .list ul li a:hover img {
	background: #e6c37d;
	}

#character .list ul li .name1 {
	font-size: 2.8rem;
	font-weight: bold;
	color: #fff;
	letter-spacing: 3px;
	}

#character .list ul li .name2 {
	font-size: 1.6rem;
	font-family: 'Paytone One';
	color: #e6c37d;
	line-height: 1;
	}

/* detail */
#character .detail {
	margin: 0 auto 50px auto;
	overflow: hidden;
	position: relative;
	}

#character .detail .next ,
#character .detail .prev {
	top: 50%;
	margin: -15px 0 0 0;
	position: absolute;
	}

#character .detail .next {
	right: 20px;
	}

#character .detail .next:hover {
	right: 15px;
	}

#character .detail .prev {
	left: 20px;
	}

#character .detail .prev:hover {
	left: 15px;
	}

#character .detail .next img ,
#character .detail .prev img {
	width: 30px;
	}

#character .detail .box {
	max-width: 1040px;
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	margin: auto;
	}

#character .detail .box .image {
	width: 400px;
	}

#character .detail .box .image img {
	width: 100%;
	}

#character .detail .box .text {
	width: 640px;
	color: #fff;
	padding: 40px 0 0 0;
	}

#character .detail .box .text h3 {
	font-size: 5.0rem;
	font-weight: bold;
	letter-spacing: 10px;
	line-height: 1;
	margin: 0 0 15px 0;
	}

#character .detail .box .text .name {
	font-size: 1.6rem;
	font-family: 'Paytone One';
	color: #e6c37d;
	line-height: 1;
	letter-spacing: 1px;
	margin: 0 0 20px 0;
	}

#character .detail .box .text p {
	margin: 0 0 30px 0;
	}

#character .detail .box .text .voice {
	margin: 0 0 50px 0;
	display: -webkit-inline-flex;
	display: -ms-inline-flex;
	display: inline-flex;
	align-items: center;
	}

#character .detail .box .text .voice .cv {
	font-size: 1.6rem;
	font-family: 'Paytone One';
	color: #01a4a7;
	line-height: 1;
	text-align: center;
	margin: 0 10px 0 0;
	padding: 5px 15px;
	background: #fff;
	display: inline-block;
	}

#character .detail .box .text .voice .actor {
	font-size: 2.2rem;
	margin: 0 10px 0 0;
	}

#character .detail .box .text .voice a.popup img {
	width: 34px;
	}

#character .detail .box .text .voice a.popup:hover {
	opacity: 0.7;
	}

#character .detail .box .text .face img {
	width: 100%;
	}

#character .select {
	width: 100%;
	max-width: 1040px;
	border-top: 2px solid #fff;
	margin: auto;
	padding: 15px 0 0 0;
	}

#character .select ul {
	width: calc(100% + 15px);
	margin: 0 0 0 -7.5px;
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	}

#character .select ul li {
	width: 14.28571%;
	text-align: center;
	padding: 15px 7.5px 0 7.5px;
	}

#character .select ul li a {
	display: block;
	}

#character .select ul li a.current {
	pointer-events: none;
	}

#character .select ul li a.current:hover {
	transform: scale(1,1);
	pointer-events: none;
	}

#character .select ul li a:hover {
	transform: scale(1.02,1.02);
	}

#character .select ul li a img {
	width: 100%;
	border-radius: 50%;
	background: #fff;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	transition: all 0.3s ease;
	}

#character .select ul li a.current img ,
#character .select ul li a:hover img {
	background: #e6c37d;
	}

#character .select ul li a img {
	width: 100%;
	}

/* comment */
.popupWrapper.cast {
	display: -webkit-flex;
	display: -ms-flex;
	display: flex;
	align-items: center;
	}

.popupWrapper.cast .photo {
	width: 40%;
	padding: 0 40px 0 0;
	}

.popupWrapper.cast .photo img {
	width: 100%;
	}

.popupWrapper.cast .text {
	width: 60%;
	}

@media (max-width: 768px){
#character {
	padding: 120px 30px;
	}

/* list */
#character .list {
	margin: 0 auto -45px auto;
	}

#character .list ul {
	width: calc(100% + 20px);
	margin: 0 0 0 -10px;
	}

#character .list ul li {
	margin: 0 0 40px 0;
	padding: 0 20px;
	}

#character .list ul li .name1 {
	font-size: 2.4rem;
	}

#character .list ul li .name2 {
	font-size: 1.5rem;
	}

/* detail */
#character .detail .next ,
#character .detail .prev {
	top: 23%;
	margin: 0;
	}

#character .detail .next ,
#character .detail .next:hover {
	right: 0;
	}

#character .detail .prev ,
#character .detail .prev:hover {
	left: 0;
	}

#character .detail .box {
	display: block;
	}

#character .detail .box .image {
	width: 100%;
	text-align: center;
	}

#character .detail .box .image img {
	width: 60%;
	}

#character .detail .box .text {
	width: 100%;
	padding: 20px 0 0 0;
	}

#character .detail .box .text h3 {
	font-size: 4.6rem;
	text-align: center;
	}

#character .detail .box .text .name {
	text-align: center;
	}

#character .detail .box .text p {
	margin: 0 0 20px 0;
	}

#character .detail .box .text .voice {
	margin: 0 0 30px 0;
	}

#character .detail .box .text .voice .cv {
	font-size: 1.4rem;
	}

#character .detail .box .text .voice .actor {
	font-size: 2.0rem;
	}

#character .detail .box .text .voice a.popup img {
	width: 28px;
	}

@media (max-width: 640px){
#character {
	padding: 80px 20px;
	}

/* list */
#character .list {
	margin: 0 auto -80px auto;
	}

#character .list ul li .name1 {
	font-size: 2.0rem;
	}

#character .list ul li .name2 {
	font-size: 1.0rem;
	}

#character .list ul li {
	width: 50%;
	}

/* btn */
#introduction .about {
	margin: 0 0 80px 0;
	padding: 0 20px;
	position: static;
	}

#introduction .about ul li {
	margin: 0 0 10px 0;
	}

#introduction .about ul li a {
	width: 100%;
	line-height: 1;
	writing-mode: lr-tb;
	-ms-writing-mode: lr-tb;
	overflow: hidden;
	display: flex;
	align-items: center;
	position: relative;
	}

#introduction .about ul li a::before ,
#introduction .about ul li a::after {
	content: "";
	width: 5px;
	height: 5px;
	top: 50%;
	right: 10px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	margin: -4px 0 0 0;
	position: absolute;
	display: block;
	z-index: 4;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	transition: all 0.3s ease;
	}

#introduction .about ul li a::after {
	right: 15px;
	}

#introduction .about ul li.about1 a ,
#introduction .about ul li.about1 a:hover {
	background: url(../img/character/ico_about1.png) center left 10px no-repeat #dc3e4a;
	background-size: 18px 16px;
	padding: 15px 10px 15px 35px;
	}

#introduction .about ul li.about2 a ,
#introduction .about ul li.about2 a:hover {
	background: url(../img/character/ico_about2.png) center left 10px no-repeat #dc3e4a;
	background-size: 16px 22px;
	padding: 15px 10px 15px 35px;
	}

/* detail */
#character .detail {
	margin: 0 auto 40px auto;
	}

#character .detail .next ,
#character .detail .prev {
	top: 21%;
	}

#character .detail .next img ,
#character .detail .prev img {
	width: 25px;
	}

#character .detail .box .image img {
	width: 80%;
	}

#character .detail .box .text h3 {
	font-size: 3.0rem;
	letter-spacing: 5px;
	margin: 0 0 10px 0;
	}

#character .detail .box .text .name {
	font-size: 1.4rem;
	}

#character .detail .box .text .voice .cv {
	padding: 3px 10px;
	}

#character .detail .box .text .voice .actor {
	font-size: 1.8rem;
	}

#character .select {
	padding: 10px 0 0 0;
	}

#character .select ul {
	width: calc(100% + 10px);
	margin: 0 0 0 -5px;
	flex-wrap: wrap;
	}

#character .select ul li {
	width: 25%;
	padding: 10px 5px 0 5px;
	}

/* comment */
.popupWrapper.cast {
	display: block;
	}

.popupWrapper.cast .photo {
	width: 100%;
	text-align: center;
	padding: 0 0 20px 0;
	}

.popupWrapper.cast .photo img {
	width: 50%;
	}

.popupWrapper.cast .text {
	width: 100%;
	}
}