@charset "utf-8";

.listHeader {
	padding: 8px 10px;
	color: #FFFFFF;
	background: #444444;
}
.listHeader dt {
	position: relative;
	z-index: 10;
	min-width: 4.5em;
	background-color: #FEFEFE;
	color: #632523;
	font-size: 10px;
	line-height: 18px;
	padding: 0 5px;
	border-radius: 2px 0 0 2px;
	margin-right: 15px;
}
.listHeader dt:after {
	content: '';
	display: block;
	position: absolute;
	z-index: -1;
	top: 2px;
	right: -7px;
	width: 14px;
	height: 14px;
	background-color: #FEFEFE;
	-webkit-transform: rotate(45deg) scale(.95);
}
.listHeader dt,
.listHeader dd {
	margin-bottom: 1px;
}

.listSubHeader {
	position: relative;
	background-color: #f0eddd;
	padding: 5px 10px;
	margin-bottom: 15px;
	border-radius: 0 0 2px 2px;
}
.listSubHeader:after {
	content: '';
	position: absolute;
	left: 20px;
	bottom: -6px;
	display: block;
	width: 0;
	height: 0;
	border-top: 6px solid transparent;
	border-right: 6px solid #f0eddd;
	border-bottom: 6px solid #f0eddd;
	border-left: 6px solid transparent;
	-webkit-transform: rotate(45deg);
}
.changeSearchRule {
	position: absolute;
	top: 50%;
	right: 4px;
	margin-top: -16px;
}

