/* GCHS Lost a Pet + Found a Pet — shared styles. */

.gchs-lf {
	--gchs-lf-bg:       var(--wp--preset--color--base, #ffffff);
	--gchs-lf-accent:   var(--wp--preset--color--primary, #1f3a93);
	--gchs-lf-heading:  var(--wp--preset--color--primary-dark, #1a3650);
	--gchs-lf-text:     var(--wp--preset--color--contrast, #1a1a1a);
	--gchs-lf-muted:    var(--wp--preset--color--neutral-mid, #686868);
	--gchs-lf-border:   rgba(0, 0, 0, 0.08);
	--gchs-lf-warning:  #b45309;
	--gchs-lf-warn-bg:  #fef3c7;
	--gchs-lf-radius:   12px;

	color: var(--gchs-lf-text);
}

.gchs-lf > * + * { margin-top: 4rem; }

/* ── Hero ──────────────────────────────────────────────────────── */

.gchs-lf__hero {
	padding: clamp(2rem, 5vw, 3.5rem);
	background: linear-gradient(135deg,
		color-mix(in srgb, var(--gchs-lf-accent) 10%, var(--gchs-lf-bg)),
		var(--gchs-lf-bg) 80%);
	border: 1px solid color-mix(in srgb, var(--gchs-lf-accent) 18%, transparent);
	border-radius: 16px;
}

.gchs-lf__hero-content {
	max-width: 760px;
	margin: 0 auto;
	text-align: center;
}

.gchs-lf__hero-tagline {
	display: inline-block;
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--gchs-lf-accent);
	margin-bottom: 0.75rem;
}

.gchs-lf__hero-heading {
	font-size: clamp(2rem, 4.5vw, 3.25rem);
	font-weight: 800;
	line-height: 1.1;
	margin: 0 0 1rem;
	color: var(--gchs-lf-heading);
}

.gchs-lf__hero-intro {
	font-size: 1.1rem;
	line-height: 1.6;
	color: var(--gchs-lf-text);
	opacity: 0.85;
	margin-bottom: 1.5rem;
}
.gchs-lf__hero-intro p { margin: 0 0 0.75em; }

.gchs-lf__hero-ctas {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
	justify-content: center;
	margin-top: 1.5rem;
}

.gchs-lf__hero-fineprint {
	margin: 1rem 0 0;
	font-size: 0.85rem;
	color: var(--gchs-lf-muted);
	font-style: italic;
}

/* ── Buttons ──────────────────────────────────────────────────── */

.gchs-lf__btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.85rem 1.5rem;
	font-weight: 700;
	font-size: 1rem;
	border-radius: 999px;
	text-decoration: none;
	border: 2px solid transparent;
	cursor: pointer;
	transition: transform 160ms ease, background-color 160ms ease, color 160ms ease, border-color 160ms ease;
}

.gchs-lf__btn--primary {
	background: var(--gchs-lf-accent);
	color: #fff;
}
.gchs-lf__btn--primary:hover,
.gchs-lf__btn--primary:focus-visible {
	transform: translateY(-2px);
	background: color-mix(in srgb, var(--gchs-lf-accent) 85%, #000);
}

.gchs-lf__btn--ghost {
	background: transparent;
	color: var(--gchs-lf-accent);
	border-color: var(--gchs-lf-accent);
}
.gchs-lf__btn--ghost:hover,
.gchs-lf__btn--ghost:focus-visible {
	transform: translateY(-2px);
	background: var(--gchs-lf-accent);
	color: #fff;
}

/* ── Section headers ──────────────────────────────────────────── */

.gchs-lf__section-header {
	text-align: center;
	max-width: 720px;
	margin: 0 auto 2rem;
}
.gchs-lf__section-heading {
	font-size: clamp(1.5rem, 2.6vw, 2.1rem);
	font-weight: 700;
	margin: 0 0 0.5rem;
	color: var(--gchs-lf-heading);
}
.gchs-lf__section-intro {
	font-size: 1rem;
	line-height: 1.6;
	color: var(--gchs-lf-muted);
	margin: 0;
}

/* ── Steps (numbered ordered list) ────────────────────────────── */

.gchs-lf__steps-list {
	list-style: none;
	margin: 0;
	padding: 0;
	max-width: 760px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.gchs-lf__step {
	display: flex;
	gap: 1.25rem;
	padding: 1.25rem 1.5rem;
	background: var(--gchs-lf-bg);
	border: 1px solid var(--gchs-lf-border);
	border-radius: var(--gchs-lf-radius);
	transition: border-color 160ms ease, box-shadow 160ms ease;
}
.gchs-lf__step:hover {
	border-color: color-mix(in srgb, var(--gchs-lf-accent) 30%, var(--gchs-lf-border));
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.04);
}

.gchs-lf__step-num {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 999px;
	background: var(--gchs-lf-accent);
	color: #fff;
	font-weight: 700;
	font-size: 1rem;
}

.gchs-lf__step-body { min-width: 0; flex: 1; }
.gchs-lf__step-title {
	margin: 0 0 0.25rem;
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--gchs-lf-heading);
}
.gchs-lf__step-desc {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--gchs-lf-text);
	opacity: 0.85;
}

/* ── Advice cards (Lost a Pet) ────────────────────────────────── */

.gchs-lf__advice-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1rem;
}
.gchs-lf__advice-card {
	padding: 1.25rem 1.5rem;
	background: var(--gchs-lf-bg);
	border: 1px solid var(--gchs-lf-border);
	border-radius: var(--gchs-lf-radius);
}
.gchs-lf__advice-title {
	margin: 0 0 0.4rem;
	font-size: 1rem;
	font-weight: 700;
	color: var(--gchs-lf-heading);
}
.gchs-lf__advice-body {
	margin: 0;
	font-size: 0.93rem;
	line-height: 1.55;
	color: var(--gchs-lf-text);
	opacity: 0.85;
}

/* ── Places (animal control, etc.) ────────────────────────────── */

.gchs-lf__places-list {
	list-style: none;
	margin: 0;
	padding: 0;
	max-width: 800px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.gchs-lf__place {
	padding: 1.25rem 1.5rem;
	background: var(--gchs-lf-bg);
	border: 1px solid var(--gchs-lf-border);
	border-radius: var(--gchs-lf-radius);
}
.gchs-lf__place-name {
	margin: 0 0 0.35rem;
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--gchs-lf-heading);
}
.gchs-lf__place-note {
	margin: 0 0 0.5rem;
	font-size: 0.93rem;
	line-height: 1.55;
	color: var(--gchs-lf-text);
	opacity: 0.85;
}
.gchs-lf__place-details {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1.25rem;
	font-size: 0.92rem;
}
.gchs-lf__place-line {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	color: var(--gchs-lf-accent);
	text-decoration: none;
}
a.gchs-lf__place-line:hover,
a.gchs-lf__place-line:focus-visible {
	text-decoration: underline;
}

/* ── Callout (scammer warning, etc.) ──────────────────────────── */

.gchs-lf__callout {
	display: flex;
	gap: 1rem;
	align-items: flex-start;
	padding: 1.25rem 1.5rem;
	border-radius: var(--gchs-lf-radius);
	max-width: 800px;
	margin: 0 auto;
}
.gchs-lf__callout--warning {
	background: var(--gchs-lf-warn-bg);
	border: 1px solid #fcd34d;
	color: #78350f;
}
.gchs-lf__callout-icon {
	flex-shrink: 0;
	margin-top: 2px;
	color: var(--gchs-lf-warning);
}
.gchs-lf__callout-body { min-width: 0; }
.gchs-lf__callout-heading {
	margin: 0 0 0.3rem;
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--gchs-lf-warning);
}
.gchs-lf__callout-text {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.55;
}

