@charset "utf-8";

/************************************************************
 * CLASSES(コンポーネント)
 ************************************************************/

/* 一覧 */
.preListHead {
	padding: 0 10px 5px;
	border-bottom: 2px solid #D9D9D9;
	position: relative;
}
.preListBottom {
	padding: 10px 10px 0;
	font-size: 10px;
}
.contentsBottom {
	position: relative;
}

.contentsBottom li{
	float:left;
	border:1px solid #555555;
}

.contentsBottom li a{
	display:block;
	width:2em;
	height:2em;
	background-color:#333333;
	color:#FFFFFF !important;
	text-align:center;
	padding-top:5px;
}

.postList {
	margin-top: 30px;
	border-top: 2px solid #D9D9D9;
	padding: 10px 10px 0;
	position: relative;
	overflow: hidden;
	zoom: 1;
}

.postList li a:hover{
	background-color:#FFFFFF;
	color:#333333 !important;
	text-decoration:none;
}

.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;
}
.hairCatalogue {
	border:1px solid #FF7799;
}
.hairCatalogue dt{
	border:1px solid #FFFFFF;
	background-color:#FFE6E6;
}
.hairCatalogue dd{
	background-color:#FFFFFF;
	border-top:1px solid #FF7799;
}

.stylistTitleOuter{
	background-color: #A6A39B;
}

/* スタイリストのキャッチコピー */
.stylistCatch a{
	color: #666666;
	text-decoration:none;
}

/* TABLE */
.bgOrange {
	background-color: #F5AA55!important;
}

.bgThCatarogue td {
	background-color: #F5F5F5;
}

.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;
}

/* 見出し */
.title {
	background-position: 0 top;
	height: 45px;
}
.titleInner {
	color: #FFFFFF;
	font-size: 18px;
	padding: 10px;
}

.detailTitle {
	font-size: 18px;
}

/* 一覧 */
.richPreList {
	background-position: 0 -70px;
	padding: 13px 10px;
	color: #CCC;
	position: relative;
	zoom: 1;
}
.richPostList {
	margin-top: -15px;
	padding: 11px 15px;
	background-position: 0 -140px;
	position: relative;
	zoom: 1;
}
.separateSpace {
	height: 45px;
}

/* クーポン */
.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;
	zoom: 1;
	position: relative;
	z-index: 10;
}

.CouponMenuList a {
	padding-left: 10px;
	background-position: -193px -244px;
}
.CouponArea {
	background-color: #F6F6F6;
	margin-top: 10px;
}

.CouponArea dl:first-child,
.CouponArea .CouponAreaCoupon dl:first-child,
.CouponArea .CouponAreaMenu dl:first-child {
	border-top: none;
}

.CouponArea dl{
	border-top: 1px dotted #999999;
	padding-bottom: 3px;
	padding-top: 3px;
}

.CouponAreaCoupon,
.CouponAreaMenu {
	padding: 10px;
}
.CouponAreaCoupon + .CouponAreaMenu {
	padding-top: 0;
}
.CouponAreaCoupon dl,
.CouponAreaMenu dl {
	border-top: 1px dotted #999;
	padding: 2px 0;
}
.CouponArea div:first-child.CouponAreaMenu,
.CouponArea .CouponAreaMenu:first-child {
	border-top: none;
}
.slcMapCouponWrap + .slcMapCouponWrap,
.slcMapMenuWrap + .slcMapMenuWrap {
	border-top: 1px solid #E0E1E2;
	margin-top: 8px;
	padding-top: 10px;
}
.CouponAreaCoupon + .CouponAreaMenu .slcMapMenuWrap:first-child {
	border-top: 1px solid #E0E1E2;
	padding-top: 10px;
}
.mainContentsST	{margin:0 1px; background-color:#F2F2F2; zoom:1;}
.mainContentsSTHead {
	padding: 2px 0;
	border-bottom: 2px solid #7b705e;
}
.mainContentsSTBottom	{padding: 5px 5px 2px 5px;}
.CouponMark { margin: 2px 10px 0 0; }

.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;
}

