::-webkit-scrollbar {
  width: 12px;
}
::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 10px;
}
::-webkit-scrollbar-thumb {
  background: #888;
  border-radius: 10px;
}
::-webkit-scrollbar-thumb:hover {
  background: #555;
}
.title-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0.5rem 4rem;
}

.title-group .title-group-box h2 {
  margin: 0;
  font-size: 20px;
  font-weight: bold;
}
.title-group-box {
  display: flex;
}
.title-group-box .ic-saved-draft {
  font-size: 12px;
  padding: 1rem;
  font-weight: 600;
  line-height: 2.5rem;
}
.title-group-box .ic-saved-draft i {
  font-size: 14px;
}
.title-group p {
  margin: 4px 0 0;
  color: #333;
  font-weight: 600;
}

.action-buttons {
  display: flex;
  gap: 12px;
}

.btn-preview,
.btn-next,
.btn-exit {
  padding: 8px 16px;
  border-radius: 24px;
  font-weight: 500;
  border: none;
  cursor: pointer;
}

.btn-preview {
  border: 1px solid #ccc;
  background-color: #f9f9f9;
  color: #333;
}

.btn-next {
  background-color: #d60000;
  color: white;
}

.btn-exit {
  border: 1px solid black;
  background-color: white;
  color: black;
}

.progress-bar-step-upload {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  margin: 16px 4rem;
}

.progress-segment {
  flex: 1;
  height: 4px;
  background-color: #f0f0f5;
  border-radius: 2px;
  overflow: hidden;
}

.fill {
  width: 0%;
  height: 100%;
  background: #f35704;
  background-size: 300% 100%;
  transition: width 0.5s ease;
}

.icon-CaretDown-demand,
.icon-CaretDown-address,
.icon-CaretDown-info,
.icon-CaretDown-select,
.icon-CaretDown-contact,
.icon-CaretDown-title,
.icon-CaretDown-guide {
  transition: transform 0.3s ease;
}

.icon-CaretDown-demand.active,
.icon-CaretDown-address.active,
.icon-CaretDown-info.active,
.icon-CaretDown-select.active,
.icon-CaretDown-contact.active,
.icon-CaretDown-title.active {
  transform: rotate(180deg);
}
.icon-CaretDown-guide.active {
  transform: rotate(270deg);
}
.icon-CaretDown-select,
.icon-CaretDown-info {
  transform: rotate(0deg);
}

.icon-CaretDown-demand:before,
.icon-CaretDown-address:before,
.icon-CaretDown-info:before,
.icon-CaretDown-select::before,
.icon-CaretDown-contact::before,
.icon-CaretDown-title::before,
.icon-CaretDown-guide::before {
  content: "\e901";
}
.box-demand {
  width: 77rem;
  border: 1px solid #eff1f5;
  border-radius: 10px;
  margin: 2rem auto;
  padding: 0 1rem;
}
.box-notify-quantity-image {
  display: block;
  background-color: #c1c9d2;
  width: 77rem;
  border: 1px solid #eff1f5;
  border-radius: 10px;
  padding: 0 1rem;
  margin: 1rem auto;
}
.box-notify-warning-quantity-image {
  display: none;
  background-color: #fff0f0;
  width: 77rem;
  border: 1px solid #fff0f0;
  border-radius: 10px;
  padding: 0 1rem;
  margin: 1rem auto;
  color: #c20000;
}
.box-address-demand,
.box-info-demand,
.box-other-info-demand,
.box-info-contact,
.box-info-title,
.box-footer {
  display: none;
}
.box-address-demand.active,
.box-info-demand.active,
.box-other-info-demand.active,
.box-info-contact.active,
.box-info-title.active {
  display: block;
  width: 77rem;
  border: 1px solid #eff1f5;
  border-radius: 10px;
  padding: 0 1rem;
  margin: 1rem auto;
}
.box-footer.active {
  display: block;
  width: 79rem;
  height: 8rem;
}
.button-action-footer {
  border-top: 1px solid #eff1f5;
  padding: 0 1rem;
  display: flex;
  justify-content: space-between;
}
.box-demand .name-demand {
  display: flex;
  line-height: 20px;
  align-items: center;
  gap: 6px;
  color: var(--Heading);
  font-weight: 600;
  justify-content: space-between;
  cursor: pointer;
}
.box-demand p,
.box-demand .name-demand p,
.box-address-demand p,
.box-address-demand.active .info-demand p,
.box-info-demand p,
.box-info-demand.active .info-demand p,
.box-other-info-demand p,
.box-other-info-demand.active .other-info-demand p,
.box-info-contact p,
.box-info-contact.active .info-contact p,
.box-info-title p,
.box-info-title.active .info-title p {
  padding: 1rem 0rem;
  margin-bottom: 0;
}
.box-address-demand.active .address-demand,
.box-info-demand.active .info-demand,
.box-other-info-demand.active .other-info-demand,
.box-info-contact.active .info-contact,
.box-info-title.active .info-title {
  display: flex;
  font-size: 16px;
  line-height: 20px;
  align-items: center;
  gap: 6px;
  font-weight: 600;
  justify-content: space-between;
  cursor: pointer;
}
.box-other-info-demand.active .other-info-demand span {
  font-size: 12px;
  font-weight: 400;
}
.box-demand .name-demand i {
  font-size: 20px;
  font-family: "icomoon" !important;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
}

.box-demand.active .menu-demand {
  width: 100%;
  display: flex;
  justify-content: space-around;
}
.menu-demand {
  gap: 10px;
}

.notify-demand.active,
.notify-address.active,
.notify-info.active,
.notify-contact.active,
.notify-title.active {
  display: block;
  text-decoration: underline;
  cursor: pointer;
}

.menu-demand,
.notify-demand,
.notify-address,
.notify-info,
.notify-other-info,
.notify-contact,
.notify-title,
.input-address-demand,
#other-info-notify {
  display: none;
}
.notify-other-info.active {
  display: block;
  cursor: pointer;
}
.notify-other-info.active #add-info,
#other-info-notify {
  text-decoration: underline;
}

.demand-box {
  text-align: center;
  padding: 1.2rem 3rem;
  width: 23.5rem;
  border-radius: 10px;
  border: 1px solid #c1c9d2;
  margin-bottom: 1rem;
  cursor: pointer;
}
.box-address-demand.active .input-address-demand.active {
  border: 1px solid rgba(0, 0, 0, 0.169);
  padding: 0.8rem 1.5rem;
  border-radius: 20px;
  margin: 0 7rem 1rem 7rem;
}
.input-address-demand.active {
  display: block;
  cursor: pointer;
}
.input-address-select,
.input-info-select {
  width: 100%;
  position: relative;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: -0.4px;
  color: #3e4246;
  font-size: 14px;
  border: 1px solid rgba(0, 0, 0, 0.169);
  background-color: transparent;
  padding: 0.5rem 1rem;
  border-radius: 20px;
  margin-bottom: 1rem;
  display: block;
  cursor: pointer;
}
.input-address-select::placeholder,
.input-info-select::placeholder {
  color: #5c5e61;
}

.input-search-address,
.input-search-info {
  position: sticky;
  top: 0;
  width: 100%;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -0.4px;
  color: #3e4246;
  font-size: 1.2rem;
  border: 1px solid rgba(0, 0, 0, 0.169);
  background-color: transparent;
  padding: 0.7rem 3rem;
  border-radius: 20px;
  margin-bottom: 1rem;
  background-color: #fff;
}
.demand-sell:hover,
.demand-rent:hover {
  background-color: rgba(0, 0, 0, 0.071);
}

.demand-sell.active,
.demand-rent.active {
  border: 2px solid #282c2e;
}

.modalAddress {
  border-radius: 1rem !important;
  top: 0rem;
  box-shadow: 0 4px 8px 0 rgba(40, 44, 46, 0.122);
  width: 64.5rem !important;
  min-height: 38rem !important;
  height: auto;
  max-height: 78rem !important;
  left: -7rem;
}
.modalLegal,
.modalInterior,
.modalNearPlace,
.modalPhoneNumber,
.modalGenerated {
  border-radius: 1rem !important;
  top: 15rem;
  box-shadow: 0 4px 8px 0 rgba(40, 44, 46, 0.122);
}
.modalImage {
  width: 64rem;
  border-radius: 1rem !important;
  top: 5rem;
  box-shadow: 0 4px 8px 0 rgba(40, 44, 46, 0.122);
  left: -10rem;
}
.modalDiscount {
  border-radius: 1rem !important;
  top: 15rem;
  left: -6rem;
  width: 60rem;
  box-shadow: 0 4px 8px 0 rgba(40, 44, 46, 0.122);
}
.modalDefine,
.modalComparePrices {
  border-radius: 1rem !important;
  top: 5rem;
  left: -16rem;
  height: 64rem;
  width: 83rem;
  box-shadow: 0 4px 8px 0 rgba(40, 44, 46, 0.122);
}
.modalAddress .modal-header,
.modalLegal .modal-header,
.modalInterior .modal-header,
.modalNearPlace .modal-header,
.modalPhoneNumber .modal-header,
.modalGenerated .modal-header,
.modalImage .modal-header,
.modalDiscount .modal-header,
.modalDefine .modal-header,
.modalComparePrices .modal-header {
  background-color: #1c1f22;
  border-top-left-radius: 1rem;
  border-top-right-radius: 1rem;
}
.modalAddress .modal-header .modal-title,
.modalAddress .modal-header button span,
.modalLegal .modal-header .modal-title,
.modalLegal .modal-header button span,
.modalInterior .modal-header .modal-title,
.modalInterior .modal-header button span,
.modalNearPlace .modal-header .modal-title,
.modalNearPlace .modal-header button span,
.modalPhoneNumber .modal-header .modal-title,
.modalPhoneNumber .modal-header button span,
.modalGenerated .modal-header .modal-title,
.modalGenerated .modal-header button span,
.modalImage .modal-header .modal-title,
.modalImage .modal-header button span,
.modalDiscount .modal-header .modal-title,
.modalDiscount .modal-header button span,
.modalDefine .modal-header .modal-title,
.modalDefine .modal-header button span,
.modalComparePrices .modal-header .modal-title,
.modalComparePrices .modal-header button span {
  color: #fff;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: -0.4px;
  font-size: 2rem;
  margin-bottom: 0;
  display: flex;
  flex-grow: 1;
  padding: 1rem;
}
.modalAddress .modal-header button,
.modalLegal .modal-header button,
.modalInterior .modal-header button,
.modalNearPlace .modal-header button,
.modalPhoneNumber .modal-header button,
.modalGenerated .modal-header button,
.modalImage .modal-header button,
.modalDiscount .modal-header button,
.modalDefine .modal-header button,
.modalComparePrices .modal-header button {
  opacity: 1;
}
.box-input-modal-address-demand {
  width: 100%;
}
.modal-input-address-demand {
  position: relative;
  width: 100%;
  border: 1px solid rgba(0, 0, 0, 0.169);
  padding: 0.8rem 3rem;
  border-radius: 20px;
  margin-bottom: 1rem;
  cursor: pointer;
}
.box-input-modal-address-demand .find-address-demand {
  position: absolute;
  top: 1.15rem;
  left: 1rem;
  font-weight: 600;
}
.box-input-modal-address-demand .close-address-demand {
  position: absolute;
  top: 1.15rem;
  right: 2rem;
  font-weight: 600;
  cursor: pointer;
  visibility: hidden;
}

