@charset "utf-8";
/*==========================================================================

   base width

==========================================================================*/
body {
	min-width: 1020px; /* 幅狭時のスクロールで見切り調整 */
}
.container {
	width: 1020px;
	margin-right: auto;
	margin-left: auto;
}


/*==========================================================================

   base frame

==========================================================================*/
#header {
	position: relative;
	z-index: 1000;
}
#main {
	padding-top: 55px;
}
#side {
}
#footer {
	padding-top: 52px;
	background: #f2f2f2;
	z-index: 5;
	position: relative;
}


/*==========================================================================

   layout type

==========================================================================*/
/*
	----------------------------------

	grid

	----------------------------------
*/
.l-grid {
	overflow: hidden;
	font-size: 0;
}
.l-grid__item {
	display: inline-block;
	vertical-align: top;
}

/*

	grid2
	(itemをmargin-leftで並べる際に、初回itemのみmargin-left:0;の仕様のgridセット

*/
.l-grid.grid--margin-l {
	display: table;
	padding-bottom: 5px;
	padding-right: 5px;
}
.l-grid.grid--margin-l .l-grid__item:first-child {
	margin-left: 0;
}


/*
	----------------------------------

	col

	----------------------------------
*/
.l-col {
	display: table;
	width: 100%;
}
.l-col__item {
	display: table-cell;
	vertical-align: top;
}

/*
	----------------------------------

	media ( photo + text)

	----------------------------------
*/
.l-media:before,
.l-media:after {
	display: table;
	content: " ";
}
.l-media:after {
	clear: both;
}
.l-media__image {
	float: left;
}
.l-media__image img {
	max-width: 100%;
	height: auto;
}
.l-media__image.is-rev {
	float: right;
}
.l-media__body {
	overflow: hidden;
}

/*



/*==========================================================================

   header

==========================================================================*/
.header-container {
	padding-top: 194px;
}
#header {
	margin-top: -194px;
}
.header-logo {
	width: 263px;
	height: 129px;
	position: absolute;
	top: 0;
	left: 50%;
	margin-left: -132px;
		white-space: nowrap;
		text-indent: 100%;
		overflow: hidden;
	z-index: 2;
}
.header-logo .is-logo {
	display: block;
	height: 100%;
	background-size: 263px 129px;
	background-repeat: no-repeat;
	background-image: url(../img/logo_main01@2x.png);
}
.brandHeader {
	overflow: hidden;
	height: 31px;
	font-size: 11px;
	font-weight: bold;
	line-height: 31px;
	background: #f2f2f2;
}
.brandHeader-title {
	float: left;
	width: 270px;
	height: 31px;
	margin-left: 10px;
}
.brandHeader-nav {
	float: right;
}
.brandHeader-nav__list {
	display: table;
	height: 31px;
	text-align: center;
}
.brandHeader-nav__item {
	display: table-cell;
	vertical-align: middle;
	border-left: 1px solid #ccc;
}
.brandHeader-nav__item a {
	display: block;
	height: 31px;
	padding: 0 5px;
}
.brandHeader-nav__item a:hover {
	background-color: #fff;
}
.assistHeader {
	position: relative;
	height: 120px;
}
.assistHeader-sns {
	display: inline-block;
	position: relative;
	top: 5px;
	left: 10px;
}
.assistHeader-contact {
	display: inline-block;
	position: absolute;
	top: 5px;
	right: 5px;
}
.assistHeader-contact__item {
	margin-left: 5px;
	width: 110px;
}
.assistHeader-contact__item .btn {
	box-sizing: border-box;
	width: 110px;
	height: 50px;
	font-size: 12px;
	font-weight: bold;
	letter-spacing: 0.08em;
  line-height: 1.2;
}
.assistHeader-contact__item.contact_btn .btn {
	background-color: #ebf5fc;
	color: #0062a7;
}
.assistHeader-contact__item.contact_btn .btn:hover {
	background-color: #fff;
}

.assistHeader-contact__item:nth-child(3) {
	width: 195px;
}

.assistHeader-contact__item:nth-child(3) .btn {
	width: 195px;
	padding-left: 23px;
	font-size: 14px;
}
.assistHeader-contact__item:nth-child(3) .btn:hover {
	padding-left: 23px;
}

.assistHeader-contact__item:nth-child(3) .btn span {
	font-weight: normal;
}
.assistHeader-contact__item .btn span{
	font-size: 11px;
}