/* フリーワード検索一覧エリア名表示 */
.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;
}

/* 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 {
	width: 641px;
	height: 24px;
	padding-top: 12px !important;
	position: absolute;
	bottom: 7px;
	left: 0;
}

/* addObj */
div.b1-2 div.addObj {
	margin: 16px 0 24px;
}
div.b1-2 div.addObj table {
	border: solid 1px #DDDDDD;
	border-collapse: collapse;
	margin: 0 auto;
}
div.b1-2 div.addObj table.menuTable {
	width: 576px;
}
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.tr1:last-child th,
div.b1-2 div.addObj td.td1 tr.tr1:last-child td {
	border-bottom: none;
}
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;
	margin: 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;
	overflow: hidden;
	*zoom: 1;
	line-height: 1.4;
}
div.b1-2 p.add {
	margin: 0px auto;
	width: 641px;
	height: 24px;
	padding-top: 12px !important;
	position: absolute;
	bottom: 7px;
	left: 0;
	text-align: center;
}

/* popUpFooter */
.tbClose {
	color: #BFB4AB !important;
	font-weight: bold;
	text-decoration: none !important;
	background: url(/CSP/img/hc/icons/icon_tb_close.png?switch=2025062510) 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;
}

/* エリア選択 */
#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;
}

/* 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/bt/sprites/i.png?switch=2025062510");
	background-repeat: no-repeat;
	background-position: -156px -5280px;
}
.ensenDisplayIcon > span > span:hover:before {
	background-position: -180px -5280px;
}
.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/bt/sprites/i.png?switch=2025062510");
	background-repeat: no-repeat;
	background-position: -168px -5280px;
}
.ensenDisplayIconClosed > span > span:hover:before {
	background-position: -192px -5280px;
}
/* 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 {
	color: #6D6D6D;
	display: none;
	position: absolute;
	z-index: 300;
}
.stationPopupBoxWrapper {
	background-color: #FFFFFF;
	border: 1px solid #999999;
	box-sizing: border-box;
	padding: 16px;
	position: relative;
	width: 404px;
	z-index: 300;
}
.stationPopupHead {
	color: #665555;
	font-weight: bold;
}
.stationPopupBoxList {
	margin-top: 12px;
}
.stationPopupBoxList dd + dt {
	margin-top: 12px;
}
.stationPopupList {
	display: inline-flex;
	flex-wrap: wrap;
	margin: 8px 0 -4px;
}
.stationPopupList > li {
	display: flex;
	font-size: 12px;
	margin: 0 4px 4px 0;
	width: 120px;
}
.stationPopupList > li:nth-child(3n) {
	margin-right: 0;
}
.stationPopupBtnWrap {
	border-bottom: 1px solid #E0E1E2;
	display: flex;
	justify-content: center;
	margin: 16px -16px 0;
	padding-bottom: 16px;
}
.stationPopupReSearchBtn {
	appearance: none;
	background-color: #D36985;
	border: 1px solid #D36985;
	border-radius: 4px;
	color: #FFFFFF;
	cursor: pointer;
	font-size: 12px;
	font-weight: bold;
	height: 36px;
	opacity: 1;
	width: 218px;
}
.stationPopupAnotherStationBtn {
	align-items: center;
	border: 1px solid #E0E1E2;
	border-radius: 4px;
	box-sizing: border-box;
	color: #666666 !important;
	display: flex;
	font-size: 12px;
	font-weight: bold;
	height: 28px;
	justify-content: center;
	width: 105px;;
}
.stationPopupReSearchBtn:hover,
.stationPopupAnotherStationBtn:hover {
	opacity: 0.7;
	text-decoration: none;
	transition: opacity 0.15s ease-in-out;
}
.stationPopupOtherSearchBtnList {
	display: flex;
	justify-content: center;
	margin-top: 12px;
}
.stationPopupOtherSearchBtnList > li + li {
	margin-left: 8px;
}
.stationCloseBox {
	margin-top: 16px;
	text-align: center;
}
.stationCloseBox > a {
	position: relative;
	text-decoration: underline;
}
.stationCloseBox > a::before {
	content: "";
	height: 28px;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 100%;
}

/************************************************************
 * MyStyleSave Style
 ************************************************************/

