@charset "UTF-8";
/* CSS Document */

/*//////////----- CASTLIST -----//////////*/

.castlist a{
	display:block;
	height:100%;
	
	color:#000;
	
	transition:0.25s;
}

.castlist a:hover{
	opacity: 0.8;
	text-decoration: none;
}

.castlist div.inner{
	box-sizing: border-box;
	padding:5px;
	
	position: relative;
	
	background-color:#fff;
	color:#000;
	
	height:100%;
}

@media only screen and (min-width: 1080px){
	
	.castlist div.inner{
		padding:10px;
	}
	
}

.castlist div.castimg{
	width:100%;
	
	position: relative;
}

.castlist div.castimg p.thumbnail{
	width:100%;
}

.castlist div.castimg p.thumbnail img{
	width:100%;
	vertical-align: bottom;
}

.castlist div.castimg span.today{
	width:100%;
	
	font-size:0.8rem;
	line-height:30px;
	font-weight:bold;
	
	text-align: center;
	
	background-color: rgba(0,70,140,0.90);
	color:#fff;
	
	position: absolute;
	left:0;
	bottom:0;
}

.castlist div.castimg p.icon-newface{
	display:block;
	
	width:40px;
	height:40px;
	
	position: absolute;
	top:5px;
	right:5px;
}

.castlist div.castimg p.icon-newface img{
	width:100%;
	vertical-align: bottom;
	
	background-color:#048;
	color:#fff;
	
	box-sizing: border-box;
	padding:10px;
}

.castlist div.castimg p.icon-newface span.note{
	display:block;
	width:100%;
	
	background-color:#048;
	color:#fff;
	
	font-size:0.6rem;
	line-height:20px;
	font-weight:bold;
	
	text-align: center;
}

.castlist div.castimg p.icon-grade{
	display:block;
	
	width:40px;
	height:40px;
	
	position: absolute;
	bottom:35px;
	left:5px;
}

.castlist div.castimg p.icon-grade img{
	width:100%;
	vertical-align: bottom;
	
	background-color:#fff;
	color:#000;
	
	box-sizing: border-box;
	padding:10px;
}

.castlist div.castimg p.icon-grade span.note{
	display:block;
	width:100%;
	
	background-color:#fff;
	color:#000;
	
	font-size:0.6rem;
	line-height:20px;
	font-weight:bold;
	
	margin-top:20px;
	
	text-align: center;
}

.castlist div.casttext{
	background-color:#fff;
	color:#000;
}

.castlist div.casttext h4{
	font-size:1.0rem;
	line-height:30px;
	font-weight:bold;
	
	text-align: center;
}

.castlist div.casttext h4 span.age{
	font-size:0.8rem;
	line-height:25px;
	font-weight:normal;
}

.castlist div.casttext h4 span.age:before{
	content:"（";
}

.castlist div.casttext h4 span.age:after{
	content:"）";
}

.castlist div.casttext ul.size{
	display:flex;
	flex-flow: row wrap;
	align-items: center;
	justify-content: center;
	
	width:100%;
}

.castlist div.casttext ul.size li{
	font-size:0.8rem;
	line-height:25px;
}

.castlist div.casttext ul.size li:after{
	content:"/";
	
	font-size:0.6rem;
	line-height:25px;
	
	box-sizing: border-box;
	padding:0 1.5px;
}

.castlist div.casttext ul.size li:last-child:after{
	display:none;
}

.castlist div.casttext ul.size li:before{
	font-size:0.6rem;
	line-height:25px;
}

.castlist div.casttext ul.size li.tall:before{
	content:"T:";
}

.castlist div.casttext ul.size li.bust:before{
	content:"B:";
}

.castlist div.casttext ul.size li.bust span.cup{
	font-size:0.6rem;
	line-height:25px;
}

.castlist div.casttext ul.size li.bust span.cup:before{
	content:"_";
}

.castlist div.casttext ul.size li.waist:before{
	content:"W:";
}

.castlist div.casttext ul.size li.hip:before{
	content:"H:";
}

.castlist div.casttext ul.feature{
	display:flex;
	flex-flow: row wrap;
	align-items: center;
	justify-content: center;
	
	width:100%;
}

.castlist div.casttext ul.feature li{
	width:calc(50% - 2.5px);
	
	font-size:0.6rem;
	line-height:15px;
	
	text-align: center;
	
	background-color:#048;
	color:#fff;
}

.castlist div.casttext ul.feature li:nth-child(odd){
	margin-right:2.5px;
}

