@charset "UTF-8";
/* #### reservation_login  ####  */
.reservation__inner {
  background: url(../_img/common/reservation_back.jpeg) no-repeat center center / cover;
  width: 100%;
  min-height: calc(100dvh - 238px - 72px);
  height: 100%;
  padding: 40px 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.login_box {
  max-width: 486px;
  width: 100%;
  padding: 64px 40px 72px 40px;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0px 0px 24px 0px rgba(0, 0, 0, 0.06);
  backdrop-filter: blur(10px);
}
.login_box .logo {
  width: 169.39px;
  height: 32px;
  margin-bottom: 40px;
}
.login_box .logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.reser_ip {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.reser_ip span {
  color: #2393af;
  font-size: 16px;
  font-weight: 500;
  line-height: 160%; /* 25.6px */
  letter-spacing: -0.4px;
}

.reser_ip input {
  border-radius: 8px;
  background: rgba(241, 241, 245, 0.8);
  backdrop-filter: blur(10px);
  height: 56px;
}

.login_box .btn-big {
  background: #176275;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  margin-top: 20px;
}
.reser_num {
  padding: 12px 16px;
  border-radius: 8px;
  background: rgba(35, 147, 175, 0.08);
  width: 100%;
  display: inline-block;
  color: #2393af;
  font-size: 16px;
  font-weight: 600;
  line-height: 150%; /* 24px */
  letter-spacing: -0.4px;
}
.reser_ul {
  margin-top: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.reser_ul li {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.reser_ul li a {
  display: flex;
  align-items: center;
  gap: 4px;
  color: #333;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%; /* 25.6px */
  letter-spacing: -0.4px;
}
.reser_ul li a::after {
  content: "";
  display: inline-block;
  background: url(../_img/common/icon_arrow_right_bl.svg) no-repeat center center / contain;
  width: 24px;
  height: 24px;
}
.badge_reser {
  padding: 0 12px;
  border-radius: 50px;
  background: #f6f9f9;
  height: 26px;
  line-height: 26px;
  display: inline-block;
  color: #176275;
  text-align: center;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: -0.35px;
}
/* 예약  */
.state__inner {
  padding: 80px 40px;
  width: calc(100% - 240px);
  margin-left: 240px;
}
.state__inner .tit {
  display: flex;
  align-items: center;
  gap: 24px;
  padding-bottom: 16px;
  width: 100%;
  border-bottom: 2px solid #eee;
}
.state__inner .tit h1 {
  color: #111;
  font-size: 28px;
  font-weight: 600;
  line-height: 135%; /* 37.8px */
  letter-spacing: -0.7px;
}

.state__inner .cont {
  /* padding-top: 40px; */
}
.reser_tbl {
  width: 100%;
}

.state__inner .tbl_wrap {
  overflow-x: auto;
}

.state__inner .tbl_wrap table {
  table-layout: fixed;
  min-width: 1400px;
}
.state__inner.review__inner .tbl_wrap table {
  table-layout: fixed;
  min-width: 520px;
}
.reser_tbl thead {
  border-top: 1px solid #111;
  border-bottom: 1px solid #111;
  background: #f1f1f5;
  height: 44px;
}
.reser_tbl thead th {
  color: #111;
  text-align: center;
  font-size: 14px;
  font-weight: 500;
  line-height: 140%; /* 19.6px */
  letter-spacing: -0.35px;
}
.reser_tbl tbody tr {
  height: 44px;
  text-align: center;
  background: #f7f7fb;
}
.reser_tbl tbody tr:nth-child(2n) {
  background: #fff;
}
.reser_tbl tbody td {
  color: #111;
  text-align: center;
  font-size: 14px;
  font-weight: 600;
  line-height: 140%; /* 19.6px */
  letter-spacing: -0.35px;
  padding: 7px 10px;
}

.state__inner .tbl_tit {
  color: #111;
  font-size: 20px;
  font-weight: 600;
  line-height: 135%; /* 27px */
  letter-spacing: -0.5px;
  margin-bottom: 16px;
  margin-top: 40px;
}
.bl_badge {
  border-radius: 4px;
  background: #111;
  padding: 0 8px;
  height: 34px;
  line-height: 34px;
  color: #fff;
  text-align: center;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: -0.4px;
}
.reser_visa {
  display: flex;
  flex-direction: column;
  gap: 24px;
  max-width: 800px;
  width: 100%;
}
.state__inner .file_ip span {
  color: #111;
  font-size: 16px;
  font-weight: 500;
  line-height: 135%; /* 21.6px */
  letter-spacing: -0.4px;
}
.state__inner .file_ip span b {
  margin-left: 4px;
  color: #999;
  font-size: 14px;
  font-weight: 400;
  line-height: 135%; /* 18.9px */
  letter-spacing: -0.35px;
}
.state__inner .file_ip .file_label > input {
  display: none;
}
.state__inner .file_ip .file_label .file_btn {
  border-radius: 8px;
  padding: 0 24px;
  font-size: 16px;
  font-weight: 600;
  color: #111;
}
.state__inner .file_ip {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.state__inner .file_ip .ip_box {
  display: flex;
  gap: 8px;
}
.state__inner .file_ip .ip_box input {
  width: 100%;
  height: 56px;
  line-height: 56px;
  border-radius: 8px;
  background: rgba(241, 241, 245, 0.8);
  backdrop-filter: blur(10px);
  border: none;
}
.state__inner .btn-save {
  background: #176275;
  width: 200px;
  margin: 16px auto 0;
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  color: #fff;
}
.reser_search {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 40px;
}
.reser_search .ip_box {
  display: flex;
  gap: 8px;
  align-items: center;
  width: 100%;
}

.reser_search .reser-input {
  border-radius: 8px;
  background: rgba(241, 241, 245, 0.8);
  backdrop-filter: blur(10px);
  height: 56px;
  line-height: 56px;
  width: 100%;
  border: none;
}
.reser_search .btn-big {
  width: 406px;
  border-radius: 8px;
  background: #176275;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.4px;
  flex-shrink: 0;
}

.reser_tbl .tbl_btn {
  border-radius: 4px;
  border: 1px solid #111;
  background: #fff;
  padding: 0 8px;
  height: 30px;
  line-height: 30px;
  font-size: 14px;
  font-weight: 600;
  color: #333;
}

.reser_tbl_pagination {
  display: flex;
  align-items: center;
  gap: 24px;
  justify-content: center;
  margin-top: 40px;
}
.reser_tbl_pagination .nums {
  display: flex;
  align-items: center;
  gap: 0;
  justify-content: center;
}
.reser_tbl_pagination li {
  height: 32px;
  width: 32px;
}
.reser_tbl_pagination li a {
  width: 32px;
  height: 32px;
  display: inline-block;
  line-height: 32px;
  text-align: center;
  background: #fff;
  font-size: 14px;
  color: #999999;
  font-weight: 400;
}

.reser_tbl_pagination li.num.select a {
  font-weight: 600;
  color: #176275;
}
.reser_tbl_pagination li.prev a,
.reser_tbl_pagination li.next a {
  display: flex;
  align-items: center;
  justify-content: center;
}
.reser_tbl_pagination li.prev a p {
  background: url(../_img/common/icon_arrow_left_tbl.svg) no-repeat center center / contain;
  width: 32px;
  height: 32px;
}
.reser_tbl_pagination li.next a p {
  background: url(../_img/common/icon_arrow_left_tbl.svg) no-repeat center center / contain;
  transform: rotate(180deg);
  width: 32px;
  height: 32px;
}
.reser_tbl_pagination li.first a p {
  background: url(../_img/common/icon_arrow_first_tbl.svg) no-repeat center center / contain;
  width: 32px;
  height: 32px;
}
.reser_tbl_pagination li.end a p {
  background: url(../_img/common/icon_arrow_first_tbl.svg) no-repeat center center / contain;
  transform: rotate(180deg);
  width: 32px;
  height: 32px;
}
.reser_inform {
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding: 20px;
  border-radius: 16px;
  background: #f7f7fb;
}
.reser_inform li {
  display: flex;
  gap: 40px;
}
.reser_inform li span {
  width: 102px;
  color: #111;
  font-size: 16px;
  font-weight: 500;
  line-height: 140%; /* 22.4px */
  letter-spacing: -0.4px;
}
.reser_inform li h5 {
  color: #111;
  font-size: 16px;
  font-weight: 600;
  line-height: 140%; /* 22.4px */
  letter-spacing: -0.4px;
}
.state__inner .title_B {
  color: #111;
  font-size: 20px;
  font-weight: 600;
  line-height: 135%; /* 27px */
  letter-spacing: -0.5px;
  margin-top: 80px;
  margin-bottom: 20px;
}
.reser_tab .tabnav {
  display: flex;
  width: 100%;
}
.reser_tab .tabnav li {
  width: calc(100% / 4);
}
.reser_tab .tabnav li a {
  width: 100%;
  display: inline-block;
  text-align: center;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #333;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.4px;
  border-bottom: 4px solid #f1f1f5;
}

.reser_tab .tabnav li a.active {
  border-bottom: 4px solid #176275;
  color: #176275;
}
.reser_tab .tabcontent {
  margin-top: 20px;
}
.reser_gray_box {
  display: flex;
  padding: 20px;
  flex-direction: column;
  gap: 24px;
  border-radius: 16px;
  background: #f7f7fb;
}
.reser_gray_box .total {
  max-width: 482px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 2px;
}
.reser_gray_box .total h1 {
  color: #111;
  font-size: 24px;
  font-weight: 700;
  line-height: 140%; /* 33.6px */
  letter-spacing: -0.6px;
}
.reser_tab_ul {
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid #d9d9d9;
  gap: 24px;
  padding-bottom: 24px;
}
.reser_tab_ul li {
  display: flex;
  gap: 40px;
  align-items: center;
}
.reser_tab_ul li.tret_two {
  align-items: start;
}
.reser_tab_ul li h2 {
  color: #111;
  font-size: 16px;
  font-weight: 400;
  line-height: 140%; /* 22.4px */
  letter-spacing: -0.4px;
}
.reser_tab_ul li h1 {
  color: #111;
  font-size: 16px;
  font-weight: 600;
  line-height: 140%; /* 22.4px */
  letter-spacing: -0.4px;
}

.reser_tab_ul .sub_ul {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.btn-go_state {
  border-radius: 8px;
  background: #505050;
  width: 120px;
  color: #fff;
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.4px;
  margin-top: 80px;
}
.reser_inform_box {
  display: flex;
  padding: 20px;
  gap: 120px;
  align-self: stretch;
  border-radius: 16px;
  background: #f7f7fb;
}
.reser_inform_box .item {
  max-width: 342px;
  width: 100%;
}
.reser_inform_box .item h1 {
  color: #176275;
  font-size: 18px;
  font-weight: 600;
  line-height: 140%; /* 25.2px */
  letter-spacing: -0.45px;
  margin-bottom: 24px;
}
.reser_inform_box .inform_txt_ul {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
}
.reser_inform_box .inform_txt_ul li {
  display: flex;
  align-items: center;
  gap: 40px;
}
.reser_inform_box .inform_txt_ul li p {
  width: 102px;
  color: #111;
  font-size: 16px;
  font-weight: 400;
  line-height: 140%; /* 22.4px */
  letter-spacing: -0.4px;
}
.reser_inform_box .inform_txt_ul li span {
  color: #111;
  font-size: 16px;
  font-weight: 600;
  line-height: 140%; /* 22.4px */
  letter-spacing: -0.4px;
}
.visa_service_tit {
  display: flex;
  padding: 20px;
  gap: 24px;
  border-radius: 16px;
  background: #f7f7fb;
  margin-bottom: 40px;
}
.visa_service_tit h1,
.visa_service_tit_B h1 {
  color: #111;
  font-size: 16px;
  font-weight: 500;
  line-height: 140%; /* 22.4px */
  letter-spacing: -0.4px;
  width: 102px;
}
.visa_service_tit h2,
.visa_service_tit_B h2 {
  color: #111;
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  line-height: 140%; /* 22.4px */
  letter-spacing: -0.4px;
}
.visa_img_upload {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 20px;
  max-width: 800px;
  width: 100%;
}
.no-look-file {
  display: none;
}
.visa_img_upload .item {
  width: 100%;
}
.visa_img_upload .item h1 {
  color: #111;
  font-size: 16px;
  font-weight: 500;
  line-height: 135%; /* 21.6px */
  letter-spacing: -0.4px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.visa_img_upload .item h1 b {
  color: #999;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: -0.35px;
}
.visa_img_upload .item .upload {
  display: flex;
  gap: 8px;
  width: 100%;
}
.visa_img_upload .item .upload > input[type="text"] {
  width: 100%;
  height: 56px;
  border-radius: 8px;
  background: rgba(241, 241, 245, 0.8);
  backdrop-filter: blur(10px);
  border: none;
}
.visa_img_upload .item .upload .btn-upload {
  height: 56px;
  line-height: 56px;
  padding: 0 24px;
  border-radius: 8px;
  border: 1px solid #247488;
  color: #247488;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.4px;
  flex-shrink: 0;
}
.visa_service_tit.spaceBetween {
  justify-content: space-between;
}
.visa_service_tit .left {
  display: flex;
  align-items: center;
  gap: 40px;
}
.visa_service_tit .right {
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.btn-template {
  border-radius: 4px;
  border: 1px solid #111;
  background: #fff;
  padding: 0 8px;
  color: #333;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.35px;
  height: 30px;
  line-height: 30px;
}
.reser_visa_box .btn-save {
  width: 120px;
  margin-top: 20px;
}
.review_write_form {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-top: 40px;
}
.review_write_form .text_box {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.review_write_form .text_box span {
  color: #111;
  font-size: 16px;
  font-weight: 500;
  line-height: 135%; /* 21.6px */
  letter-spacing: -0.4px;
}
.review_write_form .review_write_textarea {
  border-radius: 8px;
  background: rgba(241, 241, 245, 0.8);
  backdrop-filter: blur(10px);
  height: 320px;
  padding: 16px;
  gap: 10px;
  max-width: 800px;
  width: 100%;
  border: none;
}
.review_write_form .files_box {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.review_write_form .files_box .upload_file {
  display: flex;
  gap: 10px;
  align-items: center;
  height: 56px;
  line-height: 56px;
  padding: 0 16px;
  border-radius: 800px;
  background: #f4f7f9;
  backdrop-filter: blur(10px);
  color: #1f6c80;
  font-size: 16px;
  font-weight: 600;
}
.review_write_form .files_box .upload_file .x-btn {
  background: url(../_img/common/icon_green_x.svg) no-repeat center center / contain;
  width: 24px;
  height: 24px;
  display: inline-block;
}
.review_write_form .files_box .btn-upload {
  border-radius: 8px;
  border: 1px solid #1f6c80;
  background: #fff;
  backdrop-filter: blur(10px);
  display: flex;
  height: 56px;
  padding: 0 16px;
  align-items: center;
  gap: 10px;
  color: #1f6c80;
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.4px;
}
.review_write_form .btns {
  display: flex;
  gap: 8px;
  align-items: center;
}
.review_write_form .btns .btn {
  font-size: 16px;
  width: 120px;
  font-weight: 600;
}
.checkbox_group {
  /* display: flex;
  gap: 16px;
  flex-wrap: wrap; */
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
/* 약관동의1 */
.terms_item {
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.9);
  padding: 32px;
  height: 100%;
  overflow-y: auto;
}

.terms__area {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-bottom: 20px;
  border-bottom: 1px solid #f1f1f5;
  margin-bottom: 20px;
}
.terms_item .terms__area:last-of-type {
  margin-bottom: 40px;
  padding-bottom: 0;
  border-bottom: none;
}
.terms__area .tit {
  font-size: 16px;
  font-weight: 600;
  line-height: 135%;
}
.terms__area .cont {
  border-radius: 8px;
  border: 1px solid #e5e5e5;
  background: #fff;
  padding: 12px;
  min-height: 120px;
  max-height: 120px;
  overflow-y: auto;
}
.terms__area .cont::-webkit-scrollbar {
  width: 6px;
}
.terms__area .cont::-webkit-scrollbar-thumb {
  width: 6px;
  background-color: #f1f1f5;
  border-radius: 50px;
}
.terms__area .cont::-webkit-scrollbar-track {
  width: 6px;
  background-color: transparent;
  margin: 12px 0;
}
.terms__area .cont p {
  font-size: 18px;
  color: #333;
  line-height: 140%;
}
.terms__area .agree-text {
  font-size: 13px;
  font-weight: 500;
  line-height: 135%;
}
.terms__area .agree-text b {
  color: #2f81bb;
}
.terms__area .agree-text span {
  color: #f00;
}
.terms__area .checkbox-A p {
  font-size: 13px;
  color: #111;
  font-weight: 500;
}
.terms__area .checkbox-A.disabled > * {
  color: #999;
  opacity: 0.5;
}
.terms__area .checkbox-A h5 {
  font-size: 12px;
  color: #767676;
  font-weight: 500;
}
.terms__area .checkbox-A input[type="checkbox"] + em {
  width: 20px;
  height: 20px;
}
@media screen and (max-width: 768px) {
  .reservation__inner {
    background: url(../_img/common/reservation_back_mo.jpeg) no-repeat center center / cover;
    min-height: calc(100dvh - 194px - 56px);
  }
  .login_box {
    padding: 24px 20px;
  }
  .login_box .logo {
    width: 127.041px;
    height: 24px;
    margin: 0 auto 24px;
  }
  .reser_ip span {
    text-align: center;
    font-size: 14px;
  }
  .reser_ip input {
    height: 44px;
    line-height: 44px;
  }
  .login_box .btn-big {
    margin-top: 8px;
    height: 44px;
    line-height: 44px;
  }
  .reser_num {
    padding: 8px 12px;
    font-size: 14px;
    letter-spacing: -0.35px;
  }
  .reser_ul li a {
    font-size: 14px;
    letter-spacing: -0.35px;
    gap: 0;
  }
  .badge_reser {
    height: 25px;
    line-height: 25px;
    font-size: 13px;
    letter-spacing: -0.325px;
  }
  .state__inner {
    margin-left: 0;
    width: 100%;
    height: 100%;
    padding: 150px 20px 40px;
  }
  .state__inner .tit.col {
    flex-direction: column;
    align-items: start;
  }
  .state__inner .tit {
    gap: 12px;
    padding-bottom: 12px;
  }
  .state__inner .tit h1 {
    font-size: 20px;
  }
  .state__inner .radio_btns {
    justify-content: start;
    gap: 8px;
  }
  .state__inner .cont {
    /* padding-top: 20px; */
  }
  .state__inner .tbl_tit {
    margin-top: 20px;
    margin-bottom: 12px;
    font-size: 16px;
  }
  .reser_tbl thead {
    height: 40px;
  }
  .bl_badge {
    height: 30px;
    line-height: 30px;
    font-size: 14px;
  }
  .state__inner .file_ip span {
    font-size: 14px;
  }
  .state__inner .file_ip span b {
    font-size: 12px;
  }
  .state__inner .file_ip .ip_box input {
    height: 44px;
    line-height: 44px;
  }
  .state__inner .file_ip .file_label .file_btn {
    height: 44px;
    line-height: 44px;
    padding: 0 12px;
    font-size: 14px;
  }
  .reser_visa {
    gap: 20px;
  }
  .state__inner .btn-save {
    margin: 0 auto;
    width: 100%;
    height: 44px;
    line-height: 44px;
  }
  .reser_search {
    flex-direction: column;
    gap: 8px;
    margin-top: 20px;
  }
  .reser_search .reser-select {
    height: 44px;
    width: 100%;
  }
  .reser_search .btn-big {
    height: 44px;
    line-height: 44px;
    width: 60px;
  }
  .reser_search .reser-input {
    height: 44px;
    line-height: 44px;
  }
  .reser_tbl_pagination {
    gap: 16px;
  }
  .reser_inform,
  .reser_inform li {
    gap: 20px;
  }
  .reser_inform li span,
  .reser_inform li h5 {
    font-size: 13px;
  }
  .state__inner .title_B {
    margin-top: 20px;
    margin-bottom: 10px;
    font-size: 16px;
  }
  .reser_tab .tabnav li a p {
    font-size: 13px;
    line-height: 140%; /* 18.2px */
  }
  .reser_tab_ul {
    gap: 10px;
    padding-bottom: 20px;
  }
  .reser_tab_ul li h2 {
    width: 80px;
    font-size: 13px;
  }
  .reser_tab_ul li {
    gap: 0;
  }
  .reser_tab_ul li h1.w200 {
    width: 97px;
    font-size: 12px;
    text-align: left;
  }
  .reser_tab_ul li h1 {
    font-size: 13px;
    width: 100px;
    text-align: center;
  }
  .reser_gray_box {
    gap: 20px;
  }
  .reser_gray_box .total h1:first-child {
    font-size: 13px;
  }
  .reser_gray_box .total h1 {
    font-size: 15px;
  }
  .btn-go_state {
    margin-top: 20px;
    width: 100%;
    height: 44px;
    line-height: 44px;
  }
  .reservation_list {
    padding: 150px 20px 64px;
  }
  .reser_inform_box {
    flex-wrap: wrap;
    gap: 24px;
  }
  .reser_inform_box .item h1 {
    margin-bottom: 10px;
    font-size: 16px;
  }
  .reser_inform_box .inform_txt_ul {
    gap: 10px;
  }
  .reser_inform_box .inform_txt_ul li p,
  .reser_inform_box .inform_txt_ul li span,
  .visa_img_upload .item h1 {
    font-size: 14px;
  }
  .visa_service_tit {
    justify-content: space-between;
    margin-bottom: 20px;
    padding: 12px 20px;
  }
  .visa_service_tit h2,
  .visa_service_tit h1 {
    font-size: 14px;
  }
  .visa_img_upload .item h1 {
    flex-direction: column;
    gap: 2px;
    align-items: start;
  }
  .visa_img_upload .item h1 b {
    font-size: 13px;
  }
  .visa_img_upload .item .upload > input[type="text"] {
    height: 44px;
    font-size: 14px;
  }
  .visa_img_upload .item .upload .btn-upload {
    height: 44px;
    line-height: 44px;
    padding: 0 16px;
  }
  .visa_service_tit.spaceBetween {
    flex-direction: column;
    gap: 20px;
  }
  .btn-template {
    height: 44px;
    line-height: 44px;
    width: 100%;
  }
  .state__inner .btn-save {
    margin-top: 20px;
    width: 100px;
    font-size: 14px;
  }
  .state__inner .tbl_wrap.mt40 {
    margin-top: 20px;
  }
  .review_write_form {
    margin-top: 20px;
  }
  .review_write_form .review_write_textarea {
    height: 200px;
  }
  .review_write_form .files_box .btn-upload {
    height: 44px;
    line-height: 44px;
  }

  .review_write_form .files_box .upload_file {
    height: 36px;
    line-height: 36px;
    gap: 4px;
    padding: 0 12px;
  }
  .review_write_form .btns .btn {
    height: 44px;
    line-height: 44px;
    width: 100%;
  }
  .checkbox_group {
    gap: 12px;
  }
  .terms_item {
    padding: 20px 12px;
    max-height: 100%;
  }
  .terms__area .cont {
    min-height: 200px;
    max-height: 200px;
  }
  .terms__area {
    margin-bottom: 12px;
    padding-bottom: 12px;
  }
  .terms_item .terms__area:last-of-type {
    margin-bottom: 12px;
  }
  .terms_item .btn-big {
    height: 44px;
    line-height: 44px;
    font-size: 16px;
  }
  .terms__area .cont p {
    font-size: 14px;
  }
}

@media screen and (max-width: 768px) {
  .mail_form {
    padding: 40px 20px 64px 20px;
    max-width: 100%;
  }
}
