@charset "UTF-8";

/* ====================================
piapro_characters
===================================== */
html.enable-javascript .slider-sample{
  visibility: hidden;
}
html.enable-javascript.window-load .slider-sample{
  visibility: visible;
}

#main.character{
	padding-bottom: 0;
}

/*  chara_top ------------------------------*/
#chara_top{
	padding: 40px 0;
	background: #ddd;
	line-height: 1.8;
}

#chara_top h2{
	font-size: 1.2em;
	font-weight: bold;
	margin-bottom: 5px;
}

@media screen and (max-width: 768px){
	#chara_top h2{
		font-size: 1.0em;
		line-height: 1.7;
	}
}

.option_chara li{
	width: 80px;
	height: 80px;
	border-radius: 50%;
	display: inline-block;
	margin: 0 5px 5px 0;
	border: 4px solid #fff;
	background: center center;
	background-size: contain;
}

.option_chara a{
	color: transparent;
	display: block;
	width: 100%;
	height: 100%;
}

.option_chara li{
	-webkit-transition: all 0.1s ease;
	transition: all 0.1s ease;
}

.option_chara .miku{
	background-image:url(../images/btn_miku.jpg);
}
.option_chara .rin{
	background-image:url(../images/btn_rin.jpg);
}
.option_chara .len{
	background-image:url(../images/btn_len.jpg);
}
.option_chara .luka{
	background-image:url(../images/btn_luka.jpg);
}
.option_chara .meiko{
	background-image:url(../images/btn_meikov3.jpg);
}
.option_chara .kaito{
	background-image:url(../images/btn_kaitov3.jpg);
}

