@charset "UTF-8";


/* ---------------
	SALON LIST
-------------------------------------------------------*/
.salon-area-wrap {
	max-width: 800px;
	width: 100%;
	margin: 20px auto 0 auto;
}
.salon-area-wrap .salon-ttl {
	font-size: 18px;
	font-weight: normal;
	border-bottom: 1px solid #000;
	padding: 0 0 10px 0;
}
.salon-area-wrap .salon-ttl-sub {
	background: #f3f3f3;
	padding: 10px 0;
	font-size: 14px;
	margin: 40px 0 0 0;
}
.salon-area-wrap .salon-ttl-sub + .salon-list { margin-top: 40px; }
.salon-area-wrap .salon-list { margin: 60px 0 0 0; }
.salon-area-wrap .salon-list > li {
	padding: 30px 0;
	border-bottom: 1px solid #d4d4d4;
	position: relative;
}
.salon-area-wrap .salon-list > li:first-child { border-top: 1px solid #d4d4d4; }
.salon-area-wrap .salon-list > li > .ttl {
	width: 20%;
	text-align: left;
	font-size: 16px;
	font-weight: normal;
	margin: 0 2% 0 0;
	padding-left: 16px;
	text-indent: -16px;
	line-height: 1.4;
}
.salon-area-wrap .salon-list > li > .ttl:before {
	font-size: 12px;
	padding: 0;
	margin: -6px 0 0 0;
}
.salon-area-wrap .salon-list > li .access {
	width: 60%;
	text-align: left;
	font-size: 12px;
	margin-right: 16%;
}
.salon-area-wrap .salon-list > li .access .post-code { letter-spacing: 1px; }
.salon-area-wrap .salon-list > li .access .post-code:before { content: '〒'; }
.salon-area-wrap .salon-list > li .access .address {}
.salon-area-wrap .salon-list > li .access .address > span { margin: 0 10px 0 0; line-height: 1.5;}
.salon-area-wrap .salon-list > li .access .address > a {
	font-size: 10px;
	display: inline-block;
	vertical-align: middle;
	border: 1px solid #000;
	line-height: 1;
	padding: 3px 8px 2px;
	text-decoration: none;
	letter-spacing: 1px;
	margin-top: -2px;
}
.salon-area-wrap .salon-list > li .access .address > a:hover {
	background: #000;
	color: #fff;
}
.salon-area-wrap .salon-list > li .access .address > a > span {}
.salon-area-wrap .salon-list > li .access .train {
	width: 48%;
	background: url(../images/icon/icon-train.png) no-repeat left 0;
	padding: 0 0 0 18px;
	line-height: 16px;
	margin-right: 3%;
}
.salon-area-wrap .salon-list > li .access .tel {
	width: 48%;
	background: url(../images/icon/icon-tel-1.png) no-repeat left 0;
	padding: 0 0 0 18px;
	font-size: 16px;
	font-weight: bold;
	line-height: 18px;
	letter-spacing: 1px;
}
.salon-area-wrap .salon-list > li .post-info { margin: 16px 0 0 0; }
.salon-area-wrap .salon-list > li .btn-link {
	width: 110px;
	position: absolute;
	top: 52px;
	right: 0;
}
.salon-area-wrap .salon-list > li .btn-link li { margin: 3px 0 0 0; }


/* ---------------
	SALON
-------------------------------------------------------*/
.salon {}
.salon .salon-ttl-wrap { position: relative; }
.salon .salon-ttl-wrap .ttl-wrap1 span { margin: 10px 0 0 0; }
.salon .salon-ttl-wrap .ttl-wrap1 span:first-child { margin: 0; }
.salon .shop-reservation {
	display: inline-block;
	vertical-align: middle;
	position: absolute;
	top: 0;
	right: 20px;
	border-left: 1px solid #000;
	padding: 0 0 0 16px;
}
.salon .shop-reservation.top {}
.salon .shop-reservation .post-txt {
	text-align: left;
	display: inline-block;
	vertical-align: middle;
	margin: 0 10px 0 0;
}
.salon .shop-reservation .post-txt .tel {
	font-size: 20px;
	font-weight: bold;
	line-height: 1.2;
}
.salon .shop-reservation .post-txt .mail {
	font-size: 11px;
	letter-spacing: 1px;
}
.salon .shop-reservation .post-txt .tel span {
	background: url(../images/icon/icon-tel-1.png) no-repeat left center;
	padding: 0 0 0 20px;
}
.salon .shop-reservation .post-txt .mail span {}
.salon .shop-reservation .webform {
	display: inline-block;
	vertical-align: middle;
}
.salon .shop-visual {
	margin: 10px 0 0 0;
	text-align:center;
	overflow: hidden;
}
.salon .shop-visual .slider {}
.salon .shop-visual .slider li {}
.salon .shop-visual .slider li img { width: 100%; }


/* ---------------
	TAB NAV
-------------------------------------------------------*/
.tab-nav {
	display: table;
	text-align: center;
	width: 960px;
	margin: 0 auto;
	position: relative;
	z-index: 2;
}
.tab-nav li {
	display: table-cell;
	vertical-align: middle;
	width: 49%;
	padding: 0 0 0 1px;
	cursor: pointer;
	position: relative;
	z-index: 100;
}
.tab-nav li:first-child { margin: 0; padding: 0; }
.tab-nav li span {
	display: block;
	background-color: #000;
	color: #fff;
	text-decoration: none;
	font-size: 12px;
	line-height: 38px;
	-webkit-transition: all 0.3s ease-in-out;
	-moz-transition: all 0.3s ease-in-out;
	-ms-transition: all 0.3s ease-in-out;
	transition: all 0.3s ease-in-out;
	cursor: pointer;
	width: 100%;
	height: 100%;
}
.tab-nav li.select span,
.tab-nav li span:hover {
	background: #e1e1e1;
	color: #000;
}
.tab-contents .tab-inner { display: none; padding: 60px 0 0;}
.tab-contents .tab-inner:first-child { display: block; }


/* ---------------
	TAB CONTENTS INFORMATION
-------------------------------------------------------*/
/* top */
.tab-inner.information .top-wrap {}
.tab-inner.information .top-wrap .ttl {
	font-size: 20px;
	font-weight: normal;
	letter-spacing: 2px;
}
.tab-inner.information .top-wrap .txt {
	font-size: 13px;
	margin: 26px 0 0 0;
	text-align: center;
	line-height: 2.2;
}
/* information */
.tab-inner.information .information-contents {
	background-color: #f4f4f4;
	padding: 80px 0 100px;
	margin-top: 80px;
}
.tab-inner.information .information-contents .information-contents-inner {
	max-width: 820px;
	width: 100%;
	margin: 0 auto;
}
.tab-inner.information .information-contents-inner > .ttl {
	font-size: 34px;
	font-weight: normal;
	letter-spacing: 2px;
	text-align: center;
	border-bottom: 1px solid #000;
	padding: 0 0 14px 0;
}
.tab-inner.information .information-contents .access-map {
	text-align: left;
	margin: 30px 0 0 0;
}
.tab-inner.information .information-contents .access-map dl {
	border-bottom: 1px solid #dadada;
	font-size: 13px;
	padding: 14px 0;
}
.tab-inner.information .information-contents .access-map dl dt,
.tab-inner.information .information-contents .access-map dl dd {
	display: inline-block;
	vertical-align: top;
}
.tab-inner.information .information-contents .access-map dl dt {
	width: 24%;
	text-align: center;
	margin: 0 2% 0 0;
}
.tab-inner.information .information-contents .access-map dl dd {
	width: 70%;
}
.tab-inner.information .information-contents .access-map dl.access dd {
	background: url(../images/icon/icon-train.png) no-repeat left 4px;
	padding: 0 0 0 20px;
}
.tab-inner.information .information-contents .service-wrap {
	padding: 50px 0 0;
}
.tab-inner.information .information-contents .service-wrap .google-map {
	float: left;
	position: relative;
	width: 450px;
}
.tab-inner.information .information-contents .service-wrap .google-map #map {
	width: 450px;
	height: 286px;
	background-color: #fff;
}
.tab-inner.information .information-contents .service-wrap .service-inner {
	float: right;
	position: relative;
	width: 320px;
}
.tab-inner.information .information-contents .service-wrap .service-inner > .ttl {
	font-size: 16px;
	font-weight: normal;
	border-bottom: 1px solid #000;
	padding: 0 0 8px 0;
	letter-spacing: 1px;
}
.tab-inner.information .information-contents .service-wrap .service-inner .box {
	border-bottom: 1px solid #ddd;
	padding: 20px 0 20px 0;
}
.tab-inner.information .information-contents .service-wrap .service-inner .box .sub-ttl {
	text-align: left;
	font-size: 12px;
	line-height: 1;
}
.tab-inner.information .information-contents .service-wrap .service-inner .box > ul {
	text-align: left;
	display: table;
	width: 340px;
	margin: 0 -10px 0 0;
	overflow: hidden;
}
.tab-inner.information .information-contents .service-wrap .service-inner .box > ul li {
	text-align: center;
	display: inline-block;
	vertical-align: middle;
	width: 100px;
	background-color: #fff;
	color: #666;
	font-size: 12px;
	margin: 10px 10px 0 0;
	line-height: 24px;
}
.tab-inner.information .information-contents .service-wrap .service-inner .box > ul li.on {
	background-color: #000;
	color: #fff;
}
.tab-inner.information .information-contents .service-wrap .service-inner .box > ul li .icon-img {
	display: block;
	text-align: center;
	margin: 0 auto;
}
.tab-inner.information .information-contents .service-wrap .service-inner .box > ul li .icon-txt {}
.tab-inner.information .information-contents .service-wrap .google-map .map-link,
.tab-inner.information .information-contents .service-wrap .service-inner .popup {
	text-align: right;
	padding: 16px 0 0 0;
	position: relative;
}
.tab-inner.information .information-contents .service-wrap .google-map .map-link a { text-decoration: none; }
.tab-inner.information .information-contents .service-wrap .service-inner .popup:before {
	position: absolute;
	right: 0;
	top: 54%;
	font-size: 12px;
}
.tab-inner.information .information-contents .service-wrap .service-inner .popup > input {
	border: none;
	background: none;
	padding: 0;
	margin: 0;
	cursor: pointer;
	padding: 10px 20px 10px 10px;
}

