/* Contact Page */

#contact .contact-hero {
  position: relative !important;
  height: 45vh !important;
  min-height: 380px !important;
  display: flex !important;
  align-items: center !important;
  overflow: hidden !important;
}

#contact .contact-hero-bg {
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
}

#contact .contact-hero-bg img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

#contact .contact-hero-overlay {
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(
    90deg,
    rgba(0, 0, 0, 0.6),
    rgba(0, 0, 0, 0.4)
  ) !important;
}

#contact .contact-hero-content {
  position: relative !important;
  z-index: 1 !important;
  padding-top: 96px !important;
}

#contact .contact-breadcrumb {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin-bottom: 8px !important;
  color: rgba(255, 255, 255, 0.6) !important;
  font-size: 14px !important;
}

#contact .contact-breadcrumb a {
  color: rgba(255, 255, 255, 0.6) !important;
  text-decoration: none !important;
}

#contact .contact-breadcrumb a:hover {
  color: #ffffff !important;
}

#contact .contact-hero h1 {
  margin: 0 !important;
  color: #ffffff !important;
  font-size: 40px !important;
  line-height: 1.05 !important;
  font-weight: 700 !important;
}

/* Contact info */

#contact .contact-info-section {
  background: #ffffff !important;
}

#contact .contact-info-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 48px !important;
}

#contact .contact-section-title {
  margin: 0 0 32px !important;
  color: #1f1f1f !important;
  font-size: 30px !important;
  line-height: 1.15 !important;
  font-weight: 700 !important;
}

#contact .contact-info-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 24px !important;
}

#contact .contact-info-item {
  display: flex !important;
  align-items: flex-start !important;
  gap: 16px !important;
}

#contact .contact-info-icon {
  width: 48px !important;
  min-width: 48px !important;
  height: 48px !important;
  border-radius: 999px !important;
  background: rgba(200, 16, 46, 0.1) !important;
  color: #c8102e !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

#contact .contact-info-icon i {
  color: #c8102e !important;
  font-size: 20px !important;
  line-height: 1 !important;
}

#contact .contact-info-item h4 {
  margin: 0 0 4px !important;
  color: #777777 !important;
  font-size: 14px !important;
  line-height: 1.3 !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
}

#contact .contact-info-item a {
  color: #c8102e !important;
  font-size: 24px !important;
  line-height: 1.25 !important;
  font-weight: 700 !important;
  text-decoration: none !important;
}

#contact .contact-info-item a:hover {
  color: #a80d27 !important;
}

#contact .contact-info-item p {
  margin: 0 !important;
  color: #1f1f1f !important;
  font-size: 20px !important;
  line-height: 1.4 !important;
  font-weight: 600 !important;
}

#contact .contact-map-wrap {
  height: 100% !important;
  min-height: 400px !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.12) !important;
}

#contact .contact-map-wrap iframe {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 400px !important;
}

/* Contact form */

#contact .contact-form-section {
  background: #f8f7f4 !important;
}

#contact .contact-form-container {
  max-width: 768px !important;
}

#contact .contact-form-title {
  margin: 0 0 8px !important;
  color: #1f1f1f !important;
  font-size: 30px !important;
  line-height: 1.15 !important;
  font-weight: 700 !important;
  text-align: center !important;
}

#contact .contact-form-subtitle {
  margin: 0 0 40px !important;
  color: #777777 !important;
  font-size: 16px !important;
  line-height: 1.5 !important;
  text-align: center !important;
}

#contact .contact-form-card {
  background: #ffffff !important;
  border-radius: 16px !important;
  padding: 32px !important;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.08) !important;
}

#contact .contact-form-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px !important;
}

#contact .contact-form-group {
  margin-bottom: 16px !important;
}

#contact .contact-form-group label {
  display: block !important;
  margin: 0 0 8px !important;
  color: #1f1f1f !important;
  font-size: 14px !important;
  font-weight: 500 !important;
}

#contact .contact-form-group input,
#contact .contact-form-group textarea {
  width: 100% !important;
  padding: 13px 16px !important;
  border-radius: 12px !important;
  border: 1px solid #dddddd !important;
  background: #ffffff !important;
  color: #1f1f1f !important;
  font-size: 15px !important;
  line-height: 1.4 !important;
  outline: none !important;
  box-sizing: border-box !important;
  transition:
    border-color 200ms ease,
    box-shadow 200ms ease !important;
}

#contact .contact-form-group textarea {
  resize: none !important;
}

