/**
 * JD Stride — Fluent Forms Skin
 *
 * Overrides Fluent Forms default styles to match the JDS brand.
 * Uses brand variables so colour changes in client-jdstride.css
 * automatically cascade here too.
 *
 * Load order: after brand pack CSS (enqueued in inc/enqueue.php)
 *
 * Targets Fluent Forms v5.x class structure.
 * The .fluentform wrapper class is added by Fluent Forms to every form.
 */


/* ════════════════════════════════════════════════
   BASE INPUTS
════════════════════════════════════════════════ */

.fluentform .ff-el-input--content input[type="text"],
.fluentform .ff-el-input--content input[type="email"],
.fluentform .ff-el-input--content input[type="tel"],
.fluentform .ff-el-input--content input[type="number"],
.fluentform .ff-el-input--content input[type="url"],
.fluentform .ff-el-input--content select,
.fluentform .ff-el-input--content textarea {
    width: 100%;
    padding: 14px 16px;
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.95rem;
    color: #111827;
    background: #ffffff;
    border: 1.5px solid #D1D5DB;
    border-radius: 4px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    appearance: none;
    -webkit-appearance: none;
    box-shadow: none;
    outline: none;
    line-height: 1.5;
}

.fluentform .ff-el-input--content input:focus,
.fluentform .ff-el-input--content select:focus,
.fluentform .ff-el-input--content textarea:focus {
    border-color: var(--brand-secondary, #2E5BFF);
    box-shadow: 0 0 0 3px rgba(46, 91, 255, 0.12);
}

.fluentform .ff-el-input--content textarea {
    min-height: 120px;
    resize: vertical;
}


/* ════════════════════════════════════════════════
   LABELS
════════════════════════════════════════════════ */

.fluentform .ff-el-input--label label,
.fluentform label.ff-el-form-label {
    display: block;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #111827;
    margin-bottom: 8px;
    font-family: var(--font-body, 'Inter', sans-serif);
}

/* Required asterisk */
.fluentform .ff-el-is-required .ff-el-input--label label::after,
.fluentform .ff-el-is-required label::after {
    content: ' *';
    color: var(--brand-error, #ef4444);
}


/* ════════════════════════════════════════════════
   SUBMIT BUTTON
════════════════════════════════════════════════ */

.fluentform .ff_submit_btn_wrapper button[type="submit"],
.fluentform button.ff-btn-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 16px 32px;
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #ffffff;
    background: var(--brand-accent, #FF6B35);
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
    box-shadow: 0 4px 14px rgba(255, 107, 53, 0.35);
    position: relative;
    overflow: hidden;
}

.fluentform .ff_submit_btn_wrapper button[type="submit"]:hover,
.fluentform button.ff-btn-submit:hover {
    background: #e65a2b;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(255, 107, 53, 0.45);
}

.fluentform .ff_submit_btn_wrapper button[type="submit"]:active,
.fluentform button.ff-btn-submit:active {
    transform: translateY(0);
    box-shadow: 0 2px 8px rgba(255, 107, 53, 0.3);
}

/* Loading state */
.fluentform button.ff-btn-submit.ff-loading {
    opacity: 0.75;
    pointer-events: none;
}


/* ════════════════════════════════════════════════
   FORM GROUP SPACING
════════════════════════════════════════════════ */

.fluentform .ff-el-group {
    margin-bottom: 20px;
}

.fluentform .ff-el-group:last-of-type {
    margin-bottom: 0;
}


/* ════════════════════════════════════════════════
   CHECKBOXES & RADIOS
════════════════════════════════════════════════ */

.fluentform .ff-el-input--content .ff-checkbox-group label,
.fluentform .ff-el-input--content .ff-radio-group label {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.9rem;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    cursor: pointer;
    color: #374151;
    margin-bottom: 8px;
}

.fluentform .ff-el-input--content input[type="checkbox"],
.fluentform .ff-el-input--content input[type="radio"] {
    width: 18px;
    height: 18px;
    accent-color: var(--brand-secondary, #2E5BFF);
    cursor: pointer;
    flex-shrink: 0;
}


/* ════════════════════════════════════════════════
   VALIDATION MESSAGES
════════════════════════════════════════════════ */

.fluentform .error.text-danger,
.fluentform .ff-el-is-error .error {
    font-size: 0.78rem;
    color: var(--brand-error, #ef4444);
    margin-top: 5px;
    display: block;
    font-weight: 500;
}

.fluentform .ff-el-is-error input,
.fluentform .ff-el-is-error select,
.fluentform .ff-el-is-error textarea {
    border-color: var(--brand-error, #ef4444) !important;
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1) !important;
}


/* ════════════════════════════════════════════════
   SUCCESS MESSAGE
════════════════════════════════════════════════ */

.fluentform .ff-message-success,
.fluentform .ff-form-success {
    padding: 20px 24px;
    background: rgba(16, 185, 129, 0.08);
    border-left: 4px solid var(--brand-success, #10b981);
    border-radius: 4px;
    font-size: 1rem;
    color: #065f46;
    font-weight: 500;
}


/* ════════════════════════════════════════════════
   FORM INSIDE .form-box (hero / dark sections)
   When Fluent Forms is embedded inside the JDS
   .form-box component, adjust colours for the
   white card context.
════════════════════════════════════════════════ */

.form-box .fluentform .ff-el-input--content input,
.form-box .fluentform .ff-el-input--content select,
.form-box .fluentform .ff-el-input--content textarea {
    background: #F8F7F5;
    border-color: #E5E3DF;
}

.form-box .fluentform .ff-el-input--content input:focus,
.form-box .fluentform .ff-el-input--content select:focus,
.form-box .fluentform .ff-el-input--content textarea:focus {
    background: #ffffff;
    border-color: var(--brand-secondary, #2E5BFF);
}


/* ════════════════════════════════════════════════
   FORM INSIDE .glass-panel (dark hero sections)
   Adjust input styling for glassmorphism context.
════════════════════════════════════════════════ */

.glass-panel .fluentform .ff-el-input--content input,
.glass-panel .fluentform .ff-el-input--content select,
.glass-panel .fluentform .ff-el-input--content textarea {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
    color: #ffffff;
}

.glass-panel .fluentform .ff-el-input--content input::placeholder,
.glass-panel .fluentform .ff-el-input--content textarea::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.glass-panel .fluentform .ff-el-input--content input:focus,
.glass-panel .fluentform .ff-el-input--content select:focus,
.glass-panel .fluentform .ff-el-input--content textarea:focus {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(255, 255, 255, 0.5);
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.08);
}

.glass-panel .fluentform .ff-el-input--label label {
    color: rgba(255, 255, 255, 0.85);
}


/* ════════════════════════════════════════════════
   REMOVE FLUENT FORMS BRANDING
════════════════════════════════════════════════ */

.ff-powered-by,
.ff-el-progress-status,
.fluentform .ff_conv_app_header_img {
    display: none !important;
}


/* ════════════════════════════════════════════════
   MOBILE: GLASS-PANEL FORM INPUTS
   When .glass-panel loses its backdrop-filter
   on mobile (see custom.css), the transparent
   input backgrounds become unreadable against
   the solid fallback panel colour.
   Replace with opaque-enough inputs that work
   on the dark solid background.
════════════════════════════════════════════════ */

@media (max-width: 768px) {

    .glass-panel .fluentform .ff-el-input--content input,
    .glass-panel .fluentform .ff-el-input--content select,
    .glass-panel .fluentform .ff-el-input--content textarea {
        background: rgba(255, 255, 255, 0.12);
        border-color: rgba(255, 255, 255, 0.25);
        color: #ffffff;
    }

    .glass-panel .fluentform .ff-el-input--content input:focus,
    .glass-panel .fluentform .ff-el-input--content select:focus,
    .glass-panel .fluentform .ff-el-input--content textarea:focus {
        background: rgba(255, 255, 255, 0.18);
        border-color: rgba(255, 255, 255, 0.55);
        box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.08);
    }

    /* Submit button — slightly more compact on mobile */
    .fluentform .ff_submit_btn_wrapper button[type="submit"],
    .fluentform button.ff-btn-submit {
        padding: 14px 24px;
        font-size: 0.95rem;
    }
}