/* ── Waiting list body block ──────────────────────────────────── */

.gchs-lf__waitlist-body {
	max-width: 760px;
	margin: 0 auto;
	padding: 1.5rem 1.75rem;
	background: color-mix(in srgb, var(--gchs-lf-accent) 4%, var(--gchs-lf-bg));
	border: 1px solid color-mix(in srgb, var(--gchs-lf-accent) 18%, transparent);
	border-radius: var(--gchs-lf-radius);
	font-size: 1rem;
	line-height: 1.65;
}
.gchs-lf__waitlist-body p:first-child { margin-top: 0; }
.gchs-lf__waitlist-body p:last-child  { margin-bottom: 0; }

/* ── Staff contact card ───────────────────────────────────────── */

.gchs-lf__contact-card {
	display: flex;
	gap: 1.5rem;
	align-items: center;
	max-width: 720px;
	margin: 0 auto;
	padding: 1.75rem;
	background: var(--gchs-lf-bg);
	border: 1px solid var(--gchs-lf-border);
	border-radius: var(--gchs-lf-radius);
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.04);
}
.gchs-lf__contact-photo {
	flex-shrink: 0;
	width: 96px;
	height: 96px;
	object-fit: cover;
	border-radius: 999px;
}
.gchs-lf__contact-info { min-width: 0; flex: 1; }
.gchs-lf__contact-name {
	margin: 0 0 0.15rem;
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--gchs-lf-heading);
}
.gchs-lf__contact-role {
	margin: 0 0 1rem;
	font-size: 0.9rem;
	color: var(--gchs-lf-muted);
}
.gchs-lf__contact-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