/* recommended */
.tab-inner.information .recommended-wrap { padding: 90px 0 100px 0; }
.tab-inner.information .recommended-inner {
	max-width: 820px;
	width: 100%;
	margin: 0 auto;
}
.tab-inner.information .recommended-inner .ttl-recommended {}
.tab-inner.information .recommended-inner .ttl-recommended span {
	display: block;
	line-height: 1.4;
	font-weight: normal;
	letter-spacing: 1px;
}
.tab-inner.information .recommended-inner .recommended-point { margin: 40px 0 0 0; }
.tab-inner.information .recommended-inner .recommended-point dl {
	border-width: 1px 1px 0 1px;
	border-style: solid;
	border-color: #000;
	padding: 30px 0;
}
.tab-inner.information .recommended-inner .recommended-point dl.last { border-width: 1px; }
.tab-inner.information .recommended-inner .recommended-point dl dt,
.tab-inner.information .recommended-inner .recommended-point dl dd {
	display: inline-block;
	vertical-align: middle;
}
.tab-inner.information .recommended-inner .recommended-point dl dt {
	width: 38%;
	margin: 0 2% 0 0;
}
.tab-inner.information .recommended-inner .recommended-point dl dt i {
	display: inline-block;
	vertical-align: middle;
	margin: 0 auto;
	font-style: normal;
	font-size: 16px;
	font-weight: bold;
	border-bottom: 2px solid #000;
}
.tab-inner.information .recommended-inner .recommended-point dl dt .title {
	font-size: 13px;
	font-weight: bold;
	display: block;
	margin: 12px 0 0 0;
}
.tab-inner.information .recommended-inner .recommended-point dl dd {
	width: 50%;
	text-align: justify;
	font-size: 13px;
}

