@charset "UTF-8";
/* ----------------------------------------------------------------
ブレークポイント設定
----------------------------------------------------------------- */
/* ----------------------------------------------------------------
カラー
----------------------------------------------------------------- */
#shop-detail *, #shop-detail *::before, #shop-detail *::after {
  box-sizing: border-box;
}
#shop-detail .shop-detail_inner .store-info .reservation .carrier {
  flex-wrap: wrap;
}
#shop-detail .shop-detail_inner .store-info .reservation .carrier .carrier_li {
  width: calc((100% - 40px) / 3);
}
#shop-detail .date_select_title {
  margin-bottom: 20px;
}
#shop-detail .date_select_box {
  margin-bottom: 10px;
  position: relative;
  overflow: hidden;
}
#shop-detail .date_select_box .date_select_box_inner {
  position: relative;
  overflow: hidden;
  width: 100%;
}
#shop-detail .date_select_box .date_select_box_inner::before, #shop-detail .date_select_box .date_select_box_inner::after {
  width: 18px;
  height: 110px;
  background: #fff;
  content: "";
  position: absolute;
  top: 0;
  z-index: 999;
}
#shop-detail .date_select_box .date_select_box_inner::before {
  left: 0;
}
#shop-detail .date_select_box .date_select_box_inner::after {
  right: 0;
}
#shop-detail .date_select_box .date_select {
  display: flex;
  position: relative;
  transition: transform 0.3s ease;
}
#shop-detail .date_select_box .date_select_prev,
#shop-detail .date_select_box .date_select_next {
  position: absolute;
  width: 18px;
  height: 80px;
  background: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  bottom: 0;
  z-index: 9999;
}
#shop-detail .date_select_box .date_select_prev img,
#shop-detail .date_select_box .date_select_next img {
  width: 6px;
}
#shop-detail .date_select_box .date_select_prev {
  left: 0;
  border: 1px solid #EAEAEA;
  border-right: none;
  border-radius: 10px 0 0 10px;
}
#shop-detail .date_select_box .date_select_prev img {
  transform: scale(-1, 1);
}
#shop-detail .date_select_box .date_select_next {
  right: 0;
  border: 1px solid #EAEAEA;
  border-radius: 0 10px 10px 0;
}
#shop-detail .date_select {
  margin: 0 18px;
  display: flex;
  position: relative;
}
#shop-detail .date_select li {
  width: 42px;
  min-width: 42px;
  margin-right: -1px;
}
#shop-detail .date_select li.select .date_select_list {
  background: #FA208D;
  color: #fff;
}
#shop-detail .date_select li.select .date_select_list .availability {
  color: #fff;
}
#shop-detail .date_select .date_week {
  height: 30px;
}
#shop-detail .date_select .date_select_list {
  height: 80px;
  padding: 10px 0;
  border: 1px solid #EAEAEA;
  cursor: pointer;
  flex-shrink: 0;
}
#shop-detail .date_select .date_select_list .date_select_day {
  margin-bottom: 14px;
  font-size: 1rem;
}
#shop-detail .date_select .date_select_list .availability {
  font-size: 2.4rem;
  line-height: 1;
}
#shop-detail .date_select .date_select_list .availability.availability_a {
  color: #FA208D;
}
#shop-detail .date_type01 img {
  width: 22px;
  margin: 0 auto;
}
#shop-detail .shop-detail_inner .store-reservation .calendar-area .calendar-wrap .ex-inputs::after {
  display: none;
}
#shop-detail .ex-inputs {
  padding-right: 80px !important;
  position: relative;
}
#shop-detail .ex-inputs-header {
  text-align: center;
  margin-bottom: 8px;
}
#shop-detail .ex-inputs-start,
#shop-detail .ex-inputs-end {
  font-family: fot-udmarugo-large-pr6n, sans-serif;
}
#shop-detail .ex-inputs-start .year,
#shop-detail .ex-inputs-end .year {
  display: block;
  font-size: 1.4rem;
}
#shop-detail .ex-inputs-start .month,
#shop-detail .ex-inputs-start .day,
#shop-detail .ex-inputs-end .month,
#shop-detail .ex-inputs-end .day {
  font-size: 1.7rem;
}
#shop-detail .ex-inputs-start .month span,
#shop-detail .ex-inputs-start .day span,
#shop-detail .ex-inputs-end .month span,
#shop-detail .ex-inputs-end .day span {
  font-size: 2.3rem;
}
#shop-detail .ex-inputs-period {
  padding: 0 8px;
}
#shop-detail .date-picker-div {
  display: flex;
  align-items: center;
}

