.menu {
	display: none;
}

.header .inner_pc, .header .inner_sp {
	display: flex;
	justify-content: space-between;
}

.header .mv__title {
	display: inline-block;
}

.headerLogo, .headerContact {
    display: inline-flex;
    align-items: center;
}


.headerContact .headerTel {
	width: 275px;
}

.headerContact .headerMail {
	width: 226.3px;
	margin-left: 5px;
}

.btnMailSp {
    display: none;
}

.imgTitle {
    height: 98px;
    background: #032C76;
    margin-top: 88px;
}

.imgTitleContent {
    width: 610px;
    margin: 0 auto;
    position: relative;
    height: 98px;
}

.titleInquiries img {
	position: absolute;
	left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
	width: 425px;
	max-width: 100%;
}


.p-reservations__line {
    background-color: #00c300;
    padding: 5px 10px;
    width: 60%;
    margin: 0 auto 0;
}


.p-reservations__line img {
    max-width: 100%;
}


.formContact {
	width: 800px;
	max-width: 100%;
	margin: 75px auto 35px auto;
}

.formContact input, .formContact textarea, .formContact select, .formContact button {
	font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
}

.formContact .formRow {
	display: flex;
	border-top: 1px solid #898989;
}

.formContact .formRow:last-child {
	border-bottom: 1px solid #898989;
}

.formContact .formRowTitle {
	width: 29.375%;
	min-height: 58px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0 2px 0 12px;
	box-sizing: border-box;
	background-color: #F1F8FD;
	border-left: 1px solid #898989;
	border-right: 1px solid #898989;
}

.formContact .formRowTitle p {
	color: #000;
	font-size: 1.9rem;
	font-weight: 900;
}

.formContact .formRowTitle .redLbl{
	color: #FFF;
	font-size: 1.7rem;
	font-weight: 900;
	background-color: #ED1C24;
	padding: 5px 6px;
}

.formContact .formRowTitle .greenLbl{
	color: #FFF;
	font-size: 1.7rem;
	font-weight: 900;
	background-color: #8CC63F;
	padding: 5px 6px;
}

.formContact .formRowInput {
	width: 70.625%;
	min-height: 58px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-left: 18px;
	box-sizing: border-box;
	border-right: 1px solid #999899;
}

.formContact .formRowInput .nSize {
	width: 68.625%;
	height: 34px;
	font-size: 1.762rem;
	padding-left: 20px;
}

.formContact .formRowInput .nKibou {
	width: 68.625%;
	height: 34px;
	font-size: 1.762rem;
	padding-left: 20px;
}

.formContact .formRowInput input {
	border: 1px solid #999899;
	-webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
	border-radius: 0;
}

.formContact .formRowInput input::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
	color: #CCCCCC;
	opacity: 1; /* Firefox */
}

.formContact .formRowInput input:-ms-input-placeholder { /* Internet Explorer 10-11 */
	color: #CCCCCC;
}

.formContact .formRowInput input::-ms-input-placeholder { /* Microsoft Edge */
	color: #CCCCCC;
}

.formContact select {
	border: 1px solid #999899;
	color: #cccccc;
	-webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
	border-radius: 0;
	background: #fff;
}

.formContact select option {
	color: #1A1A1A;
}

.formContact .bk {
    color: #1A1A1A;
}

.formContact .selectNSize {
	position: relative;
	max-width: 100%;
	width: 374px;
}

.formContact .smallSize {
	display: flex;
    width: 166px;
    justify-content: space-between;
}

.formContact .selectNSize:after {
	content: '';
	position: absolute;
	width: 16.5px;
	height: 14.3px;
	background-image: url(../img/select_arrow.svg);
	background-repeat: no-repeat;
	background-size: 100% 100%;
	right: 8px;
	top: 50%;
	transform: translate(0, -50%);
}

.formContact .selectNSize select {
	font-size: 1.762rem;
	width: 100%;
	height: 38px;
	padding-left: 15px;
}

.formContact .smallSize select {
	width: 100px; 
}

.formContact .smallSize:after {
	display: none;
}

.formContact .selectNSize .colSmallSize {
	position: relative;
}