/* border-radius */
.jscRadius3px {
	border-radius: 3px;
}

.btnSaveToMyStyleDone,
.btnSaveToMyStylistDone {
	display: none;
	color: #333333 !important;
	text-decoration: none !important;
	text-indent: 0px;
	cursor: pointer;
}

/************************************************************
 * conditionMenuList Style
 ************************************************************/
.conditionMenuWrap {
	padding: 10px 5px 5px !important;
}
.conditionMenuList {
	width: 100%;
}
.conditionMenuList {
	display: flex;
	flex-wrap: wrap;
}
.conditionMenuList > li {
	margin: 0 0 5px 5px;
	width: calc(50% - 5px);
}
.conditionMenuList > li > label {
	cursor: pointer;
	padding-left: 19px;
	position: relative;
}
.conditionMenuList > li > input {
	display: none;
}
.conditionMenuList > li > label::before,
.conditionMenuList > li > label::after {
	border-radius: 50%;
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
.conditionMenuList > li > label::before {
	border: 1px solid #CCCCCC;
	box-sizing: border-box;
	height: 14px;
	left: 0;
	width: 14px;
}
.conditionMenuList > li > input:checked + label::after {
	background-color: #D36985;
	height: 8px;
	left: 3px;
	width: 8px;
}

/* list and mapList change btn */
.mapBtnWrap {
	display: flex;
	float: right;
	font-size: 12px;
}
.mapBtnWrap > li {
	display: flex;
}
.mapBtnWrap img {
	height: 18px;
	width: 18px;
}
.mapBtnWrap span {
	margin-left: 5px;
}

/* SEARCH LIST SALON CASSETTE */
.searchListCassette {
	border: 1px solid #CCCCCC;
	border-radius: 4px;
	margin-top: 10px;
	word-wrap: break-word;
}
.searchListCassette ~ .searchListCassette {
	margin-top: 10px;
}
.slcHeadWrap {
	background-color: #F2F2F2;
	border-bottom: 2px solid #927979;
	border-radius: 4px 4px 0 0;
}
.slcHeadContents {
	min-height: 34px;
	padding: 10px 10px 5px;
	position: relative;
}
.slcHeadContentsInner {
	padding-right: 150px;
}
.slcHead {
	font-size: 16px;
	word-wrap: break-word;
}
.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;
}
.slcIcnPr {
	border: 1px solid #AAAAAA;
	border-radius: 3px;
	display: inline-block;
	margin-right: 6px;
	padding: 1px 2px;
	vertical-align: middle;
}
.slcIcnPr > span {
	color: #AAAAAA;
	display: block;
	font-size: 10px;
	line-height: 1;
	transform: scale(0.9);
}
.slcClassIcn {
	margin-top: 6px;
}
.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;
}
.slcBody {
	padding: 15px 10px 10px 5px;
	position: relative;
}
.slcImage {
	float: left;
	margin-right: 20px;
	text-align: center;
	width: 229px;
}
.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: #CC4466 !important;
	display: block;
	font-size: 14px;
	font-weight: bold;
	text-decoration: none !important;
	word-wrap: break-word;
}
.slcCatch > a:hover {
	color: #D7718E !important;
}
.slcDetail {
	color: #665555;
	margin-top: 18px;
	min-height: 42px;
	position: relative;
}
.slcDetail dt {
	float: left;
	font-weight: bold;
	padding-bottom: 2px;
	padding-left: 25px;
	padding-top: 2px;
	width: 74px;
}
.slcDetail dd {
	overflow: hidden;
	padding-top: 2px;
	word-wrap: break-word;
}
.slcDetailOther {
	color: #665555;
	min-height: 55px;
	position: relative;
	width: 369px;
}
.slcDetailOther > dl {
	display: inline-block;
	margin-top: 10px;
	vertical-align: top;
	width: 180px;
}
.slcDetailAccessIcon { background-position: -177px -6938px; }
.slcDetailPriceIcon { background-position: -177px -6988px; }
.slcDetailSeatIcon { background-position: -180px -7036px; }
.slcDetailBlogIcon { background-position: -180px -7086px; }
.slcDetailMessageIcon { background-position: -180px -7134px; }
.slcCouponMenu {
	background-color: #FCF8DF;
	margin-top: 24px;
	padding: 15px 10px 10px 10px;
}
.slcCouponMenuHead {
	overflow: hidden;
	padding-right: 15px;
	word-wrap: break-word;
}
.slcCouponMenuHead > a {
	color: #FB615F;
	font-size: 11px;
	font-weight: bold;
}
.slcCouponMenuAll {
	float: right;
}
.slcCoupon {
	margin-top: 12px;
}
.slcCouponList {
	position: relative;
}
.slcCouponList ~ .slcCouponList {
	margin-top: 12px;
}
.slcCouponName {
	float: left;
	position: relative;
	width: 370px;
}
.slcCouponListIcon {
	background-color: #FB615F;
	color: #FFFFFF;
	font-size: 10px;
	left: 0;
	line-height: 1;
	padding: 2px;
	position: absolute;
	top: 1px;
	width: 20px;
	word-wrap: break-word;
}
.slcCouponListLimitedIcon {
	background: #FFFFFF;
	border: 1px solid #CCBBBB;
	color: #665555;
	display: inline-block;
	float: left;
	font-size: 10px;
	line-height: 1;
	margin: 1px 6px 0 0;
	padding: 1px;
	vertical-align: top;
}
.slcCouponListLimitedIcon + .slcCouponLink {
	display: block;
	overflow: hidden;
}
.slcCouponListIcon + .slcCouponListLimitedIcon {
	margin-left: 28px;
}
.CouponMark + .slcCouponLink {
	display: block;
	overflow: hidden;
}
.slcCouponLink {
	font-size: 11px;
	word-break: break-all;
}
.slcCouponListIcon + .slcCouponLink {
	padding-left: 30px;
}
.slcCouponPrice {
	color: #FA4372;
	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: 10px;
	top: 10px;
	z-index: 1;
}
.slcReserve {
	bottom: 0;
	position: absolute;
	right: 0;
	width: 130px;
}
/* /SEARCH LIST SALON CASSETTE */