.castlist div.casttext ul.feature li:nth-child(even){
	margin-left:2.5px;
}

.castlist div.casttext p.standby{
	font-size:0.8rem;
	line-height:30px;
	font-weight:bold;
	
	text-align: center;
}

/*//////////----- SEARCH -----//////////*/

.search{
	box-sizing: border-box;
	padding:5px;
	
	background-color:#fff;
	color:#000;
}

.search input[type="checkbox"]{
	display:none;
}

.search label.dropdown{
	display:block;
	
	font-size:0.8rem;
	line-height:40px;
	font-weight:bold;

	text-align: center;
	
	background-color:#222;
	color:#fff;
	
	box-sizing: border-box;
	border-radius:5px;
	
	position: relative;
}

.search label.dropdown:before{
	display:block;
	content:"";
	
	width:25px;
	height:25px;
	
	position: absolute;
	top:7.5px;
	left:7.5px;
	
	background-color:#fff;
	background-image: url("../images/icon-search-black.png");
	background-repeat: no-repeat;
	background-size:15px;
	background-position: center;
	
	border-radius:50px;
}

.search label.dropdown:after{
	display:block;
	content:"";
	
	width:25px;
	height:25px;
	
	position: absolute;
	top:7.5px;
	right:7.5px;
	
	background-image: url("../images/icon-arrow-right.png");
	background-repeat: no-repeat;
	background-size:15px;
	background-position: center;
	
	transform: rotate(90deg);
	
	transition: 0.25s;
}

.search label.dropdown:hover{
	opacity: 0.8;
	cursor: pointer;
}

.search label.liftup{
	display:block;
	
	width:180px;
	margin:0 auto;
	
	font-size:0.8rem;
	line-height:30px;
	font-weight:bold;
	
	box-sizing: border-box;
	border:solid 1px #222;
	
	color:#222;
	background-color:#fff;
	
	text-align: center;
	margin-bottom:20px;
}

.search label.liftup:hover{
	opacity: 0.8;
	cursor: pointer;
}

.search input[type="checkbox"]:checked ~ label.dropdown:after{
	transform: rotate(270deg);
}

.search-content{	
	height:0;
	overflow: hidden;
	
	opacity: 0;
	
	transition: 0.5s;
}

.search input[type="checkbox"]:checked ~ .search-content{
	height:auto;
	
	opacity: 1.0;
	
	/*box-sizing: border-box;
	padding:10px;*/
	
	overflow: visible;	
}

.search-content div.row{
	box-sizing: border-box;
	padding:0 10px;
	margin-bottom:15px;
}

.search-content div.row:first-child{
	margin-top:10px;
}

.search-content div.row ul{
	margin-top:10px;
	
	display:flex;
	flex-flow: row wrap;
	align-items: stretch;
	justify-content: flex-start;
	
	width:100%;
}

.search-content div.row ul li{
	width:50%;
	
	font-size:0.8rem;
	line-height:30px;
	font-weight:bold;
	
	text-align: center;
	
	box-sizing: border-box;
	padding:5px;
}

.search-content div.row:nth-child(1) ul li:nth-child(1){
	width:100%;
}

.search-content div.row:nth-child(2) ul li:last-child{
	width:100%;
}

.search-content div.row ul li span.note{
	display:block;
	
	background-color:#fff;
	color:#048;
	
	box-sizing: border-box;
	border:solid 2px #048;
	border-radius:2.5px;
}

.search-content div.row ul li span.note:hover{
	cursor: pointer;
}

.search-content div.row ul li span.selected{
	background-color:#048;
	color:#fff;
}

@media only screen and (min-width: 640px){
	
	.search-content div.row ul li{
		width:calc(100%/3);
	}
	
}

/*//////////----- CAST-PAGE -----//////////*/


#cast div.post-content{
	width:100%;
	
	display:flex;
	flex-flow: row wrap;
	align-items: stretch;
	justify-content: flex-start;
	
	box-sizing: border-box;
	padding:5px;
}

#cast article{
	width:50%;
	
	box-sizing: border-box;
	padding:2.5px;
}

@media only screen and (min-width: 640px){
	
	#cast article{
		width:calc(100%/3);
	}
	
}

@media only screen and (min-width: 760px){
	
	#cast article{
		width:25%;
		
		padding:5px;
	}
	
}

@media only screen and (min-width: 960px){
	
	#cast article{
		width:calc(100%/3);
	}
	
}
