/* Form Styles */
.form-item {
  margin-bottom: 1rem;
}

.form-item label {
  display: block;
  font-weight: 500;
  color: var(--passport-blue);
  margin-bottom: 0.25rem;
}

.form-item input,
.form-item textarea,
.form-item select {
  width: 100%;
  padding: 0.5rem;
  border: 1px solid #ddd;
  border-radius: 4px;
}

.form-item input:focus,
.form-item textarea:focus,
.form-item select:focus {
  outline: none;
  border-color: var(--passport-blue);
}

.form-item textarea {
  min-height: 80px;
}



/* Required field indicator */
.form-required::after {
  content: ' *';
  color: var(--passport-error);
  font-weight: bold;
}

/* Form actions */
.form-actions {
  margin-top: 1rem;
}

/* Comment moderation styles */
#disableAutosaveButton {
  background: #fff3cd;
  color: #856404;
  border: 1px solid #ffeaa7;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  font-size: 0.8rem;
  cursor: pointer;
  margin-top: 0.5rem;
}

#disableAutosaveButton:hover {
  background: #ffeaa7;
}

.comment--unpublished {
  opacity: 0.7;
  border-left: 3px solid var(--passport-warning);
}

.comment-moderation-status {
  font-size: 0.8rem;
  color: var(--passport-warning);
  font-style: italic;
  margin-bottom: 0.5rem;
}

/* File upload styling */
.form-item input[type="file"] {
  padding: 0.5rem;
  background: var(--passport-light);
  border: 2px dashed var(--passport-blue);
}

.form-item input[type="file"]:hover {
  border-color: var(--passport-gold);
  background: rgba(245, 158, 11, 0.1);
}

/* Checkbox and Radio styling */
.form-item input[type="checkbox"],
.form-item input[type="radio"] {
  width: auto;
  margin-right: 0.5rem;
  accent-color: var(--passport-blue);
}

.form-checkboxes,
.form-radios {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.form-checkboxes .form-item,
.form-radios .form-item {
  display: flex;
  align-items: center;
  margin-bottom: 0.5rem;
}

.form-checkboxes label,
.form-radios label {
  margin-bottom: 0;
  font-weight: normal;
}

/* Error states */
.form-item.error input,
.form-item.error textarea,
.form-item.error select {
  border-color: var(--passport-error);
  background: rgba(239, 68, 68, 0.05);
}

.error-message {
  color: var(--passport-error);
  font-size: 0.9rem;
  margin-top: 0.25rem;
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.error-message::before {
  content: '⚠️';
  font-family: 'Font Awesome 5 Free', 'Font Awesome 6 Free', sans-serif;
  font-weight: 900;
}

.error-message.icon-fallback::before {
  content: '\f071';
}

/* Success states */
.form-item.success input,
.form-item.success textarea,
.form-item.success select {
  border-color: var(--passport-success);
  background: rgba(16, 185, 129, 0.05);
}

.success-message {
  color: var(--passport-success);
  font-size: 0.9rem;
  margin-top: 0.25rem;
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.success-message::before {
  content: '✅';
  font-family: 'Font Awesome 5 Free', 'Font Awesome 6 Free', sans-serif;
  font-weight: 900;
}

.success-message.icon-fallback::before {
  content: '\f00c';
}

/* Search forms */
.search-form {
  display: flex;
  max-width: 400px;
  margin: 1rem auto;
}

.search-form input {
  flex: 1;
  border-radius: var(--border-radius) 0 0 var(--border-radius);
  border-right: none;
}

.search-form button {
  border-radius: 0 var(--border-radius) var(--border-radius) 0;
  padding: 0.75rem 1.5rem;
}

/* Contact forms */
.contact-form {
  max-width: 600px;
  margin: 0 auto;
}

.contact-form .form-item {
  margin-bottom: 1.5rem;
}

/* Webform styling */
.webform-submission-form {
  background: white;
  border-radius: var(--border-radius);
  box-shadow: var(--shadow);
  padding: 2rem;
}

.webform-submission-form .webform-element {
  margin-bottom: 1.5rem;
}

.webform-submission-form .webform-element-title {
  font-weight: 600;
  color: var(--passport-blue);
  margin-bottom: 0.5rem;
}

#edit-comment-body-0-format {
  display: none;
}

/* CAPTCHA styling */
.captcha {
  margin: 0;
  padding: 0;
  border: none;
}

.g-recaptcha {
  /* shrink to 80% (change 0.8 to any value) */
  transform: scale(0.8);
  transform-origin: 0 0; /* keep it aligned to top-left */
  -webkit-transform: scale(0.8);
  -webkit-transform-origin: 0 0;
}

/* ensure iframe fits container width if necessary */
.g-recaptcha iframe {
  width: 100% !important;
  height: auto !important;
}

/* Responsive */
@media (max-width: 768px) {
 
  .form-actions {
    flex-direction: column;
    align-items: stretch;
  }
  
  .form-actions .button {
    width: 100%;
    margin-bottom: 0.5rem;
  }
}