@charset "utf-8";

/************************************************************
 * CLASSES(コンポーネント)
 ************************************************************/

/* 一覧 */
.preList {
	margin-top: 15px;
	background-color: #FFF;
	position: relative;
	z-index: 1;
}
.preListHead {
	padding: 0 10px 5px;
	border-bottom: 2px solid #D9D9D9;
	position: relative;
}
.preListBottom {
	padding: 10px 10px 0;
	font-size: 10px;
}
.postList {
	margin-top: 20px;
	border-top: 2px solid #D9D9D9;
	padding: 10px 10px 0;
	position: relative;
	overflow: hidden;
	zoom: 1;
}
#listWrapper {
	margin-top: -12px;
	position: relative;
	zoom: 1;
	z-index: 0;
}
.listCassette {
	margin-top: 10px;
	padding-top: 10px;
	border-top: 2px solid #DDD;
}
.listTitle {
	display: block;
	background-color: #A6A39B;
	position: relative;
}
.listTitleHeading {
	line-height: 27px;
	font-size: 16px;
}
.listBody {
	padding: 10px 0 0;
}
.listData {
	line-height: 1.7;
	margin-bottom: -1px;
	padding-bottom: 6px;
	margin-top: 5px;
}

/* ピックアップメニュー名 */
.pickupMenuName a{
	color: #333333;
	text-decoration:none;
}
/* ピックアップのキャッチコピー */
.pickupCatch a{
	color: #9966CC;
	text-decoration:none;
}

/* クーポン */
.couponList {
	width: 190px;
	font-size: 10px;
	border-top: 1px solid #CDCDCC;
	border-left: 1px solid #CDCDCC;
}
.couponList li {
	position: relative;
	zoom: 1;
}
.couponList a {
	display: block;
	padding: 10px 10px 10px 40px;
	border-right: 1px solid #CDCDCC;
	border-bottom: 1px solid #CDCDCC;
	zoom: 1;
}
.couponList a:hover {
	background-color: #FFF0F0;
}
/* クーポンリスト */
.couponList2 {
	width: 160px;
	font-size: 10px;
	background-position: -4910px 0;
	background-repeat: repeat-y;
}
.couponList2Head {
	background-position: -4590px top;
	background-repeat: no-repeat;
}
.couponList2Bottom {
	background-position: -4750px bottom;
	background-repeat: no-repeat;
	position: relative;
	zoom: 1;
	z-index: 1;
	overflow: hidden;
}
.couponList2Bottom li {
	position: relative;
	zoom: 1;
}
.couponList2Bottom a {
	display: block;
	padding: 10px 7px 10px 38px;
	border-bottom: 1px solid #CDCDCC;
	margin-bottom: -1px;
	*margin-bottom: 0;
	_margin-bottom: -1px;
	zoom: 1;
	position: relative;
	z-index: 10;
}

.area {
	position: relative;
	overflow: hidden;
	zoom: 1;
}
.areaList {
	float: left;
	position: relative;
	overflow: hidden;
}
.areaList li {
	display: inline;
	border-left: 1px solid #DDD;
	margin-right: 6px;
	margin-left: -1px;
	padding-left: 5px;
}
.CouponArea {
	background-color: #F6F6F6 !important;
	border: none !important;
	margin: 5px 0 10px;
	padding: 10px;
}
.CouponArea dl {
	border-top: 1px solid #E0E1E2;
	padding: 10px 0 8px;
}
.CouponArea dl:first-child {
	border-top: none;
	padding-top: 0;
}
.CouponArea dl:last-child {
	padding-bottom: 0;
}
.couponTypeName {
	background-color: #9966CC;
	color: #FFFFFF;
	display: inline-block;
	font-size: 10px;
	line-height: 1;
	padding: 3px;
}
.CouponArea dd {
	line-height: 21px;
}
.slnCouponMenuInfo {
	align-items: center;
	display: flex;
	justify-content: space-between;
}
.slnCouponMenuInfoLink {
	flex: 1;
}
.slnCouponMenuInfoPrice {
	color: #C43357;
	font-size: 11px;
	font-weight: bold;
	margin-left: 10px;
	min-width: 52px;
	text-align: right;
	white-space: nowrap;
}