.option_chara .miku:hover  { border-color:#15C0B0; }
.option_chara .rin:hover   { border-color:#FF9100; }
.option_chara .len:hover   { border-color:#FFD900; }
.option_chara .luka:hover  { border-color:#FF60C0; }
.option_chara .meiko:hover { border-color:#c83d3d; }
.option_chara .kaito:hover { border-color:#4874e1; }

.more_link{
	color: #15c0b0;
	border: 1px solid #15c0b0;
	display: inline-block;
	padding: 2px 10px;
	text-align: left;
}

.more_link:hover{
	background: #15c0b0;
	color: #333;
}

/*  chara_sec ------------------------------*/
.ch_sec{
	padding: 60px 0;
	line-height: 1.8;
	overflow: hidden;
}

.ch_sec#ch_miku		{ background: #e8f2f1; }
.ch_sec#ch_rin		{ background: #fff4e2; }
.ch_sec#ch_len		{ background: #fffce9; }
.ch_sec#ch_luka		{ background: #fff0f3; }
.ch_sec#ch_meiko	{ background: #f9e3e5; }
.ch_sec#ch_kaito	{ background: #efeff9; }

.ch_sec .set_width,
.derivation{
	position: relative;
	z-index: 0;
}

.ch_sec .set_width,
.derivation{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	padding-bottom: 30px;
}

/*  chara_detail ------------------------------*/
.chara_name{
	width: 50%;
	margin-bottom: 30px;
	max-width: 350px;
}
@media screen and (max-width: 768px){
	.chara_name{
		width: 100%;
	}
}

.chara_detail{
	width: 59%;
	position: relative;
	z-index: 2;
}
#ch_meiko .chara_detail{
	width: 55%;
}
#ch_kaito .chara_detail{
	width: 55%;
}

@media screen and (max-width: 768px){
	.chara_txt{
		background: rgba(255, 255, 255, 0.8);
		padding: 15px;
		font-size: 10pt;
		line-height: 1.7;
	}
}

.chara_txt h3{
	font-size: 1.1em;
	font-weight: bold;
	line-height: 1.7;
	margin-bottom: 5px;
}

@media screen and (max-width: 768px){
	.chara_txt h3{
		font-size: 1.0em;
		line-height: 1.6;
	}
}

@media screen and (min-width: 501px){
	.chara_txt h3 span{
		display: block;
	}
}

.chara_prof{
	margin-top: 40px;
	font-size: 0.8em;
}

@media screen and (max-width: 768px){
	.chara_prof{
		background: rgba(255, 255, 255, 0.8);
		margin-top: 20px;
		padding: 15px;
	}
}

.chara_prof_color{
	display: inline-block;
	width: 15px;
	height: 15px;
	margin-right: 5px;
	vertical-align: middle;
}

.chara_costume_btn{
	display: inline-block;
	margin: 20px 0 40px;
	padding: 8px 20px;
	border: 1px #3fa0ff solid;
	border-radius: 6px;
	transition: .1s;
}

.chara_costume_btn:hover{
	border: 1px #7abdff solid;
	background: #7abdff;
	color: #fff;
}

.chara_product{
	width: 68%;
	list-style: none;
	margin-top: 30px;
}

.chara_product li{
	width: 48%;
	float: left;
	height: 150px;
	margin-top: 20px;
}

.chara_product_img{
	width: 85%;
	margin: auto;
}

.chara_product_img img{
	width: 100%;
	height: auto;
}

.chara_product_txt{
	font-size: 0.9em;
	display: inline-block;
	vertical-align: middle;
	text-align: center;
}

@media screen and (max-width: 500px){
	.chara_product_txt{
		font-size: 0.8em;
	}
}

.chara_product_txt h4{
	line-height: 1.2;
	padding-top: 10px;
}

.chara_product_txt h4 span{
	display: inline-block;
}

.product_date{
	font-size: .8em;
}

/*  chara_img ------------------------------*/
.chara_img{
	width: 36%;
	z-index: 1;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}

@media screen and (max-width: 768px){
	.chara_img{
		position: absolute;
		top: 0;
		right: 0;
		width: 50%;
	}
}

@media screen and (max-width: 500px){
	.chara_img{
		width: 90%;
	}
}

.chara_img > div{
	position: relative;
}

@media screen and (min-width: 769px){
	.chara_img div > img{
		margin-left: auto;
		margin-right: auto;
	}
}

.chara_img.miku div > img{
	width: 87%;
}
.chara_img.rin div > img{
	width: 41%;
}
.chara_img.len div > img{
	width: 44%;
}
.chara_img.luka div > img{
	width: 39%;
}
.chara_img.meiko div > img{
	width: 100%;
}
.chara_img.kaito div > img{
	width: 118%;
}

@media screen and (max-width: 768px){
	.chara_img div > img{
		position: relative;
		margin-left: auto;
	}

	.chara_img.miku div > img{
		width: 95%;
		right: -8%;
	}
	.chara_img.rin div > img{
		width: 36%;
		right: 15%;
	}
	.chara_img.len div > img{
		width: 40%;
		right: 11%;
	}
	.chara_img.luka div > img{
		width: 35%;
		right: 19%;
	}
	.chara_img.meiko div > img{
		width: 93%;
	}
	.chara_img.kaito div > img{
		width: 108%;
	}
}

@media screen and (max-width: 500px){
	.chara_img.miku div > img{
		width: 95%;
		right: -26%;
	}
	.chara_img.rin div > img{
		width: 45%;
		right: 0%;
	}
	.chara_img.len div > img{
		width: 49%;
		right: -8%;
	}
	.chara_img.luka div > img{
		width: 42%;
		right: -1%;
	}
	.chara_img.meiko div > img{
		width: 115%;
		right: -15%;
	}
	.chara_img.kaito div > img{
		width: 133%;
		right: 4%;
	}
}

@media screen and (min-width: 1217px){
	.chara_img.kaito div > img{
		margin-top: -70px;
		right: 15%;
		position: relative;
	}
}

/* .chara_img_sub{
	width: 65px;
	position: relative;
	bottom: 30px;
	list-style: none;
	margin-left: auto;
	z-index: 0;
} */

.chara_img_sub{
	width: 65px;
	position: absolute;
	right: 0;
	list-style: none;
	margin-left: auto;
	z-index: 0;
}

@media screen and (min-width: 501px){
	.chara_img_sub{
		position: absolute;
	}

	#ch_miku .chara_img_sub{
		bottom: 300px;
	}

	#ch_rin .chara_img_sub,
	#ch_len .chara_img_sub{
		bottom: 210px;
	}

	#ch_luka .chara_img_sub{
		bottom: 150px;
	}

	#ch_meiko .chara_img_sub{
		bottom: 80px;
	}

	#ch_kaito .chara_img_sub{
		bottom: 80px;
	}
}

