/* Service Paw donations form — WCAG 2.2 AA-compliant defaults; site theme can override.
 *
 * Design tokens chosen to meet:
 *   1.4.3 Contrast (Minimum) — text >= 4.5:1
 *   1.4.11 Non-text Contrast — UI borders + focus indicators >= 3:1
 *   2.4.7 Focus Visible — distinct, 3px outline
 *   2.5.8 Target Size (Minimum) — interactive controls >= 24x24 CSS px
 *
 * All colors are token-driven via CSS custom properties using the WP block-theme
 * convention (--wp--preset--color--* and --wp--custom--brand--*). The fallback
 * values match The Service Paw Project's deployed brand palette (see
 * project_branding.md): Service Navy #0F2C5C (primary CTA, white-on-navy passes
 * AA at 12.7:1), navy-hover #0A1F44, pale-blue soft fill #E6ECF6 for selected
 * pill states. When theme.json declares matching slugs the plugin auto-picks
 * them up zero-touch; the fallbacks below render only on themes that don't
 * declare the slug (e.g. portability outside spp-child).
 */

.spaw-donate {
	max-width: 640px;
	margin: 2rem auto;
	font-family: inherit;
	color: var(--wp--preset--color--contrast, #1f2328); /* 14.7:1 on white */
}

.spaw-donate .spaw-form {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.spaw-donate .spaw-fieldset {
	border: 1px solid var(--wp--preset--color--border-strong, #80868b); /* 3.44:1 on white */
	border-radius: 8px;
	padding: 1rem 1.25rem 1.25rem;
	margin: 0;
}

/* When JS programmatically focuses a fieldset (e.g., the payment section after
 * Continue is clicked), make that focus visible. tabindex=-1 fieldsets aren't
 * in the normal tab order, so this :focus rule only fires on script-driven moves. */
.spaw-donate .spaw-fieldset:focus {
	outline: 3px solid var(--wp--custom--brand--primary, #0F2C5C);
	outline-offset: 3px;
}

.spaw-donate legend {
	padding: 0 0.5rem;
	font-weight: 600;
	font-size: 1rem;
}

.spaw-donate .spaw-radio-row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 0.5rem;
}

.spaw-donate .spaw-pill {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.5rem 0.9rem;
	min-height: 2.75rem;       /* 44px — comfortably above 2.5.8's 24px floor */
	border: 2px solid var(--wp--preset--color--border-strong, #80868b);
	border-radius: 999px;
	cursor: pointer;
	user-select: none;
	transition: border-color 0.15s, background 0.15s;
	background: var(--wp--preset--color--base, #fff);
}

.spaw-donate .spaw-pill:hover {
	border-color: var(--wp--preset--color--contrast, #3c4043);
}

.spaw-donate .spaw-pill input[type="radio"] {
	margin: 0;
	min-width: 1rem;
	min-height: 1rem;
}

.spaw-donate .spaw-pill:has(input[type="radio"]:checked) {
	border-color: var(--wp--custom--brand--primary, #0F2C5C);
	background: var(--wp--preset--color--primary-soft, #E6ECF6);
	color: var(--wp--preset--color--on-primary-soft, #0F2C5C); /* 9.0:1 on #FBE9E7 */
}

.spaw-donate .spaw-pill:focus-within {
	outline: 3px solid var(--wp--custom--brand--primary, #0F2C5C);
	outline-offset: 3px;
}

.spaw-donate .spaw-other-amount {
	margin-top: 0.75rem;
}

.spaw-donate .spaw-field {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	margin-top: 0.75rem;
}

.spaw-donate .spaw-field:first-child {
	margin-top: 0;
}

.spaw-donate label {
	font-weight: 500;
	font-size: 0.95rem;
}

.spaw-donate .spaw-req {
	color: var(--wp--custom--brand--required, #c62828);
}

.spaw-donate input[type="text"],
.spaw-donate input[type="email"],
.spaw-donate input[type="number"],
.spaw-donate select {
	font: inherit;
	padding: 0.55rem 0.7rem;
	border: 1px solid var(--wp--preset--color--border-strong, #80868b);
	border-radius: 6px;
	background: var(--wp--preset--color--base, #fff);
	color: var(--wp--preset--color--contrast, #1f2328);
	min-height: 2.75rem;       /* 44px touch target */
}

.spaw-donate input:focus,
.spaw-donate select:focus {
	outline: 3px solid var(--wp--custom--brand--primary, #0F2C5C);
	outline-offset: 1px;
	border-color: var(--wp--custom--brand--primary, #0F2C5C);
}

.spaw-donate input[aria-invalid="true"],
.spaw-donate select[aria-invalid="true"] {
	border-color: var(--wp--custom--brand--error, #b71c1c);
	background: var(--wp--preset--color--error-soft, #fff5f5);
}

.spaw-donate input[aria-invalid="true"]:focus,
.spaw-donate select[aria-invalid="true"]:focus {
	outline-color: var(--wp--custom--brand--error, #b71c1c);
}

.spaw-donate .spaw-grid-2 {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0.75rem;
}

.spaw-donate .spaw-grid-3 {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	gap: 0.75rem;
}

@media (max-width: 540px) {
	.spaw-donate .spaw-grid-2,
	.spaw-donate .spaw-grid-3 {
		grid-template-columns: 1fr;
	}
}

.spaw-donate .spaw-payment-element {
	min-height: 60px;
	padding: 0.5rem;
	border: 1px dashed var(--wp--preset--color--border-strong, #80868b);
	border-radius: 6px;
}

.spaw-donate .spaw-help {
	font-size: 0.9rem;
	color: var(--wp--preset--color--muted, #3c4043);
	margin-top: 0.5rem;
}

.spaw-donate .spaw-optin label {
	display: inline-flex;
	gap: 0.5rem;
	align-items: flex-start;
	font-weight: 400;
}

.spaw-donate .spaw-form-error {
	color: var(--wp--custom--brand--error, #b71c1c);
	font-weight: 600;
	min-height: 1.5em;
}

.spaw-donate .spaw-form-status {
	color: var(--wp--custom--brand--primary, #0F2C5C);
	font-weight: 500;
	min-height: 1.5em;
}

.spaw-donate .spaw-submit {
	font: inherit;
	font-weight: 600;
	font-size: 1.05rem;
	padding: 0.85rem 1.5rem;
	background: var(--wp--custom--brand--primary, #0F2C5C); /* white-on-this 5.0:1, AA */
	color: var(--wp--preset--color--base, #fff);
	border: 0;
	border-radius: 6px;
	cursor: pointer;
	min-height: 3rem;
}

.spaw-donate .spaw-submit:hover {
	background: var(--wp--preset--color--primary-hover, #0A1F44); /* 7.4:1 */
}

.spaw-donate .spaw-submit:focus-visible {
	outline: 3px solid var(--wp--preset--color--primary-hover, #0A1F44);
	outline-offset: 3px;
}

.spaw-donate .spaw-submit:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

.spaw-donate .spaw-error {
	padding: 0.85rem 1rem;
	background: var(--wp--preset--color--error-soft, #ffe7e7);
	border: 1px solid var(--wp--custom--brand--error, #b71c1c);
	color: var(--wp--custom--brand--error-text, #6d1414);
	border-radius: 6px;
	font-weight: 500;
}

@media (prefers-reduced-motion: reduce) {
	.spaw-donate .spaw-pill {
		transition: none;
	}
}

/* ===== Thank-you / processing / failure panel (post-redirect) ===== */

.spaw-thanks {
	max-width: 640px;
	margin: 2rem auto;
	padding: 2rem;
	border-radius: 10px;
	border: 1px solid var(--wp--preset--color--border-strong, #80868b);
	background: var(--wp--preset--color--base, #fff);
	color: var(--wp--preset--color--contrast, #1f2328);
	font-family: inherit;
}

.spaw-thanks:focus {
	outline: 3px solid var(--wp--custom--brand--primary, #0F2C5C);
	outline-offset: 4px;
}

.spaw-thanks__heading {
	margin: 0 0 0.75rem;
	font-size: 1.6rem;
	line-height: 1.25;
}

.spaw-thanks__lead {
	font-size: 1.1rem;
	margin: 0 0 1rem;
}

.spaw-thanks p {
	margin: 0 0 0.85rem;
	line-height: 1.55;
}

.spaw-thanks--success {
	border-color: var(--wp--preset--color--success, #0b703f);
	background: var(--wp--preset--color--success-soft, #f0f9f4);
}
.spaw-thanks--success .spaw-thanks__heading {
	color: var(--wp--preset--color--success-text, #0a4d2c);
}

.spaw-thanks--processing {
	border-color: var(--wp--preset--color--warn, #b56a00);
	background: var(--wp--preset--color--warn-soft, #fff8eb);
}
.spaw-thanks--processing .spaw-thanks__heading {
	color: var(--wp--preset--color--warn-text, #6b3f00);
}

.spaw-thanks--failed {
	border-color: var(--wp--custom--brand--error, #b71c1c);
	background: var(--wp--preset--color--error-soft, #fff5f5);
}
.spaw-thanks--failed .spaw-thanks__heading {
	color: var(--wp--custom--brand--error-text, #6d1414);
}

.spaw-thanks__footer {
	margin-top: 1.25rem;
	font-size: 0.95rem;
}

.spaw-thanks__link {
	color: var(--wp--custom--brand--primary, #0F2C5C);
	text-decoration: underline;
}
.spaw-thanks__link:hover {
	color: var(--wp--preset--color--primary-hover, #0A1F44);
}
.spaw-thanks__link:focus-visible {
	outline: 3px solid var(--wp--custom--brand--primary, #0F2C5C);
	outline-offset: 3px;
	border-radius: 3px;
}

.spaw-thanks__link--cta {
	display: inline-block;
	margin-top: 0.5rem;
	padding: 0.7rem 1.25rem;
	background: var(--wp--custom--brand--primary, #0F2C5C);
	color: var(--wp--preset--color--base, #fff);
	text-decoration: none;
	border-radius: 6px;
	font-weight: 600;
	min-height: 2.75rem;
}
.spaw-thanks__link--cta:hover {
	background: var(--wp--preset--color--primary-hover, #0A1F44);
	color: var(--wp--preset--color--base, #fff);
}

/* Logged-in donor pre-fill (v0.6.8) — banner + collapsed info summary */
.spaw-prefill-banner {
	background: var(--wp--preset--color--primary-soft, #E6ECF6);
	border-left: 4px solid var(--wp--custom--brand--primary, #0F2C5C);
	padding: 0.85rem 1rem;
	border-radius: 6px;
	margin: 0 0 1.25rem;
	font-size: 0.95rem;
	line-height: 1.5;
	color: var(--wp--preset--color--contrast, #0F172A);
}
.spaw-prefill-banner p {
	margin: 0;
}
.spaw-prefill-banner .spaw-prefill-actions {
	margin-top: 0.25rem;
	font-size: 0.875rem;
}
.spaw-prefill-banner a {
	color: var(--wp--custom--brand--primary, #0F2C5C);
	text-decoration: underline;
	text-underline-offset: 2px;
	font-weight: 600;
}
.spaw-prefilled-info {
	margin: 0 0 1rem;
	background: #fff;
	border: 1px solid var(--wp--preset--color--border, #CBD5E1);
	border-radius: 8px;
}
.spaw-prefilled-info > summary {
	padding: 0.75rem 1rem;
	cursor: pointer;
	font-size: 0.9rem;
	color: var(--wp--preset--color--muted, #475467);
	list-style: none;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-wrap: wrap;
}
.spaw-prefilled-info > summary::-webkit-details-marker { display: none; }
.spaw-prefilled-info > summary::before {
	content: '▸';
	transition: transform 0.15s ease;
	display: inline-block;
	color: var(--wp--custom--brand--primary, #0F2C5C);
}
.spaw-prefilled-info[open] > summary::before { transform: rotate(90deg); }
.spaw-prefilled-info > summary:focus {
	outline: 3px solid var(--wp--custom--brand--primary, #0F2C5C);
	outline-offset: 2px;
}
.spaw-prefill-summary {
	color: var(--wp--preset--color--contrast, #0F172A);
	font-weight: 600;
	overflow: hidden;
	text-overflow: ellipsis;
}
.spaw-prefill-edit {
	margin-left: auto;
	color: var(--wp--custom--brand--primary, #0F2C5C);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 2px;
}
.spaw-prefilled-info > .spaw-fieldset {
	margin: 0 1rem 1rem;
}

/* Monthly thank-you "what your gift adds up to" callout (v0.6.8) */
.spaw-thanks__panel {
	margin: 1.25rem 0;
	padding: 1rem 1.25rem;
	background: var(--wp--preset--color--primary-soft, #E6ECF6);
	border-left: 4px solid var(--wp--custom--brand--accent, #B8860B);
	border-radius: 6px;
}
.spaw-thanks__panel h3 {
	margin: 0 0 0.4rem;
	font-size: 1rem;
	color: var(--wp--custom--brand--primary, #0F2C5C);
}
.spaw-thanks__panel p {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--wp--preset--color--contrast, #0F172A);
}