.modalAddress .modal-body,
.modalLegal .modal-body,
.modalInterior .modal-body,
.modalNearPlace .modal-body,
.modalPhoneNumber .modal-body,
.modalGenerated .modal-body,
.modalImage .modal-body,
.modalDiscount .modal-body,
.modalDefine .modal-body,
.modalComparePrices .modal-body {
  overflow: auto;
}
.modalAddress .modal-body p {
  font-size: 14px;
  margin-bottom: 1rem;
}
.btn-choose-address-modal {
  position: relative;
  overflow: hidden;
  z-index: 1;
  border: 1px solid #c1c9d2;
  color: #333;
  box-shadow: 0 2px 4px rgba(40, 44, 46, 0.122), inset 0 2px 2px hsla(0, 0%, 100%, 0.4);
  border-radius: 100px;
  padding: 12px 16px;
  background-color: #fff;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out;
}

.btn-choose-address-modal::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.1);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease-in-out;
  z-index: -1;
  border-radius: inherit;
}

.btn-choose-address-modal:hover::before {
  transform: scaleX(1);
}

.modal-body-address {
  position: relative;
}
.modal-body-address .suggestions {
  background-color: white;
  z-index: 1000;
  width: 100%;
  max-height: 270px;
  overflow-y: auto;
  display: none;
}

.modal-body-address .suggestions div {
  padding: 10px;
  cursor: pointer;
}

.modal-body-address .suggestions div:hover {
  background-color: #f0f0f0;
}
.modal-body-select-address {
  display: none;
}
.select-wrapper-address-select,
.select-wrapper-info-select {
  position: relative;
  width: 100%;
  pointer-events: "auto";
  cursor: "pointer";
}
.select-wrapper-address-select.disabled {
  cursor: default;
  pointer-events: none;
}
.select-wrapper-address-select.disabled input {
  border-color: #c1c9d2;
  background-color: #eff1f5;
  border-radius: 20px;
}
.select-wrapper-address-select:hover,
.select-wrapper-info-select:hover {
  background-color: rgba(0, 0, 0, 0.169);
  border-radius: 20px;
}
.icon-CaretDown-select {
  position: absolute;
  top: 0.9rem;
  right: 1rem;
  font-weight: 600;
  cursor: pointer;
}
.span-meter {
  position: absolute;
  top: 0.7rem;
  right: 0.5rem;
  font-weight: 600;
  cursor: pointer;
}
.suggestions-address,
.suggestions-info {
  position: absolute;
  display: none;
  padding: 0.5rem 1rem;
  height: auto;
  overflow: auto;
  z-index: 30;
  background: #fff;
  width: 100%;
  border: 1px solid rgba(0, 0, 0, 0.175);
  border-radius: 20px;
  box-sizing: border-box;
  transition: 0.3s ease;
}
.suggestions-datetime {
  position: absolute;
  display: none;
  padding: 0.5rem 1rem;
  height: auto;
  overflow: auto;
  z-index: 30;
  background: #fff;
  width: 100%;
  border: 1px solid rgba(0, 0, 0, 0.175);
  border-radius: 20px;
  box-sizing: border-box;
  transition: 0.3s ease;
  bottom: 3rem;
  top: auto;
  transform-origin: bottom center;
}
.suggestions-address i,
.suggestions-info i,
.suggestions-datetime i {
  position: absolute;
  top: 1rem;
  left: 1.5rem;
  font-weight: 600;
}
.suggestions-address .suggestion-item,
.suggestions-info .suggestion-item,
.suggestions-datetime .suggestion-item {
  padding: 0.5rem 1rem;
  font-weight: 600;
  cursor: pointer;
}
.suggestions-address .suggestion-item.active,
.suggestions-info .suggestion-item.active,
.suggestions-datetime .suggestion-item.active {
  background-color: #88888847;
}

.suggestions-info .suggestion-item:hover,
.suggestions-datetime .suggestion-item:hover,
.suggestions-address .suggestion-item:hover {
  background-color: #f0f0f0;
}
.input-search-address:hover,
.input-search-info:hover {
  background-color: rgba(0, 0, 0, 0.169);
}
.box-suggestions-address,
.box-suggestions-info,
.box-suggestions-datetime {
  position: relative;
}
.box-input-search-address,
.box-input-search-info {
  position: sticky;
  width: 100%;
  top: 0;
  background-color: #fff;
}
.cancel-select-address,
.cancel-select-info,
.cancel-select-legal-papers,
.cancel-select-interior,
.cancel-select-house-direction,
.cancel-select-balcony-direction,
.cancel-select-phone {
  display: none;
}
.cancel-select-address.active,
.cancel-select-info.active,
.cancel-select-legal-papers.active,
.cancel-select-interior.active,
.cancel-select-house-direction.active,
.cancel-select-balcony-direction.active,
.cancel-select-phone.active {
  position: sticky;
  display: flex;
  flex-direction: row-reverse;
  bottom: -8px;
  background: #fff;
  z-index: 20;
  padding: 0.5rem;
}
#cancel-select-info-time-post-news {
  top: 15rem;
}
.cancel-select-address.active .btn-cancel-select-address,
.cancel-select-info.active .btn-cancel-select-info,
.cancel-select-legal-papers.active .btn-cancel-select-legal-papers,
.cancel-select-interior.active .btn-cancel-select-interior,
.cancel-select-house-direction.active .btn-cancel-select-house-direction,
.cancel-select-balcony-direction.active .btn-cancel-select-balcony-direction,
.cancel-select-phone.active .btn-cancel-select-phone {
  border: 1px solid #3e4143;
  border-radius: 20px;
  color: #0d1011;
  padding: 0.5rem 1rem;
  box-shadow: 0 2px 4px rgba(40, 44, 46, 0.078);
  cursor: pointer;
}
.no-result-message-address {
  padding: 6rem;
  color: red;
  font-size: 1.5rem;
  text-align: center;
  font-weight: 600;
}
.modalAddress .modal-footer {
  display: none;
}
.modalAddress .modal-footer.active.box-confirm-address-demand {
  display: flex;
  width: 100%;
  justify-content: space-between;
}
.modalAddress .modal-footer.active.box-confirm-address-demand .cancel-address {
  text-decoration: underline;
  border: none;
  background: #fff;
  cursor: pointer;
}
.modalAddress .modal-footer.active.box-confirm-address-demand .confirm-address,
.modalLegal .modal-footer .save-legal,
.modalInterior .modal-footer .save-interior,
.modalNearPlace .modal-footer .save-place,
.modalPhoneNumber .modal-footer .save-phone-number,
.modalPhoneNumber .modal-footer .verify-phone-number,
.modalDiscount .modal-footer .apply-discount,
.modalGenerated .modal-footer .use-generated,
.modalDefine .modal-footer .understand {
  padding: 1rem;
  border-radius: 20px;
  font-weight: 600;
  font-size: 1.5rem;
  background-color: #f35704;
  color: #fff;
  border-color: #d64b00;
  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
}
.modalLegal .modal-footer .save-legal:hover,
.modalInterior .modal-footer .save-interior:hover,
.modalNearPlace .modal-footer .save-place:hover,
.modalPhoneNumber .modal-footer .save-phone-number:hover,
.modalPhoneNumber .modal-footer .verify-phone-number:hover,
.modalDiscount .modal-footer .apply-discount:hover,
.modalDefine .modal-footer .understandt:hover,
.modalGenerated .modal-footer .use-generated:hover {
  background: #ff752b;
}
.modalLegal .modal-footer .cancel-legal,
.modalInterior .modal-footer .cancel-interior,
.modalNearPlace .modal-footer .cancel-place,
.modalDiscount .modal-footer .cancel-discount,
.modalPhoneNumber .modal-footer .cancel-phone-number,
.modalGenerated .modal-footer .cancel-phone-number {
  padding: 1rem;
  border-radius: 20px;
  font-weight: 600;
  font-size: 1.5rem;
  background-color: #fff;
  color: #333;
  border-color: #333;
  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
}
.modalLegal .modal-footer .cancel-legal:hover,
.modalInterior .modal-footer .cancel-interior:hover,
.modalNearPlace .modal-footer .cancel-place:hover,
.modalDiscount .modal-footer .cancel-discount:hover,
.modalPhoneNumber .modal-footer .cancel-phone-number:hover,
.modalGenerated .modal-footer .cancel-phone-number:hover {
  background-color: rgba(0, 0, 0, 0.169);
}
.modalAddress .modal-footer.active.box-confirm-address-demand .confirm-address:hover,
.modalPhoneNumber .modal-footer .save-phone-number:hover,
.modalPhoneNumber .modal-footer .verify-phone-number:hover {
  color: #fff;
  background-color: #ff752b;
}
.modalAddress .modal-footer.active.box-confirm-address-demand .confirm-address.disabled,
.modalPhoneNumber .modal-footer .save-phone-number.disabled,
.modalPhoneNumber .modal-footer .verify-phone-number.disabled {
  cursor: default;
  pointer-events: none;
  background-color: #eff1f5;
  padding: 1rem;
  border-radius: 20px;
  font-weight: 600;
  color: #737d87;
  border: none;
  box-shadow: none;
}
.body-select-address-inmap {
  display: none;
}
.body-select-address-inmap.active {
  display: block;
}
.choose-address-in-map p {
  margin-bottom: 0.5rem;
}
.pull-map-to-ping-address {
  display: none;
}
.pull-map-to-ping-address.active {
  display: flex;
  justify-content: space-between;
}
.pull-map-to-ping-address.active .reset-ping-address {
  text-decoration: underline;
  cursor: pointer;
}
.box-success-choose-address {
  display: none;
}
.box-success-choose-address.active {
  display: flex;
  justify-content: space-between;
}
.box-success-choose-address.active p {
  cursor: pointer;
}
.box-success-choose-address.active i {
  display: none;
}
.box-success-choose-address.active i.active {
  display: flex;
  height: 3rem;
  width: 3rem;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  box-shadow: 0 2px 4px rgba(40, 44, 46, 0.122), inset 0 2px 2px hsla(0, 0%, 100%);
  cursor: pointer;
  border: #3e4143;
  border-radius: 20%;
  transform: translate(5px, -10px);
}
.box-success-choose-address.active i.active:hover {
  background-color: rgba(0, 0, 0, 0.071);
}
.span-meter {
  font-size: 11px;
  border: none;
  top: 0.25rem;
  background-color: #eff1f5;
  padding: 4px 8px;
  border-radius: 20%;
  transition: border-color 0.15s ease-in-out;
}
.input-info-input,
.select-info-unit {
  width: 100%;
  position: relative;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: -0.4px;
  color: #3e4246;
  font-size: 1.5rem;
  border: 1px solid rgba(0, 0, 0, 0.169);
  background-color: transparent;
  padding: 0.5rem 1rem;
  border-radius: 20px;
  margin-bottom: 1rem;
  display: block;
}
.title-body-select-info p {
  padding: 0.5rem;
}
.body-select-info-price-unit {
  display: flex;
  gap: 10px;
}
.body-select-info-price-unit .box-info-price {
  width: 70%;
}
.body-select-info-price-unit .box-info-unit {
  width: 30%;
}
.select-info-unit {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
.body-select-info-type,
.body-select-other-info-type,
.box-info-unit {
  width: 100%;
  box-sizing: border-box;
  position: relative;
}
#body-select-type {
  width: 70%;
}
.body-select-info-type .suggestions-info {
  width: 100%;
}
#suggestions-info-type {
  max-height: 17rem;
  height: auto;
}
.item-type-bds {
  display: flex;
  justify-content: space-between;
}
.badge-status-type-bds {
  background-color: #fff0f0;
  border-color: #c20000;
  color: #940000;
  font-weight: 600;
  font-size: 0.875rem;
  border-radius: 8px;
  line-height: 0;
  border: 1px solid;
  align-items: center;
  padding: 0.75rem;
}
.box-suggestions-info {
  height: auto;
  overflow: auto;
}