#shop-detail .date-picker-div.disabled {
  color: #818181;
}

#shop-detail .ex-inputs-default {
  cursor: pointer;
}
#shop-detail .ex-inputs-default:hover {
  color: #FA208D;
}
#shop-detail .ex-inputs-start:focus,
#shop-detail .ex-inputs-end:focus {
  border-color: #46A5F5;
}
#shop-detail .ex-inputs-picker {
  position: absolute;
  z-index: 1000;
  left: 50%;
  top: calc(100% + 8px);
  opacity: 0;
  z-index: -20;
  transform: translateX(-50%);
  transition: all 0.25s;
}

/* 無効状態のスタイル */
#shop-detail .ex-inputs-btn.disabled {
    cursor: not-allowed;
}

#shop-detail .ex-inputs-btn.disabled img {
    filter: grayscale(70%) opacity(0.5);
}

/* バツ印オーバーレイ */
#shop-detail .ex-inputs-btn .cross-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
}

#shop-detail .ex-inputs-btn .cross-overlay::before,
#shop-detail .ex-inputs-btn .cross-overlay::after {
    content: '';
    position: absolute;
    background: rgba(255, 0, 0, 0.8);
    transform-origin: center;
    box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

#shop-detail .ex-inputs-btn .cross-overlay::before {
    top: 50%;
    left: 10%;
    right: 10%;
    height: 4px;
    transform: translateY(-50%) rotate(45deg);
}

#shop-detail .ex-inputs-btn .cross-overlay::after {
    top: 50%;
    left: 10%;
    right: 10%;
    height: 4px;
    transform: translateY(-50%) rotate(-45deg);
}

#shop-detail .ex-inputs-btn {
  width: 80px;
  height: 80px;
  cursor: pointer;
  position: absolute;
  right: 0;
  top: 0;
}
#shop-detail .ex-inputs-btn img {
  border-radius: 0 11px 11px 0;
}
#shop-detail .ex-inputs-picker-visible {
  opacity: 1;
  z-index: 1000;
}
#shop-detail .calendar_explanation {
  margin-bottom: 30px;
  display: flex;
  flex-wrap: wrap;
}
#shop-detail .calendar_explanation .calendar_explanation_txt {
  margin-right: 10px;
}
#shop-detail .calendar_explanation .calendar_explanation_txt img {
  width: 15px;
  display: inline-block;
}
#shop-detail .calendar_explanation .calendar_explanation_txt span {
  color: #FA208D;
}
#shop-detail .time-select li {
  cursor: pointer;
}
#shop-detail .time-select li.impossible {
  cursor: inherit;
}
#shop-detail #rct-form .rct-form {
  padding: 0;
}
#shop-detail #rct-form .rct-form_inner {
  width: 100%;
  max-width: inherit;
  padding: 0;
  box-shadow: none;
}
#shop-detail #rct-form .rct-form_inner .form-container #jobForm {
  margin: 0;
}
#shop-detail #rct-form .required {
  background: none;
  color: #D8007F;
}
#shop-detail #rct-form select:disabled,
#shop-detail #rct-form input:disabled,
#shop-detail #rct-form textarea:disabled,
#shop-detail #rct-form button:disabled {
  background-color: #efefef !important;
}
#shop-detail .date-completed {
  padding: 20px 5px;
  background: #fdf1f9;
}
#shop-detail .shop_detail_bnr {
  max-width: 640px;
  width: 100%;
  margin: 0 auto 60px;
}
#shop-detail .shop_detail_bnr li a {
  box-shadow: 0px 5px 18px -10px #818181;
  border-radius: 30px;
  display: block;
}
#shop-detail .shop_detail_bnr li a:hover {
  opacity: 0.7;
}
@media (max-width: 1280px) {
  #shop-detail {
    /*  1280px  */
    /*  1280px  */
  }
}
@media (max-width: 1024px) {
  #shop-detail {
    /*  1024px  */
    /*  1024px  */
  }
}
@media (max-width: 768px) {
  #shop-detail {
    /*  768px  */
    /*  768px  */
  }
}
@media (max-width: 480px) {
  #shop-detail {
    /*  480px  */
    /*  480px  */
  }
}
@media (max-width: 320px) {
  #shop-detail {
    /*  320px  */
    /*  320px  */
  }
}