#contact .contact-form-group input:focus,
#contact .contact-form-group textarea:focus {
  border-color: #c8102e !important;
  box-shadow: 0 0 0 3px rgba(200, 16, 46, 0.18) !important;
}

#contact .contact-submit-button {
  width: 100% !important;
  border: 0 !important;
  padding: 14px 24px !important;
  border-radius: 999px !important;
  background: #c8102e !important;
  color: #ffffff !important;
  font-size: 16px !important;
  line-height: 1 !important;
  font-weight: 600 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  cursor: pointer !important;
  transition:
    background-color 250ms ease,
    transform 250ms ease !important;
}

#contact .contact-submit-button:hover {
  background: #a80d27 !important;
  transform: scale(1.02) !important;
}

#contact .contact-submit-icon {
  transition: transform 250ms ease !important;
}

#contact .contact-submit-button:hover .contact-submit-icon {
  transform: translateX(4px) !important;
}

/* Responsive */

@media (min-width: 768px) {
  #contact .contact-hero {
    height: 55vh !important;
  }

  #contact .contact-hero h1 {
    font-size: 60px !important;
  }

  #contact .contact-section-title,
  #contact .contact-form-title {
    font-size: 36px !important;
  }

  #contact .contact-form-card {
    padding: 40px !important;
  }

  #contact .contact-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (min-width: 1024px) {
  #contact .contact-info-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #contact .contact-hero h1 {
    font-size: 72px !important;
  }
}

@media (max-width: 767px) {
  #contact .contact-hero {
    min-height: 340px !important;
  }

  #contact .contact-hero h1 {
    font-size: 38px !important;
  }

  #contact .contact-info-item a {
    font-size: 21px !important;
  }

  #contact .contact-info-item p {
    font-size: 18px !important;
  }

  #contact .contact-form-card {
    padding: 24px !important;
  }
}
.contact-alert {
  margin: 0 0 18px;
  padding: 14px 18px;
  border-radius: 14px;
  font-size: 15px;
  line-height: 1.45;
  font-weight: 600;
}

.contact-alert-success {
  background: rgba(34, 197, 94, 0.12);
  color: #166534;
  border: 1px solid rgba(34, 197, 94, 0.25);
}

.contact-alert-error {
  background: rgba(227, 6, 19, 0.1);
  color: #b00010;
  border: 1px solid rgba(227, 6, 19, 0.25);
}
/* Contact hero -> info section rounded merge */

#contact .contact-hero {
  position: relative !important;
  z-index: 1 !important;
  padding-bottom: 70px !important;
}

#contact .contact-info-section {
  position: relative !important;
  z-index: 3 !important;
  margin-top: -48px !important;
  padding-top: 112px !important;
  border-radius: 48px 48px 0 0 !important;
  background: #ffffff !important;
  overflow: hidden !important;
}

@media (max-width: 767px) {
  #contact .contact-hero {
    padding-bottom: 48px !important;
  }

  #contact .contact-info-section {
    margin-top: -32px !important;
    padding-top: 84px !important;
    border-radius: 30px 30px 0 0 !important;
  }
}
/* Privacy policy final spacing fix */

body#privacy-policy .privacy-policy-card h1 {
  margin: 0 0 24px !important;
}

body#privacy-policy .privacy-policy-card h2 {
  margin: 26px 0 4px !important;
}

body#privacy-policy .privacy-policy-card h3 {
  margin: 8px 0 8px !important;
}

body#privacy-policy .privacy-policy-card p {
  margin: 0 0 4px !important;
}

body#privacy-policy .privacy-policy-card ul {
  margin: 0 0 14px !important;
  padding: 0 !important;
}

body#privacy-policy .privacy-policy-card li {
  margin: 0 0 2px !important;
}

/* when heading follows text/list, give it normal section breathing */
body#privacy-policy .privacy-policy-card p + h2,
body#privacy-policy .privacy-policy-card ul + h2 {
  margin-top: 30px !important;
}

body#privacy-policy .privacy-policy-card p + h3,
body#privacy-policy .privacy-policy-card ul + h3 {
  margin-top: 22px !important;
}

/* when paragraph/list directly follows heading, don't make giant gap */
body#privacy-policy .privacy-policy-card h2 + p,
body#privacy-policy .privacy-policy-card h3 + p,
body#privacy-policy .privacy-policy-card h2 + ul,
body#privacy-policy .privacy-policy-card h3 + ul {
  margin-top: 0 !important;
}