.mainContentsST {margin:0 1px; background-color:#F2F2F2; zoom:1;}
.mainContentsSTHead {
	padding: 2px 0;
	border-bottom: 2px solid #7b705e;
}
.mainContentsSTBottom {padding: 5px 5px 2px 5px;}

/* フリーワード検索一覧エリア名表示 */
.cassetteArea {
	border-right: 1px solid #bfbfbf;
	border-bottom: 1px solid #bfbfbf;
	border-left: 1px solid #bfbfbf;
	background-color: #D9D9D9;
	padding: 0 3px 0 10px;
	position: relative;
	height:100%;
}

/* フリーワード一覧ハイライト表示 */
.highlightFw {
	background-color: yellow;
	font-weight: bold;
}

/* 表 */
.bdCell {
	border-top: 1px solid #DDDDDD;
	border-left: 1px solid #DDDDDD;
}
.bdCell th,
.bdCell td {
	border-right: 1px solid #DDDDDD;
	border-bottom: 1px solid #DDDDDD;
}

/* Header */
.pageBody h3 {
	border-bottom: solid 3px #E4E0D9;
	margin-bottom: 17px;
	padding: 5px 0px 12px 10px;
	font-size: 20px;
}

/* submitObj */
div.b1-2 div.submitObj {
	background-color: rgb(238, 235, 228);
	margin-bottom: 21px;
	height: 48px;
	position: absolute;
	bottom: -21px;
	left: 0;
	width: 641px;
	border-top: 1px solid rgb(190, 176, 158);
	opacity: 0.85;
	-ms-filter: alpha(opacity="85");
	filter: alpha(opacity="85");
}
div.b1-2 .btnTBCloseFooterWrap {
	position: absolute;
	bottom: 15px;
	right: 52px;
	z-index: 10;
	display: inline-block;
	*display: inline;
	*zoom: 1;
}
div.b1-2 .btnTBCloseFooterWrap .tbClose {
	color: rgb(153, 135, 111) !important;
}

div.b1-2 p.select {
	margin: 0px auto;
	width: 641px;
	height: 24px;
	padding-top: 12px !important;
	position: absolute;
	bottom: 7px;
	left: 0;
}

/* addObj */
div.b1-2 div.addObj {
	margin-bottom: 24px;
}
div.b1-2 div.addObj table {
	border: solid 1px #DDDDDD;
	border-collapse: collapse;
	width: 570px;
	margin: 0 auto;
	/*\*//*/
	border-left: none;
	border-bottom: none;
	/**/
}
div.b1-2 div.addObj table table {
	border: solid 0px;
	border-collapse: collapse;
	width: auto;
	font-size: 100%;
}
div.b1-2 div.addObj th {
	border: solid 1px #DDDDDD;
	padding: 10px 12px;
	text-align: left;
	/*\*//*/
	border-right: none;
	border-top: none;
	/**/
}
div.b1-2 div.addObj th.th1 {
	background-color: #EEEBE4;
	width: 86px;
	text-align: center;
}
div.b1-2 div.addObj th.th2 {
	background-color: #F5F5F5;
	width: 50px;
	font-weight: normal;
	/*\*//*/
	width: 74px;
	/**/
}
div.b1-2 div.addObj td {
	border: solid 1px #DDDDDD;
	padding: 10px 12px;
	/*\*//*/
	border-right: none;
	border-top: none;
	/**/
}
div.b1-2 div.addObj td.td1 tr.tr3 td td,
div.b1-2 div.addObj td.td1 tr.tr2 td td,
div.b1-2 div.addObj td.td1 tr.tr1 td td,
div.b1-2 div.addObj td td {
	border: solid 0px;
	padding: 0px 18px 0px 0px;
	*padding: 0px 14px 0px 0px;
	/*\*//*/
	padding: 0px 10px 0px 0px;
	/**/
}
div.b1-2 div.addObj td.td1 td {
	padding: 10px 0px 10px 12px;
}
div.b1-2 div.addObj td.td1 table {
	width: 100%;
}
div.b1-2 div.addObj td.td1 table table {
	width: auto;
}
div.b1-2 div.addObj td.td1 tr.tr1 th {
	border: none;
	border-right: solid 1px #DDDDDD;
	border-bottom: solid 1px #DDDDDD;
}
div.b1-2 div.addObj td.td1 tr.tr1 td {
	border: none;
	border-bottom: solid 1px #DDDDDD;
}
div.b1-2 div.addObj td.td1 tr.tr2 th {
	border: none;
	border-right: solid 1px #DDDDDD;
}
div.b1-2 div.addObj td.td1 tr.tr2 td {
	border: none;
}
div.b1-2 div.addObj td.td1 tr.tr3 th {
	border: none;
	border-top: solid 1px #DDDDDD;
	border-right: solid 1px #DDDDDD;
}
div.b1-2 div.addObj td.td1 tr.tr3 td {
	border: none;
	border-top: solid 1px #DDDDDD;
}
div.b1-2 div.addObj td.td1 {
	padding: 0px;
}
div.b1-2 div.addObj td.td2 {
	width: 89px;
	/*\*//*/
	width: 123px;
	/**/
}

div.b1-2 div.addObj table.areaAdd {
	border: none;
	padding: 0;
}
div.b1-2 div.addObj table.areaAdd td {
	border: none;
	padding: 0px 18px 4px 0px;
	vertical-align: top;
}
div.b1-2 div.addObj table.areaAdd td input {
	float: left;
	margin-right: 3px;
}
div.b1-2 div.addObj table.areaAdd td input[type="checkbox"]:disabled + span {
	opacity: 0.3;
}
div.b1-2 div.addObj table.areaAdd td span.formtxt {
	display: block;
	line-height: 1.4;
	overflow: hidden;
	*zoom: 1;
}
div.b1-2 p.add {
	margin: 0px auto;
	width: 641px;
	height: 24px;
	padding-top: 12px !important;
	position: absolute;
	bottom: 7px;
	left: 0;
}

/* popUpFooter */
.tbClose {
	color: #BFB4AB !important;
	font-weight: bold;
	text-decoration: none !important;
	background: url(/CSP/img/hc/icons/icon_tb_close.png?switch=2025071615) no-repeat left center;
	padding-left: 20px;
	font-size: 14px;
}


.pageBody .areaContents {
	margin-top: 10px;
	padding: 0 20px;
}

#TB_ajaxContent.TB_modal {
    padding: 0 15px !important;
}
.pageBody {
    padding-top: 15px;
    padding-bottom: 15px;
}
/* PC沿線一覧 */
.ensenListWrapper {
	border: 1px solid #D9D9D9;;
}
.ensenListHead {
	line-height: 35px;
	background-color: #f2f2f2;
	padding-left: 10px;
}
.ensenListName {
	vertical-align: middle;
}
.polularStationList {
	font-size: 0;
}
.polularStationList li {
	margin-left: 8px;
	padding-right: 0!important;
	width: 108px!important;
	font-size: 12px;
}
.polularStationList li a,
.polularStationList li p {
	vertical-align: middle;
}
.polularStationList li span {
	display: inline-block;
	vertical-align: middle;
}
.recentStationList {
	font-size: 0;
	margin-top: -5px;
	width: 596px;
	word-wrap: break-word;
}
.recentStationList li {
	display: inline-block;
	font-size: 12px;
	margin-left: 8px;
	margin-top: 5px;
	min-width: 108px;
}
.ensenListInner {
	font-size: 0;
}
.ensenListInner li{
	display: inline-block;
	width: 221px;
	margin-left: 24px;
	vertical-align: top;
	font-size: 12px;
}
.ensenListInner span {
	display: inline-block;
	vertical-align: middle;
}
.ensenListInner li input {
	position: relative;
	margin-left: -18px;
}
.ensenDisplayAll {
	margin: 10px auto 0 auto;
	width: 134px;
	line-height: 30px;
	text-align: center;
}
.ensenSelectBtn {
	background-color: #CCCCCC;
	margin: 20px auto 0 auto;
	width: 130px;
	line-height: 30px;
	text-align: center;
}
.ensenDisplayIcon > span > span {
	position: relative;
	width: 124px!important;
	padding-left: 5px;
	font-weight: normal;
}
.ensenDisplayIcon > span > span:before {
	display: block;
	position: absolute;
	top: 6px;
	left: 6px;
	content: '';
	width: 8px;
	height: 8px;
	background-image: url("/CSP/img/kr/sprites/i.png?switch=2025071615");
	background-repeat: no-repeat;
	background-position: -156px -4050px;
}
.ensenDisplayIcon > span > span:hover:before {
	background-position: -180px -4050px;
}
.ensenDisplayIconClosed > span > span {
	position: relative;
	width: 100%;
	padding-left: 0;
	font-weight: normal;
}
.ensenDisplayIconClosed > span > span:before {
	display: block;
	position: absolute;
	top: 6px;
	left: 6px;
	content: '';
	width: 8px;
	height: 8px;
	background-image: url("/CSP/img/kr/sprites/i.png?switch=2025071615");
	background-repeat: no-repeat;
	background-position: -168px -4050px;
}
.ensenDisplayIconClosed > span > span:hover:before {
	background-position: -192px -4050px;
}
/* PC駅一覧 */
.stationListWrapper {
	border: 1px solid #D9D9D9;
}
.stationListHead {
	line-height: 35px;
	background-color: #ECEEE1;
	text-align: center;
}
.stationListName {
	vertical-align: top;
}
.stationListInner li{
	display: inline-block;
	vertical-align: top;
	margin-left: 18px;
	width: 164px;
}
.stationListInner li input {
	margin-left: -18px;
}
.stationListInner span {
	display: inline-block;
	vertical-align: middle;
}
.stationResult {
	margin: 50px auto 0 auto;
	width: 280px;
}
.stationResult li{
	float: left;
	width: 111px;
	margin-right: 50px;
}
.stationResult li + li {
	margin-right: 0;
	width: 111px;
}
/* PC駅選択ライトボックス */
.stationPopupBox {
	display: none;
	position: absolute;
	z-index: 300;
	color: #777777;
}
.stationPopupBoxWrapper {
	position: relative;
	width: 362px;
	padding: 10px 0;
	background-color: #FFFFFF;
	border: 1px solid #999999;
	z-index: 300;
}
.stationPopupBoxList {
	border: 1px solid #CCCCCC;
	margin-top: 10px;
	padding: 10px;
}
.stationPopupBoxList li {
	margin-top: 5px;
	display: block;
}
.stationPopupBoxList dd {
	margin-top: 5px;
	display: block;
}
.stationPopupList {
	display: inline-block;
	font-size: 0;
}
.stationPopupList li {
	display: inline-block;
	vertical-align: top;
	width: 81px;
	margin-left: 18px;
	font-size: 12px;
}
.stationPopupList li input {
	margin-left: -18px;
}
.stationPopupAnotherSearch {
	text-align: center;
}
.stationPopupAnotherSearch li:first-child {
	margin-left: 0;
}
.stationPopupAnotherSearch li {
	display: inline-block;
	margin-left: 10px;
}
.stationCloseBox {
	text-align: center;
	margin-top: 15px;
}
.stationCloseBox a {
	text-decoration: none;
	color: #777777;
}
.stationCloseBox img {
	vertical-align: middle;
}

