/* ==========================================================================
   Forms & Buttons
   ========================================================================== */

/* --- Inputs --- */

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="date"],
textarea,
select {
    display: block;
    width: 100%;
    padding: 0.625rem 0.875rem;
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
    color: var(--color-text);
    background-color: var(--color-bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    appearance: none;
}

input:focus,
textarea:focus,
select:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(0, 115, 229, 0.15);
    outline: none;
}

input:disabled,
textarea:disabled,
select:disabled {
    background-color: var(--color-bg-light);
    color: var(--color-text-muted);
    cursor: not-allowed;
}

textarea {
    resize: vertical;
    min-height: 7.5rem;
}

::placeholder {
    color: var(--color-text-muted);
    opacity: 1;
}

/* --- Labels --- */

label {
    display: block;
    margin-bottom: var(--spacing-xs);
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
}

/* --- Form-specific button overrides ---
   Base button styles live in utilities.css
   WPForms overrides also in utilities.css */

.button--full {
    width: 100%;
}

.site-container .wpforms-container .wpforms-form .wpforms-field input {
    border-radius: 0;
    height: auto;
    padding: 0.9375rem;
}

/* --- Formidable Forms Compatibility --- */

.frm_forms .frm_form_field {
    margin-bottom: var(--spacing-md);
}

.frm_login_form.with_frm_style .frm_form_fields > fieldset{
  background-color: #f0f1f8;
  padding:20px;
}

/* Default inner padding for non-login Formidable forms (reset password, contact, registration etc.) */
.frm_forms.with_frm_style:not(.frm_login_form) .frm_form_fields > fieldset {
    padding: var(--spacing-xl);
    background-color: var(--color-bg);
    border-radius: var(--radius-lg);
}

.frm_forms input[type="text"],
.frm_forms input[type="email"],
.frm_forms input[type="tel"],
.frm_forms input[type="url"],
.frm_forms input[type="password"],
.frm_forms textarea,
.frm_forms select {
    width: 100%;
}

.frm_forms .frm_submit {
    margin-top: 25px;
}

.frm_forms .frm_submit button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.5rem;
    font-weight: var(--font-weight-semibold);
    color: var(--color-white);
    background-color: var(--color-primary);
    border: 2px solid var(--color-primary);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
}

@media (any-hover: hover) {
    .frm_forms .frm_submit button:hover {
        background-color: var(--color-primary-hover);
        border-color: var(--color-primary-hover);
    }
}

/* --- Formidable Login Form --- */

.frm_login_form .frm_primary_label {
    font-family: var(--font-bariol);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-semibold);
    color: var(--color-purple-light);
    padding: 5px 0;
    margin-bottom: 0;
}

.frm_login_form input[type="text"],
.frm_login_form input[type="password"] {
    height: 35px;
    padding: 0 18px;
    font-size: 15px;
    border: 1px solid #bfc3c8;
    border-radius: 0;
}

.frm_login_form .frm_submit input[type="submit"] {
    display: inline-block;
    background-color: var(--color-accent);
    color: var(--color-black);
    font-size: var(--font-size-lg);
    padding: 10px 50px;
    border: 1px solid var(--color-accent);
    border-radius: var(--radius-sm);
    cursor: pointer;
    margin: 10px 0;
    transition: background-color var(--transition-fast);
}

@media (any-hover: hover) {
    .frm_login_form .frm_submit input[type="submit"]:hover {
        background-color: var(--color-accent-hover);
        border-color: var(--color-accent-hover);
        color: var(--color-white);
    }
}

.frm_login_form .login-remember {
    display: none;
}

/* --- Search Form --- */

.search-form {
    display: flex;
    gap: var(--spacing-sm);
}

.search-form input[type="search"] {
    flex: 1;
}
