.concierge {
  width: 100%;
  padding: 150px 0;
}
.concierge_title {
  font-size: 32px;
  font-weight: 500;
  letter-spacing: -1.2px;
  color: #333;
  padding-bottom: 30px;
  border-bottom: 2px solid #333;
}
.concierge_contents {
  margin: 30px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-bottom: 30px;
}
.contents_title {
  margin-bottom: 30px;
}
.contents_img {
  width: 100%;
}
.concierge_contents_bottom {
  width: 100%;

  margin: 0 auto;
  padding: 30px;
  border-top: 1px solid rgba(51, 51, 51, 0.089);
  border-bottom: 1px solid rgba(51, 51, 51, 0.089);
}
form {
  max-width: 800px;
  width: 100%;
  padding: 50px 0;
  margin: 0 auto;
}
.form_row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 15px;
}
.form_label {
  flex: 1;
}
.form_item {
  flex: 3;
  position: relative;
}
.form_label p {
  font-size: 16px;
  font-weight: 400;
  letter-spacing: -0.7px;
  color: #333;
  text-align: left;
  position: relative;
}
input[type="text"] {
  width: 100%;
  height: 48px;
  border: 1px solid #c1c1c1;
  background-color: #fff;
  padding: 0 41px 0 14px;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: -0.2px;
  color: #333;
  position: relative;
}
input[type="text"]:focus {
  outline: 0;
}
.form_item_1 {
  display: flex;
  align-items: center;
  gap: 10px;
}
.form_flex {
  display: flex;
  gap: 15px;
}
.form_felxwrap {
  flex-wrap: wrap;
}
.nub_search {
  width: 150px;
  border: 1px solid #fff;
  outline: #333;
  display: inline-block;
  height: 48px;
  outline: #333 solid 1px;
}
.form_column {
  flex-direction: column;
}
.form_row {
  flex-direction: row;
}
#phoneSelect {
  width: 100px;
  height: 48px;
  padding: 0 40px 0 14px;
}
#phoneSelect option {
  border-top: 0;
  height: 46px;
}
.form_phone {
  display: flex;
  flex: 3;
  align-items: center;
  gap: 15px;
}
.form_interest {
  display: flex;
  gap: 15px;
  flex-wrap: wrap;
  margin-bottom: 15px;
}

.form_interest li {
  display: flex;
  flex-grow: 1;
  flex-basis: 30%;

  align-items: center;
  position: relative;
}
.form_interest li input {
  opacity: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
  top: 0;
  left: 0;
  position: absolute;
}
.form_interest li label {
  margin-right: 10px;
  width: 15px;
  height: 15px;
  position: relative;
  border: 1px solid #333;
}
.form_interest li input:checked ~ label:after {
  width: 5px;
  left: 2px;
  top: 6px;
  background-color: #fff;
  content: "";
  height: 2px;
  position: absolute;

  transform: rotate(45deg);
}
.form_interest li input:checked ~ label::before {
  width: 8px;
  left: 5px;
  top: 5px;
  background-color: #fff;
  content: "";
  height: 2px;
  position: absolute;

  transform: rotate(-45deg);
}
.form_interest li span {
  font-size: 14px;
}
.form_interest li input:checked ~ label {
  background-color: #333;
}
.form_live {
  display: flex;
  align-items: center;
  gap: 20px;
}
.form_live li {
  position: relative;
  display: flex;
  align-items: center;
}

.form_live input {
  width: 100%;
  position: absolute;
  height: 100%;
  top: 0;
  left: 0;
  opacity: 0;
}

.form_live label {
  width: 15px;
  height: 15px;
  margin-right: 10px;
  border-radius: 15px;
  border: 1px solid #333;
  position: relative;
}
.form_live input:checked ~ label {
  background-color: #333;
}
.form_live input:checked ~ label:after {
  width: 40%;
  height: 40%;
  border-radius: 50px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  content: "";

  position: absolute;
}
.form_money_btn span {
  font-size: 15px;
}
.form_money_text {
  font-size: 15px;
  margin-bottom: 15px;
  color: rgba(51, 51, 51, 0.808);
  margin-bottom: 15px;
}
input[type="range"] {
  width: 100%;
  -webkit-appearance: none;
}