/* SEARCH LIST TAB */
.searchListTab {
	border-bottom: 2px solid #BFB4AB;
	padding-left: 10px;
}
.searchListTab li {
	background-color: #FFFFFF;
	border: solid #CCCCCC;
	border-width: 1px 1px 0 1px;
	-webkit-border-radius: 4px 4px 0 0;
	border-radius: 4px 4px 0 0;
	color: #666666;
	display: inline-block;
	font-size: 13px;
	font-weight: bold;
	height: 30px;
	line-height: 30px;
	min-width: 134px;
	text-align: center;
}
.searchListTab li.isCurrent {
	border-color: #BFB4AB;
	border-width: 2px 2px 0 2px;
	margin-bottom: -2px;
	position: relative;
}
.searchListTab li.isCurrent:before {
	background-color: #FFFFFF;
	bottom: -3px;
	content: " ";
	display: block;
	height: 3px;
	position: absolute;
	width: 100%;
}
.searchListTab li a {
	display: block;
	color: #666666;
	text-decoration: none;
}
.searchListTab li + li {
	margin-left: 2px;
}
/* /SEARCH LIST TAB */

/* AROUNDSEARCH */
.aroundSearchTitle {
	margin-top: 60px;
}
.searchResultZeroOuterFrame + .aroundSearchTitle {
	margin-top: 20px;
}
/* /AROUNDSEARCH */