.cancel-select-info.active .btn-cancel-select-info:hover {
  background-color: #fff0f0;
  border-color: #c20000;
  color: #940000;
}
.body-select-info-price-unit .box-info-unit .suggestions-info {
  height: auto;
  overflow: hidden;
  padding: 0;
  bottom: 5rem;
}
.price-suggestion-info-price {
  margin: 4px;
  padding: 6px 12px;
  border: 1px solid #ccc;
  background: #f9f9f9;
  border-radius: 20px;
  cursor: pointer;
  font-size: 13px;
}
.price-suggestion-info-price:hover {
  background: #e0e0ff;
}
.label-total-price-suggestiong-price {
  font-size: 12px;
}
.value-suggestiong-price {
  font-size: 12px;
  font-weight: 600;
}
.price-result-info-price {
  padding: 0.5rem !important;
}
.item-unit-bds {
  font-size: 14px;
}
.input-info-price-detail.disabled {
  cursor: default;
  pointer-events: none;
  background-color: #eff1f5;
  padding: 0.5rem 1rem;
  border-radius: 20px;
  font-weight: 600;
  color: #737d87;
  border: none;
  box-shadow: none;
}
.error-notify-detail {
  color: red;
  display: none;
  padding: 0rem 0.5rem;
  font-size: 14px;
  font-weight: 600;
  transform: translateY(-10px);
}
@keyframes shake {
  0% {
    transform: translateY(-10px) translateX(0);
  }
  20% {
    transform: translateY(-10px) translateX(-4px);
  }
  40% {
    transform: translateY(-10px) translateX(4px);
  }
  60% {
    transform: translateY(-10px) translateX(-4px);
  }
  80% {
    transform: translateY(-10px) translateX(4px);
  }
  100% {
    transform: translateY(-10px) translateX(0);
  }
}
.error-notify-detail.show {
  display: block;
  animation: shake 0.4s ease;
}
.box-select-info-demand,
.box-select-other-info-demand {
  display: none;
}
.box-select-info-demand.active,
.box-select-other-info-demand.active {
  display: block;
  margin-bottom: 1rem;
}
#suggestions-legal-papers,
#suggestions-status-interior,
#suggestions-house-direction,
#suggestions-balcony-direction,
#suggestions-info-phone,
#suggestions-time-post-news {
  height: auto;
  padding: 0px;
}
#box-suggestions-legal-papers,
#box-suggestions-status-interior,
#box-suggestions-house-direction,
#box-suggestions-balcony-direction,
#box-suggestions-info-phone,
#box-suggestions-time-post-news {
  height: auto;
}
#legal-add,
#interior-add {
  text-decoration: underline;
}
.item-legal-papers {
  display: flex;
  justify-content: space-between;
}
.edit-item-legal-papers i {
  position: static;
  margin-top: 0.2rem;
  display: none;
}
.item-legal-papers.active .edit-item-legal-papers i {
  display: block;
}
.title-quantity-interior {
  display: flex;
  justify-content: space-between;
  margin-bottom: 1rem;
}
.title-quantity-interior p {
  padding: 0.5rem;
}
.quantity-interior {
  display: flex;
}
.quantity-interior .quantity-icons {
  padding: 0.5rem;
  margin-top: 0.25rem;
}
.quantity-interior .quantity-icons i {
  margin: 0 0.5rem;
  font-size: 20px;
  width: 20px;
}
.quantity-interior .btn-quantity-interior {
  border-radius: 50%;
  width: 3.5rem;
  height: 3.5rem;
  background-color: #fff;
  color: #333;
  border: solid #c7ced7;
  box-shadow: 0 2px 4px rgba(40, 44, 46, 0.122);
}
.quantity-interior .btn-quantity-interior:hover {
  background-color: rgba(0, 0, 0, 0.169);
}
.quantity-interior .btn-quantity-interior:disabled {
  background-color: #c7ced7;
  border: #c7ced7;
}
.notify-other-info-tag {
  display: none;
}
.notify-other-info-tag.active {
  display: flex;
  justify-content: space-between;
  text-decoration: none !important;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.notify-other-info-tag .notify {
  font-weight: 600;
}
#add-phone-number span {
  text-decoration: underline;
}
#input-info-contact-phone-detail {
  cursor: pointer;
}
.box-quick-generated {
  display: flex;
  justify-content: space-between;
}
.box-quick-generated p {
  padding: 0.5rem;
}
.btn-generated {
  font-weight: 600;
  border-radius: 20px;
  font-size: 14px;
  padding: 1rem;
  background-color: #fff;
  box-shadow: 0 2px 4px rgba(40, 44, 46, 0.122);
}
.btn-generated:hover {
  background-color: rgba(0, 0, 0, 0.169);
}
.textarea-info-input {
  width: 100%;
  position: relative;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -0.4px;
  color: #3e4246;
  font-size: 12px;
  border: 1px solid rgba(0, 0, 0, 0.169);
  background-color: transparent;
  padding: 0.5rem 1rem;
  border-radius: 20px;
  margin-bottom: 0.5rem;
  display: block;
  height: 5rem;
}
.textarea-description {
  height: 10rem;
}
.totalCharacter {
  font-size: 12px;
  font-weight: 400;
  margin-left: 1rem;
}
#error-textarea-title-detail,
#error-textarea-description-detail {
  padding-top: 0.5rem;
}
.modalGenerated {
  top: 10rem;
}
.titleGenerated {
  font-size: 12px;
  margin-bottom: 1rem;
}
.box-style-generated {
  display: flex;
  justify-content: space-around;
}
.select-style-generated {
  border: 1px solid;
  padding: 1rem 4rem;
  border-radius: 20px;
  font-size: 16px;
  font-weight: 600;
  width: 22rem;
  text-align: center;
  box-shadow: 0 4px 8px 0 rgba(40, 44, 46, 0.122);
}
.select-style-generated:hover {
  background-color: rgba(0, 0, 0, 0.169);
  cursor: pointer;
}
.stylePolite {
  color: #005730;
  border-color: #005730;
  background-color: #e5fff4;
}
.stylePolite.active {
  box-shadow: 0 4px 8px 0 #005730;
}
.styleYouthful {
  color: #942f00;
  border-color: #942f00;
  background-color: #ffeee5;
}
.styleYouthful.active {
  box-shadow: 0 4px 8px 0 #942f00;
}
.textarea-content-generated {
  width: 100%;
  margin: 1.5rem 0.25rem;
  height: 16rem;
  border-radius: 20px;
  padding: 0.5rem;
  font-size: 12px;
}
.modalGenerated .modal-body .textarea-content-generated,
.modalGenerated .modal-footer {
  display: none;
}