.assistHeader-contact__tel {
	margin: 10px;
	font-size: 12px;
	text-align: center;
}
.assistHeader-contact__tel:before {
	display: inline-block;
	font: normal normal normal 18px/1 "icomoon";
	content: "\f3cd";
	margin-top: -.1em;
	margin-right: 9px;
	vertical-align: middle;
	font-weight: 900;
}
.assistHeader-contact__item {
	position: relative;
	box-shadow: 3px 3px 0px #fef693;
}
.footerSalonApproach__inquiryItem {
	position: relative;
	box-shadow: 6px 6px 0px #fef693;
}
.assistHeader-contact__item .btn-01::before, .footerSalonApproach__inquiryItem .btn-01 span::before {
	display: block;
	position: absolute;
	top: 49%;
	transform: translateY(-50%);
	left: 12%;
	z-index: 10;
	font: 300 1.25vw /1 "icomoon";
}
.footerSalonApproach__inquiryItem .btn-01 span::before {
	font-size: 1.5vw;
	top: 46%;
	left: -40px;
}
.assistHeader-contact__item .btn-01:hover {
	padding-left: 8px;
	box-shadow: unset;
	transform: translate(2px, 2px);
}
.footerSalonApproach__inquiryItem .btn-01:hover {
	padding-left: 28px;
	box-shadow: unset;
	transform: translate(5px, 5px);
}

/*
	----------------------------------

	globalNav - base

	----------------------------------
*/
.globalNav {
	position: relative;
	width: 100%;
}
.globalNav a {
	color: #000;
}

/* clearfix */
.globalNav:before,
.globalNav:after {
	content: " ";
	display: table;
}
.globalNav:after {
	clear: both;
}
.globalNav {
	*zoom: 1;
}

/*
	----------------------------------

	globalNav - main

	----------------------------------
*/
.globalNav__list {
	width: 100%;
	max-width: 1050px;
	margin: 0 auto;
	text-align: center;
}
.globalNav__item {
	display: inline-block;
	font-size: 13px;
	text-align: center;
}
.globalNav__label {
	padding: 10px 15px;
	display: inline-block;
	cursor: pointer;
}

a.globalNav__label { padding: 10px 8px;}
span.globalNav__label { padding: 10px 10px 20px;}

.globalNav__item:hover,
.globalNav__item:hover > a {
	color: #fff;
	background: #0062a7;
	transition: all .3s;
}

/*
	----------------------------------

	globalNav - child

	----------------------------------
*/
.globalChildNav {
	position: absolute;
	top: 43px;
	left: 0;
	box-sizing: border-box;
	width: 100%;
	padding: 35px 10px 28px;
	background: #0062a7;
	transition: all .2s;
}
.globalChildNav {
	visibility: hidden;
	opacity: 0;
	z-index: 1;
}
.globalChildNav a {
	color: #fff;
}
.globalChildNav__item {
	display: inline-block;
	margin: 0 4px;
	vertical-align: top;
}
.globalChildNav__item .is-item__image {
    border: 1px solid #0062a7;
    transition: all .3s;
    width:144px;
    margin: 0 auto 12px;
}

.globalChildNav__item .is-item__image.wide{
	width: 240px;
}

.globalChildNav__item .is-item__image img {
	width: 144px;
}
.globalChildNav__item .is-item__image.wide img {
	width: 240px;
}
.globalChildNav__item:hover .is-item__image {
	border: 1px solid #fff;
}
.globalChildNav__item:hover .is-item__image img {
	opacity: .6;transition: all .3s;

}
.globalChildNav__item span {
	line-height: 1.2em;
}
/*
	----------------------------------

	globalNav - hover action

	----------------------------------
*/
.globalNav__item:hover > .globalChildNav {
	top: 43px;
	visibility: visible;
	opacity: 1;
	z-index: 2;
}


/*==========================================================================

   header - scroll

==========================================================================*/
#header.scroll {
	position: fixed;
	top: 0;
	width: 100%;
	margin-top: 0;
	background: #fff;
	z-index: 100;
	transition: margin-top .3s;
}
#header.scroll .brandHeader {
	display: none;
}
#header.scroll .assistHeader-contact__list {
	float: right;
}
#header.scroll .assistHeader-contact__item .btn {
	height: 39px;
	transition: .3s;
}
#header.scroll .assistHeader-contact__tel {
	float: right;
}
#header.scroll .header-logo {
	width: 125px;
	height: 44px;
	top: 5px;
	margin-left: -62px;
}
#header.scroll .header-logo .is-logo {
	display: block;
	height: 100%;
	background-size: 125px 44px;
	background-repeat: no-repeat;
	background-image: url(../img/logo_sub01@2x.png);
}
#header.scroll .assistHeader {
	height: 80px;
}
#header.scroll .globalNav__list {
	height: auto;
}
#header.scroll .globalNav__item:hover > .globalChildNav {
	top: 43px;
}