/* slnCassetteList */
.slnCassetteList > li {
	border: 1px solid #CCCCCC;
	border-radius: 4px;
	overflow-wrap: break-word;
	word-wrap: break-word;
}
.slnCassetteList > li + li {
	margin-top: 20px;
}
.slnCassetteHeader {
	align-items: flex-start;
	display: flex;
	padding: 10px 10px 0;
}
.slnPRCassette .slnCassetteHeader::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;
}
.slnName {
	font-size: 16px;
	min-width: 100px; /* 半角文字列の折り返し対応 */
	padding-right: 20px;
}
.slnBookmarkBtn {
	margin-left: auto;
}
.slnCassetteBody {
	display: flex;
	justify-content: space-between;
	margin-top: 20px;
	padding: 0 10px 10px;
}
.slnImgList {
	font-size: 0;
	text-align: center;
	width: 219px;
}
.slnImgList > li {
	display: inline-block;
}
.slnImgList > li:nth-child(n+2) {
	margin-top: 12px;
}
.slnImgList > li:nth-child(3) {
	margin-left: 12px;
}
.slnImgList > li + li {
	width: calc(50% - 6px);
}
.slnImgList > li > a {
	display: block;
	position: relative;
}
.slnImgList > li > a:hover {
	opacity: 0.8;
}
.slnImgList img {
	width: 100%;
}
/* ヘアスタイル動画 ▶︎あり */
.slnStyleVideoTime {
	align-items: center;
	background-color: rgba(51,51,51,0.8);
	border-radius: 2px;
	bottom: 4px;
	color: #FFFFFF;
	display: flex;
	font-size: 12px;
	font-weight: bold;
	line-height: 1;
	padding: 4px;
	position: absolute;
	right: 4px;
}
.slnStyleVideoTime::before {
	background: url(/CSP/img/svg/pc/icon_play_white.svg?switch=2025062510) center / contain;
	content: "";
	height: 12px;
	margin-right: 2px;
	width: 12px;
}
/* ヘアスタイル動画 ▶︎なし */
.slnStyleVideoTimeNoLink {
	background-color: rgba(51,51,51,0.8);
	border-radius: 2px;
	bottom: 4px;
	color: #FFFFFF;
	font-size: 12px;
	font-weight: bold;
	line-height: 1;
	padding: 4px;
	position: absolute;
	right: 4px;
}
.slnInfo {
	width: 499px;
}
.slnCatch {
	color: #CC4466;
	font-size: 14px;
	font-weight: bold;
}
.slnCatch > a {
	color: inherit;
	text-decoration: none;
}
.slnCatch > a:hover {
	color: #D7718E;
}
.slnDetail {
	display: flex;
	flex-wrap: wrap;
	margin-top: 18px;
}
.slnDetail + .slnDetail {
	margin-top: 0;
	min-height: 52px;
}
.slnDetail > dt {
	background-repeat: no-repeat;
	background-size: contain;
	box-sizing: border-box;
	color: #665555;
	font-weight: bold;
	height: 20px;
	padding: 1px 0 1px 27px;
	width: 101px;
}
.slnDetail > dt.access {
	background-image: url(/CSP/img/bt/icons/icn_access.png?switch=2025062510);
}
.slnDetail > dt.price {
	background-image: url(/CSP/img/bt/icons/icn_price.png?switch=2025062510);
}
.slnDetail > dt.seat {
	background-image: url(/CSP/img/bt/icons/icn_seat.png?switch=2025062510);
}
.slnDetail > dt.blog {
	background-image: url(/CSP/img/bt/icons/icn_blog.png?switch=2025062510);
}
.slnDetail > dt.message {
	background-image: url(/CSP/img/bt/icons/icn_message.png?switch=2025062510);
}
.slnDetail > dd.access {
	width: 398px;
}
.slnDetail > dd:not(.access):not(.onlinePayment) {
	width: 81px;
}
.slnDetail > :not(.access):not(.onlinePayment) {
	margin-top: 10px;
}
.slnDetail > dd.onlinePayment {
	margin-top: 16px;
	width: 100%;
}
.slnDetail > dd.seat,
.slnDetail > dd.message {
	margin-right: 130px;
	padding-right: 5px;
}
.slnKodawariVideo {
	margin-top: 24px;
}
.slnKodawariVideoLink {
	border: 1px solid #E0E1E2;
	border-radius: 8px;
	display: flex;
	margin-top: 24px;
	padding: 12px 40px 12px 12px;
	position: relative;
	text-decoration: none !important;
}
.slnKodawariVideoLink::after {
	background: url(/CSP/img/svg/pc/icon_arrow_right_grey.svg?switch=2025062510) center / contain;
	content: "";
	height: 20px;
	position: absolute;
	right: 13px;
	top: 50%;
	transform: translateY(-50%);
	width: 20px;
}
.slnKodawariVideoLink:hover {
	opacity: 0.7;
}
.slnKodawariVideoThumbnail {
	border: 1px solid #E0E1E2;
	box-sizing: border-box;
	height: 83px;
	min-width: 146px;
	overflow: hidden;
	width: 146px;
}
.slnKodawariVideoThumbnail > img {
	width: 100%;
}
.slnKodawariVideoTxtWrap {
	margin-left: 12px;
}
.slnKodawariVideoTxtLinkHead {
	color: #665555;
	font-weight: bold;
	line-height: 1.5;
}
.slnKodawariVideoTxt {
	color: #333333;
	display: block;
	margin-top: 4px;
	word-break: break-word;
}
.slnCouponMenu,
.slnCoupon {
	background-color: #F6F6F6;
	padding: 15px 10px 10px;
}
.slnCouponMenu {
	margin-top: 24px;
}
.slnCoupon {
	margin-top: 16px;
}
.slnCouponMenuHeader,
.slnCouponHeader {
	align-items: flex-start;
	display: flex;
	justify-content: space-between;
}
.slnCouponMenuHeading,
.slnCouponHeading {
	flex: 1;
	font-size: 11px;
	font-weight: bold;
	min-width: 100px; /* 半角文字列の折り返し対応 */
}
.slnCouponMenuHeading,
.slnCouponHeading > a {
	color: #665555;
}
.slnCouponMenuList,
.slnCouponList {
	margin-top: 10px;
}
.slnCouponMenuList > li + li,
.slnCouponList > li + li {
	margin-top: 12px;
}
.slnCouponLabelList {
	display: flex;
	flex-wrap: wrap;
}
.slnCouponLabelList > li {
	font-size: 10px;
	line-height: 1;
	margin-bottom: 4px;
}
.slnCouponLabelList > li:not(:last-child) {
	margin-right: 4px;
}
.slnCouponLabelCT01 {
	background-color: #FADCE3;
	color: #C43357;
	padding: 3px;
}
.slnCouponLabelCT02 {
	background-color: #D97791;
	color: #FFFFFF;
	padding: 3px;
}
.slnCouponLabelCT03 {
	background-color: #FCECF0;
	border: 1px solid #F3D6DE;
	color: #C43357;
	padding: 2px;
}
.slnLimitedCouponLabel {
	background-color: #FFFFFF;
	border: 1px solid #CCBBBB;
	color: #665555;
	padding: 2px;
}
.slnCouponMenuInfo {
	align-items: center;
	display: flex;
	justify-content: space-between;
}
.slnCouponMenuLink,
.slnCouponLink {
	font-size: 11px;
	min-width: 100px; /* 半角文字列の折り返し対応 */
}
.slnCouponMenuLink {
	flex: 1;
}
.slnCouponPrice,
.slnMenuPrice {
	font-size: 11px;
	font-weight: bold;
	margin-left: 20px;
	min-width: 52px;
	text-align: right;
	white-space: nowrap;
}
.CouponAreaCoupon .slnCouponPrice,
.CouponAreaMenu .slnMenuPrice {
	margin-left: 10px;
}
.slnCouponPrice,
.slnMenuPrice {
	color: #CC4466;
}

