.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;
  }
}
