/* Page-specific styles for /donate.php.
   Extracted from inline style="..." attributes so the page can run
   under a strict CSP without 'unsafe-inline' for style or script. */

.don-hero               { padding: 64px 24px 56px; }

.don-section            { max-width: 760px; }

/* Thank-you banner */
.don-thanks             { padding: 32px; background: #e6f7ec; border: 1px solid #2e8b57; border-radius: 8px; margin-bottom: 32px; }
.don-thanks h2          { color: #2e8b57; margin: 0 0 12px; text-align: center; }
.don-thanks p           { margin: 0; text-align: center; }

/* Bank details table */
.don-bank               { width: 100%; border-collapse: collapse; font-size: 15px; background: #fff; border: 1px solid var(--pub-border); border-radius: 6px; overflow: hidden; }
.don-bank td            { padding: 12px 16px; border-bottom: 1px solid var(--pub-border); }
.don-bank tr:last-child td { border-bottom: 0; }
.don-bank .lbl          { color: var(--pub-text-muted); width: 42%; }
.don-bank .val          { font-weight: 600; }
.don-bank .mono         { font-family: monospace; }
.don-bank .ref-row .lbl,
.don-bank .ref-row .val { background: #fff8e1; }
.don-bank .ref-row .val { font-weight: 700; font-family: monospace; font-size: 18px; color: var(--pnw-red); }
.don-bank-note          { font-size: 13px; color: var(--pub-text-muted); margin-top: 16px; }

.don-bank-warning       { padding: 18px 22px; background: #fff8e1; border: 1px solid #f0ad4e; border-radius: 6px; }

.don-back-row           { margin-top: 32px; text-align: center; }

/* Lead paragraph spacing */
.don-lead               { margin-bottom: 32px; }

/* Error panel */
.don-err                { padding: 14px 18px; background: #fbeaea; border: 1px solid #c0392b; border-radius: 6px; color: #a73127; margin-bottom: 24px; }

/* Honeypot — hidden off-screen (the field that bots fill in) */
.don-honeypot           { position: absolute; left: -9999px; height: 0; overflow: hidden; }

/* Reset styling for the form's fieldset wrappers */
.don-fs                 { border: 0; padding: 0; margin: 0 0 24px; }
.don-fs legend          { font-weight: 600; margin-bottom: 8px; padding: 0; }
.don-fs-soft            { font-weight: 400; color: var(--pub-text-muted); font-size: 13px; }

/* Amount preset grid */
.don-amount-grid        { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 10px; }
.don-amount-label       { display: block; cursor: pointer; }

.amt-radio              { display: none; }
.amt-card               { border: 2px solid var(--pub-border); border-radius: 8px; padding: 16px 12px; text-align: center; transition: border-color .15s, background .15s; background: #fff; }
.amt-card:hover         { border-color: var(--pub-text-muted); }
.amt-card--selected     { border-color: var(--pnw-red); background: #fff5f6; }
.amt-card__amt          { font-family: var(--font-display); font-size: 24px; color: var(--pnw-red); letter-spacing: 1px; }
.amt-card__sub          { font-size: 12px; color: var(--pub-text-muted); margin-top: 4px; }

/* Custom-amount box — collapsed by default, slides open when "Other" is picked */
.don-custom             { max-height: 0; opacity: 0; overflow: hidden; margin-top: 0;
                          transition: max-height .25s ease, opacity .25s ease, margin-top .25s ease; }
.don-custom--open       { max-height: 140px; opacity: 1; margin-top: 14px; }
.don-custom-label       { display: block; font-size: 13px; color: var(--pub-text-muted); margin-bottom: 4px; }
.don-amount-note        { margin-top: 16px; text-align: center; font-family: var(--font-display); text-transform: uppercase; letter-spacing: 1px; font-size: 20px; color: var(--pnw-red) !important; }

/* Inputs (shared) */
.don-input              { width: 100%; padding: 10px 12px; border: 1px solid var(--pub-border); border-radius: 6px; font-family: var(--font-body); font-size: 15px; }
.don-textarea           { resize: vertical; }

/* Donor fields */
.don-checkbox-label     { display: flex; align-items: center; gap: 8px; font-size: 14px; margin-bottom: 12px; cursor: pointer; }
.don-row-2              { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.don-row-1              { margin-top: 12px; }
.don-field-label        { display: block; font-weight: 500; margin-bottom: 4px; font-size: 14px; }

.don-msg                { margin-bottom: 24px; }

/* Recurring sub-fields — JS toggles .is-hidden */
.don-recur-fields       { display: block; margin-left: 24px; }
.don-recur-fields.is-hidden { display: none; }
.don-recur-select       { padding: 8px 12px; border: 1px solid var(--pub-border); border-radius: 6px; font-family: var(--font-body); }
.don-recur-help         { font-size: 12px; color: var(--pub-text-muted); margin: 8px 0 0; }

/* Donor fields disabled (when anonymous) */
.don-donor-fields.is-disabled { opacity: .4; pointer-events: none; }

/* Submit row */
.don-actions            { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.don-actions__hint      { font-size: 12px; color: var(--pub-text-muted); }

/* "Coming soon" footer panel */
.don-coming             { margin-top: 48px; padding: 18px; background: var(--pub-bg-alt); border-radius: 6px; border: 1px dashed var(--pub-border); font-size: 13px; color: var(--pub-text-muted); }
.don-coming strong      { color: var(--pnw-dark); }

/* ── Payment-method picker (Netcash Pay Now / eMandate / EFT) ────────── */
.don-paymethods         { display: flex; flex-direction: column; gap: 12px; margin-top: 8px; }
.don-paymethod          { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border: 1px solid var(--pub-border); border-radius: 8px; cursor: pointer; background: #fff; transition: border-color .15s, box-shadow .15s; }
.don-paymethod:hover    { border-color: var(--pnw-red); }
.don-paymethod input    { flex-shrink: 0; margin: 0; transform: scale(1.2); accent-color: var(--pnw-red); }
.don-paymethod input:checked + .don-paymethod__body { color: var(--pnw-dark); }
.don-paymethod:has(input:checked) { border-color: var(--pnw-red); box-shadow: 0 0 0 1px var(--pnw-red); }
.don-paymethod__body    { display: flex; flex-direction: column; gap: 2px; }
.don-paymethod__body strong { font-size: 15px; }
.don-paymethod__body strong i { width: 18px; color: var(--pnw-red); margin-right: 4px; }
.don-paymethod__body span   { font-size: 13px; color: var(--pub-text-muted); }

/* Continue-to-Pay-Now form on the thanks page */
.don-paynow-form        { margin: 16px 0 8px; text-align: center; }
.don-paynow-form button { padding: 14px 28px; font-size: 16px; }