/* エリア選択 */
#areaText, #areaTextSelected { display: inline; word-break: break-all; }
#areaText li, #areaTextSelected li { display: inline; }
#areaText li:before, #areaTextSelected li:before {
    content:", ";
}
#areaText li:first-child:before, #areaTextSelected li:first-child:before {
    content:"";
}

.disable {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
    color: #999999 !important;
}

.conditionCouponWrap {
	padding: 10px 5px !important;
}
.conditionCouponList {
	width: 100%;
}

/* for 2column */
.conditionCouponList li {
	display: table;
	float: left;
	margin-bottom: 3px;
	text-align: left;
	width: 50%;
}

.conditionCouponList li span,
.conditionCouponList li label {
	display: table-cell;
	vertical-align: top;
	word-wrap: break-word;
}
.conditionCouponList li label {
	line-height: normal;
}

/* for radio button */
.conditionCouponList.typeRadio li span {
	width: 24px;
}

/* list and mapList change btn */
.mapBtnWrap {
	float: right;
	font-size: 12px;
}
.mapBtnWrap img,
.mapBtnWrap span{
	vertical-align:middle;
	display:inline-block;
	cursor: default;
}
.mapBtnWrap img {
	width: 18px;
	height: 18px;
}
.mapBtnWrap span {
	margin-left: 2px;
}

