/* ======================
   WSForm Styles (scoped to .wsf-theme)
   ====================== */

/* FORM */
.wsf-theme .wsf-form {
  padding: var(--form-padding) !important;           /* optional !important */
  background: var(--form-bg) !important;             /* optional !important */
  font-family: var(--form-font-family) !important;   /* optional !important */
}

/* INPUTS + SELECT (single-line controls) */
.wsf-theme .wsf-form :where(
  input.wsf-field:not([type=checkbox],[type=radio],[type=range],[type=file],[type=hidden]),
  select.wsf-field
) {
  background: var(--field-bg) !important;
  color: var(--field-text) !important;
  border-color: var(--field-border-color) !important;
  border-width: var(--field-border-width) !important;
  border-style: solid !important;
  border-radius: var(--field-radius) !important;

  padding-inline: var(--field-pad-inline) !important; /* optional !important */

  font-size: var(--field-font-size) !important;       /* optional !important */
  font-weight: var(--field-font-weight) !important;   /* optional !important */
  letter-spacing: var(--field-letter-spacing) !important; /* optional !important */
  line-height: var(--control-line-height) !important; /* optional !important */

  height: var(--control-height) !important;           /* keep */
  box-sizing: border-box !important;                  /* optional !important */
}

/* SELECT-specific trim */
.wsf-theme .wsf-form select.wsf-field {
  padding-block: calc(var(--field-pad-block) - var(--select-trim-block)) !important; /* optional !important */
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* TEXTAREA (auto height) */
.wsf-theme .wsf-form textarea.wsf-field {
  background: var(--field-bg) !important;
  color: var(--field-text) !important;
  border-color: var(--field-border-color) !important;
  border-width: var(--field-border-width) !important;
  border-style: solid !important;
  border-radius: var(--field-radius) !important;

  padding-block: var(--field-pad-block) !important;   /* optional !important */
  padding-inline: var(--field-pad-inline) !important; /* optional !important */

  font-size: var(--field-font-size) !important;       /* optional !important */
  font-weight: var(--field-font-weight) !important;   /* optional !important */
  line-height: var(--field-line-height) !important;   /* optional !important */
  letter-spacing: var(--field-letter-spacing) !important; /* optional !important */
}

/* PLACEHOLDER */
.wsf-theme .wsf-form .wsf-field::placeholder {
  color: var(--field-placeholder) !important;         /* optional !important */
  opacity: 1 !important;                              /* optional !important */
}

/* LABELS */
.wsf-theme .wsf-form label.wsf-label {
  color: var(--label-text) !important;
  background: var(--label-bg) !important;             /* optional !important */
  border-color: var(--label-border-color) !important; /* optional !important */
  border-width: var(--label-border-width) !important; /* optional !important */
  border-style: solid !important;                     /* optional !important */

  font-size: var(--label-font-size) !important;       /* optional !important */
  font-weight: var(--label-font-weight) !important;   /* optional !important */
  line-height: var(--label-line-height) !important;   /* optional !important */
}

/* FOCUS STATES */
.wsf-theme .wsf-form :is(input.wsf-field, select.wsf-field, textarea.wsf-field):focus-visible,
.wsf-theme .wsf-form :is(input.wsf-field, select.wsf-field, textarea.wsf-field):focus {
  outline: var(--field-focus-outline-width) solid var(--field-border-color) !important;
  box-shadow: var(--field-focus-shadow) !important;
  border-color: var(--field-border-color) !important;
}

/* DISABLED */
.wsf-theme .wsf-form :is(input.wsf-field, select.wsf-field, textarea.wsf-field):disabled,
.wsf-theme button.wsf-button.wsf-button-primary:disabled {
  opacity: var(--disabled-opacity) !important;        /* optional !important */
  cursor: not-allowed !important;                     /* optional !important */
}

/* CONSENT / SMALL COPY */
.wsf-theme .aa-wsf-consent { margin-bottom: 0 !important; padding-bottom: 0 !important; /* optional !important */ }
.wsf-theme .aa-wsf-consent p,
.wsf-theme .wsf-form .wsf-help,
.wsf-theme .wsf-form .wsf-description {
  margin-bottom: .5em !important;                     /* optional !important */
  font-size: var(--consent-font-size) !important;     /* optional !important */
}
.wsf-theme div.wsf-field-wrapper.aa-wsf-consent div[data-text-editor] > p {
  margin: 0 !important;                                /* optional !important */
  font-size: var(--consent-font-size) !important;      /* optional !important */
}

/* REQUIRED * */
.wsf-theme .wsf-form .wsf-required-wrapper > .wsf-text-danger {
  display: inline-block !important;                    /* optional !important */
  color: var(--req-asterisk-color) !important;
  font-family: var(--form-font-family) !important;     /* optional !important */
  font-size: inherit !important;                       /* optional !important */
  transform: scale(var(--req-asterisk-scale)) !important;
  transform-origin: left !important;                   /* optional !important */
  line-height: 1 !important;                           /* optional !important */
  vertical-align: inherit !important;                  /* optional !important */
}

/* BUTTON */
.wsf-theme button.wsf-button.wsf-button-primary {
  /* typography */
  font-size: var(--btn-font-size) !important;          /* optional !important */
  font-weight: var(--btn-font-weight) !important;      /* optional !important */
  text-transform: var(--btn-text-transform) !important;/* optional !important */
  text-decoration: var(--btn-text-decoration) !important;/* optional !important */
  letter-spacing: var(--btn-letter-spacing) !important;/* optional !important */

  /* visual */
  color: var(--btn-fg) !important;
  background-color: var(--btn-bg) !important;
  border-color: var(--btn-border-color) !important;
  border-width: var(--btn-border-width) !important;
  border-style: solid !important;
  border-radius: var(--btn-radius) !important;

  /* box model */
  padding-block: var(--btn-pad-block) !important;      /* keep */
  padding-inline: var(--btn-pad-inline) !important;    /* optional !important */
  width: var(--btn-width) !important;                  /* optional !important */
  min-width: var(--btn-min-width) !important;          /* optional !important */
  max-width: var(--btn-max-width) !important;          /* optional !important */

  /* motion */
  transition: var(--btn-transition) !important;        /* optional !important */
  transform-origin: var(--btn-transform-origin) !important; /* optional !important */
}
.wsf-theme button.wsf-button.wsf-button-primary:hover {
  color: var(--btn-hover-fg) !important;
  background: var(--btn-hover-bg) !important;
  border-color: var(--btn-hover-border-color) !important;
  transform: scale(var(--btn-hover-scale)) !important; /* optional !important */
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .wsf-theme button.wsf-button.wsf-button-primary,
  .wsf-theme button.wsf-button.wsf-button-primary:hover {
    transition: none !important;                       /* optional !important */
    transform: none !important;                        /* optional !important */
  }
}

/* CAPTCHA & SUBMIT ALIGNMENT */
.wsf-theme .aa-wsf-captcha,
.wsf-theme .aa-wsf-submit { text-align: center !important; /* optional !important */ }

/* ALERT SUCCESS (post-submit) */
.wsf-theme .wsf-alert.wsf-alert-success {
  background-color: var(--alert-success-bg) !important;
  color: var(--alert-success-text) !important;
  border-color: var(--alert-success-border) !important;
  border-left-color: var(--alert-success-accent) !important;
  border-left-width: var(--alert-success-accent-width) !important;
  border-style: solid !important;
  border-radius: var(--alert-success-radius) !important;
  padding-block: var(--alert-success-pad-block) !important;  /* optional !important */
  padding-inline: var(--alert-success-pad-inline) !important;/* optional !important */
}
.wsf-theme .wsf-alert.wsf-alert-success hr {
  border-color: var(--alert-success-border) !important;
}

/* INVALID FEEDBACK */
.wsf-theme .wsf-invalid-feedback {
  padding-top: 5px !important;                          /* optional !important */
  font-size: var(--feedback-font-size) !important;      /* optional !important */
}