.box-footer.active {
  position: fixed;
  bottom: 0;
  right: 29%;
  z-index: 150;
  background: #fff;
  margin: 0;
}
.box-footer .btn-next {
  padding: 1rem;
  border-radius: 20px;
  font-weight: 600;
  background-color: #f35704;
  color: #fff;
  border-color: #d64b00;
  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  margin: 1rem;
  float: right;
}
.box-footer .previous-action {
  display: none;
  padding: 1rem;
  border-radius: 20px;
  font-weight: 600;
  background-color: #fff;
  color: #333;
  border-color: #333;
  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  margin: 1rem;
  float: left;
}
.box-info-title.active {
  margin-bottom: 6rem !important;
}
.box-footer .btn-next:hover {
  background: #ff752b;
}
.box-footer .previous-action:hover {
  background-color: rgba(0, 0, 0, 0.169);
}
.box-footer .btn-next.disabled {
  cursor: default;
  pointer-events: none;
  background-color: #eff1f5;
  padding: 1rem;
  margin: 2rem;
  border-radius: 20px;
  font-weight: 600;
  color: #737d87;
  border: none;
  box-shadow: none;
}
.use-generated {
  float: right;
}
.notify-after-generated {
  display: none;
  font-size: 12px;
}
.notify-after-generated span {
  font-size: 14px;
  font-weight: 600;
}
.title-group-step {
  display: none;
}
.title-group-step.active {
  display: block;
}
.demand,
.mediaa,
.checkout,
.confirm {
  display: none;
  margin-top: 12rem;
}
.demand {
  margin-bottom: 10rem;
}
.content-header {
  position: fixed;
  width: 100%;
  background: #fff;
  z-index: 50;
  top: 0;
}

.demand.active,
.mediaa.active,
.checkout.active,
.confirm.active {
  display: block;
}
.notify-title-description {
  display: none;
  margin-bottom: 1rem;
}
.notify-title-description p {
  padding: 0rem;
}
#notify-title {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
#notify-description {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: normal;
}
.box-notify-quantity-image.active p,
.box-notify-warning-quantity-image p {
  padding: 1rem;
  margin: 0;
}
.box-notify-quantity-image.active p i,
.box-notify-warning-quantity-image p i {
  margin-right: 1rem;
}
.mediaa .box-titleImage {
  width: 77rem;
  margin: 1rem auto;
  display: flex;
  justify-content: space-between;
}
.box-drop-image {
  display: block;
  background-color: #fff;
  width: 77rem;
  height: 28.5rem;
  border: 1px dashed #333;
  border-radius: 10px;
  margin: 2rem auto;
}
.guide-add-image,
.guide-add-image-360 {
  display: block;
  background-color: #fff;
  width: 77rem;
  border-radius: 10px;
  padding: 0 1rem;
  margin: 1rem auto;
}
.icon-drop-image {
  justify-content: center;
  align-items: center;
  display: flex;
  margin-top: 4rem;
}
.icon-drop-image i {
  font-size: 6rem;
  width: 6rem;
  margin: 1.5rem;
  cursor: pointer;
}
.box-button-drop-image {
  margin: 1rem;
  display: flex;
  justify-content: space-evenly;
  padding-top: 4rem;
}
.button-drop-image {
  border: 2px solid #333;
  padding: 0.5rem 2rem;
  border-radius: 20px;
  font-size: 14px;
  cursor: pointer;
  box-shadow: 0 2px 4px rgba(40, 44, 46, 0.078);
}
.button-drop-image:hover {
  background-color: rgba(0, 0, 0, 0.071);
}
.button-drop-image:hover i {
  transform: scale(1.5);
}
.button-drop-image i {
  margin-right: 0.5rem;
  font-size: 16px;
  transition: transform 0.3s ease;
}
.button-drop-image.disabled {
  cursor: default;
  pointer-events: none;
  background-color: unset;
  border: 1px solid #c1c9d2;
  box-shadow: none;
  color: #737d87;
}
.notify-drop-image {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.notify-drop-image p {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  cursor: default;
}
#real-file-input {
  display: none;
}
.box-show-image-choosed {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  background-color: #fff;
  width: 77rem;
  border-radius: 10px;
  margin: 1rem auto;
}
.box-show-image-choosed > .box-image {
  flex: 0 0 25%;
  max-width: 25%;
  box-sizing: border-box;
  padding: 0.5rem;
}
.box-image-preview-item {
  width: 180px;
  height: 14rem;
  margin: 4px;
  display: inline-block;
  vertical-align: top;
}
.image-preview-item {
  position: relative;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  overflow: hidden;
  display: flex;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.4);
  /* object-fit: cover; */
}
.preview-image {
  height: 11rem;
}
.preview-image-description {
  background-color: #282c2e;
  width: 100%;
  padding: 5px 10px;
  color: #c1c9d2;
  font-size: 12px;
  font-weight: 600;
  text-align: center;
  position: relative;
  cursor: pointer;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
}
.preview-image-description-modal {
  background-color: #282c2e;
  width: 100%;
  padding: 5px 10px;
  color: #c1c9d2;
  font-size: 12px;
  font-weight: 600;
  text-align: center;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
}
.preview-image-description-modal::placeholder {
  color: #c1c9d2;
}
.preview-image-description i,
.box-preview-image-description-modal i {
  position: absolute;
  top: 8px;
  right: 10px;
}
.box-preview-image-description-modal {
  position: relative;
}
.box-preview-image-description-modal i {
  top: 11px;
  font-size: 14px;
  color: #c1c9d2;
}
.button-edit-image {
  display: none;
  font-weight: 600;
  font-size: 14px;
  border: 1px solid;
  border-radius: 20px;
  padding: 0.5rem 1.5rem;
  margin-top: 0.2rem;
  cursor: pointer;
  box-shadow: 0 2px 4px rgba(40, 44, 46, 0.078);
}
.button-edit-image:hover {
  background-color: rgba(0, 0, 0, 0.169);
}
#drop-area.highlight {
  border: 2px dashed #007bff;
  background-color: #f0f8ff;
}

.image-list {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}

.sortable-image {
  position: relative;
  width: 300px;
  background: #f0f0f0;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  cursor: grab;
}
.sortable-image:active {
  cursor: grabbing;
}
.preview-image {
  display: block;
}
.image-preview-item-modal {
  display: flex;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.4);
}
.preview-image-modal {
  display: block;
  height: 13rem;
}
.titleEditImage {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 1rem;
}
.image-placeholder {
  width: 300px;
  height: 15rem;
  border: 2px dashed #bbb;
  background-color: #f8f8f8;
}
#editImage .modal-dialog {
  width: auto;
  max-width: 42rem;
}
.modalImage .modal-body::-webkit-scrollbar {
  width: 6px;
}
.modalImage .modal-body::-webkit-scrollbar-thumb {
  background-color: rgba(0, 0, 0, 0.2);
  border-radius: 3px;
}
.modalImage .modal-body {
  height: auto;
  max-height: 39rem;
}
.badge-preview {
  position: absolute;
  top: 8px;
  width: 100%;
  display: flex;
  gap: 13px;
}
.badge-avatar {
  background-color: #c00;
  color: white;
  padding: 2px 8px;
  border-radius: 12px;
  font-size: 12px;
  z-index: 1;
  font-weight: bold;
}
.badge-360 {
  background: #c1c9d2;
  color: #3e4246;
  border-radius: 12px;
  font-size: 12px;
  padding: 2px 8px;
  z-index: 1;
  font-weight: bold;
}

.button-icon-modal {
  position: absolute;
  top: 7px;
  border-radius: 50%;
  width: 3rem;
  height: 3rem;
  background-color: #fff;
  color: #0d1011;
  align-items: center;
  display: flex;
  justify-content: center;
  cursor: pointer;
}
.button-icon-modal.disabled {
  cursor: default;
  background-color: #eff1f5;
  color: #737d87;
  pointer-events: none;
}
.button-icon-modal:hover {
  background-color: #cccecf;
}
.button-icon-modal.star {
  right: 11rem;
}
.button-icon-modal.d360 {
  right: 7.5rem;
}
.button-icon-modal.rotate {
  right: 4rem;
}
.button-icon-modal.trash {
  right: 0.5rem;
}
.button-icon-modal.d360.active {
  background-color: #737d87;
  border: 2px solid;
}
.content-guide-add-image,
.content-guide-add-image-360 {
  background: #c1c9d2;
  border-radius: 10px;
  padding: 0.75rem;
  font-size: 14px;
  font-weight: 500;
  max-height: 0;
  opacity: 0;
  visibility: hidden;
  overflow: hidden;
  transform: translateY(-10px);
  padding: 0 0.75rem;
  transition: max-height 0.4s ease, opacity 0.4s ease, transform 0.4s ease, padding 0.4s ease;
}