input[type="range"]:focus {
  outline: none;
}

input[type="range"]::-webkit-slider-runnable-track {
  width: 100%;
  height: 5px;
  background-color: rgb(235, 235, 235);
  cursor: pointer;
}

input[type="range"]::-webkit-slider-thumb {
  border: 5px solid #fff;
  box-shadow: 0 0 1px 1px rgba(0, 0, 0, 0.1);
  height: 20px;
  width: 20px;
  border-radius: 30px;
  background: #000;
  cursor: pointer;
  -webkit-appearance: none;
  margin-top: -8px;
}
.range_text {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px;
}
.range_text span {
  text-align: center;
  font-size: 16px;
}
.form_money_price {
  color: #333;
  font-weight: 500;
}
.form_money_btn {
  width: auto;
  margin-bottom: 15px;
  position: relative;
  display: flex;
  align-items: center;
}
.form_money_btn input {
  position: absolute;
  width: 100%;
  opacity: 0;
  height: 100%;
  top: 0;
  left: 0;
}
.form_money_btn label {
  width: 15px;
  height: 15px;
  margin-right: 10px;
  border: 1px solid #333;
  position: relative;
}
#money:checked ~ label {
  background-color: #333;
}
.form_money_btn input:checked ~ label:after {
  width: 5px;
  left: 2px;
  top: 6px;
  background-color: #fff;
  content: "";
  height: 2px;
  position: absolute;

  transform: rotate(45deg);
}
.form_money_btn input:checked ~ label::before {
  width: 8px;
  left: 5px;
  top: 5px;
  background-color: #fff;
  content: "";
  height: 2px;
  position: absolute;

  transform: rotate(-45deg);
}

.form_item select {
  width: 100%;
  height: 48px;
  padding: 0 15px;
}

.conditions {
  width: 100%;
  margin-top: 50px;
}
.form_agree {
  display: flex;
  position: relative;
  justify-content: flex-start;
  align-items: center;
}
.form_agree input {
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.form_agree label {
  width: 15px;
  height: 15px;
  margin-right: 10px;
  position: relative;
  border: 1px solid #333;
}
.form_agree span {
  font-size: 14px;
}
.form_agree input:checked ~ label {
  background-color: #333;
}
.form_agree input:checked ~ label:after {
  width: 5px;
  left: 2px;
  top: 6px;
  background-color: #fff;
  content: "";
  height: 2px;
  position: absolute;

  transform: rotate(45deg);
}
.form_agree input:checked ~ label::before {
  width: 8px;
  left: 5px;
  top: 5px;
  background-color: #fff;
  content: "";
  height: 2px;
  position: absolute;

  transform: rotate(-45deg);
}
.conditions_wrap {
  background-color: #fafafa;
  margin-top: 30px;
}
.conditions_wrap {
  height: 150px;
  overflow-y: scroll;
}
.complete_btn_wrap {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.complete_btn {
  width: 130px;
  height: 50px;
  background-color: #333;
}
.complete_btn span {
  color: #fff;
  font-size: 18px;
  font-weight: 700;
}
.readonly {
  background-color: rgba(51, 51, 51, 0.068) !important;
}

.essential {
  position: relative;
  display: inline-block;
}
.essential:after {
  width: 4px;
  height: 4px;
  background-color: red;
  border-radius: 5px;
  position: absolute;
  top: 3px;
  right: -8px;
  content: "";
}
.address_p::before {
  content: "(공사 예정 주소)";
  font-size: 14px;
  color: #333;
  position: absolute;
  top: 50%;
  width: 200%;
  right: 0;
  word-break: keep-all;
  transform: translate(110%, -50%);
}
.form_schedule {
  width: 100%;
  position: relative;
}
#date_schedule {
  opacity: 0;
  width: 30px;

  height: 30px;
  cursor: pointer;
}
.form_schedule label {
  position: absolute;
  width: 30px;
  height: 30px;
  background: url(../img/icons/icon-input-date.png) no-repeat center/contain;
  cursor: pointer;
}
.date_btn {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translate(0, -50%);
  z-index: 1;
  cursor: pointer;
}