/* staff */
.tab-inner.information .staff-wrap {
	background-color: #f4f4f4;
	padding: 90px 0 30px 0;
}
.tab-inner.information .staff-inner {
	max-width: 820px;
	width: 100%;
	margin: 0 auto;
}
.tab-inner.information .staff-inner .ttl-staff {
	font-size: 34px;
	font-weight: normal;
	line-height: 1.2;
}
.tab-inner.information .staff-list {}
.tab-inner.information .staff-list ul {
	overflow: hidden;
	text-align: left;
}
.tab-inner.information .staff-list ul li {
	display: inline-block;
	vertical-align: top;
	width: 47%;
	text-align: left;
	margin-top: 6%;
}
.tab-inner.information .staff-list ul li.even { margin-right: 4%; }
.tab-inner.information .staff-list ul li .staff-img {
	display: inline-block;
	vertical-align: top;
	width: 152px;
	margin: 0 20px 0 0;
}
.tab-inner.information .staff-list ul li .staff-img img {
	background-color: #fff;
	padding: 5px;
}
.tab-inner.information .staff-list ul li .staff-txt {
	display: inline-block;
	vertical-align: top;
	width: 208px;
	text-align: left;
}
.tab-inner.information .staff-list ul li .staff-txt .txt {
	font-size: 12px;
	text-align: justify;
}
.tab-inner.information .staff-list ul li .staff-txt .stylist-data {
	border-bottom: 1px solid #000;
	padding: 14px 0 8px;
}
.tab-inner.information .staff-list ul li .staff-txt .stylist-data span { display: block; }
.tab-inner.information .staff-list ul li .staff-txt .stylist-data .rank {
	font-size: 11px;
	letter-spacing: 1px;
}
.tab-inner.information .staff-list ul li .staff-txt .stylist-data .name {
	font-size: 16px;
	line-height: 1.4;
}
.tab-inner.information .staff-list ul li .staff-txt .stylist-data .name-en {
	font-family: "Times New Roman", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "メイリオ", Meiryo, serif;
	font-style: italic;
	font-size: 12px;
	letter-spacing: 1px;
}
.tab-inner.information .staff-list .price-info {
	text-align: left;
	padding: 80px 0 20px;
	color: #777;
	letter-spacing: 1px;
}


