body#contact #wrapper .container {
  max-width: 1220px;
}

body#contact #wrapper > .container > .row {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 36px;
  align-items: stretch;
}

body#contact #left-column,
body#contact #content-wrapper {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  float: none !important;
}

body#contact .contact-rich {
  height: 100%;
  padding: 34px 26px;
  border-radius: 26px;
  background: #111;
  color: #fff;
  overflow: hidden;
}

body#contact .contact-rich h4 {
  margin: 0 0 30px;
  padding-bottom: 18px;
  position: relative;
  font-size: 28px;
  line-height: 1.15;
  color: #fff;
  text-transform: uppercase;
}

body#contact .contact-rich h4::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 72px;
  height: 4px;
  border-radius: 99px;
  background: #d4af37;
}

body#contact .contact-rich .icon i {
  color: #fff;
  font-size: 25px;
}

body#contact .contact-rich .data,
body#contact .contact-rich .block > a {
  min-width: 0;
  font-size: 15px;
  line-height: 1.65;
  color: rgba(255,255,255,.86);
  overflow-wrap: anywhere;
  word-break: normal;
}

body#contact .contact-rich a {
  color: #d4af37;
  font-weight: 700;
  text-decoration: none;
}

body#contact .contact-rich hr {
  margin: 26px 0;
  border: 0;
  border-top: 1px solid rgba(255,255,255,.12);
}

body#contact #content.page-content {
  padding: 58px 62px;
  border-radius: 26px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.07);
  box-shadow: 0 18px 55px rgba(0,0,0,.08);
}

body#contact .contact-form form,
body#contact .contact-form .form-fields {
  width: 100%;
}

body#contact .contact-form .form-group.row {
  display: block !important;
  margin: 0 0 24px !important;
}

body#contact .contact-form .form-group.row > label,
body#contact .contact-form .form-group.row > div,
body#contact .contact-form .form-group.row > span,
body#contact .contact-form .col-md-3,
body#contact .contact-form .col-md-6,
body#contact .contact-form .col-md-9,
body#contact .contact-form .offset-md-3,
body#contact .contact-form .col-md-offset-3 {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 0 10px 0 !important;
  float: none !important;
}

body#contact .contact-form h3 {
  margin: 0 0 34px;
  font-size: 48px;
  line-height: 1;
  font-weight: 700;
  color: #111;
  letter-spacing: -1px;
  text-transform: uppercase;
}

body#contact .contact-form .form-control-label {
  display: block !important;
  margin: 0 0 9px !important;
  text-align: left !important;
  font-size: 15px;
  line-height: 1.3;
  font-weight: 700;
  color: #111;
}

body#contact .contact-form .form-control,
body#contact .contact-form select,
body#contact .contact-form textarea {
  width: 100% !important;
  max-width: 100% !important;
  min-height: 58px;
  padding: 15px 18px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.14);
  background: #fff;
  color: #111;
  font-size: 16px;
  box-shadow: none;
}

body#contact .contact-form textarea {
  min-height: 150px;
  resize: vertical;
}

body#contact .contact-form .form-control:focus,
body#contact .contact-form select:focus,
body#contact .contact-form textarea:focus {
  border-color: #C9A14A;
  box-shadow: 0 0 0 4px rgba(201,161,74,.13);
  outline: none;
}

body#contact .bootstrap-filestyle.input-group {
  display: flex !important;
  width: 100% !important;
}

body#contact .bootstrap-filestyle .form-control {
  border-radius: 14px 0 0 14px !important;
}

body#contact .bootstrap-filestyle .input-group-btn,
body#contact .bootstrap-filestyle .group-span-filestyle {
  width: auto !important;
  flex: 0 0 auto;
}

body#contact .bootstrap-filestyle .btn {
  height: 58px;
  padding: 0 22px;
  border-radius: 0 14px 14px 0;
  background: #111;
  border: 1px solid #111;
  color: #fff;
  font-weight: 700;
  text-transform: none;
}

body#contact .form-control-comment {
  display: block !important;
  margin-top: 8px !important;
  font-size: 13px;
  color: #777;
}

body#contact .gdpr_consent {
  width: 100%;
  padding: 20px 22px;
  border-radius: 18px;
  background: #faf8f2;
  border: 1px solid rgba(201,161,74,.24);
}

body#contact .psgdpr_consent_message {
  display: grid !important;
  grid-template-columns: 22px 1fr;
  gap: 14px;
  align-items: start;
  width: 100%;
  margin: 0;
  text-align: left;
  font-size: 15px;
  line-height: 1.7;
  color: #333;
}

body#contact #content.page-content .psgdpr_consent_message input {
  width: 20px !important;
  height: 20px !important;
  margin: 3px 0 0 !important;
  accent-color: #C9A14A;
}

body#contact .psgdpr_consent_message > span:first-of-type {
  display: none !important;
}

body#contact .psgdpr_consent_message > span:last-child {
  min-width: 0;
  overflow-wrap: break-word;
}

body#contact .psgdpr_consent_message a {
  color: #C9A14A;
  font-weight: 700;
}

body#contact #captcha-box {
  margin: 26px 0 0 0 !important;
  text-align: left !important;
  max-width: 304px;
}

body#contact .contact-form .form-footer {
  margin-top: 26px !important;
  padding: 0 !important;
  text-align: left !important;
}

body#contact .contact-form .form-footer .btn.btn-primary {
  width: 100% !important;
  min-height: 58px;
  border: 0;
  border-radius: 14px;
  background: #d4af37;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  text-transform: none;
  box-shadow: 0 14px 30px rgba(212,175,55,.26);
}

body#contact .contact-form .form-footer .btn.btn-primary:hover:not(:disabled) {
  background: #C9A14A;
  color: #fff;
}

body#contact .contact-form .form-footer .btn.btn-primary:disabled {
  opacity: .45;
}

@media (max-width: 991px) {
  body#contact #wrapper > .container > .row {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}

@media (max-width: 991px) {
  body#contact .contact-rich {
    height: auto;
    margin-left: 20px;
    margin-right: 20px;
  }
}

@media (max-width: 991px) {
  body#contact #content.page-content {
    padding: 34px 22px;
    margin-left: 20px;
    margin-right: 20px;
  }
}

@media (max-width: 991px) {
  body#contact .contact-form h3 {
    font-size: 38px;
  }
}

@media (max-width: 991px) {
  body#contact #captcha-box {
    overflow-x: auto;
  }
}

@media (max-width: 767px) {
  body#contact #captcha-box {
    transform: scale(0.88);
    transform-origin: left top;
    width: 304px;
    height: 70px;
    overflow: hidden;
  }
}

body#contact #content.page-content input.btn.btn-primary {
  margin-top: 20px;
}

body#contact .contact-rich .block {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 16px;
  align-items: start;
}

body#contact .contact-rich .icon {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: #d4af37;
  display: flex;
  align-items: center;
  justify-content: center;
  grid-row: 1 / 3;
}

body#contact .contact-rich .data.email {
  margin: 0;
  line-height: 1.5;
}

body#contact .contact-rich .data.email br {
  display: none;
}

body#contact .contact-rich .block > a[href^="mailto:"] {
  grid-column: 2;
  margin-top: -12px;
  display: block;
  font-size: 15px;
  line-height: 1.5;
  color: #d4af37;
  font-weight: 700;
  text-decoration: none;
  word-break: break-word;
}