.reserve .container {
  max-width: 1240px;
}
.reserve .container > div {
  margin-bottom: 50px;
}
.reserve .form-tit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-bottom: 15px;
  border-bottom: 1px solid #6e6e6e;
}
.reserve .form-tit .tit {
  font-size: 18px;
  color: #4a4a4a;
}
.reserve .form-tit p:last-child {
  color: #292929;
}
@media screen and (max-width: 768px) {
  .reserve .form-tit .tit {
    font-size: 16px;
  }
}
.reserve .form select {
  background: url(../images/reserve/icon-arrow.png) no-repeat center;
  background-position: top 50% right 10px;
  color: #7b7b7b;
}
@media screen and (max-width: 1024px) {
  .reserve .form select {
    background-size: 10px 6px;
  }
}
.reserve .form .point {
  color: #d44e51;
  vertical-align: middle;
}
.reserve .form .input-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-bottom: 1px solid #d9d9d9;
}
.reserve .form .input-flex > div {
  width: 50%;
}
.reserve .form .input-flex > div.textarea-wrap {
  width: 100%;
}
.reserve .form .input-flex > div.date-wrap {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .reserve .form .input-flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    border-bottom: none;
  }
  .reserve .form .input-flex > div {
    width: 100%;
  }
}
.reserve .form .input-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 16px 20px;
}
.reserve .form .input-wrap p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 5px;
  max-width: 175px;
  width: 100%;
  color: #727272;
  font-size: 16px;
  letter-spacing: -1px;
}
.reserve .form .input-wrap p .point {
  margin-bottom: -7px;
}
.reserve .form .input-wrap input {
  max-width: 390px;
  width: 100%;
  height: 42px;
  border: 1px solid #d0d0d0;
  color: #7b7b7b;
}
.reserve .form .input-wrap label {
  display: none;
}
@media screen and (max-width: 1024px) {
  .reserve .form .input-wrap {
    padding: 10px 0;
  }
  .reserve .form .input-wrap p {
    max-width: 125px;
  }
}
@media screen and (max-width: 768px) {
  .reserve .form .input-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .reserve .form .input-wrap p {
    font-size: 16px;
  }
  .reserve .form .input-wrap input {
    max-width: 100%;
  }
}
.reserve .form .tel-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 5px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 75%;
}
.reserve .form .tel-wrap select,
.reserve .form .tel-wrap input {
  max-width: 120px;
  width: 100%;
}
.reserve .form .tel-wrap select {
  height: 42px;
}
@media screen and (max-width: 768px) {
  .reserve .form .tel-wrap {
    width: 100%;
  }
}
.reserve .form .input-chk {
  width: 100%;
}
.reserve .form .input-chk .input-wrap {
  width: 100%;
}
.reserve .form .input-chk .box-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
  width: 80%;
}
@media screen and (max-width: 768px) {
  .reserve .form .input-chk {
    width: 100%;
    gap: 10px;
  }
  .reserve .form .input-chk .box-wrap {
    width: 100%;
  }
}
.reserve .form .chk-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.reserve .form .chk-wrap p {
  width: auto;
}
.reserve .form .chk-wrap input[type=checkbox] {
  margin-left: 20px;
  width: 20px;
  height: 20px;
}
.reserve .form .chk-wrap label {
  display: none;
}
@media screen and (max-width: 768px) {
  .reserve .form .chk-wrap input[type=checkbox] {
    margin-left: 8px;
    width: 15px;
    height: 15px;
  }
}
.reserve .form .select-2 {
  max-width: 180px;
  width: 100%;
}
.reserve .form .select-2 select {
  width: 100%;
}
.reserve .form .textarea-wrap {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding-bottom: 30px;
}
.reserve .form .textarea-wrap textarea {
  padding: 10px 15px;
  width: 100%;
}
@media screen and (max-width: 1024px) {
  .reserve .form .textarea-wrap {
    padding-bottom: 20px;
  }
}
.reserve .form .date-wrap > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
}
.reserve .form .date-wrap > span {
  margin-right: 20px;
  color: #7b7b7b;
}
@media screen and (max-width: 1024px) {
  .reserve .form .date-wrap > span {
    margin-right: 0;
  }
}
@media screen and (max-width: 768px) {
  .reserve .form .date-wrap > span {
    display: none;
  }
}
.reserve .form .date-input {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
}
.reserve .form .date-input:last-child {
  margin-left: 10px;
}
.reserve .form .date-input label {
  display: block;
}
.reserve .form .date-input img {
  display: none;
}
.reserve .form .date-input label,
.reserve .form .date-input .time-icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-right: 20px;
  width: 42px;
  height: 42px;
  font-size: 20px;
  border-radius: 2px;
  border: 1px solid #d0d0d0;
}
.reserve .form .date-input label {
  color: #7b7b7b;
}
.reserve .form .date-input .time-icon {
  color: #bebebe;
}
.reserve .form .date-input input,
.reserve .form .date-input select {
  max-width: 178px;
  width: 100%;
  margin-right: 5px;
}
.reserve .form .date-input > span {
  display: none;
  color: #7b7b7b;
}
@media screen and (max-width: 1024px) {
  .reserve .form .date-input label,
  .reserve .form .date-input .time-icon {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .reserve .form .date-input:last-child {
    margin-left: 5px;
  }
  .reserve .form .date-input > span {
    display: block;
  }
}
@media screen and (max-width: 480px) {
  .reserve .form .date-input:last-child {
    margin-left: 5px;
  }
  .reserve .form .date-input > span {
    display: block;
  }
}
.reserve .form .btn-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 30px;
  margin-top: 100px;
  margin-bottom: 80px;
}
.reserve .form .btn-wrap .btn-reserve,
.reserve .form .btn-wrap .btn-location {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  max-width: 254px;
  width: 100%;
  max-height: 65px;
  line-height: 65px;
  border-radius: 5px;
  font-size: 18px;
  border: none;
}
.reserve .form .btn-wrap .btn-location {
  color: #222121;
  border: 1px solid #ababab;
}
.reserve .form .btn-wrap .btn-reserve {
  color: #fff;
  background: #0059a9;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .reserve .form .btn-wrap {
    gap: 15px;
    margin-top: 80px;
    padding: 0 20px;
  }
  .reserve .form .btn-wrap .btn-reserve,
  .reserve .form .btn-wrap .btn-location {
    max-width: 200px;
    max-height: 60px;
    line-height: 60px;
    font-size: 16px;
  }
}
.reserve .pop-privacy {
  display: inline-block;
  margin-right: 20px;
  border-bottom: 1px solid #7b7b7b;
  font-size: 16px;
  color: #7b7b7b;
}
.reserve .popup {
  position: fixed;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  z-index: 10;
  background: rgba(11, 11, 11, 0.631372549);
  display: none;
}
.reserve .popup.show {
  display: block;
}
.reserve .popup-wrap {
  position: relative;
  height: 100%;
  max-width: 800px;
  max-height: 500px;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.reserve .popup-body {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 2.5rem 1.25rem;
  background-color: #fff;
  overflow-y: auto;
}
.reserve .popup .pop-close {
  position: absolute;
  top: -45px;
  right: 0;
  border: none;
  background: none;
  color: white;
  font-size: 24px;
}