/* Contact Form Styles */
.contact-form {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.contact-form label {
  font-weight: 600;
  font-size: 14px;
  color: #202326;
  letter-spacing: .02em;
}

.contact-form input,
.contact-form select,
.contact-form textarea {
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  padding: 12px 14px;
  border: 1px solid rgba(13, 31, 60, .16);
  border-radius: 4px;
  font-family: "Plus Jakarta Sans", Arial, sans-serif;
  font-size: 15px;
  line-height: 1.5;
  color: #202326;
  background: #ffffff;
  transition: border-color .24s ease, box-shadow .24s ease, background .24s ease;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
  color: rgba(32, 35, 38, .56);
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--orange);
  box-shadow: 0 0 0 3px rgba(255, 140, 10, .12);
  background: #fafbfc;
}

.contact-form input:hover,
.contact-form select:hover,
.contact-form textarea:hover {
  border-color: rgba(13, 31, 60, .24);
}

.contact-form select {
  cursor: pointer;
  appearance: none;
  background-image: 
    linear-gradient(45deg, transparent 50%, var(--orange) 50%),
    linear-gradient(135deg, var(--orange) 50%, transparent 50%);
  background-position: calc(100% - 12px) calc(1em + 2px), calc(100% - 8px) calc(1em + 2px);
  background-size: 4px 4px, 4px 4px;
  background-repeat: no-repeat;
  padding-right: 28px;
}

.contact-form textarea {
  resize: vertical;
  min-height: 140px;
  font-family: "Plus Jakarta Sans", Arial, sans-serif;
}

.form-note {
  font-size: 13px;
  color: rgba(32, 35, 38, .72);
  text-align: center;
  margin: 12px 0 0;
}

.form-message {
  padding: 16px;
  border-radius: 4px;
  text-align: center;
  margin-bottom: 20px;
  display: none;
}

.form-message.show {
  display: block;
  animation: slideDown .3s ease;
}

.form-error {
  background: rgba(211, 47, 47, .08);
  border: 1px solid rgba(211, 47, 47, .28);
  color: #b71c1c;
}

/* Form states */
.contact-form input:invalid:not(:placeholder-shown),
.contact-form textarea:invalid:not(:placeholder-shown) {
  border-color: #d32f2f;
}

.contact-form button:hover {
  transform: translateY(-2px);
}

.contact-form button:active {
  transform: translateY(0);
}

.form-honeypot {
  display: none !important;
}

/* Mobile responsive */
@media (max-width: 768px) {
  .contact-form {
    gap: 18px;
  }
  
  .form-group {
    gap: 6px;
  }
  
  .contact-form input,
  .contact-form select,
  .contact-form textarea {
    padding: 11px 12px;
    font-size: 16px;
  }
}

/* Success state */
.form-success {
  padding: 16px;
  border-radius: 4px;
  background: rgba(76, 175, 80, .1);
  border: 1px solid rgba(76, 175, 80, .3);
  color: #2e7d32;
  text-align: center;
  margin-bottom: 20px;
  display: none;
}

.form-success.show {
  display: block;
  animation: slideDown .3s ease;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