#header.scroll .assistHeader-contact__tel{
	display: none;
}

/*==========================================================================

   footer

==========================================================================*/
/*
	----------------------------------

	footerSalonInfo

	----------------------------------
*/
.footerSalonInfo__lead {
	margin-bottom: 42px;
	font-size: 20px;
	text-align: center;
}
.footerSalonInfo__list {
	width: 1013px;
}
.footerSalonInfo__caution {
	font-size: 18px;
	text-align: center;
	line-height: 1.5;
	margin-top: 30px;
}
.footerSalonInfo__caution a{
	text-decoration: underline;
	font-weight: bold;
	color: #cf4c98;
}
.footerSalonInfo__caution a:hover{
	text-decoration: none;
}
.footerSalonInfo__item {
	margin-left: 7px;
	font-size: 14px;
	text-align: center;
}
.footerSalonInfo__item:first-child {
	margin-left: 0;
}
.footerSalonInfo__item .is-item__image {
	margin-bottom: 12px;
}
.footerSalonInfo__item .is-item__number {
	font-family: 'Lato', sans-serif;
	margin: 8px 0;
	font-size: 21px;
}
.footerSalonInfo__item .is-item__number span.salon_area {
	font-size: 10px;
	display: block;
	margin: 6px 0 10px;
}
.footerSalonInfo__item .is-item__link {
	font-size: 10px;
}
.footerSalonInfo__item .is-item__title2 {
	margin-bottom:5px;
	font-size: 16px;
}


/*
	----------------------------------

	footerSalonApproach

	----------------------------------
*/
.footerSalonApproach {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	box-sizing: border-box;
	width: 686px;
	margin: 80px auto 40px;
	padding: 40px 36px 30px;
	border: 1px solid #e8e8e8;
	background: #fff;
	z-index: 5;
	position: relative;
}
.footerSalonApproach:last-child {
	margin-bottom: 100px;
}
.footerSalonApproach .midashi {
	color: #0062a7;
	font-size: 18px;
	position: absolute;
	top: -30px;
	left: 50%;
	transform: translateX(-50%);
}
.footerSalonApproach__image {
	width: 145px;
}
.footerSalonApproach__text {
	width: 430px;
}
.footerSalonApproach__text .is-text__copy {
	margin-bottom: 9px;
	font-size: 18px;
	line-height: 1.3;
}
.footerSalonApproach__text .is-text__lead {
	font-size: 12px;
	line-height: 1.7;
}
.footerSalonApproach__inquiryItem {
	margin-left: 4px;
	font-size: 12px;
}

.footerSalonApproach__link .is-link__to-salon {
	display: table;
	width: 100%;
	margin-bottom: 20px;
	font-size: 14px;
}
.footerSalonApproach__inquiryItem .is-item__btn {
	box-sizing: border-box;
	/*3ko */width: 306px;
	/*2ko width: 220px;*/
	height: 51px;
	font-size: 14px;
	line-height: 16px;
	vertical-align: middle;
	padding-left: 2em;
	transition: .3s;
}
.footerSalonApproach__inquiryItem .is-item__btn span{
	position: relative;
}

/*
	----------------------------------

	footerBrandInfo

	----------------------------------
*/
.footerBrandInfo__header {
	text-align: center;
}
.footerBrandInfo__title {
	width: 944px;
	margin: 0 auto;
}
.footerBrandInfo__list {
	margin: 50px 0;
	font-size: 0;
	text-align: center;
}
.footerBrandInfo__item {
	display: inline-block;
	margin: 0 4px;
	transition: all .5s;
}
.footerBrandInfo__item:hover {
	opacity: .6;
}