@media screen and (max-width: 1216px){
	#ch_miku .chara_img_sub{
		bottom: 300px;
	}

	#ch_rin .chara_img_sub,
	#ch_len .chara_img_sub{
		bottom: 300px;
	}

	#ch_luka .chara_img_sub{
		bottom: 260px;
	}

	#ch_meiko .chara_img_sub{
		bottom: 230px;
	}

	#ch_kaito .chara_img_sub{
		bottom: 140px;
	}
}

@media screen and (max-width: 500px){
	#ch_luka .chara_img_sub,
	#ch_meiko .chara_img_sub{
		bottom: 100%;
	}
}

@media screen and (max-width: 500px) and (min-width: 401px){
	#ch_kaito .chara_img_sub{
		bottom: 130px;
	}
}

@media screen and (max-width: 400px){
	#ch_kaito .chara_img_sub{
		bottom: 230px;
	}
}

.chara_img_sub::after,
.chara_img_sub::after,
.chara_img_sub::after,
.chara_img_sub::after{
	content: "Art by KEI";
	display: block;
	position: absolute;
	right: 0;
	bottom: -30px;
	width: 100px;
	text-align: right;
	font-size: 0.8rem;
	color: #666;
	z-index: 1;
}

#ch_meiko .chara_img_sub::after,
#ch_kaito .chara_img_sub::after{
	content: "Art by iXima";
	display: block;
	position: absolute;
	right: 0;
	bottom: -30px;
	width: 100px;
	text-align: right;
	font-size: 0.8rem;
	color: #666;
	z-index: 1;
}

.chara_img_sub li{
	width: 65px;
	height: 65px;
	border-radius: 50%;
	margin-bottom: 10px;
	border: 4px solid #fff;
	overflow: hidden;
	box-sizing: border-box;
	transition: .1s;
	cursor: pointer;
}

#ch_miku .chara_img_sub li:hover{ border-color:#15C0B0; }
#ch_rin .chara_img_sub li:hover{ border-color:#FF9100; }
#ch_len .chara_img_sub li:hover{ border-color:#FFD900; }
#ch_luka .chara_img_sub li:hover{ border-color:#FF60C0; }
#ch_meiko .chara_img_sub li:hover{ border-color:#c83d3d; }
#ch_kaito .chara_img_sub li:hover{ border-color:#4874e1; }


@media screen and (max-width: 500px){
	.chara_img_sub li{
		border: 3px solid #fff;
	}
}

.chara_img_sub li img{
	width: 100%;
	height: auto;
}

/*  swiper ---------------------*/
.swiper_box{
	position: relative;
	width: 56%;
	margin-left: 20px;
}

@media screen and (max-width: 768px){
	.swiper_box{
		width: 80%;
		margin: 60px auto 0;
	}
}

@media screen and (max-width: 500px){
	.swiper_box{
		width: 90%;
		margin: 40px auto 0;
	}
}

#ch_luka .swiper_box,
#ch_meiko .swiper_box,
#ch_kaito .swiper_box{
	margin-left: -20px;
}

@media screen and (max-width: 500px){
	#ch_luka .swiper_box,
	#ch_meiko .swiper_box,
	#ch_kaito .swiper_box{
		margin-left: -10px;
	}
}

@media screen and (max-width: 1216px) and (min-width: 769px){
	.swiper_box{
		width: 80%;
		margin: 0 auto;
	}
	#ch_luka .swiper_box{
		margin-top: 0;
	}
	#ch_meiko .swiper_box{
		margin-top: 0;
	}
	#ch_kaito .swiper_box{
		margin-top: -50px;
	}
}