.formContact .selectNSize .colSmallSize:after {
	content: '';
	position: absolute;
	width: 16.5px;
	height: 14.3px;
	background-image: url(../img/select_arrow.svg);
	background-repeat: no-repeat;
	background-size: 100% 100%;
	right: 8px;
	top: 50%;
	transform: translate(0, -50%);
}

.rowTextarea .formRowInput {
	padding: 12px 20px;
}

.rowTextarea .formRowTitle {
	padding-bottom: 10%;
}

.formContactTextarea {
	height: 155px;
	width: 100%;
	resize: none;
	font-size: 1.762rem;
	padding: 15px;
	border: 1px solid #999899;
	-webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
	border-radius: 0;
}

.formContactTextarea::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
	color: #CCCCCC;
	opacity: 1; /* Firefox */
}

.formContactTextarea:-ms-input-placeholder { /* Internet Explorer 10-11 */
	color: #CCCCCC;
}

.formContactTextarea::-ms-input-placeholder { /* Microsoft Edge */
	color: #CCCCCC;
}

.formCheckBox {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-bottom: 5px;
}

.formCheckBox p {
	color: #000;
	font-weight: bold;
	font-size: 2.2rem;
}

.formCheckBox input {
	width: 32px;
	height: 28px;
	border: 1px solid #AEAEAE;
	margin-right: 10px;
}

.formDes {
	width: 709px;
	max-width: 100%;
	margin: 0 auto;
	border: 1px solid #ccc;
	padding: 15px 20px 20px 20px;
	box-sizing: border-box;
	margin-bottom: 20px;
	overflow-y: scroll;
	height: 200px;	
}

.formDes p {
	color: #000;
	text-align: justify;
	font-size: 1.6rem;
	line-height: 1.9;
}

.btnFormContact {
	padding-bottom: 35px;
	width: 100%;
	text-align: center;
}

.btnFormContact button {
	width: 269px;
	height: 75px;
	background-color: #DF803C;
	color: #FFF;
	font-weight: 900;
	font-size: 2.783rem;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 35px;
	border: 1px solid #DF803C;
	margin: 0 auto;
	-webkit-box-shadow: 1px 1px 4px 0px rgba(0,0,0,0.75);
	-moz-box-shadow: 1px 1px 4px 0px rgba(0,0,0,0.75);
	box-shadow: 1px 1px 4px 0px rgba(0,0,0,0.75);
	outline: none;
	cursor: pointer;
}

/*[custom checkbox]*/
.custom-checkbox {
	text-align: center;
	margin-bottom: 10px;
}

.custom-checkbox label{
	/*margin: 0 15px 0 0;*/
}
.custom-checkbox input[type="checkbox"]{
	display: none;
}
.custom-checkbox .vir-label{
	cursor: pointer;
    padding-bottom: 16px;
    display: inline-block;
}

.custom-checkbox:last-child .vir-label{
    padding-bottom: 6px;
}

.custom-checkbox .vir-content{
    vertical-align: middle;
    margin-left: 9px;
	color: #000;
    font-weight: bold;
    font-size: 2.2rem;
}
.custom-checkbox .vir-checkbox{
	width: 32px;
    height: 28.8px;
	border: 1px solid #aeaeae;
	background: #ffffff;
	vertical-align: middle;
	position: relative;
	display: inline-block;
}

.custom-checkbox input[type="checkbox"]:checked + .vir-label .vir-checkbox:before{
    content: "";
    background: #a3a3a3;
    border-radius: 50px;
    height: 20.8px;
    width: 24px;
    position: absolute;
    display: inline-block;
    top: 4px;
    left: 4px;
}

.custom-checkbox .vir-checkbox.square-style,
.custom-checkbox input[type="checkbox"]:checked + .vir-label .vir-checkbox.square-style:before{
	border-radius: 0px;
}

#errors {
    outline: none;
    margin: 0 auto 20px auto;
    text-align: center;
    position: relative;
    color: #ff0000;
    font-weight: 400;
    font-size: 2.445rem;
}
/*[custom checkbox/]*/





/* start NO19 */
.listHairAddress .collapsibleContent .shopHairMapDes p.offday {	
	color: #ED1C24;	
	font-weight: bold;	
}	

