/* RFM Forms — minimal layout. Visual tokens come from the active child theme via CSS variables.
   Override --rfm-form-* in your theme's :root to brand it. */
.rfm-form { max-width: 640px; margin: 0 auto; }
.rfm-form *, .rfm-form *::before, .rfm-form *::after { box-sizing: border-box; }
.rfm-form-hp { position: absolute !important; left: -9999px !important; height: 0 !important; width: 0 !important; overflow: hidden !important; }
.rfm-form-field { margin-bottom: 18px; }
.rfm-form-label { display: block; font-weight: 600; margin-bottom: 6px; font-size: 0.95rem; color: var(--rfm-form-label, var(--oops-ink, #111)); }
.rfm-form-req { color: var(--rfm-form-error, #d63638); margin-left: 4px; }
.rfm-form-field input,
.rfm-form-field textarea {
    width: 100%; padding: 12px 14px;
    border: 1.5px solid var(--rfm-form-border, var(--oops-line, #e0e0e0));
    border-radius: var(--rfm-form-radius, 10px);
    font: inherit; font-size: 1rem;
    background: var(--rfm-form-bg, #fff);
    color: var(--rfm-form-text, var(--oops-ink, #111));
    transition: border-color 0.15s, box-shadow 0.15s;
}
.rfm-form-field input:focus,
.rfm-form-field textarea:focus {
    outline: none;
    border-color: var(--rfm-form-accent, var(--oops-blue, #2271b1));
    box-shadow: 0 0 0 3px var(--rfm-form-accent-faint, rgba(34, 113, 177, 0.12));
}
.rfm-form-field textarea { resize: vertical; min-height: 130px; line-height: 1.5; }
.rfm-form-error { color: var(--rfm-form-error, #d63638); font-size: 0.88rem; margin-top: 4px; min-height: 1em; }
.rfm-form-actions { margin-top: 22px; }
.rfm-form-submit {
    background: var(--rfm-form-accent, var(--oops-blue, #2271b1));
    color: var(--rfm-form-on-accent, #fff);
    padding: 14px 32px;
    border: none;
    border-radius: var(--rfm-form-button-radius, 999px);
    font: inherit;
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: opacity 0.15s, transform 0.05s;
}
.rfm-form-submit:hover { opacity: 0.9; }
.rfm-form-submit:active { transform: translateY(1px); }
.rfm-form-submit:disabled { opacity: 0.5; cursor: wait; }
.rfm-form-status { margin-top: 16px; padding: 12px 16px; border-radius: 10px; display: none; font-size: 0.95rem; line-height: 1.5; }
.rfm-form-status.is-success { display: block; background: #e7f5ec; color: #1a6c2b; border: 1px solid #b8dec6; }
.rfm-form-status.is-error   { display: block; background: #fde7e7; color: #842029; border: 1px solid #f5c2c7; }
.rfm-form-turnstile-wrap { margin: 16px 0; min-height: 65px; }
@media (max-width: 600px) {
    .rfm-form-submit { width: 100%; }
}