/* SEARCH LIST SALON CASSETTE */
.searchListCassette {
	border: 1px solid #E0E1E2;
	border-radius: 8px;
	margin-top: 20px;
	word-wrap: break-word;
}
.searchListCassette ~ .searchListCassette {
	margin-top: 20px;
}
.slcHeadWrap {
	padding: 16px 16px 0;
}
.slcHeadContents {
	position: relative;
}
.slcHeadContentsInner {
	padding-right: 150px;
}
.slcHead {
	font-size: 16px;
}
.slnPRCassette .slcHead {
	align-items: flex-start;
	display: flex;
}
.slnPRCassette .slcHead::before {
	background-color: #FFFFFF;
	border: 1px solid #AAAAAA;
	border-radius: 3px;
	color: #AAAAAA;
	content: "PR";
	font-size: 10px;
	font-weight: bold;
	line-height: 1;
	margin: 5px 10px 5px 0;
	padding: 1px 2px;
}
.slcIcnUp {
	background-color: #FF9900;
	color: #FFFFFF;
	display: inline-block;
	font-size: 10px;
	font-weight: normal;
	line-height: 1;
	margin-left: 5px;
	padding: 1px 2px;
	vertical-align: middle;
}
.slcClassIcn > li {
	border-radius: 4px;
	float: left;
	font-size: 10px;
	margin-right: 5px;
	padding-left: 3px;
	padding-right: 3px;
	text-align: center;
}
.slcClassIcn .provisional {
	background-color: #FFFFFF;
	border: 1px solid #988989;
	color: #988989;
}
.slcClassIcn .mensOk {
	background-color: #D9E2ED;
	border: 1px solid #0677CF;
	color: #0677CF;
}
.slcClassIcn .mensPreference {
	background-color: #6DA1DB;
	border: 1px solid #0677CF;
	color: #FFFFFF;
}
.slcGenreIcn {
	margin-top: -5px;
}
.slcGenreIcn > li {
	float: left;
	margin: 5px 5px 0 0;
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
}
.slcBody {
	margin-top: 16px;
	padding: 0 16px 16px;
	position: relative;
}
.slcImage {
	float: left;
	margin-right: 24px;
	text-align: center;
	width: 219px;
}
.slcImage > li {
	display: inline-block;
	vertical-align: top;
}
.slcImage > li ~ li {
	margin: 10px 5px 0;
}
.slcImage a {
	display: block;
}
.slcImage a:hover {
	-ms-filter: alpha(opacity="80");
	filter: alpha(opacity="80");
	opacity: 0.8;
}
.slcContents {
	min-height: 100px;
	overflow: hidden;
}
.slcCatch > a {
	color: #7030A0 !important;
	display: block;
	font-size: 14px;
	font-weight: bold;
	text-decoration: none !important;
	word-wrap: break-word;
}
.slcCatch > a:hover {
	color: #8C61B8 !important;
}
.slcDetail {
	margin-top: 16px;
	position: relative;
}
.slcDetail > dl + dl {
	margin-top: 8px;
	width: 369px;
}
.slcDetail dt {
	background-repeat: no-repeat;
	background-size: 20px;
	box-sizing: border-box;
	color: #665555;
	float: left;
	font-weight: bold;
	padding: 1px 0 1px 28px;
	width: 84px;
}
.slcDetail dd {
	overflow: hidden;
	padding: 1px 0;
}
.slcDetailOther {
	color: #665555;
	min-height: 32px;
	position: relative;
	width: 369px;
}
.slcDetailOther > dl {
	display: inline-block;
	margin-top: 10px;
	vertical-align: top;
	width: 180px;
}
.slcDetailAccessIcon    { background-image: url(/CSP/img/common/smb/icn_access.png?switch=2025071615); }
.slcDetailStaffIcon     { background-image: url(/CSP/img/common/smb/icn_staff.png?switch=2025071615); }
.slcDetailEquipmentIcon { background-image: url(/CSP/img/common/smb/icn_seat.png?switch=2025071615); }
.slcDetailBlogIcon      { background-image: url(/CSP/img/common/smb/icn_blog.png?switch=2025071615); }
.slcDetailMessageIcon   { background-image: url(/CSP/img/common/smb/icn_message.png?switch=2025071615); }
.slcCouponMenu {
	background-color: #F6F6F6;
	margin-top: 20px;
	padding: 12px;
}
.slcCouponMenuHead {
	overflow: hidden;
	padding-right: 15px;
	word-wrap: break-word;
}
.slcCouponMenuHead > a {
	color: #665555;
	font-size: 11px;
	font-weight: bold;
}
.slcCouponMenuAll {
	float: right;
}
.slcCoupon {
	margin-top: 12px;
}
.slcCouponList {
	display: flex;
}
.slcCouponList ~ .slcCouponList {
	margin-top: 12px;
}
.slcCouponName {
	display: flex;
	flex: 1;
	position: relative;
}
.slcCouponListIcon {
	background-color: #9966CC;
	color: #FFFFFF;
	font-size: 10px;
	left: 0;
	line-height: 1;
	padding: 3px;
	position: absolute;
	top: 1px;
	word-wrap: break-word;
}
.slcCouponLink {
	display: inline-block;
	font-size: 11px;
	word-break: break-all;
}
.slcCouponListIcon + .slcCouponLink {
	padding-left: 30px;
}
.slcCouponPrice {
	color: #C43357;
	font-weight: bold;
	overflow: hidden;
	padding-left: 20px;
	text-align: right;
	word-wrap: break-word;
}
.slcMenu {
	margin-top: 6px;
}
.slcMenuList {
	margin-top: 6px;
}
.slcMenuList ~ .slcMenuList {
	margin-top: 12px;
}
.slcMenuName {
	float: left;
	width: 370px;
}
.slcMenuLink {
	display: block;
	word-wrap: break-word;
}
.slcMenuPrice {
	color: #666666;
	font-weight: bold;
	overflow: hidden;
	padding-left: 20px;
	text-align: right;
	word-wrap: break-word;
}
.slcCoupon + .slcMenu {
	margin-top: 12px;
}
.searchListPaging {
	margin-top: 10px;
	overflow: hidden;
	padding: 10px 10px 0;
	position: relative;
	zoom: 1;
}
.slcBookmark {
	position: absolute;
	right: 0;
	top: 0;
	z-index: 1;
}
.slcReserve {
	bottom: 0;
	position: absolute;
	right: 0;
	width: 130px;
}
.slcUsableTimeWrap {
	border-top: 1px solid #E0E1E2;
	padding: 16px;
}
.slcUsableTimeHeadWrap {
	display: flex;
	justify-content: space-between;
}
.slcUsableTimeHead {
	color: #665550;
	font-weight: bold;
}
.slcUsableAllTimeArea {
	position: relative;
}
.slcUsableAllTimeTrigger {
	display: block;
	padding-left: 11px;
	position: relative;
}
.slcUsableAllTimeTrigger::before {
	border-color: #8C61B8 transparent transparent transparent;
	border-style: solid;
	border-width: 3px 3.5px 0 3.5px;
	content: "";
	height: 0;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 0;
}
.slcUsableAllTimeList {
	border-radius: 8px;
	box-shadow: 0 0 8px 0 #CCCCCC;
	display: flex;
	flex-wrap: wrap;
	opacity: 0;
	padding: 16px 8px;
	position: absolute;
	right: 0;
	top: 26px;
	transition: visibility 0.3s ease-in-out, opacity 0.3s ease-in-out;
	visibility: hidden;
	width: calc(50px * 13);
	z-index: 2;
}
.slcUsableAllTimeList::before {
	background-color: #FFFFFF;
	box-shadow: 0 0 8px 0 #CCCCCC;
	content: "";
	height: 10px;
	position: absolute;
	right: 62px;
	top: -5px;
	transform: rotate(45deg);
	width: 10px;
}
.slcUsableAllTimeList > li {
	box-sizing: border-box;
	font-size: 11px;
	line-height: 1;
	text-align: center;
	width: 50px;
	z-index: 2;
}
.slcUsableAllTimeList > li:not(:nth-child(13n)) {
	border-right: 1px solid #E0E1E2;
}
.slcUsableAllTimeList > li:nth-child(n + 14) {
	margin-top: 12px;
}
.slcUsableAllTimeList::after {
	background-color: #FFFFFF;
	border-radius: 8px;
	bottom: 0;
	content: "";
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}
.slcUsableAllTimeArea:hover > .slcUsableAllTimeTrigger::before {
	border-color: transparent transparent #8C61B8 transparent;
	border-width: 0 3.5px 3px 3.5px;
}
.slcUsableAllTimeArea:hover > .slcUsableAllTimeList {
	opacity: 1;
	visibility: visible;
}
.slcUsableTimeList {
	display: flex;
	margin-top: 8px;
}
.slcUsableTimeList > li {
	border: 1px solid #E0E1E2;
	box-sizing: border-box;
	font-size: 11px;
	line-height: 30px;
	text-align: center;
	width: calc(100% / 15);
}
.slcUsableTimeList > li:not(:last-child) {
	border-right: none;
}
/* /SEARCH LIST SALON CASSETTE */