.changeSearchRule > li a {
	display: block;
	vertical-align: middle;
	padding: 0 4px;
	min-width: 100px;
	height: 30px;
	white-space: nowrap;
	line-height: 30px;
	font-size: 10px;
	color: #3A2C1E !important;
	text-align: center;
	text-decoration: none;
	border-radius: 8px 0 0 8px;
	background: -webkit-gradient(
		linear,
		left top,
		left bottom,
		from(#FFFFFF),
		to(#DEDEDE),
		color-stop(0.6, #FFFFFF)
	);
	border-top: 1px solid #737373;
	border-bottom: 1px solid #BBB8B9;
	border-left: 1px solid #737373;
	-webkit-box-sizing: border-box;
}
.changeSearchRule > li:last-child a {
	border-right: 1px solid #BBB8B9;
	border-radius: 0 8px 8px 0;
}
.changeSearchRule > li a.bdr8 {
	border-radius: 8px;
}
/* カレンダー */
.dyn_cal_wrapper {
	width: 100%;
	overflow: hidden;
}
.dyn_cal {
	width: 200%;
	position: relative;
	-webkit-transition: all .5s ease;
	border-bottom: 2px solid #9A68CD;
	-webkit-box-shadow: 0 3px 3px 0 rgba(0, 0, 0, .1);
	background-color: #F8F0EA;
}
.dyn_cal > table {
	width: 100%;
	table-layout: fixed;
	border-collapse: collapse;
}
.dyn_cal_tbl {
	width: 100%;
	table-layout: fixed;
	-webkit-box-sizing: border-box;
}

.dyn_cal_tbl th {
	font-weight: normal;
	background-color: #DDDDDD;
	color: #4f381e;
	padding: 4px;
}
.dyn_cal_tbl th {
	text-align: center;
}
.dyn_cal_tbl tr:nth-child(2) {
	background: #65388D !important;
	color: #FFFFFF;
	height: 32px;
	font-weight: bold;
}
.dyn_cal_tbl td {
	text-align: center;
	height: 40px;
}
.dyn_cal_tbl .dyn_disable {
	background: #ECECEC !important;
	-webkit-box-shadow: inset 0 0 6px 0 rgba(0, 0, 0, .2);
}
.dyn_cal_tbl td input[type="radio"] {
	position: absolute;
	z-index: 10;
	display:block;
	width: 100%;
	opacity: 0;
	height: 40px;
	margin: 0;
	padding: 0;
	-webkit-tap-highlight-color: rgba(0,0,0,0);
}
.dyn_cal_tbl td input[type="radio"]:checked + label {
	background: #554411;
	color: #FFFFFF;
}
.dyn_cal_tbl td label {
	position: relative;
	z-index: 0;
	display: block;
	width: 100%;
	height: 40px;
	line-height: 40px;
	text-align: center;
	color: #9A68CD;
	background: -webkit-gradient(
		linear,
		left top,
		left bottom,
		from(#FFFFFF),
		to(#EEE5E0)
	);
	-webkit-box-sizing: border-box;
	padding-right: 1px;
	border-left: 1px solid rgba(212, 208, 207, .8);
	border-top: 1px solid rgba(212, 208, 207, .8);
}
.dyn_cal_tbl .week:last-child label {
	border-bottom: 1px solid rgba(212, 208, 207, .8);
}
.dyn_cal_tbl .week td:last-child label {
	padding-right: 0;
	border-right: 1px solid rgba(212, 208, 207, .8);
}
.dyn_cal_tbl .dyn_sunday > label {
	background: -webkit-gradient(
		linear,
		left top,
		left bottom,
		from(#FFFFFF),
		to(#FFB7B1)
	);
}
.dyn_cal_tbl .dyn_saturday > label {
	background: -webkit-gradient(
		linear,
		left top,
		left bottom,
		from(#FFFFFF),
		to(#C9E3EC)
	);
}
.dyn_cal_close {
	text-align: center;
}
.dyn_cal_btn_prev:before {
	content: '';
	display: inline-block;
	width: 4px;
	height: 7px;
	line-height: 1;
	margin-right: 5px;
	vertical-align: 1px;
	background: url(/CSP/img/kr/smb/k_arrow_purpleL.png?switch=2025062510) no-repeat left center;
}
.dyn_cal_btn_next:before {
	content: '';
	background: 0;
	margin-right: 0;
	background: url(/CSP/img/kr/smb/k_arrow_purpleR.png?switch=2025062510) no-repeat left center;
}
.dyn_cal_btn_next:after {
	content: '';
	display: inline-block;
	width: 4px;
	height: 7px;
	line-height: 1;
	margin-left: 5px;
	vertical-align: 1px;
	background: url(/CSP/img/kr/smb/k_arrow_purpleR.png?switch=2025062510) no-repeat left center;
}

/* フリーワード一覧ハイライト表示 */
.highlightFw {
	background-color: yellow;
	font-weight: bold;
}
/*地図、リスト切り替え*/
.exchangeMapButtonWrap {
	width: 93px;
	margin-top:-6px;
	float:right;
}
.exchangeMapButtonWrap > li > a {
	display: block;
	height: 100%;
	color: #5B5A5A;
	text-decoration: none;
}
.exchangeMapButtonWrap > li {
	float: left;
	width: 36px;
	border-radius: 4px;
	text-decoration: none;
	text-align: center;
	border: 1px solid #bbb8b8;
	font-size:10px;
	background: -webkit-gradient(linear, left top, left bottom, to(#E1E1E1), color-stop(.25, white));
}

.exchangeMapBtnList {
	height: 28px;
	padding: 4px 3px 3px;
	margin-right:5px;
}
.exchangeMapBtnMap {
	height: 29px;
	padding: 3px;
}
.exchangeMapButtonWrap > .current,
.exchangeMapButtonWrap > .current > a{
	color:#FFF;
	background:#B8B7B4;
}
.exchangeButtonIcn{
	height:15px;
	display:block;
	margin:0 auto;
}
.exchangeIcnList {
	background-image:url(/CSP/img/kr/smb/icons/icn_list_off.png?switch=2025062510);
	background-size:17px 12px;
	background-repeat:no-repeat;
	width:17px;
}
.current .exchangeIcnList {
	background-image:url(/CSP/img/kr/smb/icons/icn_list_on.png?switch=2025062510);
}
.exchangeIcnMap {
	background-image:url(/CSP/img/kr/smb/icons/icn_map_off.png?switch=2025062510);
	background-size:12px 15px;
	background-repeat:no-repeat;
	width:12px;
}
.current .exchangeIcnMap {
	background-image:url(/CSP/img/kr/smb/icons/icn_map_on.png?switch=2025062510);
}

.bgBeig {
	background-color:#f0eddd;
}
.listRightLine {
	border-right:1px solid #000;
	padding:2px;
}
.genreList{
	letter-spacing: -1px;
}

.spListSlnPRLabel {
	border: 1px solid #CCCCCC;
	border-radius: 4px;
	color: #CCCCCC;
	display: inline-block;
	font-size: 8px;
	font-weight: normal;
	line-height: 1;
	margin-right: 5px;
	padding: 1px 2px;
}
.spListSlnName {
	font-size: 14px;
	position: relative;
	word-break: break-all;
}
.spListSlnBody {
	margin-top: 5px;
}
.salonOptionIconList + .spListSlnBody {
	margin-top: 8px;
}
.spListSlnAccess {
	margin-left: -5px;
	margin-top: 5px;
}
.listSlnAccess {
	margin-top: 5px;
	position: relative;
}
.listSlnAccess + .genreIconList li {
	margin-top: 9px;
}
.listSlnAccessTxt {
	font-family: monospace;
	font-size: 10px;
	font-weight: bold;
	padding-left: 20px;
	word-wrap: break-word;
}
.listSlnAccessTxt::before {
	background-image: url(/CSP/img/common/smb/sprites/icon_salon_detail.png?switch=2025062510);
	background-position: 0 -33px;
	background-repeat: no-repeat;
	background-size: 20px auto;
	content: "";
	height: 20px;
	left: 0;
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	width: 15px;
}
.spListSlnImage {
	float: left;
	margin-right: 10px;
	padding-top: 3px;
	text-align: center;
	width: 97px;
}
.spListSlnCatch {
	color: #7030A0;
	padding-left: 4px;
	word-wrap: break-word;
}
.spListSlnDetailTbl {
	margin: 5px 0 -8px;
	table-layout: fixed;
	vertical-align: top;
	width: 100%;
}
.spListSlnDetailTbl td {
	padding-bottom: 8px;
	padding-right: 5px;
	vertical-align: top;
}
.spListSlnDetailTbl td + td {
	padding-left: 5px;
	padding-right: 0;
}
.spListSlnAccessTxt {
	line-height: 22px;
	overflow: hidden;
	padding-left: 3px;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.spListSlnAccessTxt,
.spListSlnDetailTbl td > dl {
	color: #665555;
	font-size: 10px;
}
.spListSlnDetailTbl td > dl {
	line-height: 1.2em;
	overflow: hidden;
	padding-left: 5px;
}
.spListSlnDetailTbl .descriptionEmpty {
	line-height: 22px;
	overflow: hidden;
	padding-left: 5px;
}
.spListSlnDetailTbl dt,
.spListSlnDetailTbl dd {
	word-wrap: break-word;
}
.spListSlnDetailTbl dd {
	margin-top: 2px;
}
.spListSlnDetailTbl .equipmentLine dt,
.spListSlnDetailTbl .staffLine dt {
	float: left;
	width: 50px;
}
.spListSlnDetailTbl .equipmentLine dd,
.spListSlnDetailTbl .staffLine dd {
	margin-top: 0;
	overflow: hidden;
	padding-left: 10px;
}
.sdS {
	background-image: url(/CSP/img/common/smb/sprites/icon_salon_detail.png?switch=2025062510);
	background-repeat: no-repeat;
	-webkit-background-size: 20px auto;
	background-size: 20px auto;
}
.iconUp {
	background-position: 0 0;
	display: inline-block;
	height: 12px;
	margin-left: 5px;
	overflow: hidden;
	position: relative;
	text-indent: -9999px;
	width: 16px;
}
.spListSlnPRLabel,
.spListSlnName > .iconUp {
	margin-bottom: 2px;
	vertical-align: middle;
}
.iconUpOverlap::after {
	background: url(/CSP/img/common/smb/sprites/icon_salon_detail.png?switch=2025062510) no-repeat 0 0;
	background-position: 0 0;
	-webkit-background-size: 20px auto;
	background-size: 20px auto;
	content: "";
	display: inline-block;
	height: 12px;
	left: 4px;
	position: absolute;
	top: 0;
	width: 16px;
}
.spListSalonIcon {
	float: left;
	height: 22px;
	position: relative;
	width: 20px;
}
.twoImgListSlnWrap .spListSalonIcon {
	width: 21px;
}

.spListSlnWrap,
.listSlnWrap {
	padding: 15px 30px 15px 10px;
	position: relative;
}
.spListSlnWrap > a,
.listSlnWrap > a {
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}
.spListSlnWrap > a::after,
.listSlnWrap > a::after {
	border-color: #AB9C84;
	border-style: solid;
	border-width: 0 3px 3px 0;
	content: "";
	height: 7px;
	position: absolute;
	right: 10px;
	top: 50%;
	-webkit-transform: translateY(-50%) rotate(-45deg);
	transform: translateY(-50%) rotate(-45deg);
	width: 7px;
}
.spListSlnWrap .icnAccessLabel,
.listSlnWrap .icnAccessLabel {
	background-position: 4px -31px;
}
.spListSlnWrap .icnKuchikomiLabel,
.listSlnWrap .icnKuchikomiLabel,
.twoImgListSlnWrap .icnKuchikomiLabel {
	background-position: 0 -191px;
}
.spListSlnWrap .icnBlogLabel,
.listSlnWrap .icnBlogLabel,
.twoImgListSlnWrap .icnBlogLabel {
	background-position: 5px -152px;
}

/*検索一覧サロンカセット*/
.salonSearchList > li > a {
	position: absolute;
	width: 100%;
	height: 100%;
	display: block;
	top: 0;
	left: 0;
	padding: 0!important;
}
.searchResultHeader {
	background-color: #9A68CD;
	color: #FFFFFF;
	font-size: 11px;
	font-weight: bold;
	padding: 5px 8px;
}
.searchConditionWrapper {
	background-color: #F4F4F4;
	padding: 7px 8px 10px;
}
.searchConditionList {
	word-break: break-all;
}
.searchConditionHead ~ .searchConditionHead,
.searchConditionStatement ~ .searchConditionStatement {
	margin-top: 3px;
}
.searchConditionHead {
	float: left;
	font-size: 11px;
	padding-top: 1px;
	width: 70px;
}
.searchConditionStatement {
	font-weight: bold;
	overflow: hidden;
}
* + .searchConditionLower {
	margin: 8px 2px 0;
}
.searchConditionLower {
	align-items: center;
	display: flex;
	justify-content: space-between;
}
.searchResultNumberDisplay {
	color: #6D6D6D;
	font-size: 11px;
}
.searchResultNumberCount {
	color: #7030A0;
	font-size: 18px;
	font-weight: bold;
	margin-right: 2px;
}
.btnSearchConditionSetting {
	min-height: 36px;
	width: 106px;
}
.switchListSearchResult {
	box-sizing: border-box;
	padding: 10px 8px;
}
.switchListSearchResult::after {
	clear: both;
	content: "";
	display: block;
}
.switchSearchCategoryWrap {
	display: table;
	overflow: hidden;
}
.switchSearchResultView ~ .switchSearchCategoryWrap {
	height: 34px;
}
.switchSearchCategoryWrap + .switchSearchCategoryWrap {
	height: auto;
	margin-top: 10px;
}
.switchSearchCategory {
	display: table-cell;
	vertical-align: middle;
}
.switchSearchCategory > li,
.switchSearchDate > li {
	display: table-cell;
	font-size: 12px;
	padding-right: 7px;
}
.switchSearchCategory > li + li,
.switchSearchDate > li + li {
	border-left: 1px solid #BFB9B0;
	padding-left: 7px;
}
.switchSearchCategory > li {
	line-height: 1.2;
	vertical-align: middle;
}
.switchDateSearchResult {
	margin-bottom: 10px;
	margin-top: 5px;
	padding: 0 8px;
}
.switchSearchResultView,
.switchSearchResultView > li,
.btnSwitchListView {
	box-sizing: border-box;
}
.switchSearchResultView {
	float: right;
	white-space: nowrap;
}
.btnSwitchMapView {
	float: right;
	font-size: 12px;
	margin-right: 2px;
	min-height: 32px;
	padding: 0 8px 0 26px;
	position: relative;
	width: 84px;
}
.btnSwitchMapView::before {
	background: url(/CSP/img/svg/sp/icon_map_kr.svg?switch=2025062510) center / contain no-repeat;
	content: "";
	height: 18px;
	left: 4px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 18px;
}
/* ページング */
.searchResultPaging {
	margin: 24px 16px 32px;
	text-align: center;
}
.searchResultPagingNav {
	position: relative;
}
.searchResultPagingNav > li {
	position: absolute;
	top: 0;
}
.searchResultPagingNavPrev {
	left: 0;
}
.searchResultPagingNavNext {
	right: 0;
}
.searchResultPagingNavBtn,
.searchResultPagingNavBtn:link,
.searchResultPagingNavBtn:visited {
	color: #333333;
	text-decoration: none;
}
.searchResultPagingNavBtn {
	background-color: #FFFFFF;
	border: 1px solid #E0E1E2;
	border-radius: 8px;
	box-sizing: border-box;
	display: block;
	font-weight: bold;
	line-height: 1;
	padding: 11px 0;
	width: 58px;
}
@media (max-width: 374px) {
	.searchResultPagingNavBtn {
		width: 36px;
	}
}
.searchResultPagingNumList {
	display: flex;
	justify-content: center;
}
.searchResultPagingNumList > li + li {
	margin-left: 4px;
}
.searchResultPagingNum,
.searchResultPagingNum:link,
.searchResultPagingNum:visited {
	color: #909090;
	text-decoration: none;
}
.searchResultPagingNum {
	border-radius: 8px;
	display: block;
	font-weight: bold;
	line-height: 1;
	padding: 12px 0;
	width: 36px;
}
.searchResultPagingNumList > li.isCurrent .searchResultPagingNum {
	background-color: #8C61B8;
	color: #FFFFFF;
}
.searchResultPagingCount {
	color: #333333;
	margin-top: 12px;
}

/*クーポンを表示*/
.listSlnToggleArea {
	margin: 0 10px 15px;
}
a.listSlnToggleBtn {
	background-color: #F4F4F4;
	border: 1px solid #CCCCCC;
	border-radius: 2px;
	box-sizing: border-box;
	color: #665555;
	display: block;
	font-size: 10px;
	font-weight: bold;
	line-height: 1;
	padding-bottom: 10px;
	padding-left: 10px;
	padding-top: 10px;
	position: relative;
	text-decoration: none;
}
a.listSlnToggleBtn::after {
	border-color: #AB9C83;
	border-style: solid;
	border-width: 0 3px 3px 0;
	content: "";
	display: block;
	height: 6px;
	margin-top: -6px;
	position: absolute;
	right: 10px;
	top: 50%;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	width: 6px;
}
a.listSlnToggleBtn.isOpened::after {
	border-width: 3px 0 0 3px;
	margin-top: -3px;
}
.listSlnToggleWrap {
	display: none;
}
.listSlnToggleBottomCnt {
	min-height: 44px;
	position: relative;
}
.listSlnToggleAnchor {
	margin-top: 8px;
	padding: 0 12px;
	text-align: right;
}
.listSlnToggleAnchor > a::before {
	border: 4px transparent solid;
	border-left-color: #8C61B8;
	content: "";
	display: inline-block;
	margin-top: -1px;
	vertical-align: middle;
}
.listSlnToggleList > li {
	border-bottom: 1px solid #E0E1E2;
	margin: 0 12px;
	padding: 8px 0;
	position: relative;
}
.listSlnToggleListLink {
	bottom: 0;
	left: 0;
	margin: 0 -12px;
	position: absolute;
	right: 0;
	top: 0;
}
.listSlnToggleType {
	background-color: #C982EA;
	color: #FFFFFF;
	float: left;
	font-size: 10px;
	line-height: 1;
	margin-right: 5px;
	padding-top: 2px;
	padding-bottom: 2px;
	text-align: center;
	width: 24px;
}
.listSlnToggleDtl {
	color: #333333;
	display: block;
	font-size: 11px;
	font-weight: bold;
	overflow: hidden;
	word-break: break-all;
}
.slnCouponListPrice {
	color: #C43357;
    font-size: 12px;
    font-weight: bold;
    margin-top: 4px;
}
.listSlnToggleImg {
	display: inline-block;
	text-align: center;
	width: 99px;
}
.listSlnToggleImg > a {
	outline: 1px solid #CCCCCC;
	display: inline-block;
}
.listSlnToggleImg > a > img {
	max-height: 97px;
	max-width: 97px;
}
.listSlnLinkBtnWrap {
	bottom: 0;
	position: absolute;
	right: 0;
}
a.listSlnLinkBtn {
	background-color: #9271D0;
	border-bottom: 2px solid #8C61B8;
	border-radius: 4px 4px 6px 6px;
	color: #FFFFFF;
	display: block;
	font-weight: bold;
	line-height: 1;
	padding-top: 9px;
	padding-bottom: 9px;
	text-align: center;
	text-decoration: none;
	width: 180px;
}
.listImgCopyGuardWrap {
	position: relative;
	display: inline-block;
	-moz-user-select: none;
	-webkit-user-select: none;
	user-select: none;
}
.listImgCopyGuardCover {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}

/*  FW検索画面のクーポン染み出し部分  */
.couponWrapper {
	margin: 0 10px 15px;
}
.couponLink {
	align-items: baseline;
	background: #F4F4F4;
	border: 1px solid #CCCCCC;
	border-radius: 15px;
	display: flex;
	padding: 15px;
	text-decoration: none;
}
.couponTargetMember {
	background-color: #C982EA;
	color: #FFFFFF;
	flex-shrink: 0;
	font-size: 10px;
	line-height: 1;
	padding: 2px;
	width: 20px;
}
.couponInfo {
	color: #4C4C80;
	font-size: 11px;
	overflow-x: hidden;
	word-wrap: break-word;
}
/* サロン画像を2枚表示
 * キレイSP駅検索結果一覧画面以外に影響が出ないよう
 * 独自クラスを用意（.listSlnDoubleImgWrap） */
.listSlnDoubleImgWrap {
	padding: 15px 10px;
}
.listSlnDoubleImgWrap > a::after {
	content: normal;
}
.listSlnDoubleImgWrap .listSlnAccess {
	color: #665555;
	margin-top: 10px;
}
.listSlnDoubleImgWrap .spListSlnCatch {
	color: #665555;
	font-weight: bold;
	margin-top: 10px;
}
.listSlnDoubleImgWrap .spListSalonIcon {
	float: none;
	width: 21px;
}
.spListSlnImgWrap {
	border: 1px solid #CCCCCC;
	font-size: 0;
	margin: 10px auto 0;
	max-width: 414px;
}
.spListSlnImgWrap > li {
	display: inline-block;
	position: relative;
	-webkit-user-select: none;
	user-select: none;
	width: 50%;
}
.spListSlnImgWrap > li img {
	vertical-align: middle;
	width: 100%;
}
.spListSlnImgWrap > li:only-child::after {
	background: url(/CSP/img/common/logo/img_hpb_logo_200-66.png?switch=2025062510) #F4F4F4 center / 63% no-repeat;
	content: "";
	height: 100%;
	position: absolute;
	right: -100%;
	top: 0;
	width: 100%;
}
.spListSlnImgWrap > li + li img,
.spListSlnImgWrap > li::after {
	border-left: 1px solid #CCCCCC;
}
.spListSlnDetailWrap {
	display: flex;
	flex-wrap: wrap;
	margin-top: 12px;
}
.spListSlnDetailWrap > li {
	background-repeat: no-repeat;
	background-size: 20px;
	width: calc(50% - 4px);
}
.spListSlnDetailWrap > li.seat {
	background-image: url(/CSP/img/common/smb/icn_seat.png?switch=2025062510);
}
.spListSlnDetailWrap > li.staff {
	background-image: url(/CSP/img/common/smb/icn_staff.png?switch=2025062510);
}
.spListSlnDetailWrap > li.blog {
	background-image: url(/CSP/img/common/smb/icn_blog.png?switch=2025062510);
}
.spListSlnDetailWrap > li.message {
	background-image: url(/CSP/img/common/smb/icn_message.png?switch=2025062510);
}
.spListSlnDetailWrap > li:nth-child(even) {
	margin-left: 8px;
}
.spListSlnDetailWrap > li:nth-child(n + 3) {
    margin-top: 8px;
}
.spListSalonDetailTxt {
	display: flex;
	flex: 1;
	line-height: 16px;
}
.spListSalonDetailTxt > dt {
	color: #665555;
	font-family: monospace;
	font-weight: bold;
	padding: 2px 0 2px 24px;
	position: relative;
}
.spListSalonDetailTxt > dd {
	flex: 1;
	margin-left: 8px;
	padding-top: 2px;
	word-break: break-word;
}
.icnFacilityLabel {
	background-position: 0 -112px;
}
.icnStaffLabel {
	background: url(/CSP/img/kr/smb/icons/icon_staff.png?switch=2025062510) no-repeat 0 3px / 21px auto;
}
/* 閲覧サロン一覧染み出し */
.browsingSalonHistoryArea {
	bottom: 0;
	opacity: 0;
	pointer-events: none;
	position: fixed;
	transition: opacity 0.2s linear, visibility 0.2s linear;
	visibility: hidden;
	width: 100%;
}
.browsingSalonHistoryArea.isActive {
	opacity: 1;
	visibility: visible;
}
.browsingSalonHistoryArea a {
	color: #FFFFFF;
	font-weight: bold;
	text-decoration: none;
}
.browsingSalonHistoryTrigger {
	background-color: rgba(102,85,85,0.9);
	border-radius: 4px 4px 0 0;
	box-sizing: border-box;
	display: block;
	font-size: 12px;
	line-height: 38px;
	margin-left: 20px;
	padding: 2px 15px 0;
	pointer-events: auto;
	position: relative;
	width: 140px;
}
.browsingSalonHistoryTrigger::after {
	border-color: #FFFFFF;
	border-style: solid;
	border-width: 2px 0 0 2px;
	content: "";
	display: block;
	height: 6px;
	position: absolute;
	right: 15px;
	top: calc(50% + 2px);
	transform: translateY(-50%) rotate(45deg);
	width: 6px;
}
.browsingSalonHistoryTrigger.isOpened::after {
	border-width: 0 2px 2px 0;
	margin-top: -4px;
}
.browsingSalonHistoryListWrap {
	background-color: rgba(102, 85, 85, 0.9);
	padding-top: 10px;
	pointer-events: auto;
}
/* for iOS15 Safari */
@media screen and (-webkit-min-device-pixel-ratio: 0) {
	_::-webkit-full-page-media, _:future, :root .browsingSalonHistoryListWrap {
		padding-bottom: env(safe-area-inset-bottom);
	}
}
.browsingSalonHistoryList {
	display: none;
	font-size: 0;
	-webkit-overflow-scrolling: touch;
	overflow-x: auto;
	padding: 10px 15px 15px;
	white-space: nowrap;
}
.browsingSalonHistoryList > li {
	display: inline-block;
	vertical-align: top;
	white-space: normal;
	width: 85px;
}
.browsingSalonHistoryList > li + li {
	margin-left: 20px;
}
.browsingSalonHistoryList > li > a {
	display: block;
	position: relative;
}
.browsingSalonHistoryList > li img {
	vertical-align: middle;
	width: 100%;
}
.browsingSalonHistoryName {
	-webkit-box-orient: vertical;
	display: -webkit-box;
	font-size: 10px;
	-webkit-line-clamp: 3;
	line-height: 1.3;
	margin-top: 5px;
	overflow: hidden;
	word-break: break-all;
}
/* 検索一覧個社カセット写真２枚レイアウト */
.twoImgListSlnWrap {
	color: #333333;
	overflow-wrap: break-word;
	padding: 16px;
	position: relative;
	word-wrap: break-word;
}
.twoImgListSlnWrap > a {
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}
.normalSplitLineT.isBrowsed .twoImgListSlnWrap::before {
	background: #909090 url(/CSP/img/svg/sp/icon_check_white.svg?switch=2025062510) 16px 50% / 14px no-repeat;
	border-radius: 0 10px 10px 0;
	color: #FFFFFF;
	content: "閲覧済み";
	display: inline-block;
	font-size: 10px;
	font-weight: bold;
	line-height: 1;
	margin: 0 0 12px -16px;
	padding: 5px 12px 5px 34px;
}
.twoImgListSlnImgWrap {
	font-size: 0;
	margin: 12px auto 0;
	max-width: 414px;
	overflow: hidden;
}
.twoImgListSlnImgWrap > li {
	display: inline-block;
	height: calc(128 / 375 * 100vw);
	max-height: 154px;
	position: relative;
	-webkit-user-select: none;
	user-select: none;
	width: calc(50% - (1px / 2));
}
.twoImgListSlnImgWrap > li + li {
	margin-left: 1px;
}
.twoImgListSlnImgWrap > li > .listImgCopyGuardWrap {
	height: 100%;
	width: 100%;
}
.twoImgListSlnImgWrap > li img {
	height: 100%;
	object-fit: contain;
	width: 100%;
}
.twoImgListSlnImgWrap > li:only-child::after {
	background: url(/CSP/img/common/logo/img_hpb_logo_200-66.png?switch=2025062510) #F4F4F4 center / 63% no-repeat;
	content: "";
	height: 100%;
	left: calc(100% + 1px);
	position: absolute;
	top: 0;
	width: 100%;
}
.twoImgListSlnAccess {
	margin-top: 12px;
	position: relative;
}
.twoImgListSlnAccessTxt {
	background: url(/CSP/img/common/smb/icn_access.png?switch=2025062510) 0 / contain no-repeat;
	-webkit-box-orient: vertical;
	display: -webkit-box;
	font-family: monospace;
	-webkit-line-clamp: 1;
	overflow: hidden;
	padding: 1px 0 1px 24px;
	word-wrap: break-word;
}
.twoImgListSlnAccess + .genreIconList li {
	margin-top: 12px;
}
.twoImgListSlnCatch {
	margin-top: 12px;
}
/*クーポンを表示 サロン画像2枚表示時*/
.twoImgListSlnToggleArea {
	border: 1px solid #E0E1E2;
	border-radius: 8px;
	margin: 0 16px 16px;
}
a.twoImgListSlnToggleBtn {
	color: #333333;
	display: block;
	font-weight: bold;
	line-height: 1;
	padding: 12px 44px 12px 12px;
	position: relative;
	text-decoration: none;
}
a.twoImgListSlnToggleBtn::after {
	background: url(/CSP/img/common/smb/icn_arrow.png?switch=2025062510) 0 / contain;
	content: "";
	height: 20px;
	position: absolute;
	right: 12px;
	top: 50%;
	transform: translateY(-50%) rotate(180deg);
	width: 20px;
}
a.twoImgListSlnToggleBtn.isOpened::after {
	transform: translateY(-50%);
}
.twoImgListSlnToggleWrap {
	border-top: 1px solid #E0E1E2;
	display: none;
}
.twoImgListSlnToggleInner {
	padding: 4px 0 12px;
}
.slnUsableTimeArea {
	margin: 0 16px 16px;
}
.slnUsableTimeHead {
	color: #665555;
	font-weight: bold;
}
.slnUsableTimeList {
	font-size: 0;
	margin: 8px -16px 0;
	-webkit-overflow-scrolling: touch;
	overflow-x: scroll;
	scrollbar-width: none; /* for Firefox */
	white-space: nowrap;
}
.slnUsableTimeList::-webkit-scrollbar { /* for Chrome, Safari */
	display: none;
}
.slnUsableTimeList > li {
	border: 1px solid #E0E1E2;
	color: #333333;
	display: inline-block;
	font-size: 12px;
	line-height: 30px;
	text-align: center;
	width: 46px;
}
.slnUsableTimeList > li:not(:last-child) {
	border-right: none;
}
.slnUsableTimeList > li:first-child {
	margin-left: 16px;
}
.slnUsableTimeList > li:last-child {
	margin-right: 16px;
}
/*エリア絞り込み サジェストモーダル*/
.areaSuggestSearchWrapper.isFixed {
	background-color: rgba(0, 0, 0, 0.8);
	bottom: 0;
	height: 100%;
	left: 0;
	overflow: auto;
	position: fixed;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 1002;
}
.areaSuggestSearch {
	align-items: center;
	background: #FFFFFF;
	box-sizing: border-box;
	display: flex;
	padding: 12px 10px;
}
.areaSuggestSearchWrapper.isFixed .areaSuggestSearch {
	border-bottom: 1px solid #E0E1E2;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 1;
}
.areaSuggestSearchInput {
	background: url(/CSP/img/svg/sp/icon_search_gray.svg?switch=2025062510) 8px / 18px no-repeat;
	border: 1px solid #E0E1E2 !important;
	color: #333333;
	flex: 1;
	height: 36px;
	line-height: 36px !important;
	padding: 0 34px !important;
	position: relative;
}
.areaSuggestSearchInput[type="search"]::-webkit-search-cancel-button {
	-webkit-appearance: none;
	appearance: none;
	background: url(/CSP/img/svg/sp/icon_close_gray.svg?switch=2025062510) center / 14px 14px no-repeat;
	height: 44px;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 36px;
}
.areaSuggestSearchInput::placeholder {
	color: #909090;
}
.areaSuggestSearchWrapper .areaSuggestSearchClose {
	color: #333333;
	display: none;
	font-weight: bold;
	margin-left: 12px;
	position: relative;
	text-decoration: none;
	width: 60px;
}
.areaSuggestSearchWrapper .areaSuggestSearchClose::before {
	content: "";
	height: 44px;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 60px;
}
.areaSuggestSearchWrapper.isFixed .areaSuggestSearchClose {
	display: block;
}
.areaSuggestSearchResult {
	background-color: #FFFFFF;
	display: none;
	overflow-y: scroll;
	padding-top: 61px;
}
.areaSuggestSearchWrapper.isFixed .areaSuggestSearchResult {
	display: block;
}
.areaSuggestSearchResultTitle.dn {
	display: none;
}
.areaSuggestSearchResultTitle {
	color: #7030A0;
	display: block;
	margin: 12px 0 12px 10px;
}
.areaSuggestSearchResultErrorMsg {
	color: #CC0000;
	font-size: 12px;
	padding: 12px 10px;
}
.areaSuggestSearchResultList > li {
	border-top: 1px solid #E0E1E2;
}
.areaSuggestSearchResultList > li:last-child {
	border-bottom: 1px solid #E0E1E2;
}
.areaSuggestSearchResultList > li > a {
	color: #333333;
	display: block;
	font-weight: bold;
	overflow: hidden;
	padding: 13px 10px 13px 52px;
	position: relative;
	text-decoration: none;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.areaSuggestSearchResultList > li.isStation > a {
	background: url(/CSP/img/svg/sp/icon_station_kr.svg?switch=2025062510) 10px center / 20px auto no-repeat;
	color: #6D6D6D;
	font-weight: normal;
	padding-left: 38px;
}
.areaSuggestSearchResultList > li.isMiddleArea > a {
	background: url(/CSP/img/svg/sp/icon_area_kr.svg?switch=2025062510) 10px center / 20px auto no-repeat;
	padding-left: 38px;
}
.areaSuggestSearchResultList > li.isSmallArea > a::before {
	border: solid #333333;
	border-width: 0 0 2px 2px;
	content: "";
	display: block;
	height: 6px;
	left: 40px;
	position: absolute;
	top: 18px;
	width: 6px;
}
.suggestStationName {
	color: #333333;
	font-weight: bold;
}
.ensenName {
	padding-left: 12px;
}
.listScaleHead {
	background: #EEEEEE;
	color: #333333;
	line-height: 1;
	padding: 12px 16px;
}
.listScaleHead + .normalSplitLineT {
	border-top: none;
}
.listRecruitLink {
	font-size: 11px;
	position: absolute;
	right: 8px;
	top: 54px;
}
.listRecruitLink + .switchSearchResultView {
	min-height: 58px;
}
/* スマート支払いラベル */
.onlinePayNormalLabel {
	background: #FFFFFF url(/CSP/img/svg/sp/icon_check_onlinePayment.svg?switch=2025062510) 8px 50% / 14px no-repeat;
	border: 1px solid #B2B2B2;
	border-radius: 10px;
	color: #665555;
	display: inline-block;
	font-size: 10px;
	line-height: 18px;
	padding: 0 8px 0 26px;
}
.onlinePayCampaignLabel {
	background: #FFFFFF url(/CSP/img/svg/sp/icon_card_kr.svg?switch=2025062510) 8px 50% / 14px no-repeat;
	border: 1px solid #FADCE3;
	border-radius: 10px;
	color: #C43357;
	display: inline-block;
	font-size: 10px;
	line-height: 18px;
	padding: 0 8px 0 26px;
}
/* こだわり検索 スマート支払い モーダル */
.onlinePayInfoIcn {
	background: url(/CSP/img/svg/sp/icon_help_kr.svg?switch=2025062510) left calc(50% - 1px) / 14px no-repeat;
	color: #7030A0 !important;
	display: inline-block;
	font-size: 11px;
	padding-left: 18px;
	position: relative;
	text-decoration: none;
}
.onlinePayInfoIcn::before {
	content: "";
	height: 32px;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}
.onlinePayInfoModal {
	background-color: rgba(51, 51, 51, 0.8);
	bottom: 0;
	left: 0;
	opacity: 0;
	position: fixed;
	right: 0;
	top: 0;
	transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
	visibility: hidden;
	z-index: 101;
}
.onlinePayInfoModal.isOpened {
	opacity: 1;
	visibility: visible;
}
.onlinePayInfoModalBody {
	background-color: #FFFFFF;
	border-radius: 8px;
	left: 50%;
	max-width: 343px;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: calc(100% - 32px);
}
.onlinePayInfoModalBody > img {
	border-radius: 8px 8px 0 0;
	max-width: 100%;
}
.onlinePayInfoModalBody.isOpened {
	opacity: 1;
	visibility: visible;
}
.onlinePayInfoCloseBtn {
	background: transparent url(/CSP/img/svg/sp/icon_close_white.svg?switch=2025062510) center / contain no-repeat;
	height: 24px;
	left: 4px;
	position: absolute;
	top: -40px;
	width: 24px;
}
.onlinePayInfoModalBtnWrap {
	border-top: 1px solid #E0E1E2;
	padding: 16px 0;
}

@media (orientation: landscape) {
	.onlinePayInfoModalBodyWrap {
		height: 100%;
		left: 50%;
		max-width: 343px;
		overflow: auto;
		overflow-y: scroll;
		position: absolute;
		top: 50%;
		transform: translate(-50%, -50%);
		width: calc(100% - 32px);
	}
	.onlinePayInfoModalBodyWrap::-webkit-scrollbar {
		display: none;
	}
	.onlinePayInfoModalBody {
		left: 0;
		margin: 60px 0 80px;
		position: relative;
		top: 0;
		transform: none;
		width: 100%;
	}
}
