/* Contact Form UI Tweaks: autofill, error popovers, and modal popup */

/* Autofill: keep text white and avoid yellow background */
.form .field:-webkit-autofill,
.form .field:-webkit-autofill:hover,
.form .field:-webkit-autofill:focus {
  -webkit-text-fill-color: #fff !important;
  caret-color: #fff;
  -webkit-box-shadow: 0 0 0 1000px rgba(255, 255, 255, 0) inset !important;
  box-shadow: 0 0 0 1000px rgba(255, 255, 255, 0) inset !important;
  transition: background-color 9999s ease-in-out 0s !important;
}

/* Error state and popover for invalid fields */
.form .field.has-error {
  border-color: #ff4d4f;
}
.form .form-col { position: relative; }
.popover-error {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 6px;
  background: #ff4d4f;
  color: #fff;
  padding: 6px 10px;
  font-size: 12px;
  line-height: 1.3;
  border-radius: 4px;
  z-index: 60;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
}
.popover-error::before {
  content: '';
  position: absolute;
  bottom: 100%;
  left: 12px;
  border-width: 6px;
  border-style: solid;
  border-color: transparent transparent #ff4d4f transparent;
}

/* Simple result modal after submit */
body.valiant-modal-open { overflow: hidden; }
#valiant-modal-overlay.valiant-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}
#valiant-modal-overlay.show { opacity: 1; pointer-events: auto; }
#valiant-modal-overlay .valiant-modal {
  background: rgba(0, 0, 0, 0.85);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  padding: 24px;
  width: min(520px, 92vw);
  color: #fff;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4);
  position: relative;
}
#valiant-modal-overlay .valiant-modal-title {
  margin: 0 0 8px;
  font-size: 20px;
  font-weight: 700;
}
#valiant-modal-overlay .valiant-modal-body {
  font-size: 16px;
  line-height: 1.5;
  opacity: 0.9;
}
#valiant-modal-overlay .valiant-modal-close {
  position: absolute;
  top: 10px;
  right: 12px;
  border: 0;
  background: transparent;
  color: #fff;
  font-size: 24px;
  cursor: pointer;
  opacity: 0.7;
}
#valiant-modal-overlay .valiant-modal-close:hover { opacity: 1; }
#valiant-modal-overlay.success .valiant-modal { border-color: rgba(82, 196, 26, 0.5); }
#valiant-modal-overlay.error .valiant-modal { border-color: rgba(255, 77, 79, 0.5); }