/* SEARCH LIST TAB */
.searchListCareerLink {
	font-size: 12px;
	text-align: right;
}
/* /SEARCH LIST TAB */

/* AROUNDSEARCH */
.aroundSearchTitle {
	margin-top: 60px;
}
.searchResultZeroOuterFrame + .aroundSearchTitle {
	margin-top: 20px;
}
/* /AROUNDSEARCH */

/* 開始時刻・利用時間の注釈 */
.annotationMark {
	position: relative;
}
.annotationMark::after {
	content: "\203B";
	font-size: 10px;
	line-height: 1;
	position: absolute;
	top: 0;
	transform: scale(0.8);
}

/* 開始時刻・利用時間のセレクトボックス */
.startTimeSelect,
.timeSelectCell > select {
	background-color: #FFFFFF;
	border: 1px solid;
	border-color: #8E8E8E #CCCCCC #CCCCCC #8E8E8E;
	cursor: pointer;
	height: 22px;
}
.startTimeSelect {
	align-items: center;
	box-sizing: border-box;
	display: inline-flex;
	padding: 0 16px 0 6px;
	position: relative;
}
.timeSelectCell > select {
	-webkit-appearance: none;
	   -moz-appearance: none;
	        appearance: none;
	border-radius: 0;
	opacity: 1;
	padding: 0 12px 0 6px;
	width: 100%;
}
.timeSelectCell > select::-ms-expand {
	display: none;
}
.startTimeSelect::after,
.timeSelectCell::after {
	border-right: 1px solid #000000;
	border-top: 1px solid #000000;
	content: "";
	height: 5px;
	pointer-events: none;
	position: absolute;
	transform: rotate(135deg);
	width: 5px;
}
.startTimeSelect::after {
	right: 5px;
	top: 5px;
}
.timeSelectCell::after {
	right: 6px;
	top: 6px;
}

