@charset "utf-8";
/* CSS Document */

/* ------------------------------------ */
/* リストの検索 */
/* ------------------------------------ */
.search_list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.search_list .detail {
	margin-bottom: 30px;
	border-radius: var(--basic_radius);
	padding: 10px;
}

.search_list .detail a:hover{
	opacity: 0.8;
}
.search_list .detail ._first{
	display: flex;
}



.search_list .detail .cast_image{
	position: relative;
	cursor: pointer;
}

.search_list .detail .cast_image figure {
	height: 200px;
}
.search_list .detail .cast_image ._img{
	border-radius: var(--basic_radius);
	box-shadow: var(--brown_box_shadow);
	width: 100%;
	height: 100%;
	object-fit: cover;
}


.search_list .detail .cast_image ._today_work{
	position: absolute;
	width: 100%;
	height: 25px;
	bottom: 0;
	background-color: #ff4444c4;
	opacity: 0.9;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-weight: bold;
	border-radius: 0px 0px var(--basic_radius) var(--basic_radius);
}
.search_list .detail .cast_image ._today_work img{
	width: 16px;
	margin-left: 1px;
}

.search_list .detail ._first ._info{
	margin-left: 14px;
	width: 56%;
	max-width: 220px;
	display: flex;
	flex-direction: column;
}

.search_list .detail ._first .shop_detail{
	font-size: 12px;
	font-weight: bold;
	color: #525252;
	margin-top: 15px;
	line-height: 1.3;
}

.search_list .detail ._first .cast_name{
	margin-top: 5px;
	font-size: 20px;
	font-weight: bold;
	color: #9b6565;
	text-overflow: ellipsis;
	overflow: hidden;
	white-space: nowrap;
}
.search_list .detail ._first ._shop_name{
	font-size: var(--top_font_m);
	color: #9b6565;
	font-weight: bold;
	letter-spacing: 1px;
}