@media (max-width: 520px) {
	.gchs-lf__contact-card {
		flex-direction: column;
		text-align: center;
	}
	.gchs-lf__contact-actions { justify-content: center; }
	.gchs-lf__hero-ctas .gchs-lf__btn { flex: 1; justify-content: center; min-width: 0; }
}

/* ─── Finder to Foster — perks grid ───────────────────────────── */

.gchs-lf__perks-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1rem;
}
.gchs-lf__perk {
	display: flex;
	gap: 1rem;
	padding: 1.25rem;
	background: var(--gchs-lf-bg);
	border: 1px solid var(--gchs-lf-border);
	border-radius: var(--gchs-lf-radius);
}
.gchs-lf__perk-icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 999px;
	background: color-mix(in srgb, var(--gchs-lf-accent) 12%, transparent);
	color: var(--gchs-lf-accent);
	font-size: 1.1rem;
}
.gchs-lf__perk-icon svg,
.gchs-lf__perk-icon i { display: block; }
.gchs-lf__perk-body { min-width: 0; }
.gchs-lf__perk-title {
	margin: 0 0 0.25rem;
	font-size: 1rem;
	font-weight: 700;
	color: var(--gchs-lf-heading);
}
.gchs-lf__perk-desc {
	margin: 0;
	font-size: 0.92rem;
	line-height: 1.5;
	color: var(--gchs-lf-text);
	opacity: 0.85;
}

/* ─── Finder to Foster — two paths ────────────────────────────── */

.gchs-lf__paths-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.25rem;
	max-width: 920px;
	margin: 0 auto;
}
@media (max-width: 680px) {
	.gchs-lf__paths-grid { grid-template-columns: 1fr; }
}

.gchs-lf__path {
	position: relative;
	padding: 1.75rem;
	background: var(--gchs-lf-bg);
	border: 1px solid var(--gchs-lf-border);
	border-radius: var(--gchs-lf-radius);
	transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}
.gchs-lf__path:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
	border-color: color-mix(in srgb, var(--gchs-lf-accent) 30%, var(--gchs-lf-border));
}
.gchs-lf__path--accent {
	background: linear-gradient(180deg,
		color-mix(in srgb, var(--gchs-lf-accent) 5%, var(--gchs-lf-bg)),
		var(--gchs-lf-bg) 60%);
	border-color: color-mix(in srgb, var(--gchs-lf-accent) 22%, var(--gchs-lf-border));
}

.gchs-lf__path-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 14px;
	background: color-mix(in srgb, var(--gchs-lf-accent) 14%, transparent);
	color: var(--gchs-lf-accent);
	margin-bottom: 1rem;
}
.gchs-lf__path--accent .gchs-lf__path-icon {
	background: var(--gchs-lf-accent);
	color: #fff;
}

.gchs-lf__path-title {
	margin: 0 0 0.5rem;
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--gchs-lf-heading);
}
.gchs-lf__path-body {
	margin: 0;
	font-size: 0.98rem;
	line-height: 1.6;
	color: var(--gchs-lf-text);
	opacity: 0.85;
}

/* ─── Finder to Foster — kittens subheading ───────────────────── */

.gchs-lf__subheading {
	max-width: 760px;
	margin: 2rem auto 1rem;
	text-align: center;
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--gchs-lf-heading);
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

/* ─── Finder to Foster — resource cards ───────────────────────── */

.gchs-lf__resources-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.25rem;
}
.gchs-lf__resource {
	display: flex;
	flex-direction: column;
	background: var(--gchs-lf-bg);
	border: 1px solid var(--gchs-lf-border);
	border-radius: var(--gchs-lf-radius);
	overflow: hidden;
	transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}
