.contact-content {
  display: grid;
  gap: 40px;
  grid-template-columns: repeat(4, 1fr);
  margin-bottom: 120px;
}
.contact-subtitle {
  font-size: 0.75rem;
  font-weight: normal;
}
.contact-text {
  position: relative;
  padding: 10px 0px;
  border-bottom: rgba(255, 255, 255, 0.2) solid 1px;
}
.contact-text a {
  color: #FFF;
}
.contact-text a:hover {
  color: #999;
}
.contact-map {
  position: relative;
  padding-bottom: 35vw;
}
.contact-map-inner {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
}

.consult-inner {
  margin-top: 60px;
}
.consult-subtitle {
  font-weight: normal;
  font-size: 1rem;
  margin-bottom: 20px;
}
.consult-info {
  display: grid;
}
.consult-item {
  position: relative;
  margin-top: 10px;
  padding: 10px;
  border: rgba(255, 255, 255, 0.2) solid 1px;
  border-radius: 5px;
}
.consult-label {
  position: absolute;
  top: -10px;
  right: 10px;
  padding: 0 16px 0 10px;
  background: #222;
  line-height: 20px;
  font-size: 0.75rem;
  color: #FFF;
}
.consult-label:after {
  content: "";
  position: absolute;
  width: 6px;
  height: 6px;
  top: 50%;
  right: 0px;
  margin-top: -3px;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
}
.consult-input {
  width: 100%;
}
.consult-input2 {
  width: 100%;
  height: 80px;
  display: block;
}
.consult-select {
  width: 100%;
  border: none;
}
.consult-option {
  position: absolute;
  left: 0;
  top: 100%;
  width: 100%;
  box-shadow: 1px 1px 3px #000;
  background: #111;
  border: rgba(255, 255, 255, 0.2) solid 1px;
  box-sizing: border-box;
  margin-top: -1px;
  display: none;
  z-index: 5;
  font-size: 0.875rem;
}
.consult-option li {
  padding: 5px 20px;
}
.consult-option li:hover, .consult-option li.selected {
  background: #333;
  cursor: pointer;
}
.consult-option:hover li.selected {
  background: #111;
}
.consult-option:hover li.selected:hover {
  background: #333;
}
.consult-info2 {
  display: flex;
  flex-wrap: wrap;
}
.consult-code {
  position: relative;
  width: 100%;
  padding: 0;
  border: none;
}
.consult-redo {
  opacity: 0.5;
}
.consult-btn {
  display: block;
  padding: 10px 20px;
  margin: 10px 10px 0 0;
  border: rgba(255, 255, 255, 0.2) solid 1px;
  border-radius: 5px;
  line-height: 24px;
  font-size: 0.875rem;
  background: #111;
  color: #FFF;
  width: 104px;
  text-align: center;
}
.consult-btn:hover {
  background: rgba(255, 255, 255, 0.2);
}

.col1 {
  gap: 20px;
  grid-template-columns: repeat(1, 1fr);
}

.col3 {
  gap: 20px;
  grid-template-columns: repeat(3, 1fr);
}

input, textarea, select {
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  -o-appearance: none;
  appearance: none;
  border-radius: 0px;
  -webkit-border-radius: 0px;
  box-sizing: border-box;
  color: #999;
  line-height: 20px;
  font-size: 0.875rem;
  padding: 0px;
  border: none;
  background: #222;
}
input::placeholder, textarea::placeholder, select::placeholder {
  color: #666;
}
input::-webkit-input-placeholder, textarea::-webkit-input-placeholder, select::-webkit-input-placeholder {
  color: #666;
}
input:-moz-placeholder, textarea:-moz-placeholder, select:-moz-placeholder {
  color: #666;
}
input:-ms-input-placeholder, textarea:-ms-input-placeholder, select:-ms-input-placeholder {
  color: #666;
}
input.error, textarea.error, select.error {
  color: #d00;
}
input.error::placeholder, textarea.error::placeholder, select.error::placeholder {
  color: #d00;
}
input.error::-webkit-input-placeholder, textarea.error::-webkit-input-placeholder, select.error::-webkit-input-placeholder {
  color: #d00;
}
input.error:-moz-placeholder, textarea.error:-moz-placeholder, select.error:-moz-placeholder {
  color: #d00;
}
input.error:-ms-input-placeholder, textarea.error:-ms-input-placeholder, select.error:-ms-input-placeholder {
  color: #d00;
}

@media screen and (max-width: 1400px) {
  .contact-content {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 1100px) {
  .contact-map {
    padding-bottom: 60vw;
  }
  .contact-content {
    margin-bottom: 90px;
  }
}
@media screen and (max-width: 700px) {
  .contact-content {
    display: block;
  }

  .consult-info {
    display: block;
  }
  .consult-item {
    margin-top: 20px;
  }
  .consult-info2 {
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
  .consult-info2 .consult-item {
    margin-top: 0;
  }
  .consult-code {
    margin-right: 0;
  }
  .consult-btn {
    width: calc(50% - 47px);
    margin: 10px 0 0;
  }
}
@media screen and (max-width: 640px) {
  .contact-map {
    padding-bottom: 100vw;
  }
  .contact-content {
    margin-bottom: 60px;
  }

  .consult-subtitle {
    font-size: 0.875rem;
  }
}