@media screen and (min-width: 1217px){
	#ch_miku .swiper_box,
	#ch_rin .swiper_box,
	#ch_len .swiper_box{
		margin-top: -10px;
	}
	#ch_luka .swiper_box{
		margin-top: -50px;
	}
	#ch_meiko .swiper_box{
		margin-top: -120px;
	}
	#ch_kaito .swiper_box{
		margin-top: -140px;
	}
}
@media screen and (min-width: 1517px){
	#ch_miku .swiper_box{
		margin-top: -5px;
	}
	#ch_rin .swiper_box{
		margin-top: -70px;
	}
	#ch_len .swiper_box{
		margin-top: -60px;
	}
	#ch_luka .swiper_box{
		margin-top: -150px;
	}
	#ch_meiko .swiper_box{
		margin-top: -250px;
	}
	#ch_kaito .swiper_box{
		margin-top: -280px;
	}
}

.swiper-wrapper{
	list-style: none;
}

.swiper-slide{
	text-align: center;
	padding: 0 10px;
	box-sizing: border-box;
}

.swiper-button-prev{
	left: -20px;
}
.swiper-button-next{
	right: -20px;
}

#ch_miku .swiper-button-next,
#ch_miku .swiper-button-prev{
	background: #abd9d7;
}
#ch_rin .swiper-button-next,
#ch_rin .swiper-button-prev{
	background: #ecd19f;
}
#ch_len .swiper-button-next,
#ch_len .swiper-button-prev{
	background: #e0da8c;
}
#ch_luka .swiper-button-next,
#ch_luka .swiper-button-prev{
	background: #e6bad2;
}
#ch_meiko .swiper-button-next,
#ch_meiko .swiper-button-prev{
	background: #e0abab;
}
#ch_kaito .swiper-button-next,
#ch_kaito .swiper-button-prev{
	background: #a7bee0;
}

/*  miku_sub_character ---------------------*/
.derivation{
	position: relative;
	margin-top: 45px;
	border: 1px #84d0d0 solid;
	border-radius: 10px;
	padding: 20px;
}

.derivation_detail{
	position: relative;
	width: 60%;
	padding: 30px;
	z-index: 2;
}

.derivation_img{
	position: relative;
	padding-right: 30px;
}

.derivation_chara_copy{
	position: absolute;
	bottom: 15px;
	right: 20px;
	font-size: 0.8em;
}

#ch_snowmiku{
	background: url(../images/ch_img_snowmiku.png) right 45px center no-repeat;
	background-size: auto 90%;
}
#ch_sakuramiku{
	background: url(../images/ch_img_sakuramiku.png) right 15px center no-repeat;
	background-size: auto 86%;
}

@media screen and (max-width: 500px){
	#ch_snowmiku{
		background: url(../images/ch_img_snowmiku.png) right -35px top 50px no-repeat;
		background-size: 86% auto;
	}

	#ch_sakuramiku{
		background: url(../images/ch_img_sakuramiku.png) right -35px top 50px no-repeat;
		background-size: 86% auto;
	}
}

#ch_snowmiku .chara_name{
	width: 68%;
}
#ch_sakuramiku .chara_name{
	width: 30%;
}

@media screen and (max-width: 500px){
	#ch_snowmiku .chara_name{
		width: 100%;
	}
	#ch_sakuramiku .chara_name{
		width: 65%;
	}
}

@media screen and (max-width: 768px){
	.derivation{
		padding: 0;
		overflow: hidden;
	}

	.derivation_detail{
		padding: 30px 20px;
	}

	.chara_costume_btn{
		margin-bottom: 0;
	}

	.chara_copy{
		text-align: right;
		font-size: 0.8em;
		color: #666;
		z-index: 1;
		display: flex;
		align-items: flex-end;
		margin: 0 15px 15px 0;
	}

	#ch_snowmiku .derivation_img{
		width: 90%;
		margin-right: -20%;
		margin-top: 50px;
	}
	#ch_snowmiku .derivation_img .chara_copy{
		bottom: -30px;
		right: calc(20% + 20px);
	}
	#ch_sakuramiku .derivation_img{
		width: 90%;
		margin-right: -21%;
		margin-top: 40px;
	}
	#ch_sakuramiku .derivation_img .chara_copy{
		bottom: -30px;
		right: calc(20% + 24px);
	}
}