.startTimeSelect.disabled,
.timeSelectCell.disabled > select {
	color: #CCCCCC;
	cursor: default;
	pointer-events: none;
}
.timeSelectCell.disabled > select::-ms-value {
	color: #CCCCCC;
	cursor: default;
	pointer-events: none;
}
.startTimeSelect.disabled::after,
.timeSelectCell.disabled::after {
	border-color: #CCCCCC;
}
.timeSelectCell > select > option:disabled {
	color: rgba(51, 51, 51, 0.3);
}

/* 開始時刻のポップアップ */
.startTimePopup {
	background-color: #FFFFFF;
	display: none;
	left: 0;
	position: absolute;
	top: 0;
	z-index: 2;
}
.startTimePopup.isOpened {
	display: block;
}
.startTimePopupHead {
	background-color: #999999;
	color: #FFFFFF;
	line-height: 1;
	padding: 10px;
	position: relative;
}
.startTimePopupCloseBtn {
	background: url(/CSP/img/common/btn_cal_close.png?switch=2025071615) 0 0 no-repeat;
	height: 20px;
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	width: 20px;
}
.startTimePopupCloseBtn:hover {
	background-position: 0 -20px;
}
.startTimePopupBody {
	border: 1px solid #999999;
	border-top: none;
	padding: 10px;
}
.startTimeListWrapper {
	align-items: center;
	display: flex;
}
.startTimeList {
	border: 1px solid #DDDDDD;
	box-sizing: border-box;
	height: 320px;
	min-width: 90px;
	overflow-y: scroll;
	padding: 10px 10px 0 10px;
	white-space: nowrap;
}
.startTimeList::after {
	content: "";
	display: block;
	height: 10px;
}
.startTimeList > li + li {
	margin-top: 10px;
}
.startTimeList > li label {
	align-items: center;
	color: #666666;
	display: flex;
	font-size: 11px;
	width: 100%;
}
.startTimeList > li input[type="radio"] {
	margin: 0 5px 0 0;
}
.startTimeList > li label.disabled {
	color: rgba(102, 102, 102, 0.3);
}
.startTimeSetBtn {
	background-color: #FFFFFF;
	border: solid #CCCCCC;
	border-radius: 4px;
	border-width: 1px 1px 3px 1px;
	color: #666666 !important;
	display: block;
	font-size: 14px;
	font-weight: bold;
	line-height: 30px;
	margin-top: 10px;
	text-align: center;
	text-decoration: none !important;
}
.startTimeSetBtn.disabled {
	opacity: 0.3;
	pointer-events: none;
}
.startTimeSetBtn:hover {
	opacity: 0.7;
}