.listHairAddress.showSp {
	display: block;
}

.selectShop .btnArea {
	margin-top: 10px;
}

.listHairAddress ul li .hairAddressContent {
	border: none;
}
.listHairAddress.showSp {
	padding: 0 5px;
}

.listHairAddress.showSp li > .collapsibleContent {
	padding: 20px 5px 0 5px;
    box-sizing: border-box;
	border: 1px solid #0071B7;
	border-bottom-left-radius: 19.15px;
	border-bottom-right-radius: 19.15px;
	margin-top: -10px;
	padding-bottom: 10px;
}

.listHairAddress.showSp li > .collapsibleContent .collapsible {
	margin-bottom: 10px;
	background: #DEEBF7;
	color: #000000;
	border: 1px solid #000;
}

.listHairAddress.showSp li > .collapsibleContent .collapsible.active {
	margin-bottom: 0;
	z-index: 1;
}

.listHairAddress.showSp li > .collapsibleContent .collapsible:after {
	border: 1px solid #0071B7;
	border-radius: 50%;
}

.listHairAddress.showSp li > .collapsibleContent .collapsible.active:after {
	border: 1px solid #0071B7;
	border-radius: 50%;
}

.listHairAddress.showSp li > .collapsibleContent .collapsibleContent {
	padding: 20px 5px 10px 5px;
    box-sizing: border-box;
	/*border: 1px solid #000000;*/
	border: 1px solid #0071B7;
	border-bottom-left-radius: 19.15px;
	border-bottom-right-radius: 19.15px;
	position: relative;
	margin-top: -10px;
	margin-bottom: 10px;
}

.listHairAddress.showSp li > .collapsibleContent .collapsibleContent:last-child {
	margin-bottom: 0;
}

.listHairAddress.showSp li > .collapsibleContent > .collapsibleContent .collapsible {
	background: #fff;
}

.selectOnSp {
	width: 68.7%;
}

.selectOnSp .collapse.active:before {
	-webkit-transform: rotate(120deg);
    -moz-transform: rotate(120deg);
    -o-transform: rotate(120deg);
    -ms-transform: rotate(120deg);
    transform: rotate(120deg);
    /*color: #9DC3E6;*/
    color: #0071B7;
}

.selectOnSp .btnCity.active:before {
	color: #9DC3E6;
}


.btnArea {
	font-weight: normal;
	padding: 15px;
	font-size: 1.6rem;
	border: 1px solid #ccc;
	color: #000;
	box-sizing: border-box;
	width: 100%;
	margin-bottom: 10px;
}

.btnArea.active {
	margin-bottom: 0;
}

.selectOnSp .collapseContent {
	padding: 5px;
    border: 1px solid #ccc;
    border-top: none;
    margin-bottom: 10px;
    display: none;
}

.btnArea:before {
    content: "▼ ";
    color: #0071B7;
    /*color: #9DC3E6;*/
    display: inline-block;
    -webkit-transition: all 0.1s;
	transition: all 0.1s;
	padding-right: 5px;
	-webkit-transform: rotate(30deg);
    -moz-transform: rotate(30deg);
    -o-transform: rotate(30deg);
    -ms-transform: rotate(30deg);
    transform: rotate(30deg);
}

.btnCity {
	font-weight: normal;
	padding: 15px;
	font-size: 1.6rem;
	border: 1px solid #ccc;
	color: #000;
	box-sizing: border-box;
	width: 100%;
	margin-bottom: 10px;
}

.btnCity.active {
	margin-bottom: 0;
}

.btnCity:before {
    content: "▼ ";
    /*color: #0071B7;*/
    color: #9DC3E6;
    display: inline-block;
    -webkit-transition: all 0.1s;
	transition: all 0.1s;
	padding-right: 5px;
	-webkit-transform: rotate(30deg);
    -moz-transform: rotate(30deg);
    -o-transform: rotate(30deg);
    -ms-transform: rotate(30deg);
    transform: rotate(30deg);
}

.selectOnSp .collapseContent label {
	display: flex;
	align-items: center;
	font-size: 1.6rem;
	padding: 10px 0 10px 20px;
}