/* ---------------
	TAB CONTENTS MENU
-------------------------------------------------------*/
/* menu-top */
.tab-inner.menu {
	padding-bottom: 100px;
	position: relative;
	z-index: 1;
}
.tab-inner.menu .menu-top {
	max-width: 640px;
	width: 100%;
	margin: 60px auto 0;
}
.tab-inner.menu .menu-top .menu-ttl {
	font-size: 34px;
	font-weight: normal;
}
.tab-inner.menu .menu-top .menu-txt {
	font-size: 12px;
	line-height: 2;
}
.salon-food-wrap {
	border-bottom: 1px solid #bbb;
	padding: 30px 0;
}
.salon-food-inner {
	max-width: 960px;
	width: 100%;
	margin: 0 auto;
	position: relative;
	min-height: 48px;
	text-align: left;
}
.salon-food-inner .shop-tel-txt {
	text-align: left;
	line-height: 48px;
	font-size: 12px;
}
.salon-food-inner .shop-reservation.bottom { right: 0; }


/* ---------------
	MODAL
-------------------------------------------------------*/
.pop-contents {
	width: 100%;
	margin: 0 auto;
	overflow-y: auto;
}
.ie .pop-contents,
.firefox .pop-contents { height: 100%; }
.pop-contents .wrap {
	position: relative;
	height: 100%;
}
.pop-contents .wrap .closeBtn {
	font-size: 30px;
	position: absolute;
	top: 0;
	right: 0;
	background: #000;
	cursor: pointer;
	color: #fff;
	padding: 0 10px;
	font-weight: normal;
	padding: 3px 24px;
	height: 100%;
}
.salon-info-box {}
.salon-info-box .header {
	background-color: #000;
	color: #fff;
	padding: 10px;
	position: relative;
}
.salon-info-box .header h1 {
	font-size: 20px;
	font-weight: normal;
}
.salon-info-box .header h1 span {}
.salon-info-box .section-wrap:first-child { margin-right: 20px; }
.salon-info-box .section-wrap .title {
	background-color: #f3f3f3;
	font-size: 18px;
	font-weight: normal;
	padding: 10px 0;
	font-weight: bold;
}
.salon-info-box .section-wrap .group {
	padding: 40px 0 0 0;
	text-align: left;
	max-width: 520px;
	margin: 0 auto;
}
.salon-info-box .section-wrap .group .sub-title-wrap {
	border-bottom: 1px solid #000;
	position: relative;
	padding-bottom: 4px;
}
.salon-info-box .section-wrap .group .sub-title-wrap .name {
	font-size: 16px;
	font-weight: normal;
	padding: 0 0 5px 0;
	font-weight: bold;
}
.salon-info-box .section-wrap .group .sub-title-wrap .caution-wrap {
	position: absolute;
	right: 0;
	top: 2px;
}
.salon-info-box .section-wrap .group .sub-title-wrap .caution-wrap em {
	font-style: normal;
	font-weight: normal;
	font-size: 11px;
	border: 1px solid #000;
	padding: 0px 12px;
	display: inline-block;
	vertical-align: middle;
	margin: 0 0 0 8px;
}
.salon-info-box .section-wrap .group .group-inner {
	display: table;
	width: 100%;
	padding: 16px 0;
}
.salon-info-box .section-wrap .group .group-inner .txt {
	display: inline-block;
	vertical-align: top;
	width: 69%;
	padding: 0 3% 0 0;
	font-size: 12px;
}
.salon-info-box .section-wrap .group .group-inner .txt p {
    line-height: 1.7;
}
.salon-info-box .section-wrap .group .group-inner .img {
	display: inline-block;
	vertical-align: top;
	width: 30%;
	text-align: right;
}
.salon-info-box .section-wrap .group .group-inner .img img { max-width: 100%; }
.pop-contents .closeBtn-bottom {
	width: 200px;
	margin: 40px auto 60px auto;
	text-align: center;
	border: 1px solid #000;
	font-size: 14px;
	cursor: pointer;
	padding: 6px 0;
	-webkit-transition: all 0.3s ease-in-out;
	-moz-transition: all 0.3s ease-in-out;
	-ms-transition: all 0.3s ease-in-out;
	transition: all 0.3s ease-in-out;
}
.pop-contents .closeBtn-bottom:hover {
	background: #000;
	color: #fff;
}
.pop-contents .closeBtn-bottom span {
	font-weight: bold;
	font-size: 11px;
	letter-spacing: 1px;
	display: block;
}
.pop-contents .closeBtn-bottom span i {
	font-style: normal;
	font-size: 18px;
	font-weight: normal;
	margin: 0 4px 0 0;
	line-height: 1;
	vertical-align: top;
	padding: 0;
	position: relative;
	bottom: 1px;
}
.firefox .pop-contents .closeBtn-bottom span i { bottom: 0; }

p.sns_box{
	margin: 10px 0;
}
.sns_box span{
	width: 30px;
	float: left;
	margin: 0 10px 0 0!important;
}
a.staff_resbt{
	text-align: center;
	background: #a5172d;
	color: #fff;
	display: block;
	width: 100%;
	float: left;
	padding: 5px 0;
	margin: 10px 0;
}
#mapbox{
	height: 300px!important;
	border: 1px solid #dadada;
}