/* こだわり条件追加モーダル */
.conditionModal {
	align-items: center;
	background-color: rgba(51, 51, 51, 0.8);
	bottom: 0;
	display: flex;
	justify-content: center;
	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: 11;
}
.conditionModal.isOpened {
	opacity: 1;
	visibility: visible;
}
.conditionModalCloseBtn {
	height: 24px;
	left: 0;
	position: absolute;
	top: -32px;
	width: 24px;
}
.conditionModalCloseBtn::before,
.conditionModalCloseBtn::after {
	background-color: #FFFFFF;
	border-radius: 1px;
	content: "";
	height: 2px;
	left: 50%;
	position: absolute;
	top: 50%;
	width: 24px;
}
.conditionModalCloseBtn::before {
	transform: translate(-50%, -50%) rotate(45deg);
}
.conditionModalCloseBtn::after {
	transform: translate(-50%, -50%) rotate(-45deg);
}
.conditionModalCloseBtn:hover {
	opacity: 0.7;
}
.conditionModalBody {
	background-color: #FFFFFF;
	border-radius: 8px;
	margin: 64px 32px;
	max-height: calc(100vh - 128px);
	position: relative;
	width: 670px;
}
.conditionModalBody#areaPanel {
	width: 946px;
}
.conditionModalBodyScrollableArea {
	box-sizing: border-box;
	max-height: inherit;
	overflow-y: auto;
	padding: 32px;
}
.conditionModalBodyScrollableArea::-webkit-scrollbar {
	display: none;
}
.conditionModalBodyScrollableArea::after {
	content: "";
	display: block;
	height: 68px;
}
#conditionAreaChangeTarget .conditionModalBodyScrollableArea::after {
	height: 0;
}
#conditionPriceTarget .conditionModalBodyScrollableArea::after,
#conditionAreaSelectTarget .conditionModalBodyScrollableArea::after {
	height: 44px;
}
.conditionModalHead {
	color: #665555;
	font-size: 18px;
	font-weight: bold;
}
.conditionModalTable {
	border-collapse: collapse;
	margin-top: 16px;
	width: 100%;
}
.conditionModalTable > tbody > tr > th,
.conditionModalTable > tbody > tr > td {
	border: 1px solid #DDDDDD;
}
.conditionModalTable > tbody > tr > th {
	background-color: #EEEBE4;
	border: 1px solid #DDDDDD;
	padding: 10px;
	text-align: center;
	width: 110px;
}
.conditionModalTable > tbody > tr > td {
	padding: 12px 0 12px 12px;
}
.conditionModalList {
	display: flex;
	flex-wrap: wrap;
}
.conditionModalList > li {
	box-sizing: border-box;
	display: flex;
	flex-basis: 50%;
	padding-right: 12px;
	word-break: break-word;
}
.conditionModalList > li:nth-child(n + 3) {
	margin-top: 5px;
}
.conditionModalLabel {
	line-height: 1.5;
}
.conditionModalFoot {
	align-items: center;
	background-color: #FFFFFF;
	border-radius: 0 0 8px 8px;
	border-top: none;
	bottom: 0;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	left: 0;
	padding: 24px 32px 32px;
	position: absolute;
	width: 100%;
}
.conditionKodawariModalFoot {
	border-top: 1px solid #E0E1E2;
	padding: 16px 32px;
}
.conditionModalBtn {
	border-radius: 8px;
	box-sizing: border-box;
	font-size: 14px;
	font-weight: bold;
	line-height: 42px;
	text-align: center;
	text-decoration: none !important;
	width: 176px;
}
.conditionModalBtn.deselection {
	background-color: #FFFFFF;
	border: 1px solid #E0E1E2;
	color: #333333;
}
.conditionModalBtn.deselection.isInactive {
	color: rgba(51, 51, 51, 0.3);
	pointer-events: none;
}
.conditionModalBtn.filtering {
	background-color: #8C61B8;
	border: 1px solid #8C61B8;
	color: #FFFFFF;
	margin-left: 16px;
}
.conditionModalBtn:hover {
	opacity: 0.7;
}
.conditionModal input[type="checkbox"] {
	flex-shrink: 0;
	height: 18px;
	margin: 0 5px 0 0;
	vertical-align: bottom;
}
.conditionModal select:disabled {
	color: #CCCCCC;
}