/*
	----------------------------------

	footerNav

	----------------------------------
*/
.footerNav {
	border-top: 1px solid #e5e5e5;
	border-bottom: 1px solid #dcdddc;
	background: #f5f6f5;
}
.footerNav-header {
	float: left;
	width: 290px;
	padding: 215px 0 0 0;
}
.footerNav__logo {
	display: block;
	width: 177px;
	height: 62px;
	margin: 0 auto 25px;
	white-space: nowrap;
	text-indent: 100%;
	overflow: hidden;
	background-size: 177px 62px;
	background-repeat: no-repeat;
	background-image: url(../img/logo_footer01@2x.png);
}
.footerNav-sns__list {
	margin: 25px;
}
.footerNav-contact__list {
    margin: 0 auto;
}
.footerNav-contact__item {
	margin-left: 1px;
}
.footerNav-contact__item .btn {
	box-sizing: border-box;
	/*3ko*/ width: 94px;
	/*2ko width:130px;*/
	height: 58px;
	font-size: 12px;
	font-weight: bold;
}
.footerNav-contact__item .btn span{
	font-size: 10px;
}

/*
	----------------------------------

	footer-gNav

	----------------------------------
*/
.footer-gNav {
	display: table;
	float: right;
	width: 712px;
	font-size: 12px;
	box-sizing: border-box;
	border-right: 1px solid #e5e5e5;
}
.footer-gNav-col {
	display: table-cell;
	box-sizing: border-box;
	padding: 10px 0;
	border-left: 1px solid #e5e5e5;
}

.footer-gNav-col.is-col-left { width: 255px;}

.footer-gNav-cat {
	padding: 25px 25px 13px;
}
.footer-gNav-cat__title {
	margin-bottom: 20px;
}
.footer-gNav-catList__item {
	margin-bottom: 10px;
	line-height: 1.3;
}
.footer-gNav-cat.is-home,
.footer-gNav-cat.is-plan,
.footer-gNav-cat.is-cuisine,
.footer-gNav-cat.is-about,
.footer-gNav-cat.is-testimonials {
	border-bottom: 1px solid #e5e5e5;
}

/*
	----------------------------------

	footer-legalNavList

	----------------------------------
*/
.footer-legalNavList {
	font-size: 12px;
	text-align: center;
	margin-bottom: 10px;
}
.footer-legalNavList__item {
	display: inline-block;
	margin-left: 25px;
}
.footer-legalNavList__item:first-child {
	margin-left: 0;
}

/*
	----------------------------------

	footerSign

	----------------------------------
*/
.footerSign {
	padding: 20px 0 80px;
	background: #fff;
}
.footerSign__logo {
	width: 93px;
	height: 63px;
	margin: 80px auto 30px;
	text-align: center;
}
.footerSign__copyright {
	display: block;
	margin: 50px auto 0;
	font-size: 10px;
	text-align: center;
}


/* ● scale */
.scale-img {
	position: relative;
	overflow: hidden;
	height: auto;
	font-size: 0;
	line-height: 0;
	-webkit-transition: all .3s ease-in-out;
	transition: all .3s ease-in-out;
}

.scale-img img {
    width: 100%;
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
}

.scale-img:hover img {
	opacity: .8;
	-webkit-transform: scale(1.05);
	transform: scale(1.05);
}


.anchor-triangle{
	position: relative;
}
.anchor-triangle a:after {
    position: absolute;
    content: '';
    display: block;
    width: 0;
    height: 0;
    border-left: 20px solid transparent;
    border-bottom: 20px solid #d14d9a;
    right: 10px;
    bottom: 10px;
    transition: .3s;
}
.plan-btn-list{
	width: 563px;
	display: flex;
}
.plan-btn-list-item{
	width: 20%;
	text-align: center;
	box-sizing: border-box;
	border-right: 1px solid #fff;
}
.plan-btn-list-item:last-child{
	border: none;
}
.plan-btn-list-item a{
	display: block;
	background: #0062a7;
	color: #fff;
	padding-top: 20px;
	padding-bottom:20px;
	font-size: 14px;
	line-height: 1.2;
	opacity: 1;
	transition: 0.6s;
	height: 72px;
	box-sizing: border-box;
}

.plan-btn-list-item a.one-line {
	padding-top: 28px;
}
#footer-plan-btn-fixed{
	position: fixed;
	bottom:-100px;
	left:30px;
	z-index: 1000;
	transition: 0.3s;
}
#footer-plan-btn-fixed.scroll{
	bottom:30px;
	transition: 0.3s;
}

.plan-btn-list-item a.active{
	background: #fff;
    color: #0062a7;
}

.plan-btn-list-item a:hover{
	background: #fff;
    color: #0062a7;
}