.formContact .formRowInput input[type=radio] {
    background-color: initial;
    cursor: default;
    appearance: radio;
    -webkit-appearance: radio;
    -moz-appearance: radio;
    box-sizing: border-box;
    padding: initial;
    border: initial;
    font-size: 1.6rem;
    border-radius: 50%;
}

.customerFeedbackList .showSp img {
	margin-bottom: 35px;
}

.customerFeedbackList .showSp img:last-child {
	margin-bottom: 0px;
}

@media only screen and (max-width: 768px) {
	.selectShop {
		width: 100%;
	}
	.selectShop .btnArea {
		margin-top: 0;
	}
}


/* end NO19 */


.c-information {
    background-color: rgba(255,255,255,0.6);
    padding: 15px;
    line-height: 1.64;
    letter-spacing: 0.04em;
    font-size: 1.7rem;
    border-left: 1px solid #898989;
    border-right: 1px solid #898989;
    border-top: 1px solid #898989;
}

.c-information a {
	color: #007fd0;
}

.c-information label {
	display: inline-flex;
	align-items: center;
	cursor: pointer;
	margin-top: 10px;
}

.c-information input[type=checkbox] {
	width: 20px;
	height: 20px;
	margin-right: 10px;
	cursor: pointer;
}


#ui-datepicker-div {
	font-size: 18px;
}

.formRowDatepicker {
	position: relative;
	flex-wrap: wrap;
}

.customDatepicker {
	top: 46px !important;
	left: 17px !important;
}

.footerLine {
	background: #FFFFFF;
	overflow: hidden;
}

.footerLineBtn {
	display: block;
    text-align: center;
    width: 224px;
    margin: 30px auto 30px;
}

.footerLineBtn:hover {
	opacity: 0.7;
}

.footerLineBtn img {
	width: 100%;
}

