@charset "UTF-8";
body {
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.eat {
  color: rgb(119, 12, 21);
}

.w1200 {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  max-width: 1200px;
  padding: 10px;
}

h1 {
  font-size: 40px;
}

.page-calendar {
  background-color: #e7e7e7;
}

h2.tx01 {
  text-align: center;
  margin-top: 1em;
}

.calendar-wrapper {
  margin-top: 40px;
  margin-bottom: 40px;
}
.calendar-wrapper h2 {
  font-size: 30px;
}
@media screen and (max-width: 900px) {
  .calendar-wrapper h2 {
    text-align: center;
  }
}
.calendar-wrapper table {
  width: 100%;
  margin-top: 1em;
  margin-bottom: 40px;
}
@media screen and (max-width: 900px) {
  .calendar-wrapper table {
    width: initial;
    margin-left: auto;
    margin-right: auto;
  }
}
.calendar-wrapper th {
  text-align: center;
  padding: 2px;
}
.calendar-wrapper td {
  height: 60px;
  border: 1px solid #333;
  padding: 4px;
}

.reservation-form {
  margin-top: 50px;
  width: 100%;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}
.reservation-form th {
  width: 14em;
}
.reservation-form td,
.reservation-form th {
  padding: 20px;
  border-bottom: 1px solid #aaa;
  vertical-align: middle;
}
.reservation-form td input,
.reservation-form th input {
  padding: 6px;
}
.reservation-form td span.eat,
.reservation-form th span.eat {
  font-size: 14px;
}
@media screen and (max-width: 600px) {
  .reservation-form td,
  .reservation-form th {
    width: 100%;
    display: block;
  }
}
@media screen and (max-width: 600px) {
  .reservation-form th {
    border: none;
    padding-bottom: 0;
  }
}
.reservation-form .txt002 {
  font-size: 14px;
  margin-top: 0.5em;
  line-height: 1.6;
  color: rgb(119, 12, 21);
}
.reservation-form input,
.reservation-form textarea {
  width: 100%;
  padding: 4px;
  border: 1px solid #333;
}
.reservation-form input[name=event_name],
.reservation-form input[name=room_number],
.reservation-form input[name=totalprice],
.reservation-form input[name=reservation_date] {
  pointer-events: none; /* マウス操作無効 */
  border: none;
  width: 100%;
}
.reservation-form .flexcenter {
  display: flex;
  justify-content: center;
  gap: 15px;
}
@media screen and (max-width: 600px) {
  .reservation-form .flexcenter {
    flex-wrap: wrap;
  }
}
.reservation-form .flexcenter .btnbackcalendar {
  background-color: black;
  color: white;
  border: none;
  border-radius: 10px;
  line-height: 3em;
  padding-left: 2em;
  padding-right: 2em;
}
@media screen and (max-width: 600px) {
  .reservation-form .flexcenter .btnbackcalendar {
    padding: 0;
    text-align: center;
    width: 80%;
    border-radius: 6px;
    margin-top: 2rem;
  }
}
.reservation-form .submitbtn,
.reservation-form .submitbtndummy,
.reservation-form .backbtn {
  color: white;
  line-height: 3em;
  padding-left: 2em;
  padding-right: 2em;
  border: none;
  border-radius: 10px;
  min-width: 10em;
  text-align: center;
  max-width: 14em;
}
@media screen and (max-width: 600px) {
  .reservation-form .submitbtn,
  .reservation-form .submitbtndummy,
  .reservation-form .backbtn {
    height: 5em;
    padding: 0;
    width: 80%;
    max-width: initial;
    border-radius: 6px;
  }
}
.reservation-form .submitbtn,
.reservation-form .submitbtndummy {
  background-color: rgb(219, 25, 155);
}
.reservation-form .backbtn,
.reservation-form .btnbackcalendar {
  background-color: rgb(34, 34, 34);
}
@media screen and (max-width: 600px) {
  .reservation-form .backbtn,
  .reservation-form .btnbackcalendar {
    border-radius: 6px;
  }
}
.reservation-form .person td,
.reservation-form .person th {
  border-top: 2px solid #000;
  border-bottom: none;
}
@media screen and (max-width: 600px) {
  .reservation-form .person td,
  .reservation-form .person th {
    border: none;
  }
}
.reservation-form tr:last-child td {
  border: none;
}
.reservation-form p.ngtxt {
  color: red;
  margin-top: 5px;
  font-size: 13px;
}
.reservation-form .select-wrap {
  position: relative;
  display: inline-block;
}
.reservation-form .select-wrap::after {
  content: "▼";
  position: absolute;
  right: 0.5em;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: #333;
}
.reservation-form select.checkin {
  padding-left: 0.5em;
  border: 1px solid #333;
  appearance: none; /* ブラウザのデフォルト矢印を非表示 */
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 1.5em; /* ▼用のスペースを確保 */
}
.reservation-form select.checkin,
.reservation-form select.sex,
.reservation-form select.sex2 {
  padding-left: 0.5em;
  border: 1px solid #333;
  appearance: none; /* ブラウザのデフォルト矢印を非表示 */
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 1.5em; /* ▼用のスペースを確保 */
}
.reservation-form select.personnum {
  width: 4em;
  padding-left: 0.5em;
  border: 1px solid #333;
  appearance: none; /* ブラウザのデフォルト矢印を非表示 */
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 1.5em; /* ▼用のスペースを確保 */
}
.reservation-form span.hissu {
  font-size: 13px;
  margin-left: 0.5em;
  border-radius: 3px;
  margin-top: 3px;
  font-weight: normal;
  display: inline-block;
  color: rgb(119, 12, 21);
}
.reservation-form span.hissu::before {
  content: "※";
}

.txt001 {
  margin-bottom: 1em;
  margin-top: 1em;
}

.txt004 {
  margin-bottom: 1em;
  margin-top: 1em;
  font-size: 15px;
  line-height: 1.5;
}

.calendar-table td {
  background-color: white;
  height: 6rem;
}
.calendar-table .spdate {
  display: none;
  font-size: 20px;
  margin-bottom: 10px;
  text-align: center;
}
@media screen and (max-width: 900px) {
  .calendar-table .date {
    display: none;
  }
  .calendar-table .spdate {
    display: block;
    text-align: center;
  }
  .calendar-table tr.youbi {
    display: none;
  }
  .calendar-table td {
    display: none;
  }
  .calendar-table td.calendar-day,
  .calendar-table th {
    width: 100%;
    display: block;
    height: auto;
  }
  .calendar-table td.calendar-day {
    display: flex;
    flex-direction: column; /* 子要素を縦に並べる */
    justify-content: center;
    align-items: center;
    padding: 1rem;
    padding-left: 2em;
    padding-right: 2em;
    margin-bottom: 5px;
  }
  .calendar-table td.calendar-day .marker {
    padding-left: 1em;
    padding-right: 1em;
  }
  .calendar-table td.nodata {
    display: none;
  }
}

.calendar-day {
  width: 14.2857142857%;
}
.calendar-day .date {
  text-align: center;
  border-bottom: 1px dotted #000;
  margin-bottom: 0.5em;
}
.calendar-day .marker {
  display: inline-block;
  width: 100%;
  text-align: left;
  margin-bottom: 0.2em;
  padding: 3px;
  padding-left: 1em;
}
@media screen and (max-width: 900px) {
  .calendar-day .marker {
    padding: 6px;
    margin-bottom: 6px;
    border-radius: 4px;
  }
}
.calendar-day .maru {
  color: rgb(6, 15, 104);
  background-color: #9dffaa;
}

.mw_wp_form_preview .btnbackcalendar {
  display: none;
}

.submitbtn {
  display: none;
}

.mw_wp_form_confirm .reservation-form .select-wrap::after {
  display: none;
}
.mw_wp_form_confirm span.hissu {
  display: none;
}

.thanksbox {
  font-size: 17px;
  margin-top: 2em;
  margin-bottom: 2em1;
  text-align: center;
}
.thanksbox p.linktext {
  margin-top: 2em;
}

.custom-radio-group {
  display: flex;
  gap: 20px;
  margin-bottom: 1em;
}
.custom-radio-group .custom-radio {
  cursor: pointer;
  font-size: 18px;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  padding-left: 30px;
  position: relative;
}
.custom-radio-group .custom-radio::before {
  content: "";
  position: absolute;
  left: 0;
  top: 2px;
  width: 20px;
  height: 20px;
  background-image: url("../img/b.png"); /* 未選択用 横棒画像 */
  background-size: contain;
  background-repeat: no-repeat;
}
.custom-radio-group .custom-radio.selected::before {
  background-image: url("../img/a.png"); /* 選択中用 チェック画像 */
}

.bikoumemo {
  margin-left: 2em;
}
.bikoumemo li {
  list-style-type: disc;
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: 0.5em;
}

.hidden {
  display: none;
}

.flexnum {
  display: flex;
  gap: 1em;
  align-items: center;
}
.flexnum .span {
  width: 6em;
}
.flexnum .numbox input {
  width: 10em;
}

div.pricebox {
  margin-top: 0.5em;
}
div.pricebox span {
  font-weight: bold;
  font-size: 22px;
}

tr.pricebox td:last-child {
  font-weight: bold;
  font-size: 22px;
}

.mw_wp_form_confirm div.pricebox {
  display: none;
}/*# sourceMappingURL=layout.css.map */