.content-guide-add-image.active,
.content-guide-add-image-360.active {
  background: #c1c9d2;
  border-radius: 10px;
  padding: 1.75rem;
  font-size: 14px;
  font-weight: 500;
  max-height: 500px;
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.content-guide-add-image ul li {
  margin-bottom: 0.5rem;
}
.content-guide-add-image-360 p,
.content-guide-add-image-360 ol li {
  margin-bottom: 0.5rem;
}
.content-guide-add-image-360 ol {
  margin-left: 1.5rem;
}

.content-guide-add-image ul {
  margin: 0;
}
.content-guide-add-image ol {
  margin: 0;
}
.title-guide-add-image,
.title-guide-add-image-360 {
  padding: 0.5rem;
  font-weight: 600;
  position: relative;
  display: flex;
  justify-content: space-between;
}
.title-guide-add-image p,
.title-guide-add-image-360 p {
  margin: 0;
}
.title-guide-add-image p i,
.title-guide-add-image-360 p i {
  margin-right: 0.5rem;
}
.line {
  width: 77rem;
  margin: 1rem auto;
  border-bottom: 1px solid #eff1f5;
}
.discount-line {
  width: 29rem;
  margin: 1rem auto;
  border-bottom: 1px solid #eff1f5;
}
.box-add-video {
  width: 77rem;
  margin: 1rem auto;
  margin-bottom: 9rem;
}
.title-add-video span {
  font-size: 14px;
}
.title-add-video p {
  margin-bottom: 1rem;
}
.textarea-info-video {
  resize: none;
}
.textarea-info-video::placeholder {
  font-weight: 400;
  color: #5c5e61;
}

.video-preview-thumbnail {
  margin-top: 10px;
  position: relative;
  display: flex;
  justify-content: space-around;
  gap: 2rem;
  border-radius: 12px;
  overflow: hidden;
  cursor: pointer;
}

.video-preview-thumbnail img {
  width: 100%;
  display: block;
  border-radius: 12px;
}

.video-preview-thumbnail .icon-open {
  position: absolute;
  top: 8px;
  right: 8px;
  background: white;
  border-radius: 50%;
  padding: 6px;
  font-size: 14px;
}
.notify-link-video {
  display: none;
}
.notify-link-video.show {
  display: block;
  color: red;
  font-size: 14px;
  font-weight: 600;
  transform: translateY(-10px);
  animation: shake 0.4s ease;
}
.btn-preview.disabled {
  cursor: default;
  background-color: #eff1f5;
  color: #737d87;
  pointer-events: none;
}
.css-novx8y {
  display: none !important;
}
.box-checkout-service {
  width: 77rem;
  padding: 0 1rem;
  margin: 1rem auto;
}
.box-checkbox-type-service {
  width: 50rem;
  margin: auto;
  position: relative;
  display: flex;
  justify-content: space-between;
  background-color: #eff1f5;
  padding: 4px;
  border-radius: 2rem;
  overflow: hidden;
}
.slider-indicator {
  position: absolute;
  top: 4px;
  left: 4px;
  width: calc(50% - 8px);
  height: calc(100% - 8px);
  background-color: #1c1f22;
  border-radius: 2rem;
  transition: all 0.3s ease;
  z-index: 0;
}
.type-per-day,
.type-per-click {
  width: 50%;
  text-align: center;
  padding: 0.5rem;
  cursor: pointer;
  font-size: 14px;
  font-weight: 400;
  position: relative;
  z-index: 1;
  transition: color 0.3s ease;
}
.type-per-day.checked,
.type-per-click.checked {
  color: #fff;
}
.type-per-day.nochecked,
.type-per-click.nochecked {
  color: #737d87;
}
.type-per-click span {
  margin-left: 0.5rem;
  background-color: #c20000;
  color: #fff;
  font-weight: 600;
  font-size: 12px;
  border-radius: 8px;
  padding: 0.35rem;
}
.box-choose-type-service {
  display: flex;
  justify-content: space-between;
  padding: 0.5rem;
  font-size: 16px;
  font-weight: 500;
}
.box-choose-type-service p {
  margin: 1rem;
  cursor: default;
}
.title-compare-title p i {
  font-size: 10px;
  transform: translateY(-6px);
}
.title-tooltip-wrapper {
  position: relative;
  display: inline-block;
  cursor: pointer;
}
.box-compare-tooltip {
  position: absolute;
  top: 4rem;
  left: 50%;
  transform: translateX(-50%);
  background-color: #000;
  color: #fff;
  padding: 12px;
  border-radius: 10px;
  width: 250px;
  z-index: 10;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.box-compare-tooltip::before {
  content: "";
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  border: 10px solid transparent;
  border-bottom-color: #000;
}

.compare-tooltip-text {
  font-size: 13px;
  line-height: 1.5;
}

.btn-compare-link {
  margin-top: 10px;
  background: #fff;
  color: #000;
  border: none;
  padding: 6px 12px;
  border-radius: 20px;
  font-weight: bold;
  cursor: pointer;
  font-size: 13px;
}
.title-compare-title {
  position: relative;
  display: inline-block;
  font-size: 12px;
}

.title-compare-title:hover .box-compare-tooltip,
.title-compare-title .box-compare-tooltip:hover {
  opacity: 1;
  pointer-events: auto;
}
.box-choose-service-per-day,
.box-choose-service-per-click {
  display: none;
}
.box-choose-service-per-day.active,
.box-choose-service-per-click.active {
  display: block;
}
.box-choose-service-per-day .option-choose-service,
.box-choose-service-per-click .option-choose-service {
  display: flex;
  gap: 19px;
}
.box-choose-service-per-day .option-choose-service .option,
.box-choose-service-per-click .option-choose-service .option {
  width: 25%;
  border: 2px solid #333;
  border-radius: 10px;
  padding: 1.5rem 0.75rem;
  cursor: pointer;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  box-sizing: border-box;
  position: relative;
}
.icon-option i {
  font-size: 2rem;
  margin: 0.5rem 0;
}
.option-vip-diamon .icon-option i {
  color: #432f80;
  text-shadow: 0 0 4px rgba(49, 57, 140, 0.4);
}
.option-vip-gold .icon-option i {
  color: #cfc925;
  text-shadow: 0 0 4px #f0eb5b;
}
.option-vip-silver .icon-option i {
  color: #009194;
  text-shadow: 0 0 2px #aaa, 0 0 5px #95d1d2, 0 0 8px #95d1d2;
}
.option-normal .icon-option i {
  color: #333;
  text-shadow: 0 0 2px #aaa, 0 0 5px rgba(200, 200, 200, 0.6), 0 0 8px rgba(255, 255, 255, 0.4);
}
.rank-option p {
  margin-top: 0.5rem;
  margin-bottom: 0;
  font-size: 16px;
  font-weight: 600;
}
.position-display {
  font-size: 12px;
  margin: 0;
  font-weight: 400;
}
.benefit-option {
  display: flex;
  margin-top: 1rem;
  border-radius: 7px;
  font-size: 14px;
}
.benefit-option .benefit {
  padding: 0.25rem;
  display: flex;
  align-items: center;
  color: #fff;
  border-radius: 7px;
  font-size: 14px;
  font-weight: 600;
}
.box-choose-service-per-click .benefit-option .benefit {
  padding: 0.75rem;
  display: flex;
  align-items: center;
  color: #fff;
  border-radius: 7px;
  font-size: 14px;
  font-weight: 600;
}
.option-vip-diamon .benefit-option {
  background: linear-gradient(to right, #846ccc, #ffffff);
}
.option-vip-gold .benefit-option {
  background: linear-gradient(to right, #f0eb5b, #ffffff);
}
.option-vip-silver .benefit-option {
  background: linear-gradient(to right, #95d1d2, #ffffff);
}

.option-vip-diamon .benefit-option .benefit {
  background-color: #432f80;
}
.option-vip-gold .benefit-option .benefit {
  background-color: #cfc925;
}
.option-vip-silver .benefit-option .benefit {
  background-color: #009194;
}
.option-vip-diamon .benefit-option p,
.option-vip-gold .benefit-option p,
.option-vip-silver .benefit-option p {
  padding-left: 0.5rem;
  font-weight: 500;
}
.option .price-option {
  font-size: 16px;
  font-weight: 600;
  margin: 1rem 0 0 0;
}
.option .price-option-click {
  font-size: 16px;
  font-weight: 700;
  color: #c20000;
  margin: 1rem 0 0 0;
}
.option .discount-option-click {
  font-size: 12px;
  font-weight: 400;
}

.option-normal .benefit-option {
  height: 2.65rem;
}
.option:hover .benefit-option .benefit i,
.option.active .benefit-option .benefit i {
  transform: scale(1.5);
  transition: transform 0.3s ease;
}

.option-vip-diamon:hover,
.option-vip-diamon.active {
  transform: translateY(10px);
  box-shadow: 0 0 16px #846ccc;
  border-color: #432f80 !important;
}

.option-vip-gold:hover,
.option-vip-gold.active {
  transform: translateY(10px);
  box-shadow: 0 0 16px #f0eb5b;
  border-color: #cfc925 !important;
}
.option-vip-silver:hover,
.option-vip-silver.active {
  transform: translateY(10px);
  box-shadow: 0 0 16px #95d1d2;
  border-color: #009194 !important;
}

.option-normal:hover,
.option-normal.active {
  transform: translateY(10px);
  box-shadow: 0 0 16px rgba(0, 0, 0, 0.4);
  border-color: #333;
}
.box-choose-service-per-day .option-tooltip-wrapper,
.box-choose-service-per-click .option-tooltip-wrapper {
  position: relative;
  margin-top: 3rem;
  background-color: #eff1f5;
  border-radius: 16px;
  padding: 1rem;
}
.box-choose-service-per-day .option-tooltip-wrapper {
  border: 2px solid #333;
  box-shadow: 0 0 16px rgba(0, 0, 0, 0.4);
}
.box-choose-service-per-click .option-tooltip-wrapper {
  border: 2px solid #009194;
  box-shadow: 0 0 16px #95d1d2;
}
.box-choose-service-per-day .option-tooltip-wrapper .option-title {
  font-size: 12px;
  font-weight: 500;
  margin-bottom: 1rem;
}

.box-option-tooltip.active {
  display: flex;
  gap: 12px;
  position: relative;
}
.box-option-tooltip {
  display: none;
}

.option-checkbox,
.option-checkbox-free {
  position: relative;
  display: flex;
  align-items: center;
  padding: 16px 20px;
  border: 1px solid #d1d5db;
  border-radius: 12px;
  cursor: pointer;
  transition: border 0.3s;
  background-color: white;
  flex: 1;
  box-sizing: border-box;
}

.option-checkbox input[type="radio"],
.option-checkbox-free input[type="radio"] {
  appearance: none;
  width: 20px;
  height: 20px;
  border: 2px solid #ccc;
  border-radius: 50%;
  margin-left: auto;
  position: relative;
  transition: all 0.3s;
}

.option-checkbox input[type="radio"]:checked,
.option-checkbox-free input[type="radio"]:checked {
  border: 2px solid #000;
}

.option-checkbox input[type="radio"]::before,
.option-checkbox-free input[type="radio"]::before {
  content: "";
  display: block;
  position: absolute;
  top: 2px;
  left: 2px;
  width: 12px;
  height: 12px;
  background-color: black;
  border-radius: 50%;
  opacity: 0;
  transition: opacity 0.3s;
}

.option-checkbox input[type="radio"]:checked::before,
.option-checkbox-free input[type="radio"]:checked::before {
  opacity: 1;
}

.option-checkbox .content,
.option-checkbox-free .content {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.option-checkbox input[type="radio"]:checked ~ .content,
.option-checkbox-free input[type="radio"]:checked ~ .content {
  font-weight: bold;
}

.option-checkbox input[type="radio"]:checked + .content,
.option-checkbox-free input[type="radio"]:checked + .content {
  font-weight: bold;
}
.option-direction {
  content: "";
  position: absolute;
  top: -0.5rem;
  width: 1.5rem;
  height: 1.5rem;
  transform: rotate(45deg);
  border: 2px solid;
  border-bottom-color: transparent !important;
  border-right-color: transparent !important;
  background-color: #eff1f5 !important;
  opacity: 0;
  transition: top 0.4s ease, opacity 0.4s ease;
  pointer-events: none;
}

.option-direction.active {
  top: -0.7rem;
  opacity: 1;
  animation: arrowRise 0.4s ease forwards;
}
.option-direction.diamon {
  left: 7rem;
  border-color: #432f80;
}
.option-direction.gold {
  left: 24rem;
  border-color: #cfc925;
}
.option-direction.silver {
  right: 24rem;
  border-color: #009194;
}
.option-direction.normal {
  right: 7rem;
  border-color: #333;
}
.option.disabled {
  color: #737d87;
  background-color: #eff1f5;
  cursor: not-allowed !important;
  border: none !important;
  opacity: 0.6;
  transition: none !important;
}
.option.disabled:hover {
  transform: none;
  box-shadow: none;
  border-color: transparent !important;
}
@keyframes arrowRise {
  0% {
    top: -0.5rem;
    opacity: 0;
  }
  100% {
    top: -0.7rem;
    opacity: 1;
  }
}
.box-choose-datetime {
  display: flex;
  gap: 2rem;
  padding: 0 1rem;
  margin-top: 1rem;
}
.box-choose-start-date,
.box-choose-time-upload {
  width: 50%;
}
.title-choose-start-date p,
.title-choose-time-upload p {
  font-size: 14px;
  margin: 0.5rem;
}
.picker-calendar {
  position: absolute;
  top: 3px;
  right: 7px;
}
.picker-calendar i {
  font-size: 20px;
}
#end-date-info,
#Not-available {
  font-size: 12px;
  font-weight: 500;
  margin: 0;
}
#box-suggestions-time-post-news {
  max-height: 15rem;
}
.select-datestart.disabled,
.select-datetime.disabled {
  cursor: default;
  background-color: #eff1f5;
  color: #737d87;
  pointer-events: none;
  border-radius: 20px;
}
#datepicker input {
  cursor: pointer;
}
.box-discount {
  display: flex;
  justify-content: space-between;
  cursor: pointer;
}
.title-discount i {
  font-size: 1rem;
  margin: 0 0.5rem;
}
.title-discount p {
  font-size: 14px;
  font-weight: 500;
}
.choose-discount {
  display: flex;
  font-weight: 600;
}
.choose-discount .choose {
  font-size: 12px;
  color: #737d87;
}
.choose-discount .notify-discount {
  display: none;
  font-size: 14px;
  color: green;
  font-weight: 700;
  transform: translateY(-3px);
}
.choose-discount i {
  margin-left: 0.5rem;
}
.modalDiscount .modal-body {
  position: relative;
  height: 38rem;
}
.modalDefine .modal-body {
  position: relative;
  height: 45rem;
}
.modalDiscount .modal-body .box-input-discount {
  position: sticky;
  top: 0;
  background: #fff !important;
  height: 7rem;
  padding: 1rem;
  transform: translateY(-1rem);
  z-index: 1000;
}
.modalDiscount .modal-body .box-input-discount .input-discount:hover {
  background-color: #fff;
}
.modalDiscount .modal-body .box-input-discount .input-discount input {
  padding: 1rem 4rem;
}
.modalDiscount .modal-footer {
  display: flex;
  justify-content: space-between;
}

.item-discount {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 1px dashed #ddd;
  border-radius: 10px;
  padding: 12px;
  margin-bottom: 10px;
  cursor: pointer;
  transition: all 0.2s ease;
}
.item-discount:hover {
  background: #f8f9fa;
}
.item-discount.active {
  border-color: #0d6efd;
  background: #e7f1ff;
}
.item-discount.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.discount-icon {
  width: 4%;
  font-size: 2rem;
}
.discount-title {
  margin-left: 1rem;
  width: 66%;
}
.discount-title p {
  margin-bottom: 0.5rem;
}
.discount-value {
  margin-left: 1rem;
  width: 30%;
}
.discount-value p {
  font-size: 4rem;
  margin-top: -1rem;
  font-weight: 900;
  letter-spacing: -4.5px;
  color: var(--swal2-close-button-color);
  height: 0rem;
}
.item-discount .discount-title .title {
  font-size: 1.5rem;
  font-weight: 600;
}
.item-discount .discount-title .description {
  font-size: 1.3rem;
  font-weight: 400;
  height: 1.5rem;
  line-height: 14px;
  overflow: hidden;
  white-space: break-spaces;
  text-overflow: ellipsis;
}
.item-discount .discount-title .condition {
  line-height: 12px;
}
.item-discount .discount-title .expiry {
  font-size: 12px;
  font-weight: 400;
}
.item-discount.disabled {
  cursor: default;
  background-color: #eff1f5;
  color: #737d87;
  pointer-events: none;
  opacity: 0.6;
}
.item-discount .quantity-discount {
  position: absolute;
  bottom: 0;
  right: 1px;
  border-radius: 20px 0;
  display: block;
  padding: 4px 8px;
  background-color: #e5fff4;
  color: #005730;
  font-size: 14px;
  font-weight: 700;
}
.item-discount.disabled .quantity-discount {
  background-color: #ccc;
  color: #3e4246;
}
.close {
  outline: none !important;
  box-shadow: none !important;
  background-color: transparent;
  border: none;
  overflow: hidden;
}

.close:focus {
  outline: none;
  box-shadow: none;
}

.close i {
  pointer-events: none;
  display: inline-block;
  color: #fff;
  font-size: 2.5rem;
  transition: transform 1s ease;
}

.close:hover i {
  transform: rotate(360deg);
}
.process-footer {
  display: flex;
}
.process-total-price {
  display: none;
}
.process-total-price.active {
  margin-top: 2rem;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  line-height: 1;
  height: 4rem;
  padding-right: 1rem;
  border-right: 1px solid #c1c9d2;
}

.process-total-price .total-price {
  font-size: 14px;
  font-weight: 400;
}
.process-total-price .total-price span {
  font-size: 16px;
  font-weight: 700;
  margin-left: 0.25rem;
}
.process-total-price .discount-price {
  font-size: 12px;
  font-weight: 400;
  text-align: right;
  color: #c20;
}
.process-total-price p {
  margin-bottom: 0.25rem;
}
.box-guide-pay-per-click {
  display: none;
  height: auto;
  background-color: #eff1f5;
  max-width: 77rem;
  border: 1px solid #eff1f5;
  border-radius: 10px;
  font-size: 1rem;
  font-weight: 700;
  padding: 0.75rem 2rem;
  margin-top: 1rem;
}

.box-guide-pay-per-click .box-title-guide-pay-per-click {
  position: relative;
  cursor: pointer;
}
.box-guide-pay-per-click .box-title-guide-pay-per-click p i {
  margin-right: 0.5rem;
}
.box-guide-pay-per-click .box-title-guide-pay-per-click p {
  margin: 0;
}
.box-guide-pay-per-click .box-title-guide-pay-per-click .icon-CaretDown-select {
  position: absolute;
  top: 5px;
  right: -12px;
  transform: rotate(0deg);
}
.box-content-guide-pay-per-click {
  max-height: 0;
  margin-top: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, margin-top 0.3s ease;
}

.box-content-guide-pay-per-click.expanded {
  max-height: 1000px;
  margin-top: 1.5rem;
}

.box-guide-pay-per-click .box-content-guide-pay-per-click p {
  font-size: 14px;
  font-weight: 500;
}
.box-guide-pay-per-click .box-content-guide-pay-per-click p i {
  font-size: 1rem;
}
.box-content-guide-pay-per-click .item-content {
  display: flex;
  margin-bottom: 0.5rem;
}
.box-content-guide-pay-per-click .item-content i {
  transform: translateY(4px);
  width: 2rem;
}
.box-choose-service-per-click .option-tooltip-wrapper .option-title {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.box-choose-service-per-click .option-tooltip-wrapper p {
  margin: 0;
}
.box-choose-service-per-click .option-tooltip-wrapper .option-title span {
  color: #c20000;
  text-decoration: underline;
  cursor: pointer;
  margin-left: 0.5rem;
}
.box-choose-service-per-click .option-tooltip-wrapper .box-option-tooltip {
  justify-content: space-between;
}
.define-pay-per-click ul {
  margin: 0 !important;
}
.define-pay-per-click ul li {
  font-size: 14px;
  line-height: 1.25;
  margin-bottom: 0.5rem;
}
.quantity-turn-pay-per-click {
  display: flex;
  width: 15rem;
  height: 2rem;
  justify-content: space-around;
}
.quantity-turn-pay-per-click .btn-quantity-turn {
  width: 5rem;
  height: 3rem;
  border-radius: 50%;
  font-size: 2rem;
  font-weight: 600;
  cursor: pointer;
  margin: 0 1rem;
}
.quantity-turn-pay-per-click .btn-quantity-turn:hover,
.quantity-turn-pay-per-click .quantity-icons:hover {
  background-color: rgba(0, 0, 0, 0.169);
}
.quantity-turn-pay-per-click .quantity-icons {
  width: 9rem;
  height: 3rem;
  border: 2px solid #333;
  border-radius: 20px;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  background-color: #fff;
  cursor: default;
  display: flex;
  align-items: center;
  justify-content: center;
}
.quantity-turn-pay-per-click .btn-quantity-turn:disabled {
  cursor: not-allowed;
}
.quantity-turn-pay-per-click .btn-quantity-turn:disabled:hover {
  background-color: #eff1f5;
}
.box-footer .notify-process-pay-per-click {
  display: none;
  font-size: 11px;
  font-weight: 600;
  text-align: center;
  margin-bottom: 1rem;
}
.modalDefine .modal-body .define-image {
  display: flex;
  justify-content: center;
}
.modalDefine .modal-body .define-image img {
  width: 40rem;
  margin: 2rem 0;
}
.modalDefine .modal-body .define-content ul li {
  font-size: 14px;
  margin-bottom: 1rem;
  padding: 0 2rem;
}
.modalDefine .modal-body .define-notify i {
  font-size: 14px;
  font-weight: 600;
}
.option-tooltip-wrapper .box-option-tooltip .option-checkbox.active {
  border: 2px solid #333;
  box-shadow: 0 0 16px rgba(0, 0, 0, 0.4);
}
/* ============================================Confirm========================================= */
.confirm .title-confirm p {
  width: 50rem;
  padding: 0 1rem;
  margin: 1rem auto;
  font-size: 16px;
  font-weight: 700;
}
.confirm .box-confirm {
  width: 77rem;
  height: 5rem;
  padding: 0 1rem;
  margin: 1rem auto;
}
.confirm .box-confirm .box-confirm-wallet {
  transition: all 0.4s ease;
  height: 6rem;
}
.confirm .box-confirm .box-confirm-wallet.open {
  background-color: #ffe7de;
  border-radius: 10px;
  height: 20rem;
  margin-bottom: 3rem;
  transition: all 0.4s ease;
}
.confirm .box-confirm .box-confirm-wallet .box-confirm-wallet-header {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #fff;
  border: 2px solid;
  border-radius: 10px;
  padding: 1rem 5rem 1rem 2rem;
  margin-top: 2rem;
  height: 6rem;
  cursor: pointer;
}
.confirm .box-confirm .box-confirm-wallet .box-confirm-wallet-header .confirm-wallet-header {
  font-size: 1.5rem;
  font-weight: 600;
}
.confirm .box-confirm .box-confirm-wallet .box-confirm-wallet-header .title-wallet .logo-wallet {
  width: 5rem;
}
.confirm .box-confirm .box-confirm-wallet .box-confirm-wallet-header .icon-wallet {
  position: absolute;
  font-size: 1.5rem;
  top: 2rem;
  right: 1rem;
  font-weight: 600;
}
.confirm .box-confirm .box-confirm-content .box-confirm-wallet-content {
  margin: 1rem 0rem;
}
#icon-CaretDown-wallet {
  transition: transform 0.4s ease;
}

.box-confirm-wallet #icon-CaretDown-wallet {
  transform: rotate(-90deg);
}
.box-confirm-wallet.open #icon-CaretDown-wallet {
  transform: rotate(0deg);
}
.confirm .box-confirm .box-confirm-content .box-confirm-wallet-content .confirm-wallet-content {
  padding: 1rem 3rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.confirm .box-confirm .box-confirm-content .box-confirm-wallet-content .confirm-wallet-content .confirm-wallet-content-detail {
  font-weight: 600;
  color: #000;
}
.confirm .box-confirm .box-confirm-content .box-confirm-wallet-content .confirm-wallet-content .confirm-wallet-content-detail#confirm-amount-to-deposit {
  font-size: 1.75rem;
}

.confirm .box-confirm .box-confirm-realestate {
  position: relative;
  background-color: #fff;
  border: 2px solid;
  border-radius: 10px;
  padding: 1rem 2rem 5rem 2rem;
  margin-top: 2rem;
}
.confirm .box-confirm .box-confirm-realestate .box-confirm-infomation {
  display: flex;
  margin: 2rem 0;
  gap: 1rem;
}
.confirm .box-confirm .box-confirm-realestate .box-confirm-infomation .thumbnail-image {
  width: 30%;
}
.confirm .box-confirm .box-confirm-realestate .box-confirm-infomation .thumbnail-image img {
  border-radius: 10px;
  width: 17rem;
  height: 11rem;
}
.confirm .box-confirm .box-confirm-realestate .box-confirm-infomation .thumbnail-title {
  width: 70%;
}
.confirm .box-confirm .box-confirm-realestate .box-confirm-infomation .thumbnail-title .title-infomation {
  font-size: 2rem;
  font-weight: 600;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: calc(2rem + 4px);
}
.confirm .box-confirm .box-confirm-realestate .box-confirm-infomation .thumbnail-title .description-infomation {
  font-size: 1.25rem;
  font-weight: 400;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-top: 1rem;
}
.confirm .box-confirm .box-confirm-services .confirm-service-content {
  display: flex;
  justify-content: space-between;
}
.confirm .box-confirm .box-confirm-services .confirm-service-content * {
  box-sizing: border-box;
}
.confirm .box-confirm .box-confirm-services .confirm-service-content .confirm-service-left,
.confirm .box-confirm .box-confirm-services .confirm-service-content .confirm-service-right {
  width: 50%;
  display: flex;
  justify-content: space-between;
  padding-bottom: 1rem;
}
.confirm .box-confirm .box-confirm-services .confirm-service-content .confirm-service-left {
  padding-right: 1rem;
  border-right: 1px solid;
}
.confirm .box-confirm .box-confirm-services .confirm-service-content .confirm-service-right {
  padding-left: 1rem;
  border-left: 1px solid;
}
.confirm .box-confirm .box-confirm-services .confirm-service-content .confirm-service-left .content,
.confirm .box-confirm .box-confirm-services .confirm-service-content .confirm-service-right .content {
  font-weight: 600;
  color: #000;
}
.confirm .box-confirm .box-confirm-total {
  position: absolute;
  bottom: 0;
  left: 0;
  display: flex;
  width: 100%;
  padding: 1rem 2.5rem;
  justify-content: space-between;
  background-color: #e0e0e0;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
}
.confirm .box-confirm .box-confirm-total .content {
  font-size: 2rem;
  font-weight: 600;
  color: #000;
}

.notify-confirm-checkout {
  display: none;
  font-size: 14px;
  font-weight: 600;
}
.discount-title .code {
  display: none;
}
#map {
  width: 100%;
  height: 297px;
  position: relative;
}