.slnUpIcn {
	background-color: #FF9900;
	color: #FFFFFF;
	display: inline-block;
	font-size: 10px;
	font-weight: bold;
	line-height: 1;
	margin-left: 5px;
	padding: 1px 2px;
	vertical-align: middle;
}
.slcUsableTimeWrap {
	border-top: 1px solid #E0E1E2;
	padding: 10px;
}
.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: #D36985 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)):not(:last-child) {
    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 #D36985 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;
}
/* /slnCassetteList */
/* Start time annotation */
.annotationMark {
	position: relative;
}
.annotationMark::after {
	content: "\203B";
	font-size: 10px;
	line-height: 1;
	position: absolute;
	top: 0;
	transform: scale(0.8);
}
/* /Start time annotation */
.netReserveConditionsList,
.kodawariConditionsList {
	display: flex;
	flex-wrap: wrap;
}
.netReserveConditionsList > li,
.kodawariConditionsList > li {
	box-sizing: border-box;
	display: flex;
	word-break: break-word;
}
.kodawariConditionsList > li {
	flex-basis: 50%;
	padding-right: 5px;
}
.netReserveConditionsList > li + li {
	margin-left: 10px;
}
.addObj .kodawariConditionsList > li {
	padding-right: 12px;
}
.kodawariConditionsList > li:nth-of-type(n + 3) {
	margin-top: 5px;
}
.netReserveConditionsList > li > label,
.kodawariConditionsList > li > label {
	cursor: pointer;
}
.netReserveConditionsLink {
	position: absolute;
	right: 5px;
	top: 50%;
	transform: translateY(-50%);
}