.gchs-lf__resource:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
	border-color: color-mix(in srgb, var(--gchs-lf-accent) 30%, var(--gchs-lf-border));
}
.gchs-lf__resource-image {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	background: #f3f4f6;
}
.gchs-lf__resource-body {
	padding: 1.25rem 1.5rem 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	flex: 1;
}
.gchs-lf__resource-name {
	margin: 0;
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--gchs-lf-heading);
}
.gchs-lf__resource-desc {
	margin: 0;
	font-size: 0.93rem;
	line-height: 1.55;
	color: var(--gchs-lf-text);
	opacity: 0.85;
	flex: 1;
}
.gchs-lf__resource-cta {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	margin-top: 0.5rem;
	padding: 0.55rem 1rem;
	background: transparent;
	color: var(--gchs-lf-accent);
	border: 2px solid var(--gchs-lf-accent);
	font-weight: 600;
	font-size: 0.9rem;
	border-radius: 999px;
	text-decoration: none;
	width: max-content;
	transition: background-color 160ms ease, color 160ms ease;
}
.gchs-lf__resource-cta:hover,
.gchs-lf__resource-cta:focus-visible {
	background: var(--gchs-lf-accent);
	color: #fff;
}

/* ─── Rehome a Pet — best-practices grid (force 3×2, not auto-fit) ─
 * The "How to Find the Right Family" section has 6 cards. auto-fit
 * happily renders 4+2 which leaves a lonely bottom row — force 3
 * columns at desktop so it reads as a clean 3×2 block. */
.gchs-lf--rehome .gchs-lf__advice-grid {
	grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 900px) {
	.gchs-lf--rehome .gchs-lf__advice-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 560px) {
	.gchs-lf--rehome .gchs-lf__advice-grid {
		grid-template-columns: 1fr;
	}
}

/* Extra breathing room before any warning callout — they're heavy
 * visually (colored background, icon) so they need air around them. */
.gchs-lf > .gchs-lf__callout {
	margin-top: 5rem;
}

/* ─── Featured resource (Rehome a Pet — Adopt-A-Pet Rehome row) ─ */

.gchs-lf__resource--featured {
	position: relative;
	overflow: visible; /* let the badge ribbon sit above the card */
	border: 2px solid var(--gchs-lf-accent);
	background: linear-gradient(180deg,
		color-mix(in srgb, var(--gchs-lf-accent) 5%, var(--gchs-lf-bg)),
		var(--gchs-lf-bg) 40%);
	/* No margin-top here — keep card top aligned with non-featured siblings.
	 * The badge floats above via top: -14px and the parent section's margin
	 * absorbs the overhang. */
}

/* Badge is always the first child, so :first-child on the body never
 * matches. Target the body directly and bump its top padding so the
 * heading has air below the ribbon. */
.gchs-lf__resource--featured .gchs-lf__resource-body {
	padding-top: 2rem;
}

.gchs-lf__resource-badge {
	position: absolute;
	top: -14px;
	left: 50%;
	transform: translateX(-50%);
	padding: 0.35rem 0.9rem;
	background: var(--gchs-lf-accent);
	color: #fff;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	border-radius: 999px;
	white-space: nowrap;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
	z-index: 2;
}