#map .mapboxgl-canvas {
  width: 623px !important;
  height: 297px !important;
}
#suggestions-address-province,
#suggestions-address-district,
#suggestions-address-ward,
#suggestions-address-street {
  max-height: 20rem;
}
.box-suggestions-address .box-input-search-address {
  padding-top: 1rem;
  transform: translateY(-9px);
  margin-bottom: -1rem;
}
.box-suggestions-address .box-input-search-address i {
  top: 2rem;
}
.box-input-search-address .clear-input {
  display: none;
  position: absolute;
  right: 1rem;
  left: unset;
  font-weight: 600;
  cursor: pointer;
}
#input-address-select-innews {
  cursor: text;
}
#map-container,
#map-container2 {
  position: relative;
}
#map-container2 {
  display: none;
}
#center-marker,
#center-marker2 {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  display: flex;
  flex-direction: column;
  align-items: center;
}

#center-dot,
#center-dot2 {
  width: 10px;
  height: 10px;
  background: #c20000;
  border-radius: 50%;
  border: 1.5px solid #6f0000;
  margin-bottom: 2px;
}

#center-pin,
#center-pin2 {
  position: absolute;
  top: -3.25rem;
  left: -6.5px;
  font-size: 3rem;
  color: #c20000;
  line-height: 1;
  margin-bottom: -4px;
}