/* ヘルプリンク */
.helpLinkPink {
	display: inline-block;
	font-size: 11px;
	font-weight: normal;
	line-height: 18px;
	padding-left: 22px;
	white-space: nowrap;
}
.helpLinkPink:hover {
	text-decoration: none;
}
.helpLinkPink {
	background: url(/CSP/img/svg/pc/icon_help_pink.svg?switch=2025062510) 0 0 / 18px no-repeat;
	color: #C43357 !important;
}

/* こだわり条件検索 スマート支払い モーダル */
.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=2025062510) 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;
}

/* 検索条件変更モーダル */
.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 {
	background: url(/CSP/img/svg/pc/icon_close_white.svg?switch=2025062510) center / contain;
	height: 24px;
	left: 0;
	position: absolute;
	top: -32px;
	width: 24px;
}
.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 > 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: #D36985;
	border: 1px solid #D36985;
	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;
}

/* セレクトボックス */
.selectbox {
	appearance: none;
	background: url(/CSP/img/svg/pc/icon_arrow_down_gray.svg?switch=2025062510) top 3px right 5px / 14px no-repeat;
	border: 1px solid #E0E1E2;
	border-radius: 0;
	color: #333333;
	height: 22px;
	padding: 0 5px;
	width: 80px;
}
.selectbox:disabled {
	color: rgba(51, 51, 51, 0.3);
}

/* 検索条件変更 リンク一覧 */
.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;
}
.searchConditionLink {
	align-items: center;
	display: inline-flex;
}
.searchConditionLink > span {
	color: #4C4C80;
	opacity: 0.3;
}
.searchConditionLinkImage {
	width: 18px;
	height: 18px;
}
.searchConditionLinkImage > img,
.searchConditionNoLinkImage > img {
	width: 18px;
}
.searchConditionNoLinkImage > img {
	opacity: 0.3;
}