.search_list .detail._woman {
	background-image: linear-gradient(180deg, #fff8f8 0%, #fffbfb 50%, #fff 100%);
	border: 1px solid #ffaaaa;
}

.search_list .detail._man {
	background-image: linear-gradient(180deg, #eef4fe 0%, #f5f9fe 50%, #fff 100%);
	border: 1px solid #5486d1;
}


.cast_search_list ._second {
	display: flex;
	justify-content: space-between;
	margin: 10px 0 0 0;
}
.cast_search_list ._second a,
.cast_search_list ._second button {
	width: 48.8%;
	font-weight: bold;
}

.good_btn_in_search{
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content:flex-start;
	padding: 4px 10px;
	background-color: #fff;
	border-radius: var(--basic_radius);
	width: 100%;
	height: 45px;
	margin-top: auto;
	cursor: pointer;
}
.good_btn_in_search:hover{
	opacity: 0.8;
}
.good_btn_in_search .before_img{
	display: block;
	flex-shrink: 0;
	width: 24px;
	height: 21px;
}
.good_btn_in_search .before_span{
	display: block;
	margin-left: 10px;
	flex-shrink: 0;
	font-size: 13px;
	font-weight: bold;
	line-height: 1.2;
	letter-spacing: 1px;
}


/*ボタン押す前後の表示*/
.good_btn_in_search.animate{
	pointer-events: none;
	cursor: initial;
}
.good_btn_in_search.animate .before_img{
	display: none;
}
.good_btn_in_search.animate .before_span{
	display: none;
}

.good_btn_in_search span{
	color:#fff;
}

.good_btn_in_search .after_wrap{
	margin: auto;
}

.good_btn_in_search._no_press .after_wrap{
	display: none;
}
.good_btn_in_search._no_press.animate .after_wrap{
	display: block;
}
.good_btn_in_search._no_press .after_wrap span{
	color:#fff;
	font-size: var(--top_font_m);
	letter-spacing: 2px;
	font-weight: bold;
}
.good_btn_in_search._man{
	border: 1px solid var(--color_woman);
}
.good_btn_in_search._man .before_span{
	color: var(--color_woman);
}
.good_btn_in_search._woman{
	border: 1px solid var(--color_man);
}
.good_btn_in_search._woman .before_span{
	color: var(--color_man);
}

.good_btn_in_search.animate._man{
	background-color: var(--color_woman);
	color: #fff;
}
.good_btn_in_search.animate._woman{
	background-color: var(--color_man);
	color: #fff;
}

.good_btn_in_search._pressed._man span{
	color: var(--color_woman);
	font-weight: bold;
}
.good_btn_in_search._pressed._woman span{
	color: var(--color_man);
	font-weight: bold;
}

.good_btn_in_search.animate._man span{
	color: #fff;
	font-weight: bold;
}
.good_btn_in_search.animate._woman span{
	color: #fff;
	font-weight: bold;
}

.before_pressd_img{
	display: inline;
}
.after_pressd_img {
	display: none;
}
.good_btn_in_search.animate .before_pressd_img{
	display: none;
}
.good_btn_in_search.animate .after_pressd_img{
	display: inline
}
@media screen and (max-width: 760px) {
	.emotional_text{
		font-size: 3.6vw;
	}
	.good_btn_in_search.animate._woman span,
	.good_btn_in_search.animate._man span{
		font-size: 3.6vw;
	}
}




/* ホバーした時のコメント */
.balloon {
	top: -25px;
	transition: all 300ms 0s ease;
	position: absolute;
	width: 100%;
	opacity: 0;
	z-index: 10;
}
.balloon .balloon_body{
	position: relative;
	display: inline-block;
	min-width: 120px;
	max-width: 100%;
	line-height: 1;
	color: #555;
	font-size: 16px;
}
.balloon .balloon_body span {
	display: inline-block;
	padding: 5px 10px;
	border-radius: 15px;
	border: solid 2px #ff9e00;
	background-color: #FFFFFF;
	z-index: 1;
}
.balloon .balloon_body::before {
	content: "";
	position: absolute;
	top: 100%;
	left: 50px;
	margin-left: -15px;
	border: 10px solid transparent;
	border-top: 20px solid #ff9e00;
	z-index: 2;
}
.balloon .balloon_body::after {
	content: "";
	position: absolute;
	top: 92%;
	left: 50px;
	margin-left: -15px;
	border: 10px solid transparent;
	border-top: 20px solid #ffffff;
	z-index: 50;
}
.balloon_view .balloon {
	top: -30px;
	opacity: 1;
}


/* 詳細 */
.detail {
	display: flex;
	width: 49%;
	flex-direction: column;
	max-width: 415px;
}
.detail .cast_image {
	width: 40%;
	position: relative;
	flex-shrink: 0;
}
.detail .cast_image img{
	width: 100%;
	display: block;
}
.cast_detail {
	width: 60%;
	padding: 10px;
	display: flex;
	flex-direction: column;
	height: 100%;
	justify-content: space-between;
}
.cast_name {
	width: 100%;
	line-height: 1;
	margin-bottom: 5px;
}
.cast_name a{
	color: #664c4c;
	text-decoration: none;
	font-weight: bold;
	font-size: 20px;
	text-overflow: ellipsis;
	overflow: hidden;
	white-space: nowrap;
	display: block;
}
.cast_comment {
	letter-spacing: -3px;
	font-size: 18px;
	overflow: hidden;
	background: repeating-linear-gradient( -0deg, #ffdfea 0,#ffc3d4 2px,#fff 0px,#fff 23px);
	background-color: #FFFFFF;
	line-height: 1.1;
	padding: 2px 5px 5px 5px;
	background-position: 0px -16px;
	min-height: 108px;
	box-shadow: inset 0 0 0 8px #ffffff;
	border: solid 1px #ffdea8;
	z-index: 5;
}
.cast_comment .APJ{
	font-size: 100%;
	max-height: 90px;
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 4;
}
.shop_info {

}
.shop_info .head {
	display: block;
	text-align: center;
	font-weight: bold;
	font-size: 13px;
}

.shop_name {
	display: flex;
	background-color: #FFF;
	padding: 6px;
	border: solid 1px #dddddd;
	height: 58px;
	overflow: hidden;
}
.shop_name a {
	color: #664c4c;
	text-decoration: none;
	font-weight: bold;
	text-overflow: ellipsis;
	overflow: hidden;
	white-space: nowrap;
	display: block;
	max-width: 243px;
	line-height: 1;
	font-size: 14px;
	margin-bottom: 2px;
}
.shop_icon {
	width: 44px;
	height: 44px;
	margin-right: 8px;
	border-radius: 4px;
	overflow: hidden;
}
.shop_icon img {
	width: 100%;
}
.shop_detail {
	font-size: 12px;
	line-height: 1.2;
	display: block;
}


.cast_link {
	background-color: #ff9e00;
	color: #FFFFFF;
	font-size: 14px;
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	line-height: 1;
	padding: 4px 10px;
	border-radius: 50px;
	position: absolute;
	left: 63px;
	bottom: -5px;
	z-index: 10;
}
.cast_link::after {
	font-weight: bold;
	content: '\f105';
	font-family: FontAwesome;
	margin-left: 4px;
	font-size: 120%;
}
.cast_detail dd {
	position: relative;
}


/* イイねボタンの位置とサイズ */
.heart_icon {
	position: absolute;
	bottom: 0px;
	width: 44px;
	height: 44px;
}



/* ------------------------------------ */
/* レイアウト */
/* ------------------------------------ */
.list_body {
	padding: 15px;
}
.list_body_contents {
	display: flex;
}

.body_left {
	width: 415px;
	min-width: 415px;
	padding-right: 15px;
}
.body_left figure.cover {
	margin-bottom: 10px;
}
.body_right {
	background-color: #fffdf5;
	border: solid 1px #ffd22e;
	width: 100%;
	padding: 15px;
}
.body_right dl{
	display: flex;
	align-items: center;
	margin-bottom: 10px;
}
.body_right dt{
	background-color: #ffe061;
	border: solid 1px #8e8e8e;
	width: 90px;
	min-width: 90px;
	font-weight: bold;
	line-height: 1;
	padding: 5px 0;
	text-align: center;
	margin-right: 10px;
}
.body_right dd {
	flex-grow: 1;
	max-width: 375px;
}
.search_main {
	display: flex;
	flex-direction: row-reverse;
	margin-bottom: 120px;
}






/* リストの説明文 */
.info_text {
	overflow: hidden;
	max-height: 60px;
}
.info_text p{
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}






@media screen and (max-width: 760px) {
	.search_main {
		padding:0;
		margin-bottom: 10vw;
		flex-direction: column;
	}
	.search_list .detail {
		margin-bottom: 0vw;
		width: 100%;
	}
	.shop_info .head {
		font-size: 3vw;
	}
	.cast_name a {
		font-size: 4vw;
	}
	.cast_comment {
		letter-spacing: -3px;
		font-size: 4vw;
		line-height: 1.1;
		padding: 1vw 1vw 1vw 1vw;
		background-position: 0px -16px;
		min-height: 108px;
		box-shadow: inset 0 0 0 8px #ffffff;
		border: solid 1px #ffdea8;
		z-index: 5;
		min-height: 21vw;
		background: #FFFFFF;
	}
	.shop_name a {
		max-width: 100%;
		line-height: 1;
		font-size: 3vw;
		margin-bottom: 0.2vw;
	}
	.shop_detail {
		font-size: 2.5vw;
		line-height: 1.2;
		display: block;
	}
	.cast_link {
		background-color: #ff9e00;
		color: #FFFFFF;
		font-size: 3vw;
		display: inline-flex;
		align-items: center;
		text-decoration: none;
		line-height: 1;
		padding: 1vw 2vw;
		border-radius: 50px;
		position: absolute;
		left: 13vw;
		bottom: -3vw;
		z-index: 10;
	}
	.shop_name {
		display: flex;
		background-color: #FFF;
		padding: 1vw;
		border: solid 1px #dddddd;
		height: auto;
		overflow: hidden;
	}
	.shop_icon {
		width: 8vw;
		min-width: 8vw;
		height: 8vw;
		margin-right: 1.5vw;
	}
	.cast_detail {
		padding: 1.5vw;
	}

	/*newデザイン*/
	.cast_search_list{
		padding: 0;
	}
	.cast_search_list .detail{
		max-width: initial;
		border-radius: initial;
		border: initial;
		padding: 8vw 4vw;
	}
	.search_list .detail._woman {
		border: initial;
	}
	.search_list .detail._man {
		border: initial;
	}
	.detail .cast_image,
	.search_list .detail ._first ._info{
		width: 48.4%;
		max-width: initial;
	}
	.search_list .detail .cast_image figure {
		height: 100%;
	}
	.search_list .detail .cast_image figure a {
		display: block;
		width: 100%;
		height: 100%;
	}
	.search_list .detail ._first ._info{
		margin-left: 0;
	}

	.cast_search_list ._second {
		margin: 3vw 0 0 0;
	}
	.cast_search_list ._second a,
	.cast_search_list ._second button {
		width: 48.8%;
		border-width: 2px;
		font-weight: bold;
		font-size: 4.3vw;
	}

	.search_list .detail ._first{
		justify-content: space-between;
	}
	.search_list .detail ._first .cast_name{
		font-size: 4vw;
		margin-bottom: 0;
	}
	.search_list .detail .cast_image ._img{
		width: 100%;
		height: 58vw;
	}

	.search_list .detail .cast_image ._today_work{
		height: 6vw;
	}
	.search_list .detail .cast_image ._today_work img{
		width: 3vw;
		margin-left: 0.6vw;
	}

	.search_list .detail ._first .shop_detail{
		font-size: 2.8vw;
		margin-top: 2vw;
	}
	.good_btn_in_search{
		height: 10.2vw;
		border-radius: 5px;
		padding: 0 2vw;
		border-width: 2px !important;
	}
	.good_btn_in_search .before_img{
		width: 5vw;
		height: auto;
	}
	.good_btn_in_search .before_span{
		margin-left: 2vw;
		font-size: 3.4vw;
	}
	.good_btn_in_search .after_wrap img{
		width: 2.8vw;
		height: auto;
	}
}