.gchs-lf__resource--featured .gchs-lf__resource-cta {
	background: var(--gchs-lf-accent);
	color: #fff;
}
.gchs-lf__resource--featured .gchs-lf__resource-cta:hover,
.gchs-lf__resource--featured .gchs-lf__resource-cta:focus-visible {
	background: color-mix(in srgb, var(--gchs-lf-accent) 85%, #000);
	color: #fff;
}

/* ─── Found Kittens — cross-link card ────────────────────────── */

.gchs-lf__f2f-card {
	max-width: 760px;
	margin: 0 auto;
	padding: clamp(1.75rem, 3vw, 2.5rem);
	background: linear-gradient(135deg,
		color-mix(in srgb, var(--gchs-lf-accent) 10%, var(--gchs-lf-bg)),
		var(--gchs-lf-bg) 75%);
	border: 1px solid color-mix(in srgb, var(--gchs-lf-accent) 22%, transparent);
	border-radius: var(--gchs-lf-radius);
	text-align: center;
}

.gchs-lf__f2f-heading {
	margin: 0 0 0.5rem;
	font-size: clamp(1.3rem, 2.3vw, 1.75rem);
	font-weight: 700;
	color: var(--gchs-lf-heading);
}

.gchs-lf__f2f-body {
	margin: 0 0 1.25rem;
	font-size: 1rem;
	line-height: 1.6;
	color: var(--gchs-lf-text);
	opacity: 0.85;
}

/* The standalone Found-Kittens hero uses the section-header treatment but
 * needs a touch more breathing room at the top of the page. */
.gchs-lf__found-kittens-hero {
	margin-top: 0;
	margin-bottom: 2.5rem;
}
.gchs-lf__found-kittens-hero .gchs-lf__section-heading {
	font-size: clamp(1.75rem, 3.2vw, 2.5rem);
}

/* ─── Owner Surrender — Special-Case Outreach card ───────────── */

.gchs-lf__special-card {
	max-width: 760px;
	margin: 0 auto;
	padding: clamp(1.75rem, 3vw, 2.5rem);
	background: linear-gradient(135deg,
		color-mix(in srgb, var(--gchs-lf-accent) 12%, var(--gchs-lf-bg)),
		var(--gchs-lf-bg) 70%);
	border: 1px solid color-mix(in srgb, var(--gchs-lf-accent) 26%, transparent);
	border-radius: var(--gchs-lf-radius);
	text-align: center;
	box-shadow: 0 6px 22px rgba(0, 0, 0, 0.05);
}

.gchs-lf__special-header { margin-bottom: 1rem; }

.gchs-lf__special-eyebrow {
	display: inline-block;
	margin-bottom: 0.5rem;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--gchs-lf-accent);
}

.gchs-lf__special-heading {
	margin: 0;
	font-size: clamp(1.4rem, 2.5vw, 1.85rem);
	font-weight: 700;
	color: var(--gchs-lf-heading);
}

.gchs-lf__special-body {
	margin: 0 auto 1.25rem;
	max-width: 620px;
	font-size: 1rem;
	line-height: 1.65;
	color: var(--gchs-lf-text);
	opacity: 0.9;
}
.gchs-lf__special-body p { margin: 0 0 0.75em; }
.gchs-lf__special-body p:last-child { margin-bottom: 0; }

.gchs-lf__special-examples {
	list-style: none;
	padding: 0;
	margin: 0 auto 1.5rem;
	display: inline-block;
	text-align: left;
}
.gchs-lf__special-examples li {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	margin: 0.4rem 0;
	font-size: 0.95rem;
	color: var(--gchs-lf-text);
}
.gchs-lf__special-examples svg {
	flex-shrink: 0;
	margin-top: 5px;
	color: var(--gchs-lf-accent);
}

.gchs-lf__special-email {
	margin: 0.5rem 0 0;
	font-size: 0.85rem;
	color: var(--gchs-lf-muted);
}

/* ─── Owner Surrender — FAQ list ─────────────────────────────── */

.gchs-lf__faq-list {
	max-width: 760px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.gchs-lf__faq-item {
	background: var(--gchs-lf-bg);
	border: 1px solid var(--gchs-lf-border);
	border-radius: var(--gchs-lf-radius);
	transition: border-color 160ms ease;
}
.gchs-lf__faq-item[open] {
	border-color: color-mix(in srgb, var(--gchs-lf-accent) 30%, var(--gchs-lf-border));
}

.gchs-lf__faq-q {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 1rem 1.25rem;
	font-weight: 600;
	color: var(--gchs-lf-text);
	cursor: pointer;
	list-style: none;
}
.gchs-lf__faq-q::-webkit-details-marker { display: none; }
.gchs-lf__faq-q svg {
	flex-shrink: 0;
	color: var(--gchs-lf-accent);
	transition: transform 220ms ease;
}
.gchs-lf__faq-item[open] .gchs-lf__faq-q svg {
	transform: rotate(180deg);
}

.gchs-lf__faq-a {
	padding: 0 1.25rem 1.1rem;
	color: var(--gchs-lf-muted);
	line-height: 1.6;
	font-size: 0.95rem;
}
.gchs-lf__faq-a p:first-child { margin-top: 0; }
.gchs-lf__faq-a p:last-child  { margin-bottom: 0; }