/* こだわり条件追加モーダル内のネット予約項目 */
.conditionModalTable > tbody > tr > th.netReserve {
	background-color: #EFE1FF;
	color: #9966CC;
}
.netReserveConditionHelpLink {
	margin: 5px 12px 0 0;
	text-align: right;
}
.netReserveConditionHelpLink > a {
	background: url(/CSP/img/svg/pc/icon_help_kr.svg?switch=2025071615) 0 / 16px no-repeat;
	color: #7030A0;
	display: inline-block;
	padding-left: 20px;
}

/* 検索条件変更 リンク一覧 */
.searchConditionLinkList {
	display: inline-flex;
	flex-wrap: wrap;
	font-size: 0;
}
.searchConditionLinkList > li {
	align-items: center;
	display: inline-flex;
	font-size: 12px;
}
.searchConditionLinkList > li > span {
	padding: 0 5px;
}
.searchConditionLinkImage {
	height: 18px;
	width: 18px;
}
.searchConditionLinkImage > img {
	width: 18px;
}
/* onlinePayNormalLabel */
.onlinePayNormalLabel {
	background: #FFFFFF url(/CSP/img/svg/pc/icon_check_onlinePayment.svg?switch=2025071615) 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/pc/icon_card_kr.svg?switch=2025071615) 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;
}
/* freewordSearch onlinePayInfoModal */
.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: 100;
}
.onlinePayInfoModal.isOpened {
	opacity: 1;
	visibility: visible;
}
.onlinePayInfoModalBody {
	background-color: #FFFFFF;
	border-radius: 8px;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 670px;
}
.onlinePayInfoModalBody > img {
	border-radius: 8px 8px 0 0;
	max-width: 100%;
}
.onlinePayInfoModalBody.isOpened {
	opacity: 1;
	visibility: visible;
}
.onlinePayInfoCloseBtn {
	background: transparent url(/CSP/img/svg/pc/icon_close_white.svg?switch=2025071615) center / contain no-repeat;
	cursor: pointer;
	height: 24px;
	left: 4px;
	position: absolute;
	top: -40px;
	width: 24px;
}
.onlinePayInfoModalBtnWrap {
	border-top: 1px solid #E0E1E2;
	padding: 23px 0 32px;
}

.slcDetailOther > .onlinePayment {
	margin-top: 16px;
	width: 100%;
}