.progress-bar-loading {
  width: 100px;
  height: 6px;
  background-color: #eee;
  border-radius: 3px;
  overflow: hidden;
  margin: 0 auto 10px auto;
  position: relative;
}
.progress-bar-loading::before {
  content: "";
  position: absolute;
  left: -40%;
  top: 0;
  height: 100%;
  width: 40%;
  background: linear-gradient(to right, #3498db, #2980b9);
  animation: loading-progress 1s linear infinite;
}
.loading-spinner-generated {
  display: none;
}
.loading-spinner-generated.active {
  text-align: center;
  padding: 20px;
  height: 16rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@keyframes loading-progress {
  0% {
    left: -40%;
  }
  100% {
    left: 100%;
  }
}

.box-select-address {
  display: flex;
  padding: 1rem;
  gap: 2rem;
  justify-content: space-between;
}
.select-address {
  width: 50%;
  position: relative;
}
.select-address p {
  margin-bottom: 1rem;
}
.body-select-address-innews {
  width: 100%;
}
.body-select-address-innews .title-body-select-address-innews p {
  margin-bottom: 1rem;
}
.input-info-input::placeholder,
.select-info-unit::placeholder,
.textarea-info-input::placeholder {
  color: #5a6067 !important;
}
.textarea-info-input::placeholder {
  font-weight: 400;
  color: #5a6067;
}
.box-select-house-direction,
.box-select-balcony-direction {
  display: flex;
  justify-content: space-between;
}
.box-button-direction {
  display: flex;
  justify-content: space-between;
  width: 20rem;
  padding: 1rem;
}
.button-direction-cancel {
  padding: 1rem;
  border-radius: 20px;
  font-weight: 600;
  background-color: #fff;
  color: #333;
  border-color: #333;
  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  cursor: pointer;
}
.button-direction-cancel:hover {
  background-color: rgba(0, 0, 0, 0.169);
}
.button-direction-confirm {
  padding: 1rem;
  border-radius: 20px;
  font-weight: 600;
  font-size: 1.5rem;
  background-color: #9b0000;
  color: #fff;
  border-color: #6f0000;
  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  cursor: pointer;
}
.button-direction-confirm:hover {
  background-color: #c20000;
}
#map3,
#map4 {
  width: 100%;
  position: relative;
  height: 200px;
  border-radius: 8px;
  overflow: hidden;
  user-select: none;
  cursor: grab;
}
#map3 .mapboxgl-canvas,
#map4 .mapboxgl-canvas {
  width: 100% !important;
  height: 200px !important;
}

