.donate-container { max-width: 640px; }

.donate-admin-banner {
    background: #FFF7E0;
    border-left: 4px solid #D4A017;
    color: #5C4A0F;
    padding: 12px 16px;
    border-radius: 6px;
    margin-bottom: 20px;
    font-size: 0.88rem;
}

.donate-hero {
    text-align: center;
    margin-bottom: 24px;
}
.donate-hero h1 {
    margin: 0 0 8px;
}
.donate-subtitle {
    color: var(--gray-700);
    font-size: 1rem;
    margin: 0;
    line-height: 1.55;
}

.donate-form {
    background: #fff;
    border-radius: 10px;
    box-shadow: var(--shadow-md);
    padding: 28px 32px;
}

/* Bundled dues panel — pinned at the top of the form when ?dues=<id> is present.
   Visually distinct (cream + brown left bar) so the donor sees this is fixed. */
.donate-bundled-dues {
    background: #F4EFE5;
    border-left: 4px solid #3E2E18;
    border-radius: 6px;
    padding: 14px 18px;
    margin-bottom: 24px;
}
.donate-bundled-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
}
.donate-bundled-sub {
    font-size: 0.85rem;
    color: var(--gray-700);
    margin-top: 2px;
}
.donate-bundled-amt {
    font-family: 'Oswald', sans-serif;
    font-size: 1.3rem;
    font-weight: 700;
    color: #3E2E18;
}
.donate-bundled-note {
    margin: 8px 0 0;
    font-size: 0.78rem;
    color: var(--gray-500);
    line-height: 1.45;
}

.donate-section {
    margin-bottom: 24px;
    padding-bottom: 22px;
    border-bottom: 1px solid var(--gray-200);
}
.donate-section:last-of-type { border-bottom: none; padding-bottom: 0; }

.donate-section-h2 {
    font-family: 'Oswald', sans-serif;
    font-size: 1rem;
    color: var(--brown-dark);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin: 0 0 14px;
}

/* Amount chips */
.donate-amount-chips {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 8px;
}
@media (max-width: 520px) {
    .donate-amount-chips { grid-template-columns: repeat(3, 1fr); }
}
.donate-chip {
    background: #fff;
    border: 2px solid var(--gray-200);
    border-radius: 8px;
    padding: 14px 8px;
    font-family: 'Oswald', sans-serif;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--brown-dark);
    cursor: pointer;
    transition: all 0.15s;
}
.donate-chip:hover {
    border-color: var(--tl-blue);
    color: var(--tl-blue);
}
.donate-chip-active {
    background: var(--tl-blue);
    border-color: var(--tl-blue);
    color: #fff;
}
.donate-chip-active:hover { color: #fff; }

.donate-custom-group { margin-top: 12px; }
.donate-custom-input {
    position: relative;
    display: flex;
    align-items: center;
}
.donate-custom-prefix {
    position: absolute;
    left: 14px;
    color: var(--gray-500);
    font-weight: 600;
    pointer-events: none;
}
#donateCustomAmount {
    padding-left: 28px !important;
    font-size: 1.05rem !important;
}

/* Restriction + payment method radio rows */
.donate-restriction-options { display: flex; flex-direction: column; gap: 4px; }
.donate-radio-label {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 10px 12px;
    border: 1px solid transparent;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.92rem;
    line-height: 1.45;
    transition: background 0.15s, border-color 0.15s;
}
.donate-radio-label:hover {
    background: #FAF7EE;
    border-color: var(--gray-200);
}
.donate-radio-label input[type="radio"] {
    margin-top: 2px;
    accent-color: var(--tl-blue);
    flex: 0 0 auto;
}
.donate-radio-label span { flex: 1; color: var(--gray-900); }

.donate-cover-fee {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-top: 14px;
    padding: 12px 14px;
    background: #DBEDD9;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.92rem;
    color: #2D5E2A;
}
.donate-cover-fee input[type="checkbox"] {
    margin-top: 2px;
    accent-color: #2D5E2A;
}

/* Summary panel */
.donate-summary {
    background: #F4EFE5;
    border-radius: 8px;
    padding: 16px 20px;
    margin: 8px 0 18px;
}
.donate-summary-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: 0.95rem;
    color: var(--gray-700);
}
.donate-summary-row span:last-child { font-weight: 600; color: var(--brown-dark); }
.donate-summary-total {
    margin-top: 6px;
    padding-top: 8px;
    border-top: 1px solid #DDD8CE;
    font-size: 1.05rem;
}
.donate-summary-total span { color: #3E2E18 !important; font-weight: 700; }
.donate-summary-net {
    margin-top: 6px;
    font-size: 0.82rem;
    color: var(--gray-500);
    text-align: right;
}
.donate-summary-net strong { color: #2D5E2A; }

/* Submit + post-submit banner */
.donate-submit-btn {
    display: block;
    width: 100%;
    background: #BA272C;
    color: #fff;
    border: none;
    padding: 16px 24px;
    border-radius: 8px;
    font-family: 'Oswald', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    cursor: pointer;
    transition: background 0.15s, transform 0.1s;
    box-shadow: 0 3px 10px rgba(186, 39, 44, 0.3);
}
.donate-submit-btn:hover:not(:disabled) {
    background: #9E1D22;
    transform: translateY(-1px);
}
.donate-submit-btn:disabled { opacity: 0.5; cursor: default; }

.donate-tax-note {
    margin: 16px 0 0;
    font-size: 0.78rem;
    color: var(--gray-500);
    line-height: 1.55;
}

.donate-success-banner {
    background: #DBEDD9;
    color: #2D5E2A;
    padding: 16px 20px;
    border-radius: 8px;
    margin-bottom: 22px;
    font-size: 0.95rem;
    border-left: 4px solid #2D5E2A;
}

.donate-thanks-panel {
    background: #fff;
    border-radius: 10px;
    box-shadow: var(--shadow-md);
    padding: 36px 32px;
    text-align: center;
}
.donate-thanks-panel h2 {
    font-family: 'Oswald', sans-serif;
    color: var(--brown-dark);
    margin: 0 0 10px;
}
.donate-thanks-panel p {
    color: var(--gray-700);
    margin: 0 0 22px;
    line-height: 1.55;
}
.donate-make-another-btn {
    width: auto;
    display: inline-block;
    padding: 14px 28px;
}
