/**
 * @file
 * Webform styling to match React theme.
 * Applied when webforms are rendered in Drupal (e.g. survey take page).
 */

/* Webform container */
.webform-submission-form {
  max-width: 42rem;
  margin: 0 auto;
  padding: 1.5rem;
}

/* Form elements - match React/Tailwind look */
.webform-submission-form .form-item {
  margin-bottom: 1.25rem;
}

.webform-submission-form label {
  display: block;
  font-weight: 500;
  color: #334155;
  margin-bottom: 0.375rem;
  font-size: 0.875rem;
}

.webform-submission-form .form-text,
.webform-submission-form .form-email,
.webform-submission-form .form-tel,
.webform-submission-form .form-number,
.webform-submission-form input[type="text"],
.webform-submission-form input[type="email"],
.webform-submission-form input[type="tel"],
.webform-submission-form input[type="number"] {
  width: 100%;
  padding: 0.5rem 0.75rem;
  font-size: 1rem;
  line-height: 1.5;
  color: #1e293b;
  background-color: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.webform-submission-form .form-text:focus,
.webform-submission-form .form-email:focus,
.webform-submission-form textarea:focus,
.webform-submission-form select:focus {
  outline: none;
  border-color: var(--color-primary, #2563eb);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.15);
}

.webform-submission-form textarea {
  width: 100%;
  min-height: 6rem;
  padding: 0.5rem 0.75rem;
  font-size: 1rem;
  line-height: 1.5;
  color: #1e293b;
  background-color: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
}

.webform-submission-form select {
  width: 100%;
  padding: 0.5rem 2rem 0.5rem 0.75rem;
  font-size: 1rem;
  color: #1e293b;
  background-color: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.5rem;
}

/* Checkboxes and radios */
.webform-submission-form .form-checkboxes .form-item,
.webform-submission-form .form-radios .form-item {
  margin-bottom: 0.5rem;
}

.webform-submission-form input[type="checkbox"],
.webform-submission-form input[type="radio"] {
  margin-right: 0.5rem;
  width: 1rem;
  height: 1rem;
}

/* Submit button - match React Button primary */
.webform-submission-form .form-actions {
  margin-top: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid #e2e8f0;
}

.webform-submission-form .form-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: #fff;
  background-color: var(--color-primary, #2563eb);
  border: none;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: background-color 0.15s, opacity 0.15s;
}

.webform-submission-form .form-submit:hover {
  background-color: var(--color-primary-hover, #1d4ed8);
}

.webform-submission-form .form-submit:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.3);
}

/* Webform confirmation */
.webform-confirmation {
  max-width: 42rem;
  margin: 0 auto;
  padding: 1.5rem;
  text-align: center;
}

.webform-confirmation__message {
  font-size: 1.125rem;
  color: #334155;
  margin-bottom: 1rem;
}

.webform-confirmation__back a {
  display: inline-block;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-primary, #2563eb);
  text-decoration: none;
  border: 1px solid var(--color-primary, #2563eb);
  border-radius: 0.5rem;
  transition: background-color 0.15s, color 0.15s;
}

.webform-confirmation__back a:hover {
  background-color: var(--color-primary, #2563eb);
  color: #fff;
}

.webform-confirmation__close-btn {
  display: inline-block;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-primary, #2563eb);
  background: transparent;
  border: 1px solid var(--color-primary, #2563eb);
  border-radius: 0.5rem;
  cursor: pointer;
  transition: background-color 0.15s, color 0.15s;
}

.webform-confirmation__close-btn:hover {
  background-color: var(--color-primary, #2563eb);
  color: #fff;
}