.compass-icon {
  font-size: 50px;
  color: #f35704;
  position: absolute;
  top: 50% !important;
  left: 50% !important;
  transform-origin: center center;
  transform: translate(-50%, -50%) rotate(0deg);
  pointer-events: none;
  user-select: none;
  transition: transform 0.3s ease;
}
#direction-label {
  font-weight: bold;
  padding: 1rem;
  margin-left: 1rem;
  margin-top: 1rem;
}
.box-info-utilities {
  display: flex;
  justify-content: space-around;
  gap: 20px;
}
.box-info-utilities .info-utilities i {
  font-size: 2rem;
  font-weight: 400;
}
.box-info-utilities .info-utilities {
  display: flex;
  align-items: center;
}

.box-info-utilities .info-utilities .toggle-switch {
  position: relative;
  display: inline-block;
  width: 40px;
  height: 20px;
  margin-top: 10px;
}

.box-info-utilities .info-utilities .toggle-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.box-info-utilities .info-utilities .toggle-switch .slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  transition: 0.4s;
  border-radius: 20px;
  transform: translate(1rem, -4px);
}

.box-info-utilities .info-utilities .toggle-switch .slider:before {
  position: absolute;
  content: "";
  height: 16px;
  width: 16px;
  left: 2px;
  bottom: 2px;
  background-color: white;
  transition: 0.4s;
  border-radius: 50%;
}

.box-info-utilities .info-utilities .toggle-switch input:checked + .slider {
  background-color: #f35704;
}

.box-info-utilities .info-utilities .toggle-switch input:checked + .slider:before {
  transform: translateX(20px);
}
.box-content-info-utilities {
  margin-top: 1rem;
}
.item-content-utilities {
  display: none;
  margin-top: 0.5rem;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  width: 100%;
  cursor: pointer;
}
.modalPhoneNumber {
  width: 60rem;
  left: -4rem;
}
.title-info-phone-number p {
  margin-bottom: 1rem;
}

.input-info-verify,
.verify-phone-number {
  display: none;
}
.box-otp-card-inputs input {
  cursor: default;
}
.box-otp-card-inputs {
  margin: 30px 0;
  display: grid;
  gap: 30px;
  justify-content: center;
  grid-template-columns: repeat(6, auto);
}
.box-otp-card-inputs input {
  padding: 0.5px;
  width: 60px;
  height: 70px;
  font-size: 35px;
  text-align: center;
  border-radius: 20px;
  border: 3px solid var(--Color-6) !important;
}
.box-otp-card-inputs input:focus {
  outline: 3px solid var(--Primary);
  border-color: transparent;
}
.box-checkbox-type-compare-price {
  width: 50rem;
  height: 4rem;
  margin: auto;
  position: relative;
  display: flex;
  justify-content: space-between;
  background-color: #eff1f5;
  padding: 4px;
  border-radius: 2rem;
  overflow: hidden;
}
.slider-indicator-compare-price {
  position: absolute;
  top: 4px;
  left: 4px;
  width: calc(20%);
  height: calc(100% - 8px);
  background-color: #1c1f22;
  border-radius: 2rem;
  transition: all 0.3s ease;
  z-index: 0;
  box-shadow: inset 0 2px 4px rgba(255, 255, 255, 0.2), 0 4px 10px rgba(0, 0, 0, 0.3);
}
.type-feature {
  width: 20%;
}
.type-computer,
.type-phone {
  width: 40%;
}
.type-feature,
.type-computer,
.type-phone {
  text-align: center;
  padding: 0.5rem;
  cursor: pointer;
  font-size: 14px;
  font-weight: 400;
  position: relative;
  z-index: 1;
  transition: color 0.3s ease;
}
.type-feature.checked,
.type-computer.checked,
.type-phone.checked {
  color: #fff;
}
.type-feature.nochecked,
.type-computer.action-buttons,
.type-phone.nochecked {
  color: #737d87;
}
.vip-table {
  width: 100%;
  border-collapse: collapse;
  text-align: center;
  margin-top: 20px;
}

.vip-table th,
.vip-table td {
  border: 1px solid #ccc;
  padding: 12px;
}

.vip-table thead th {
  background-color: #f9f9f9;
  font-weight: bold;
}

.vip-diamond {
  color: #432f80;
}

.vip-gold {
  color: #cfc925;
}

.vip-silver {
  color: #009194;
}

.vip-normal {
  color: #333;
}
.vip-table td:first-child {
  text-align: left;
  font-weight: bold;
}
.vip-table tbody tr td i {
  color: #008549;
  font-size: 2rem;
}
.box-checkbox-type-preview-device {
  width: 50rem;
  height: 4rem;
  margin: auto;
  position: relative;
  display: flex;
  justify-content: space-between;
  background-color: #eff1f5;
  padding: 4px;
  border-radius: 2rem;
  overflow: hidden;
  margin-bottom: 2rem;
}
.slider-indicator-preview-device {
  position: absolute;
  top: 4px;
  left: 4px;
  width: calc(49%);
  height: calc(100% - 8px);
  background-color: #1c1f22;
  border-radius: 2rem;
  transition: all 0.3s ease;
  z-index: 0;
  box-shadow: inset 0 2px 4px rgba(255, 255, 255, 0.2), 0 4px 10px rgba(0, 0, 0, 0.3);
}
.type-device-computer,
.type-device-phone {
  width: 50%;
  text-align: center;
  padding: 0.5rem;
  cursor: pointer;
  font-size: 14px;
  font-weight: 400;
  position: relative;
  z-index: 1;
  transition: color 0.3s ease;
}

.type-device-computer.checked,
.type-device-phone.checked {
  color: #fff;
}
.type-device-computer.nochecked,
.type-device-phone.action-buttons {
  color: #737d87;
}

.box-feature-note {
  margin-top: 1rem;
  padding: 2rem;
}
.box-feature-note p {
  margin-bottom: 0.5rem;
}
.flex-info-demand {
  display: flex;
  gap: 2rem;
}
#suggestions-house-direction,
#suggestions-balcony-direction {
  width: 100% !important;
  margin: 0rem 1rem;
}
#suggestions-balcony-direction {
  right: 0;
}
.notify-title-description {
  cursor: pointer;
}
.remove-discount {
  position: absolute;
  top: 0;
  right: 1px;
  border-radius: 0 20px;
  display: block;
  padding: 8px 8px;
  background-color: #fff;
  color: #000;
  font-size: 14px;
  font-weight: 700;
}
.search-icon-voucher {
  position: absolute;
  top: 0.5rem;
  right: 1rem;
  width: 3rem;
  height: 3rem;
  font-size: 2rem;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
.search-icon-voucher:hover {
  cursor: pointer;
  color: #f35704;
}
.box-gallery-image-360 {
  width: 77rem;
  margin: auto;
  position: relative;
}
.outstanding-price {
  display: none;
  color: #c20000;
}
#remove-image-360 {
  position: absolute;
  top: 0rem;
  right: 0rem;
  color: #fff;
  font-size: 3rem;
  cursor: pointer;
}
/* ---------------------------------------------------- */
.loading-safari {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid rgba(0, 122, 255, 0.2);
  border-top-color: #007aff;
  animation: spin 1s linear infinite;
  box-sizing: border-box;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

#draft-feedback {
  z-index: 9999;
  display: none;
  margin-left: 2rem;
  font-size: 14px;
  font-weight: 500;
  padding: 6px 16px;
  transform: translateY(5px);
}

#draft-feedback p,
#draft-feedback div {
  margin: 0;
  border-radius: 12px;
  backdrop-filter: blur(10px);
}

.ic-saving-draft {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(0, 122, 255, 0.12);
  color: #007aff;
  padding: 6px 16px;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  backdrop-filter: blur(10px);
}

.ic-saved-draft {
  background: rgba(0, 200, 83, 0.12);
  color: #34c759;
}

.ic-error-draft {
  background: rgba(255, 59, 48, 0.12);
  color: #ff3b30;
}

.layout-preview.device-mobile {
  max-width: 390px;
  margin: 1rem auto;
}