@media only screen and (max-width: 767px){
	.headerContact .headerTelSp {
		display: inline-block;
		width: 180px;
	}

	.header {
		height: calc(100 / 640 * 100vw);
	}

	.header h1 {
		position: relative;
		top: calc(20 / 640 * 100vw);
	}

	.headerContact {
	    padding: 5px 6px 5px 12px;
	    box-sizing: border-box;
	}

	.main .content00 {
	    padding-top: calc(100 / 640 * 100vw);
	}

	.btnMailSpFixed {
	    position: fixed;
	    z-index: 999;
	    bottom: 10px;
	    left: 0;
	    background: none;
	    width: 100%;
	    display: block;
	    text-align: center;
	}

	.btnMailSp a img {
	    width: 98%;
	    display: inline-block;
	    max-width: 430px;
	}

	.imgTitle {
		height: 81.5px;
		margin-top: 64px;
	}

	.imgTitleContent {
		width: 100%;
		height: 81.5px;
	}

	.titleInquiries,
	.titleInquiries .imgTitleContent {
		height: 68px;
	}

	.titleInquiries {
		margin-top: 59px;
	}

	.titleInquiries img {
		width: 241px;
		height: 23px;
	}

	.c-information {
		margin-top: -20px;
	    border-bottom: 1px solid #898989;
	    margin-bottom: 40px;
	}

	.formContact {
		padding: 0 22px;
		margin: 55px 0 45px 0;
		box-sizing: border-box;
	}

	.formContact .formRowInput,
	.formContact .formRowTitle,
	.formContact .formRow {
		border: none;
	}

	.formContact .formRow {
		flex-wrap: wrap;
		margin-bottom: 45px;
	}

	.formContact .formRowTitle,
	.formContact .formRowInput {
		width: 100%;
	    min-height: unset;
	}

	.formContact .formRowTitle {
		padding: 0;
	    justify-content: flex-start;
	    margin-bottom: 5px;
	    background: #fff;
	}

	.formContact .formRowInput {
		padding: 0;
	}

	.formContact .formRowTitle p {
		order: 2;
		font-size: 1.38rem;
	}

	.formContact .formRowTitle .redLbl,
	.formContact .formRowTitle .greenLbl {
		order: 1;
		margin-right: 7px;
		padding: 2.5px 5px;
		font-size: 1.6rem;
	}

	.formContact .formRowInput .nSize {
		font-size: 1.6rem;
		padding-left: 8px;
		height: 48px;
		width: 100%;
	}

	.formContact .formRowInput .nKibou {
		font-size: 1.6rem;
		padding-left: 8px;
		height: 48px;
		width: 100%;
		border-bottom: none;
	}

	.formContact .selectNSize select {
		height: 52px;
		padding-left: 8px;
		font-size: 1.6rem;
	}

	.formContact .selectNSize {
		width: 170px;
	}

	.formContact .maxSizeSp {
		width: 100%;
	}

	.formContact .smallSize {
		width: 208px;
	}

	.formContact .smallSize select {
		width: 97px;
		padding: 0;
		padding-right: 9px;
		padding-left: 10px;
	}

	.formContact .selectNSize:after,
	.formContact .selectNSize .colSmallSize:after {
		width: 13px;
		height: 11px;
	}

	.formContactTextarea {
		font-size: 1.6rem;
		height: 200px;
		padding: 10px;
		box-sizing: border-box;
/*		border-bottom: none; */
	}

	.formCheckBox p {
		font-size: 1.38rem;
	}

	.formCheckBox {
		justify-content: flex-start;
		padding: 0 25px;
		margin-bottom: 3px;
	}

	.formCheckBox input {
		width: 24px;
		height: 22px;
		border: 2px solid #AEAEAE;
	}

	.formDes {
		width: calc(100% - 44px);
		padding: 15px 10px 15px 10px;
		box-sizing: border-box;
		margin-bottom: 20px;
		height: 150px;
	}

	.formDes p {
		font-size: 1.245rem;
		line-height: 1.7;
	}

	.btnFormContact {
		padding-bottom: 25px;
	}

	.btnFormContact button {
		width: 165px;
		height: 46px;
		font-size: 1.7rem;
		border-radius: 17.5px;
		margin-top: 20px;
	}

	.custom-checkbox .vir-checkbox {
		width: 25px;
		height: 22px;
	}

	.custom-checkbox .vir-content {
		font-size: 1.1225rem;
		margin-left: 4px;
	}

	.custom-checkbox {
		text-align: center;
		padding: 0 22px;
	}

	.custom-checkbox input[type="checkbox"]:checked + .vir-label .vir-checkbox:before {
	    height: 16px;
	    width: 19px;
	    top: 3px;
	    left: 3px;
	}

	.custom-checkbox .vir-label {
		padding-bottom: 0;
	}

	
	.listHairAddress ul li .hairAddressContent {
	    border-bottom-left-radius: 19.15px;
	    border-bottom-right-radius: 19.15px;
	}

	#errors {
		padding: 0 22px;
		font-size: 1.5rem;
	}

	.btnMailSpFixed {
	    position: fixed;
	    z-index: 999;
	    bottom: 10px;
	    left: 0;
	    background: none;
	}

	.lineAddress {
		padding: 0 23px;
		box-sizing: border-box;
	    margin: 0 auto 50px auto;
	}

	.lineAddress .hairAddressContent {
		display: block;
	}

	.hairAddressContentLeft, .hairAddressContentRight {
		width: 100%;
	}

	.hairAddressContentLeft {
		margin-bottom: 25px;
	}


	.hairAddressContentLeft iframe {
		width: 100%;
		height: 188px;
	}

	.hairAddressContentRight {
		padding: 0;
	}

	.lineAddress .shopHairMapDes p.title {
		font-size: 1.75rem;
	}

	.lineAddress .shopHairMapDes p {
		font-size: 1.35rem;
	}

	.lineAddress .shopHairMapDes {
		padding-bottom: 25px;
	}

	.hairAddressContentRight .storeTitle {
		display: none;
	}

	.storeTitleSp {
		font-size: 2.35rem;
		font-weight: bold;
		text-align: center;
		margin: 15px auto;
		display: block;
	}

	/*footer {
		margin-bottom: 100px;
	}*/


	.customDatepicker {
	    left: 0px !important;
	}

	.formRowDatepicker p {
		font-size: 1.38rem !important;
	  }
}